1*11c03c6dSDamjan Jovanovic /**************************************************************
2*11c03c6dSDamjan Jovanovic *
3*11c03c6dSDamjan Jovanovic * Licensed to the Apache Software Foundation (ASF) under one
4*11c03c6dSDamjan Jovanovic * or more contributor license agreements. See the NOTICE file
5*11c03c6dSDamjan Jovanovic * distributed with this work for additional information
6*11c03c6dSDamjan Jovanovic * regarding copyright ownership. The ASF licenses this file
7*11c03c6dSDamjan Jovanovic * to you under the Apache License, Version 2.0 (the
8*11c03c6dSDamjan Jovanovic * "License"); you may not use this file except in compliance
9*11c03c6dSDamjan Jovanovic * with the License. You may obtain a copy of the License at
10*11c03c6dSDamjan Jovanovic *
11*11c03c6dSDamjan Jovanovic * http://www.apache.org/licenses/LICENSE-2.0
12*11c03c6dSDamjan Jovanovic *
13*11c03c6dSDamjan Jovanovic * Unless required by applicable law or agreed to in writing,
14*11c03c6dSDamjan Jovanovic * software distributed under the License is distributed on an
15*11c03c6dSDamjan Jovanovic * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*11c03c6dSDamjan Jovanovic * KIND, either express or implied. See the License for the
17*11c03c6dSDamjan Jovanovic * specific language governing permissions and limitations
18*11c03c6dSDamjan Jovanovic * under the License.
19*11c03c6dSDamjan Jovanovic *
20*11c03c6dSDamjan Jovanovic *************************************************************/
21*11c03c6dSDamjan Jovanovic
22*11c03c6dSDamjan Jovanovic
23*11c03c6dSDamjan Jovanovic
24*11c03c6dSDamjan Jovanovic #ifndef CSV_DYN_HXX
25*11c03c6dSDamjan Jovanovic #define CSV_DYN_HXX
26*11c03c6dSDamjan Jovanovic
27*11c03c6dSDamjan Jovanovic
28*11c03c6dSDamjan Jovanovic
29*11c03c6dSDamjan Jovanovic
30*11c03c6dSDamjan Jovanovic namespace csv
31*11c03c6dSDamjan Jovanovic {
32*11c03c6dSDamjan Jovanovic
33*11c03c6dSDamjan Jovanovic
34*11c03c6dSDamjan Jovanovic /** Dyn owns an object on the heap, which will be automatically
35*11c03c6dSDamjan Jovanovic deleted in its D'tor.
36*11c03c6dSDamjan Jovanovic
37*11c03c6dSDamjan Jovanovic Dyn's main purpose is for class members on the heap:
38*11c03c6dSDamjan Jovanovic You can't forget to delete them in the D'tor. Constness will be transferred
39*11c03c6dSDamjan Jovanovic to the hold object.
40*11c03c6dSDamjan Jovanovic
41*11c03c6dSDamjan Jovanovic Dyn forbids the CopyC'tor and operator=(). So you can't incidentally
42*11c03c6dSDamjan Jovanovic run into problems with compiler defined CopyC'tor or operator=() of the
43*11c03c6dSDamjan Jovanovic owning class. If you need those, you have to define them explicitly - as
44*11c03c6dSDamjan Jovanovic you should do anyway with all classes, that own members on the heap.
45*11c03c6dSDamjan Jovanovic
46*11c03c6dSDamjan Jovanovic Dyn also works with incomplete types.
47*11c03c6dSDamjan Jovanovic You only need to write
48*11c03c6dSDamjan Jovanovic class DX;
49*11c03c6dSDamjan Jovanovic but needn't include #include <DX>.hxx.
50*11c03c6dSDamjan Jovanovic This is a difference to std::auto_ptr, where it is not absolutely clear
51*11c03c6dSDamjan Jovanovic if it is allowed to use it with incomplete types.
52*11c03c6dSDamjan Jovanovic
53*11c03c6dSDamjan Jovanovic You can also use Dyn within function bodies, to make them exception safe.
54*11c03c6dSDamjan Jovanovic
55*11c03c6dSDamjan Jovanovic @attention
56*11c03c6dSDamjan Jovanovic If you use Dyn with an incomplete type, the owning class needs to
57*11c03c6dSDamjan Jovanovic define a non-inline D'tor. Else the compiler will complain.
58*11c03c6dSDamjan Jovanovic */
59*11c03c6dSDamjan Jovanovic template <class DX>
60*11c03c6dSDamjan Jovanovic class Dyn
61*11c03c6dSDamjan Jovanovic {
62*11c03c6dSDamjan Jovanovic public:
63*11c03c6dSDamjan Jovanovic // LIFECYCLE
64*11c03c6dSDamjan Jovanovic /// From now on, let_dpObject is owned by this Dyn-object.
65*11c03c6dSDamjan Jovanovic explicit Dyn(
66*11c03c6dSDamjan Jovanovic DX * let_dpObject = 0);
67*11c03c6dSDamjan Jovanovic ~Dyn();
68*11c03c6dSDamjan Jovanovic // OPERATORS
69*11c03c6dSDamjan Jovanovic /** This deletes a prevoiusly existing dpObject!
70*11c03c6dSDamjan Jovanovic From now on, let_dpObject is owned by this Dyn-object.
71*11c03c6dSDamjan Jovanovic */
72*11c03c6dSDamjan Jovanovic Dyn<DX> & operator=(
73*11c03c6dSDamjan Jovanovic DX * let_dpObject);
74*11c03c6dSDamjan Jovanovic /// @return true, if any valid object is hold, false else.
75*11c03c6dSDamjan Jovanovic operator bool() const;
76*11c03c6dSDamjan Jovanovic
77*11c03c6dSDamjan Jovanovic const DX * operator->() const;
78*11c03c6dSDamjan Jovanovic DX * operator->();
79*11c03c6dSDamjan Jovanovic
80*11c03c6dSDamjan Jovanovic const DX & operator*() const;
81*11c03c6dSDamjan Jovanovic DX & operator*();
82*11c03c6dSDamjan Jovanovic
83*11c03c6dSDamjan Jovanovic // OPERATIONS
84*11c03c6dSDamjan Jovanovic /** @return The hold object on the heap.
85*11c03c6dSDamjan Jovanovic
86*11c03c6dSDamjan Jovanovic @ATTENTION
87*11c03c6dSDamjan Jovanovic The caller of the function is responsible to delete
88*11c03c6dSDamjan Jovanovic the returned object
89*11c03c6dSDamjan Jovanovic
90*11c03c6dSDamjan Jovanovic @postcond
91*11c03c6dSDamjan Jovanovic this->dpObject == 0.
92*11c03c6dSDamjan Jovanovic */
93*11c03c6dSDamjan Jovanovic DX * Release();
94*11c03c6dSDamjan Jovanovic
95*11c03c6dSDamjan Jovanovic // INQUIRY
96*11c03c6dSDamjan Jovanovic /// Shorthand for operator->(), if implicit overloading of -> can not be used.
97*11c03c6dSDamjan Jovanovic const DX * Ptr() const;
98*11c03c6dSDamjan Jovanovic
99*11c03c6dSDamjan Jovanovic // ACCESS
100*11c03c6dSDamjan Jovanovic /// Shorthand for operator->(), if implicit overloading of -> can not be used.
101*11c03c6dSDamjan Jovanovic DX * Ptr();
102*11c03c6dSDamjan Jovanovic /// So const objects can return mutable pointers to the owned object.
103*11c03c6dSDamjan Jovanovic DX * MutablePtr() const;
104*11c03c6dSDamjan Jovanovic
105*11c03c6dSDamjan Jovanovic private:
106*11c03c6dSDamjan Jovanovic /* Does NOT set dpObject to zero! Because it is only used
107*11c03c6dSDamjan Jovanovic internally in situations where dpObject is set immediately
108*11c03c6dSDamjan Jovanovic after.
109*11c03c6dSDamjan Jovanovic */
110*11c03c6dSDamjan Jovanovic void Delete();
111*11c03c6dSDamjan Jovanovic
112*11c03c6dSDamjan Jovanovic /** Forbidden function!
113*11c03c6dSDamjan Jovanovic -------------------
114*11c03c6dSDamjan Jovanovic Help ensure, that classes with
115*11c03c6dSDamjan Jovanovic dynamic pointers use a selfdefined copy constructor
116*11c03c6dSDamjan Jovanovic and operator=(). If the default versions of these
117*11c03c6dSDamjan Jovanovic functions are used, the compiler will throw an error.
118*11c03c6dSDamjan Jovanovic **/
119*11c03c6dSDamjan Jovanovic Dyn( const Dyn<DX> & );
120*11c03c6dSDamjan Jovanovic /** Forbidden function!
121*11c03c6dSDamjan Jovanovic -------------------
122*11c03c6dSDamjan Jovanovic Help ensure, that classes with
123*11c03c6dSDamjan Jovanovic dynamic pointers use a selfdefined copy constructor
124*11c03c6dSDamjan Jovanovic and operator=(). If the default versions of these
125*11c03c6dSDamjan Jovanovic functions are used, the compiler will throw an error.
126*11c03c6dSDamjan Jovanovic **/
127*11c03c6dSDamjan Jovanovic Dyn<DX> & operator=( const Dyn<DX> & );
128*11c03c6dSDamjan Jovanovic
129*11c03c6dSDamjan Jovanovic // DATA
130*11c03c6dSDamjan Jovanovic /// An owned heap object. Needs to be deleted by this class.
131*11c03c6dSDamjan Jovanovic DX * dpObject;
132*11c03c6dSDamjan Jovanovic };
133*11c03c6dSDamjan Jovanovic
134*11c03c6dSDamjan Jovanovic
135*11c03c6dSDamjan Jovanovic
136*11c03c6dSDamjan Jovanovic
137*11c03c6dSDamjan Jovanovic // IMPLEMENTATION
138*11c03c6dSDamjan Jovanovic template <class DX>
139*11c03c6dSDamjan Jovanovic void
Delete()140*11c03c6dSDamjan Jovanovic Dyn<DX>::Delete()
141*11c03c6dSDamjan Jovanovic {
142*11c03c6dSDamjan Jovanovic if (dpObject != 0)
143*11c03c6dSDamjan Jovanovic delete dpObject;
144*11c03c6dSDamjan Jovanovic }
145*11c03c6dSDamjan Jovanovic
146*11c03c6dSDamjan Jovanovic template <class DX>
147*11c03c6dSDamjan Jovanovic inline
Dyn(DX * let_dpObject)148*11c03c6dSDamjan Jovanovic Dyn<DX>::Dyn( DX * let_dpObject )
149*11c03c6dSDamjan Jovanovic : dpObject(let_dpObject) {}
150*11c03c6dSDamjan Jovanovic
151*11c03c6dSDamjan Jovanovic template <class DX>
152*11c03c6dSDamjan Jovanovic inline
~Dyn()153*11c03c6dSDamjan Jovanovic Dyn<DX>::~Dyn()
154*11c03c6dSDamjan Jovanovic { Delete(); }
155*11c03c6dSDamjan Jovanovic
156*11c03c6dSDamjan Jovanovic
157*11c03c6dSDamjan Jovanovic template <class DX>
158*11c03c6dSDamjan Jovanovic inline Dyn<DX> &
operator =(DX * let_dpObject)159*11c03c6dSDamjan Jovanovic Dyn<DX>::operator=( DX * let_dpObject )
160*11c03c6dSDamjan Jovanovic {
161*11c03c6dSDamjan Jovanovic if ( dpObject == let_dpObject )
162*11c03c6dSDamjan Jovanovic return *this;
163*11c03c6dSDamjan Jovanovic
164*11c03c6dSDamjan Jovanovic Delete();
165*11c03c6dSDamjan Jovanovic dpObject = let_dpObject;
166*11c03c6dSDamjan Jovanovic return *this;
167*11c03c6dSDamjan Jovanovic }
168*11c03c6dSDamjan Jovanovic
169*11c03c6dSDamjan Jovanovic template <class DX>
170*11c03c6dSDamjan Jovanovic inline
operator bool() const171*11c03c6dSDamjan Jovanovic Dyn<DX>::operator bool() const
172*11c03c6dSDamjan Jovanovic { return dpObject != 0; }
173*11c03c6dSDamjan Jovanovic
174*11c03c6dSDamjan Jovanovic template <class DX>
175*11c03c6dSDamjan Jovanovic inline
176*11c03c6dSDamjan Jovanovic const DX *
operator ->() const177*11c03c6dSDamjan Jovanovic Dyn<DX>::operator->() const
178*11c03c6dSDamjan Jovanovic { return dpObject; }
179*11c03c6dSDamjan Jovanovic
180*11c03c6dSDamjan Jovanovic template <class DX>
181*11c03c6dSDamjan Jovanovic inline DX *
operator ->()182*11c03c6dSDamjan Jovanovic Dyn<DX>::operator->()
183*11c03c6dSDamjan Jovanovic { return dpObject; }
184*11c03c6dSDamjan Jovanovic
185*11c03c6dSDamjan Jovanovic template <class DX>
186*11c03c6dSDamjan Jovanovic inline const DX &
operator *() const187*11c03c6dSDamjan Jovanovic Dyn<DX>::operator*() const
188*11c03c6dSDamjan Jovanovic { csv_assert(dpObject != 0);
189*11c03c6dSDamjan Jovanovic return *dpObject;
190*11c03c6dSDamjan Jovanovic }
191*11c03c6dSDamjan Jovanovic
192*11c03c6dSDamjan Jovanovic template <class DX>
193*11c03c6dSDamjan Jovanovic inline DX &
operator *()194*11c03c6dSDamjan Jovanovic Dyn<DX>::operator*()
195*11c03c6dSDamjan Jovanovic { csv_assert(dpObject != 0);
196*11c03c6dSDamjan Jovanovic return *dpObject;
197*11c03c6dSDamjan Jovanovic }
198*11c03c6dSDamjan Jovanovic
199*11c03c6dSDamjan Jovanovic template <class DX>
200*11c03c6dSDamjan Jovanovic inline DX *
Release()201*11c03c6dSDamjan Jovanovic Dyn<DX>::Release()
202*11c03c6dSDamjan Jovanovic { DX * ret = dpObject;
203*11c03c6dSDamjan Jovanovic dpObject = 0;
204*11c03c6dSDamjan Jovanovic return ret;
205*11c03c6dSDamjan Jovanovic }
206*11c03c6dSDamjan Jovanovic
207*11c03c6dSDamjan Jovanovic template <class DX>
208*11c03c6dSDamjan Jovanovic inline const DX *
Ptr() const209*11c03c6dSDamjan Jovanovic Dyn<DX>::Ptr() const
210*11c03c6dSDamjan Jovanovic { return dpObject; }
211*11c03c6dSDamjan Jovanovic
212*11c03c6dSDamjan Jovanovic template <class DX>
213*11c03c6dSDamjan Jovanovic inline DX *
Ptr()214*11c03c6dSDamjan Jovanovic Dyn<DX>::Ptr()
215*11c03c6dSDamjan Jovanovic { return dpObject; }
216*11c03c6dSDamjan Jovanovic
217*11c03c6dSDamjan Jovanovic template <class DX>
218*11c03c6dSDamjan Jovanovic inline DX *
MutablePtr() const219*11c03c6dSDamjan Jovanovic Dyn<DX>::MutablePtr() const
220*11c03c6dSDamjan Jovanovic { return dpObject; }
221*11c03c6dSDamjan Jovanovic
222*11c03c6dSDamjan Jovanovic } // namespace csv
223*11c03c6dSDamjan Jovanovic
224*11c03c6dSDamjan Jovanovic
225*11c03c6dSDamjan Jovanovic
226*11c03c6dSDamjan Jovanovic
227*11c03c6dSDamjan Jovanovic #ifndef CSV_HIDE_DYN
228*11c03c6dSDamjan Jovanovic #define Dyn ::csv::Dyn
229*11c03c6dSDamjan Jovanovic #endif
230*11c03c6dSDamjan Jovanovic
231*11c03c6dSDamjan Jovanovic
232*11c03c6dSDamjan Jovanovic
233*11c03c6dSDamjan Jovanovic
234*11c03c6dSDamjan Jovanovic #endif
235