xref: /trunk/main/autodoc/inc/cosv/tpl/tpltools.hxx (revision 914d351e5f5b84e4342a86d6ab8d4aca7308b9bd)
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_TPLTOOLS_HXX
25*11c03c6dSDamjan Jovanovic #define CSV_TPLTOOLS_HXX
26*11c03c6dSDamjan Jovanovic 
27*11c03c6dSDamjan Jovanovic #include <vector>
28*11c03c6dSDamjan Jovanovic #include <map>
29*11c03c6dSDamjan Jovanovic 
30*11c03c6dSDamjan Jovanovic 
31*11c03c6dSDamjan Jovanovic 
32*11c03c6dSDamjan Jovanovic 
33*11c03c6dSDamjan Jovanovic namespace csv
34*11c03c6dSDamjan Jovanovic {
35*11c03c6dSDamjan Jovanovic 
36*11c03c6dSDamjan Jovanovic 
37*11c03c6dSDamjan Jovanovic template <class COLLECTION>
38*11c03c6dSDamjan Jovanovic inline void         erase_container(
39*11c03c6dSDamjan Jovanovic                         COLLECTION &        o_rCollection );
40*11c03c6dSDamjan Jovanovic 
41*11c03c6dSDamjan Jovanovic /// Version for std::map
42*11c03c6dSDamjan Jovanovic template <class COLLECTION>
43*11c03c6dSDamjan Jovanovic void                erase_map_of_heap_ptrs(
44*11c03c6dSDamjan Jovanovic                         COLLECTION &        o_rCollection );
45*11c03c6dSDamjan Jovanovic 
46*11c03c6dSDamjan Jovanovic /// Version for other containers than std::map, with non-pair value_type.
47*11c03c6dSDamjan Jovanovic template <class COLLECTION>
48*11c03c6dSDamjan Jovanovic void                erase_container_of_heap_ptrs(
49*11c03c6dSDamjan Jovanovic                         COLLECTION &        o_rCollection );
50*11c03c6dSDamjan Jovanovic 
51*11c03c6dSDamjan Jovanovic template <class VECTOR_ELEM>
52*11c03c6dSDamjan Jovanovic void                adjust_vector_size(
53*11c03c6dSDamjan Jovanovic                         std::vector<VECTOR_ELEM> &
54*11c03c6dSDamjan Jovanovic                                             io_rVector,
55*11c03c6dSDamjan Jovanovic                         uintt               i_nSize,
56*11c03c6dSDamjan Jovanovic                         const VECTOR_ELEM & i_nFill );
57*11c03c6dSDamjan Jovanovic 
58*11c03c6dSDamjan Jovanovic 
59*11c03c6dSDamjan Jovanovic template <class KEY, class VAL>
60*11c03c6dSDamjan Jovanovic const VAL *         find_in_map(            /// Usable for all kinds of values
61*11c03c6dSDamjan Jovanovic                         const std::map< KEY, VAL > &
62*11c03c6dSDamjan Jovanovic                                             i_rMap,
63*11c03c6dSDamjan Jovanovic                         const KEY &         i_rKey );
64*11c03c6dSDamjan Jovanovic 
65*11c03c6dSDamjan Jovanovic 
66*11c03c6dSDamjan Jovanovic /** @return the value in the map, if it is in there, else 0.
67*11c03c6dSDamjan Jovanovic     @precond VAL has to be convertable to "0".
68*11c03c6dSDamjan Jovanovic */
69*11c03c6dSDamjan Jovanovic template <class KEY, class VAL>
70*11c03c6dSDamjan Jovanovic VAL                 value_from_map(
71*11c03c6dSDamjan Jovanovic                         const std::map< KEY, VAL > &
72*11c03c6dSDamjan Jovanovic                                             i_rMap,
73*11c03c6dSDamjan Jovanovic                         const KEY &         i_rKey );
74*11c03c6dSDamjan Jovanovic 
75*11c03c6dSDamjan Jovanovic /** @return the value in the map, if it is in there, else i_notFound.
76*11c03c6dSDamjan Jovanovic */
77*11c03c6dSDamjan Jovanovic template <class KEY, class VAL>
78*11c03c6dSDamjan Jovanovic VAL                 value_from_map(
79*11c03c6dSDamjan Jovanovic                         const std::map< KEY, VAL > &
80*11c03c6dSDamjan Jovanovic                                             i_rMap,
81*11c03c6dSDamjan Jovanovic                         const KEY &         i_rKey,
82*11c03c6dSDamjan Jovanovic                         VAL                 i_notFound );
83*11c03c6dSDamjan Jovanovic 
84*11c03c6dSDamjan Jovanovic template <class COLLECTION, class VALUE>
85*11c03c6dSDamjan Jovanovic bool                contains(
86*11c03c6dSDamjan Jovanovic                         const COLLECTION &  i_collection,
87*11c03c6dSDamjan Jovanovic                         const VALUE &       i_value );
88*11c03c6dSDamjan Jovanovic 
89*11c03c6dSDamjan Jovanovic // Object oriented for_each:
90*11c03c6dSDamjan Jovanovic template <class COLLECTION, class CLASS, class MEMFUNC>
91*11c03c6dSDamjan Jovanovic void                call_for_each(
92*11c03c6dSDamjan Jovanovic                         const COLLECTION &  i_rList,
93*11c03c6dSDamjan Jovanovic                         CLASS *             io_pThis,
94*11c03c6dSDamjan Jovanovic                         MEMFUNC             i_fMethod );
95*11c03c6dSDamjan Jovanovic 
96*11c03c6dSDamjan Jovanovic 
97*11c03c6dSDamjan Jovanovic 
98*11c03c6dSDamjan Jovanovic 
99*11c03c6dSDamjan Jovanovic // IMPLEMENTATION
100*11c03c6dSDamjan Jovanovic template <class COLLECTION>
101*11c03c6dSDamjan Jovanovic inline void
erase_container(COLLECTION & o_rCollection)102*11c03c6dSDamjan Jovanovic erase_container( COLLECTION & o_rCollection )
103*11c03c6dSDamjan Jovanovic {
104*11c03c6dSDamjan Jovanovic     o_rCollection.erase( o_rCollection.begin(),
105*11c03c6dSDamjan Jovanovic                          o_rCollection.end() );
106*11c03c6dSDamjan Jovanovic }
107*11c03c6dSDamjan Jovanovic 
108*11c03c6dSDamjan Jovanovic template <class COLLECTION>
109*11c03c6dSDamjan Jovanovic void
erase_map_of_heap_ptrs(COLLECTION & o_rCollection)110*11c03c6dSDamjan Jovanovic erase_map_of_heap_ptrs( COLLECTION & o_rCollection )
111*11c03c6dSDamjan Jovanovic {
112*11c03c6dSDamjan Jovanovic     typename COLLECTION::iterator itEnd = o_rCollection.end();
113*11c03c6dSDamjan Jovanovic     for ( typename COLLECTION::iterator it = o_rCollection.begin();
114*11c03c6dSDamjan Jovanovic           it != itEnd;
115*11c03c6dSDamjan Jovanovic           ++it )
116*11c03c6dSDamjan Jovanovic     {
117*11c03c6dSDamjan Jovanovic         delete (*it).second;
118*11c03c6dSDamjan Jovanovic     }
119*11c03c6dSDamjan Jovanovic 
120*11c03c6dSDamjan Jovanovic     o_rCollection.erase( o_rCollection.begin(),
121*11c03c6dSDamjan Jovanovic                          o_rCollection.end() );
122*11c03c6dSDamjan Jovanovic }
123*11c03c6dSDamjan Jovanovic 
124*11c03c6dSDamjan Jovanovic template <class COLLECTION>
125*11c03c6dSDamjan Jovanovic void
erase_container_of_heap_ptrs(COLLECTION & o_rCollection)126*11c03c6dSDamjan Jovanovic erase_container_of_heap_ptrs( COLLECTION & o_rCollection )
127*11c03c6dSDamjan Jovanovic {
128*11c03c6dSDamjan Jovanovic     typename COLLECTION::iterator itEnd = o_rCollection.end();
129*11c03c6dSDamjan Jovanovic     for ( typename COLLECTION::iterator it = o_rCollection.begin();
130*11c03c6dSDamjan Jovanovic           it != itEnd;
131*11c03c6dSDamjan Jovanovic           ++it )
132*11c03c6dSDamjan Jovanovic     {
133*11c03c6dSDamjan Jovanovic         delete *it;
134*11c03c6dSDamjan Jovanovic     }
135*11c03c6dSDamjan Jovanovic 
136*11c03c6dSDamjan Jovanovic     o_rCollection.erase( o_rCollection.begin(),
137*11c03c6dSDamjan Jovanovic                          o_rCollection.end() );
138*11c03c6dSDamjan Jovanovic }
139*11c03c6dSDamjan Jovanovic 
140*11c03c6dSDamjan Jovanovic template <class VECTOR_ELEM>
141*11c03c6dSDamjan Jovanovic void
adjust_vector_size(std::vector<VECTOR_ELEM> & io_rVector,uintt i_nSize,const VECTOR_ELEM & i_nFill)142*11c03c6dSDamjan Jovanovic adjust_vector_size( std::vector<VECTOR_ELEM> & io_rVector,
143*11c03c6dSDamjan Jovanovic                     uintt                      i_nSize,
144*11c03c6dSDamjan Jovanovic                     const VECTOR_ELEM &        i_nFill )
145*11c03c6dSDamjan Jovanovic {
146*11c03c6dSDamjan Jovanovic     if ( io_rVector.size() > i_nSize )
147*11c03c6dSDamjan Jovanovic     {
148*11c03c6dSDamjan Jovanovic         io_rVector.erase( io_rVector.begin() + i_nSize, io_rVector.end() );
149*11c03c6dSDamjan Jovanovic     }
150*11c03c6dSDamjan Jovanovic     else
151*11c03c6dSDamjan Jovanovic     {
152*11c03c6dSDamjan Jovanovic         io_rVector.reserve(i_nSize);
153*11c03c6dSDamjan Jovanovic         while ( io_rVector.size() <  i_nSize )
154*11c03c6dSDamjan Jovanovic             io_rVector.push_back(i_nFill);
155*11c03c6dSDamjan Jovanovic     }
156*11c03c6dSDamjan Jovanovic }
157*11c03c6dSDamjan Jovanovic 
158*11c03c6dSDamjan Jovanovic 
159*11c03c6dSDamjan Jovanovic template <class KEY, class VAL>
160*11c03c6dSDamjan Jovanovic const VAL *
find_in_map(const std::map<KEY,VAL> & i_rMap,const KEY & i_rKey)161*11c03c6dSDamjan Jovanovic find_in_map( const std::map< KEY, VAL > & i_rMap,
162*11c03c6dSDamjan Jovanovic              const KEY &                  i_rKey )
163*11c03c6dSDamjan Jovanovic {
164*11c03c6dSDamjan Jovanovic     typename std::map< KEY, VAL >::const_iterator
165*11c03c6dSDamjan Jovanovic             ret =  i_rMap.find(i_rKey);
166*11c03c6dSDamjan Jovanovic     return ret != i_rMap.end()
167*11c03c6dSDamjan Jovanovic                 ?   & (*ret).second
168*11c03c6dSDamjan Jovanovic                 :   (const VAL*)0;
169*11c03c6dSDamjan Jovanovic }
170*11c03c6dSDamjan Jovanovic 
171*11c03c6dSDamjan Jovanovic template <class KEY, class VAL>
172*11c03c6dSDamjan Jovanovic VAL
value_from_map(const std::map<KEY,VAL> & i_rMap,const KEY & i_rKey)173*11c03c6dSDamjan Jovanovic value_from_map( const std::map< KEY, VAL > & i_rMap,
174*11c03c6dSDamjan Jovanovic                 const KEY &                  i_rKey )
175*11c03c6dSDamjan Jovanovic {
176*11c03c6dSDamjan Jovanovic     typename std::map< KEY, VAL >::const_iterator
177*11c03c6dSDamjan Jovanovic             ret =  i_rMap.find(i_rKey);
178*11c03c6dSDamjan Jovanovic     return ret != i_rMap.end()
179*11c03c6dSDamjan Jovanovic                 ?   (*ret).second
180*11c03c6dSDamjan Jovanovic                 :   VAL(0);
181*11c03c6dSDamjan Jovanovic }
182*11c03c6dSDamjan Jovanovic 
183*11c03c6dSDamjan Jovanovic template <class KEY, class VAL>
184*11c03c6dSDamjan Jovanovic VAL
value_from_map(const std::map<KEY,VAL> & i_rMap,const KEY & i_rKey,VAL i_notFound)185*11c03c6dSDamjan Jovanovic value_from_map( const std::map< KEY, VAL > & i_rMap,
186*11c03c6dSDamjan Jovanovic                 const KEY &                  i_rKey,
187*11c03c6dSDamjan Jovanovic                 VAL                          i_notFound )
188*11c03c6dSDamjan Jovanovic {
189*11c03c6dSDamjan Jovanovic     typename std::map< KEY, VAL >::const_iterator
190*11c03c6dSDamjan Jovanovic             ret =  i_rMap.find(i_rKey);
191*11c03c6dSDamjan Jovanovic     return ret != i_rMap.end()
192*11c03c6dSDamjan Jovanovic                 ?   (*ret).second
193*11c03c6dSDamjan Jovanovic                 :   i_notFound;
194*11c03c6dSDamjan Jovanovic }
195*11c03c6dSDamjan Jovanovic 
196*11c03c6dSDamjan Jovanovic template <class COLLECTION, class VALUE>
197*11c03c6dSDamjan Jovanovic bool
contains(const COLLECTION & i_collection,const VALUE & i_value)198*11c03c6dSDamjan Jovanovic contains( const COLLECTION &  i_collection,
199*11c03c6dSDamjan Jovanovic           const VALUE &       i_value )
200*11c03c6dSDamjan Jovanovic {
201*11c03c6dSDamjan Jovanovic     return std::find(i_collection.begin(), i_collection.end(), i_value)
202*11c03c6dSDamjan Jovanovic            !=
203*11c03c6dSDamjan Jovanovic            i_collection.end();
204*11c03c6dSDamjan Jovanovic }
205*11c03c6dSDamjan Jovanovic 
206*11c03c6dSDamjan Jovanovic template <class COLLECTION, class CLASS, class MEMFUNC>
207*11c03c6dSDamjan Jovanovic void
call_for_each(const COLLECTION & i_rList,CLASS * io_pThis,MEMFUNC i_fMethod)208*11c03c6dSDamjan Jovanovic call_for_each( const COLLECTION &  i_rList,
209*11c03c6dSDamjan Jovanovic                CLASS *             io_pThis,
210*11c03c6dSDamjan Jovanovic                MEMFUNC             i_fMethod )
211*11c03c6dSDamjan Jovanovic {
212*11c03c6dSDamjan Jovanovic     typename COLLECTION::const_iterator it = i_rList.begin();
213*11c03c6dSDamjan Jovanovic     typename COLLECTION::const_iterator itEnd = i_rList.end();
214*11c03c6dSDamjan Jovanovic     for ( ; it != itEnd; ++it )
215*11c03c6dSDamjan Jovanovic     {
216*11c03c6dSDamjan Jovanovic         (io_pThis->*i_fMethod)(*it);
217*11c03c6dSDamjan Jovanovic     }
218*11c03c6dSDamjan Jovanovic }
219*11c03c6dSDamjan Jovanovic 
220*11c03c6dSDamjan Jovanovic 
221*11c03c6dSDamjan Jovanovic 
222*11c03c6dSDamjan Jovanovic 
223*11c03c6dSDamjan Jovanovic }   // namespace csv
224*11c03c6dSDamjan Jovanovic #endif
225