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