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