#include namespace omega { template Section::Section(Sequence *s, int start, int length) { assert(s->size() >= start-1 + length); it = s; _start = start; _length = length; } template Iterator *Section::new_iterator() { return new Section_Iterator(*this); } template const T &Section::operator[](int i) const { assert(1 <= i && i <= size()); return (*it)[i+(_start-1)]; } template T &Section::operator[](int i) { assert(1 <= i && i <= size()); return (*it)[i+(_start-1)]; } template int Section::index(const T &var) const { int i; for (i=1; i<=size(); i++) if ((*this)[i] == var) return i; return 0; } template int Section::size() const { return _length; } template Section_Iterator::Section_Iterator(Section &sec) { it = sec.it->new_iterator(); for (int i = 1; i < sec._start; i++) (*it)++; remaining = sec.size(); } template Section_Iterator::Section_Iterator(const Section_Iterator &si) : it(si.it), remaining(si.remaining) {} template void Section_Iterator::operator++() { this->operator++(0); } template void Section_Iterator::operator++(int) { if (remaining > 0) { (*it)++; remaining--; } } template bool Section_Iterator::live() const { return (remaining > 0); } template Iterator *Section_Iterator::new_copy() const { return new Section_Iterator(*this); } } // namespace