xref: /trunk/main/autodoc/inc/cosv/tpl/range.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_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