1*8a106958SDamjan Jovanovic /**************************************************************
2*8a106958SDamjan Jovanovic *
3*8a106958SDamjan Jovanovic * Licensed to the Apache Software Foundation (ASF) under one
4*8a106958SDamjan Jovanovic * or more contributor license agreements. See the NOTICE file
5*8a106958SDamjan Jovanovic * distributed with this work for additional information
6*8a106958SDamjan Jovanovic * regarding copyright ownership. The ASF licenses this file
7*8a106958SDamjan Jovanovic * to you under the Apache License, Version 2.0 (the
8*8a106958SDamjan Jovanovic * "License"); you may not use this file except in compliance
9*8a106958SDamjan Jovanovic * with the License. You may obtain a copy of the License at
10*8a106958SDamjan Jovanovic *
11*8a106958SDamjan Jovanovic * http://www.apache.org/licenses/LICENSE-2.0
12*8a106958SDamjan Jovanovic *
13*8a106958SDamjan Jovanovic * Unless required by applicable law or agreed to in writing,
14*8a106958SDamjan Jovanovic * software distributed under the License is distributed on an
15*8a106958SDamjan Jovanovic * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*8a106958SDamjan Jovanovic * KIND, either express or implied. See the License for the
17*8a106958SDamjan Jovanovic * specific language governing permissions and limitations
18*8a106958SDamjan Jovanovic * under the License.
19*8a106958SDamjan Jovanovic *
20*8a106958SDamjan Jovanovic *************************************************************/
21*8a106958SDamjan Jovanovic
22*8a106958SDamjan Jovanovic
23*8a106958SDamjan Jovanovic
24*8a106958SDamjan Jovanovic #ifndef CSV_TPLTOOLS_HXX
25*8a106958SDamjan Jovanovic #define CSV_TPLTOOLS_HXX
26*8a106958SDamjan Jovanovic
27*8a106958SDamjan Jovanovic #include <vector>
28*8a106958SDamjan Jovanovic #include <map>
29*8a106958SDamjan Jovanovic
30*8a106958SDamjan Jovanovic
31*8a106958SDamjan Jovanovic
32*8a106958SDamjan Jovanovic
33*8a106958SDamjan Jovanovic namespace csv
34*8a106958SDamjan Jovanovic {
35*8a106958SDamjan Jovanovic
36*8a106958SDamjan Jovanovic
37*8a106958SDamjan Jovanovic template <class COLLECTION>
38*8a106958SDamjan Jovanovic inline void erase_container(
39*8a106958SDamjan Jovanovic COLLECTION & o_rCollection );
40*8a106958SDamjan Jovanovic
41*8a106958SDamjan Jovanovic /// Version for std::map
42*8a106958SDamjan Jovanovic template <class COLLECTION>
43*8a106958SDamjan Jovanovic void erase_map_of_heap_ptrs(
44*8a106958SDamjan Jovanovic COLLECTION & o_rCollection );
45*8a106958SDamjan Jovanovic
46*8a106958SDamjan Jovanovic /// Version for other containers than std::map, with non-pair value_type.
47*8a106958SDamjan Jovanovic template <class COLLECTION>
48*8a106958SDamjan Jovanovic void erase_container_of_heap_ptrs(
49*8a106958SDamjan Jovanovic COLLECTION & o_rCollection );
50*8a106958SDamjan Jovanovic
51*8a106958SDamjan Jovanovic template <class VECTOR_ELEM>
52*8a106958SDamjan Jovanovic void adjust_vector_size(
53*8a106958SDamjan Jovanovic std::vector<VECTOR_ELEM> &
54*8a106958SDamjan Jovanovic io_rVector,
55*8a106958SDamjan Jovanovic uintt i_nSize,
56*8a106958SDamjan Jovanovic const VECTOR_ELEM & i_nFill );
57*8a106958SDamjan Jovanovic
58*8a106958SDamjan Jovanovic
59*8a106958SDamjan Jovanovic template <class KEY, class VAL>
60*8a106958SDamjan Jovanovic const VAL * find_in_map( /// Usable for all kinds of values
61*8a106958SDamjan Jovanovic const std::map< KEY, VAL > &
62*8a106958SDamjan Jovanovic i_rMap,
63*8a106958SDamjan Jovanovic const KEY & i_rKey );
64*8a106958SDamjan Jovanovic
65*8a106958SDamjan Jovanovic
66*8a106958SDamjan Jovanovic /** @return the value in the map, if it is in there, else 0.
67*8a106958SDamjan Jovanovic @precond VAL has to be convertable to "0".
68*8a106958SDamjan Jovanovic */
69*8a106958SDamjan Jovanovic template <class KEY, class VAL>
70*8a106958SDamjan Jovanovic VAL value_from_map(
71*8a106958SDamjan Jovanovic const std::map< KEY, VAL > &
72*8a106958SDamjan Jovanovic i_rMap,
73*8a106958SDamjan Jovanovic const KEY & i_rKey );
74*8a106958SDamjan Jovanovic
75*8a106958SDamjan Jovanovic /** @return the value in the map, if it is in there, else i_notFound.
76*8a106958SDamjan Jovanovic */
77*8a106958SDamjan Jovanovic template <class KEY, class VAL>
78*8a106958SDamjan Jovanovic VAL value_from_map(
79*8a106958SDamjan Jovanovic const std::map< KEY, VAL > &
80*8a106958SDamjan Jovanovic i_rMap,
81*8a106958SDamjan Jovanovic const KEY & i_rKey,
82*8a106958SDamjan Jovanovic VAL i_notFound );
83*8a106958SDamjan Jovanovic
84*8a106958SDamjan Jovanovic template <class COLLECTION, class VALUE>
85*8a106958SDamjan Jovanovic bool contains(
86*8a106958SDamjan Jovanovic const COLLECTION & i_collection,
87*8a106958SDamjan Jovanovic const VALUE & i_value );
88*8a106958SDamjan Jovanovic
89*8a106958SDamjan Jovanovic // Object oriented for_each:
90*8a106958SDamjan Jovanovic template <class COLLECTION, class CLASS, class MEMFUNC>
91*8a106958SDamjan Jovanovic void call_for_each(
92*8a106958SDamjan Jovanovic const COLLECTION & i_rList,
93*8a106958SDamjan Jovanovic CLASS * io_pThis,
94*8a106958SDamjan Jovanovic MEMFUNC i_fMethod );
95*8a106958SDamjan Jovanovic
96*8a106958SDamjan Jovanovic
97*8a106958SDamjan Jovanovic
98*8a106958SDamjan Jovanovic
99*8a106958SDamjan Jovanovic // IMPLEMENTATION
100*8a106958SDamjan Jovanovic template <class COLLECTION>
101*8a106958SDamjan Jovanovic inline void
erase_container(COLLECTION & o_rCollection)102*8a106958SDamjan Jovanovic erase_container( COLLECTION & o_rCollection )
103*8a106958SDamjan Jovanovic {
104*8a106958SDamjan Jovanovic o_rCollection.erase( o_rCollection.begin(),
105*8a106958SDamjan Jovanovic o_rCollection.end() );
106*8a106958SDamjan Jovanovic }
107*8a106958SDamjan Jovanovic
108*8a106958SDamjan Jovanovic template <class COLLECTION>
109*8a106958SDamjan Jovanovic void
erase_map_of_heap_ptrs(COLLECTION & o_rCollection)110*8a106958SDamjan Jovanovic erase_map_of_heap_ptrs( COLLECTION & o_rCollection )
111*8a106958SDamjan Jovanovic {
112*8a106958SDamjan Jovanovic typename COLLECTION::iterator itEnd = o_rCollection.end();
113*8a106958SDamjan Jovanovic for ( typename COLLECTION::iterator it = o_rCollection.begin();
114*8a106958SDamjan Jovanovic it != itEnd;
115*8a106958SDamjan Jovanovic ++it )
116*8a106958SDamjan Jovanovic {
117*8a106958SDamjan Jovanovic delete (*it).second;
118*8a106958SDamjan Jovanovic }
119*8a106958SDamjan Jovanovic
120*8a106958SDamjan Jovanovic o_rCollection.erase( o_rCollection.begin(),
121*8a106958SDamjan Jovanovic o_rCollection.end() );
122*8a106958SDamjan Jovanovic }
123*8a106958SDamjan Jovanovic
124*8a106958SDamjan Jovanovic template <class COLLECTION>
125*8a106958SDamjan Jovanovic void
erase_container_of_heap_ptrs(COLLECTION & o_rCollection)126*8a106958SDamjan Jovanovic erase_container_of_heap_ptrs( COLLECTION & o_rCollection )
127*8a106958SDamjan Jovanovic {
128*8a106958SDamjan Jovanovic typename COLLECTION::iterator itEnd = o_rCollection.end();
129*8a106958SDamjan Jovanovic for ( typename COLLECTION::iterator it = o_rCollection.begin();
130*8a106958SDamjan Jovanovic it != itEnd;
131*8a106958SDamjan Jovanovic ++it )
132*8a106958SDamjan Jovanovic {
133*8a106958SDamjan Jovanovic delete *it;
134*8a106958SDamjan Jovanovic }
135*8a106958SDamjan Jovanovic
136*8a106958SDamjan Jovanovic o_rCollection.erase( o_rCollection.begin(),
137*8a106958SDamjan Jovanovic o_rCollection.end() );
138*8a106958SDamjan Jovanovic }
139*8a106958SDamjan Jovanovic
140*8a106958SDamjan Jovanovic template <class VECTOR_ELEM>
141*8a106958SDamjan Jovanovic void
adjust_vector_size(std::vector<VECTOR_ELEM> & io_rVector,uintt i_nSize,const VECTOR_ELEM & i_nFill)142*8a106958SDamjan Jovanovic adjust_vector_size( std::vector<VECTOR_ELEM> & io_rVector,
143*8a106958SDamjan Jovanovic uintt i_nSize,
144*8a106958SDamjan Jovanovic const VECTOR_ELEM & i_nFill )
145*8a106958SDamjan Jovanovic {
146*8a106958SDamjan Jovanovic if ( io_rVector.size() > i_nSize )
147*8a106958SDamjan Jovanovic {
148*8a106958SDamjan Jovanovic io_rVector.erase( io_rVector.begin() + i_nSize, io_rVector.end() );
149*8a106958SDamjan Jovanovic }
150*8a106958SDamjan Jovanovic else
151*8a106958SDamjan Jovanovic {
152*8a106958SDamjan Jovanovic io_rVector.reserve(i_nSize);
153*8a106958SDamjan Jovanovic while ( io_rVector.size() < i_nSize )
154*8a106958SDamjan Jovanovic io_rVector.push_back(i_nFill);
155*8a106958SDamjan Jovanovic }
156*8a106958SDamjan Jovanovic }
157*8a106958SDamjan Jovanovic
158*8a106958SDamjan Jovanovic
159*8a106958SDamjan Jovanovic template <class KEY, class VAL>
160*8a106958SDamjan Jovanovic const VAL *
find_in_map(const std::map<KEY,VAL> & i_rMap,const KEY & i_rKey)161*8a106958SDamjan Jovanovic find_in_map( const std::map< KEY, VAL > & i_rMap,
162*8a106958SDamjan Jovanovic const KEY & i_rKey )
163*8a106958SDamjan Jovanovic {
164*8a106958SDamjan Jovanovic typename std::map< KEY, VAL >::const_iterator
165*8a106958SDamjan Jovanovic ret = i_rMap.find(i_rKey);
166*8a106958SDamjan Jovanovic return ret != i_rMap.end()
167*8a106958SDamjan Jovanovic ? & (*ret).second
168*8a106958SDamjan Jovanovic : (const VAL*)0;
169*8a106958SDamjan Jovanovic }
170*8a106958SDamjan Jovanovic
171*8a106958SDamjan Jovanovic template <class KEY, class VAL>
172*8a106958SDamjan Jovanovic VAL
value_from_map(const std::map<KEY,VAL> & i_rMap,const KEY & i_rKey)173*8a106958SDamjan Jovanovic value_from_map( const std::map< KEY, VAL > & i_rMap,
174*8a106958SDamjan Jovanovic const KEY & i_rKey )
175*8a106958SDamjan Jovanovic {
176*8a106958SDamjan Jovanovic typename std::map< KEY, VAL >::const_iterator
177*8a106958SDamjan Jovanovic ret = i_rMap.find(i_rKey);
178*8a106958SDamjan Jovanovic return ret != i_rMap.end()
179*8a106958SDamjan Jovanovic ? (*ret).second
180*8a106958SDamjan Jovanovic : VAL(0);
181*8a106958SDamjan Jovanovic }
182*8a106958SDamjan Jovanovic
183*8a106958SDamjan Jovanovic template <class KEY, class VAL>
184*8a106958SDamjan Jovanovic VAL
value_from_map(const std::map<KEY,VAL> & i_rMap,const KEY & i_rKey,VAL i_notFound)185*8a106958SDamjan Jovanovic value_from_map( const std::map< KEY, VAL > & i_rMap,
186*8a106958SDamjan Jovanovic const KEY & i_rKey,
187*8a106958SDamjan Jovanovic VAL i_notFound )
188*8a106958SDamjan Jovanovic {
189*8a106958SDamjan Jovanovic typename std::map< KEY, VAL >::const_iterator
190*8a106958SDamjan Jovanovic ret = i_rMap.find(i_rKey);
191*8a106958SDamjan Jovanovic return ret != i_rMap.end()
192*8a106958SDamjan Jovanovic ? (*ret).second
193*8a106958SDamjan Jovanovic : i_notFound;
194*8a106958SDamjan Jovanovic }
195*8a106958SDamjan Jovanovic
196*8a106958SDamjan Jovanovic template <class COLLECTION, class VALUE>
197*8a106958SDamjan Jovanovic bool
contains(const COLLECTION & i_collection,const VALUE & i_value)198*8a106958SDamjan Jovanovic contains( const COLLECTION & i_collection,
199*8a106958SDamjan Jovanovic const VALUE & i_value )
200*8a106958SDamjan Jovanovic {
201*8a106958SDamjan Jovanovic return std::find(i_collection.begin(), i_collection.end(), i_value)
202*8a106958SDamjan Jovanovic !=
203*8a106958SDamjan Jovanovic i_collection.end();
204*8a106958SDamjan Jovanovic }
205*8a106958SDamjan Jovanovic
206*8a106958SDamjan Jovanovic template <class COLLECTION, class CLASS, class MEMFUNC>
207*8a106958SDamjan Jovanovic void
call_for_each(const COLLECTION & i_rList,CLASS * io_pThis,MEMFUNC i_fMethod)208*8a106958SDamjan Jovanovic call_for_each( const COLLECTION & i_rList,
209*8a106958SDamjan Jovanovic CLASS * io_pThis,
210*8a106958SDamjan Jovanovic MEMFUNC i_fMethod )
211*8a106958SDamjan Jovanovic {
212*8a106958SDamjan Jovanovic typename COLLECTION::const_iterator it = i_rList.begin();
213*8a106958SDamjan Jovanovic typename COLLECTION::const_iterator itEnd = i_rList.end();
214*8a106958SDamjan Jovanovic for ( ; it != itEnd; ++it )
215*8a106958SDamjan Jovanovic {
216*8a106958SDamjan Jovanovic (io_pThis->*i_fMethod)(*it);
217*8a106958SDamjan Jovanovic }
218*8a106958SDamjan Jovanovic }
219*8a106958SDamjan Jovanovic
220*8a106958SDamjan Jovanovic
221*8a106958SDamjan Jovanovic
222*8a106958SDamjan Jovanovic
223*8a106958SDamjan Jovanovic } // namespace csv
224*8a106958SDamjan Jovanovic #endif
225