// // $COPYRIGHT$ // #ifndef MTL_COMPRESSED_ITER_H #define MTL_COMPRESSED_ITER_H #include "mtl/mtl_iterator.h" #include "mtl/mtl_config.h" #include "mtl/meta_if.h" namespace mtl { //: Compressed Storage Iterator // // Iterates through a value array and index array. // This is used by the compressed1D and compressed2D classes. // //!category: iterators //!component: type //!tparam: Value - The type of the value array //!tparam: Index - The type of the index array template class compressed_iter { typedef compressed_iter self; typedef Value values_t; typedef typename values_t::iterator value_iterator; typedef typename values_t::const_iterator value_const_iterator; typedef typename IF::RET value_iter_t; typedef Index indices_t; typedef typename indices_t::iterator index_iterator; typedef typename indices_t::const_iterator index_const_iterator; typedef typename IF::RET index_iter_t; public: typedef std::bidirectional_iterator_tag iterator_category; typedef typename Value::value_type value_type; typedef int difference_type; typedef int size_type; typedef difference_type distance_type; typedef typename IF::RET pointer; typedef typename IF::RET reference; typedef const value_type& const_reference; inline compressed_iter() : pos (0) { } inline compressed_iter(const self& x) : index_iter_(x.index_iter_), value_iter_(x.value_iter_), pos(x.pos) { } struct bogus { }; typedef typename IF, bogus>::RET NonConst; inline compressed_iter(const NonConst& x) : index_iter_(x.index_iter_), value_iter_(x.value_iter_), pos(x.pos) { } inline self& operator=(const self& x) { index_iter_ = x.index_iter_; value_iter_ = x.value_iter_; pos = x.pos; return *this; } inline compressed_iter(value_iter_t vals, index_iter_t inds, int p) : index_iter_(inds), value_iter_(vals), pos(p) { } inline size_type index() const { return index_iter_[pos] + IND_OFFSET; /* F to C */ } inline void set_index(int i) { index_iter_[pos] = i; } inline reference operator*() const { return value_iter_[pos]; } inline self& operator++() { ++pos; return *this; } inline self operator++(int) { self tmp = *this; ++pos; return tmp; } inline self& operator--() { --pos; return *this; } inline self operator--(int) { self tmp = *this; --pos; return tmp; } #if 0 // this isn't random access -JGS inline self& operator+=(int n) { pos += n; return *this; } inline self& operator-=(int n) { pos -= n; return *this; } inline self operator+(int n) { return self(value_iter_, index_iter_, pos + n); } inline self operator-(int n) const { return self(value_iter_, index_iter_, pos - n); } inline int operator-(const self& x) const { return pos - x.pos; } #endif inline bool operator != (const self& y) const { return pos != y.pos; } inline bool operator < (const self& y) const { return pos < y.pos; } inline bool operator == (const self& y) const { return pos == y.pos; } inline index_iter_t index_iter() const { return index_iter_ + pos; } inline value_iter_t value_iter() const { return value_iter_ + pos; } //protected: index_iter_t index_iter_; value_iter_t value_iter_; int pos; }; } /* namespace mtl */ #endif