00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028 #ifndef OLENA_CORE_ABSTRACT_ITER1D_HH
00029 # define OLENA_CORE_ABSTRACT_ITER1D_HH
00030
00031 # include <oln/core/coord.hh>
00032 # include <oln/core/point1d.hh>
00033 # include <oln/core/dpoint1d.hh>
00034 # include <oln/core/image1d_size.hh>
00035 # include <oln/core/abstract/iter.hh>
00036
00037 # include <mlc/contract.hh>
00038 # include <mlc/type.hh>
00039 # include <mlc/objs.hh>
00040
00041 namespace oln {
00042
00043 namespace abstract {
00044 template<class Exact>
00045 class iter1d;
00046 }
00047
00051 template<class Exact>
00052 struct iter_traits<abstract::iter1d<Exact> >: public
00053 iter_traits<abstract::iter<Exact> >
00054 {
00055 enum { dim = 1 };
00056 typedef point1d point_type;
00057 typedef dpoint1d dpoint_type;
00058 };
00059
00060 namespace abstract {
00061
00069 template<class Exact>
00070 class iter1d : public iter< Exact >
00071 {
00072 public:
00073
00074 typedef iter<Exact> super_type;
00075
00076 friend class iter<Exact>;
00077
00085 coord
00086 col() const
00087 {
00088 return this->p_.col();
00089 }
00090
00092 static std::string name()
00093 {
00094 return std::string("_iter1d<") + Exact::name() + ">";
00095 }
00096
00097 protected:
00098
00099 const coord ncols_;
00100
00106 point1d
00107 to_point() const
00108 {
00109 precondition(*this != end);
00110 invariant(this->p_.col() >= 0 &&
00111 this->p_.col() < ncols_);
00112 return this->p_;
00113 }
00114
00118 iter1d() : super_type(), ncols_(0)
00119 {}
00120
00128 iter1d(const image1d_size& size) :
00129 super_type(), ncols_(size.ncols())
00130 {
00131 precondition(size.ncols() > 0);
00132 this->exact().goto_begin_();
00133 }
00134 };
00135
00136
00137 }
00138
00139 }
00140
00141
00142 #endif // ! OLENA_CORE_ABSTRACT_ITER1D_HH