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_RANGE_HXX
25*8a106958SDamjan Jovanovic #define CSV_RANGE_HXX
26*8a106958SDamjan Jovanovic
27*8a106958SDamjan Jovanovic #include <cstring> // for std::size_t
28*8a106958SDamjan Jovanovic
29*8a106958SDamjan Jovanovic
30*8a106958SDamjan Jovanovic
31*8a106958SDamjan Jovanovic
32*8a106958SDamjan Jovanovic namespace csv
33*8a106958SDamjan Jovanovic {
34*8a106958SDamjan Jovanovic
35*8a106958SDamjan Jovanovic
36*8a106958SDamjan Jovanovic /** Represents a range of integer or iterator values.
37*8a106958SDamjan Jovanovic
38*8a106958SDamjan Jovanovic @tpl T
39*8a106958SDamjan Jovanovic Has to be assignable, add- and subtractable. That is:
40*8a106958SDamjan Jovanovic either it is
41*8a106958SDamjan Jovanovic - an integral type
42*8a106958SDamjan Jovanovic - or a random access iterator.
43*8a106958SDamjan Jovanovic */
44*8a106958SDamjan Jovanovic template <class T>
45*8a106958SDamjan Jovanovic class range
46*8a106958SDamjan Jovanovic {
47*8a106958SDamjan Jovanovic public:
48*8a106958SDamjan Jovanovic typedef T element_type; /// Provided for generic programming.
49*8a106958SDamjan Jovanovic typedef range<T> self;
50*8a106958SDamjan Jovanovic
51*8a106958SDamjan Jovanovic // LIFECYCLE
52*8a106958SDamjan Jovanovic range(
53*8a106958SDamjan Jovanovic T i_inclusiveLowerBorder,
54*8a106958SDamjan Jovanovic T i_exclusiveUpperBorder );
55*8a106958SDamjan Jovanovic ~range();
56*8a106958SDamjan Jovanovic // INQUIRY
57*8a106958SDamjan Jovanovic T begin() const;
58*8a106958SDamjan Jovanovic T end() const;
59*8a106958SDamjan Jovanovic std::size_t size() const;
60*8a106958SDamjan Jovanovic
61*8a106958SDamjan Jovanovic bool contains(
62*8a106958SDamjan Jovanovic T i_value ) const;
63*8a106958SDamjan Jovanovic bool contains(
64*8a106958SDamjan Jovanovic const self & i_other ) const;
65*8a106958SDamjan Jovanovic bool overlaps(
66*8a106958SDamjan Jovanovic const self & i_other ) const;
67*8a106958SDamjan Jovanovic /// @return i_other.begin() - this->end()
68*8a106958SDamjan Jovanovic long distance_to(
69*8a106958SDamjan Jovanovic const self & i_other ) const;
70*8a106958SDamjan Jovanovic private:
71*8a106958SDamjan Jovanovic // DATA
72*8a106958SDamjan Jovanovic T nBegin;
73*8a106958SDamjan Jovanovic T nEnd;
74*8a106958SDamjan Jovanovic };
75*8a106958SDamjan Jovanovic
76*8a106958SDamjan Jovanovic
77*8a106958SDamjan Jovanovic template <class T>
78*8a106958SDamjan Jovanovic inline range<T>
make_range(T i1,T i2)79*8a106958SDamjan Jovanovic make_range(T i1, T i2)
80*8a106958SDamjan Jovanovic {
81*8a106958SDamjan Jovanovic return range<T>(i1, i2);
82*8a106958SDamjan Jovanovic }
83*8a106958SDamjan Jovanovic
84*8a106958SDamjan Jovanovic template <class T>
85*8a106958SDamjan Jovanovic inline range<typename T::const_iterator>
range_of(const T & i_container)86*8a106958SDamjan Jovanovic range_of(const T & i_container)
87*8a106958SDamjan Jovanovic {
88*8a106958SDamjan Jovanovic return make_range( i_container.begin(),
89*8a106958SDamjan Jovanovic i_container.end()
90*8a106958SDamjan Jovanovic );
91*8a106958SDamjan Jovanovic }
92*8a106958SDamjan Jovanovic
93*8a106958SDamjan Jovanovic template <class T>
94*8a106958SDamjan Jovanovic inline range<typename T::iterator>
range_of(T & io_container)95*8a106958SDamjan Jovanovic range_of(T & io_container)
96*8a106958SDamjan Jovanovic {
97*8a106958SDamjan Jovanovic return make_range( io_container.begin(),
98*8a106958SDamjan Jovanovic io_container.end()
99*8a106958SDamjan Jovanovic );
100*8a106958SDamjan Jovanovic }
101*8a106958SDamjan Jovanovic
102*8a106958SDamjan Jovanovic
103*8a106958SDamjan Jovanovic
104*8a106958SDamjan Jovanovic
105*8a106958SDamjan Jovanovic
106*8a106958SDamjan Jovanovic // IMPLEMENTATION
107*8a106958SDamjan Jovanovic
108*8a106958SDamjan Jovanovic template <class T>
range(T i_inclusiveLowerBorder,T i_exclusiveUpperBorder)109*8a106958SDamjan Jovanovic range<T>::range( T i_inclusiveLowerBorder,
110*8a106958SDamjan Jovanovic T i_exclusiveUpperBorder )
111*8a106958SDamjan Jovanovic : nBegin(i_inclusiveLowerBorder),
112*8a106958SDamjan Jovanovic nEnd(i_exclusiveUpperBorder)
113*8a106958SDamjan Jovanovic {
114*8a106958SDamjan Jovanovic csv_assert( nBegin <= nEnd
115*8a106958SDamjan Jovanovic && "Invalid parameters for range<> constructor.");
116*8a106958SDamjan Jovanovic }
117*8a106958SDamjan Jovanovic
118*8a106958SDamjan Jovanovic template <class T>
~range()119*8a106958SDamjan Jovanovic range<T>::~range()
120*8a106958SDamjan Jovanovic {
121*8a106958SDamjan Jovanovic }
122*8a106958SDamjan Jovanovic
123*8a106958SDamjan Jovanovic template <class T>
124*8a106958SDamjan Jovanovic inline T
begin() const125*8a106958SDamjan Jovanovic range<T>::begin() const
126*8a106958SDamjan Jovanovic {
127*8a106958SDamjan Jovanovic return nBegin;
128*8a106958SDamjan Jovanovic }
129*8a106958SDamjan Jovanovic
130*8a106958SDamjan Jovanovic template <class T>
131*8a106958SDamjan Jovanovic inline T
end() const132*8a106958SDamjan Jovanovic range<T>::end() const
133*8a106958SDamjan Jovanovic {
134*8a106958SDamjan Jovanovic return nEnd;
135*8a106958SDamjan Jovanovic }
136*8a106958SDamjan Jovanovic
137*8a106958SDamjan Jovanovic template <class T>
138*8a106958SDamjan Jovanovic inline std::size_t
size() const139*8a106958SDamjan Jovanovic range<T>::size() const
140*8a106958SDamjan Jovanovic {
141*8a106958SDamjan Jovanovic csv_assert( nBegin <= nEnd
142*8a106958SDamjan Jovanovic && "Invalid range limits in range<>::size().");
143*8a106958SDamjan Jovanovic return static_cast<std::size_t>( end() - begin() );
144*8a106958SDamjan Jovanovic }
145*8a106958SDamjan Jovanovic
146*8a106958SDamjan Jovanovic template <class T>
147*8a106958SDamjan Jovanovic bool
contains(T i_value) const148*8a106958SDamjan Jovanovic range<T>::contains(T i_value ) const
149*8a106958SDamjan Jovanovic {
150*8a106958SDamjan Jovanovic return begin() <= i_value
151*8a106958SDamjan Jovanovic && i_value < end();
152*8a106958SDamjan Jovanovic }
153*8a106958SDamjan Jovanovic
154*8a106958SDamjan Jovanovic template <class T>
155*8a106958SDamjan Jovanovic bool
contains(const self & i_other) const156*8a106958SDamjan Jovanovic range<T>::contains(const self & i_other) const
157*8a106958SDamjan Jovanovic {
158*8a106958SDamjan Jovanovic // This is subtle, because this would be wrong:
159*8a106958SDamjan Jovanovic // begin() <= i_other.begin()
160*8a106958SDamjan Jovanovic // && i_other.end() <= end();
161*8a106958SDamjan Jovanovic // An empty range that begins and starts at my end()
162*8a106958SDamjan Jovanovic // must not be contained.
163*8a106958SDamjan Jovanovic
164*8a106958SDamjan Jovanovic return contains(i_other.begin())
165*8a106958SDamjan Jovanovic && i_other.end() <= end();
166*8a106958SDamjan Jovanovic }
167*8a106958SDamjan Jovanovic
168*8a106958SDamjan Jovanovic template <class T>
169*8a106958SDamjan Jovanovic bool
overlaps(const self & i_other) const170*8a106958SDamjan Jovanovic range<T>::overlaps(const self & i_other) const
171*8a106958SDamjan Jovanovic {
172*8a106958SDamjan Jovanovic return contains(i_other.begin())
173*8a106958SDamjan Jovanovic || i_other.contains(begin());
174*8a106958SDamjan Jovanovic }
175*8a106958SDamjan Jovanovic
176*8a106958SDamjan Jovanovic template <class T>
177*8a106958SDamjan Jovanovic long
distance_to(const self & i_other) const178*8a106958SDamjan Jovanovic range<T>::distance_to(const self & i_other) const
179*8a106958SDamjan Jovanovic {
180*8a106958SDamjan Jovanovic return i_other.begin() - end();
181*8a106958SDamjan Jovanovic }
182*8a106958SDamjan Jovanovic
183*8a106958SDamjan Jovanovic
184*8a106958SDamjan Jovanovic
185*8a106958SDamjan Jovanovic
186*8a106958SDamjan Jovanovic } // namespace csv
187*8a106958SDamjan Jovanovic #endif
188