xref: /AOO42X/main/autodoc/inc/cosv/tpl/range.hxx (revision 9bce9b0d387299c68bd81d539e1478357a103de5)
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