blob: 754e002ab56ef9b3dd1359b7ae869635c083f483 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
|
#include <assert.h>
namespace omega {
template <class T> Section<T>::Section(Sequence<T> *s, int start, int length)
{
assert(s->size() >= start-1 + length);
it = s;
_start = start;
_length = length;
}
template <class T> Iterator<T> *Section<T>::new_iterator()
{
return new Section_Iterator<T>(*this);
}
template <class T> const T &Section<T>::operator[](int i) const
{
assert(1 <= i && i <= size());
return (*it)[i+(_start-1)];
}
template <class T> T &Section<T>::operator[](int i)
{
assert(1 <= i && i <= size());
return (*it)[i+(_start-1)];
}
template <class T> int Section<T>::index(const T &var) const
{
int i;
for (i=1; i<=size(); i++)
if ((*this)[i] == var)
return i;
return 0;
}
template <class T> int Section<T>::size() const
{
return _length;
}
template <class T> Section_Iterator<T>::Section_Iterator(Section<T> &sec)
{
it = sec.it->new_iterator();
for (int i = 1; i < sec._start; i++)
(*it)++;
remaining = sec.size();
}
template <class T> Section_Iterator<T>::Section_Iterator(const Section_Iterator<T> &si) : it(si.it), remaining(si.remaining) {}
template <class T> void Section_Iterator<T>::operator++()
{ this->operator++(0); }
template <class T> void Section_Iterator<T>::operator++(int)
{
if (remaining > 0)
{
(*it)++;
remaining--;
}
}
template <class T> bool Section_Iterator<T>::live() const
{
return (remaining > 0);
}
template <class T> Iterator<T> *Section_Iterator<T>::new_copy() const
{
return new Section_Iterator<T>(*this);
}
} // namespace
|