image.hh 3.68 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
// Copyright (C) 2001, 2003, 2004, 2005, 2006 EPITA Research and
// Development Laboratory
//
// This file is part of the Olena Library.  This library is free
// software; you can redistribute it and/or modify it under the terms
// of the GNU General Public License version 2 as published by the
// Free Software Foundation.
//
// This library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
// General Public License for more details.
//
// You should have received a copy of the GNU General Public License
Roland Levillain's avatar
Roland Levillain committed
15
16
17
// along with this library; see the file COPYING.  If not, write to
// the Free Software Foundation, 51 Franklin Street, Fifth Floor,
// Boston, MA 02111-1307, USA.
18
19
20
21
22
23
24
25
26
27
28
//
// As a special exception, you may use this file as part of a free
// software library without restriction.  Specifically, if other files
// instantiate templates or use macros or inline functions from this
// file, or you compile this file and link it with other files to
// produce an executable, this file does not by itself cause the
// resulting executable to be covered by the GNU General Public
// License.  This exception does not however invalidate any other
// reasons why the executable file might be covered by the GNU General
// Public License.

29
30
#ifndef OLN_CORE_ABSTRACT_IMAGE_HH
# define OLN_CORE_ABSTRACT_IMAGE_HH
31

32
# include <oln/core/typedefs.hh>
33
# include <oln/automatic/image.hh>
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55


namespace oln
{

  /*! \namespace oln::abstract
  ** \brief oln::abstract namespace.
  */
  namespace abstract {


    /*! \class abstract::image<E>
    **
    ** The abstract::image class is the base class from whom derives
    ** every concrete image class.  Basically, an image is a set of
    ** points and a set of values associated with those points.
    **
    ** Parameter E is the exact type of image.
    */


    template <typename E>
56
    struct image : public virtual stc::any__simple<E>,
57
		   public virtual oln::type,
58
		   public automatic::impl< image, oln_type_of(E, morpher), E >
59
60
    {

61
    public:
62

63
      struct decl {
64

65
66
	stc_virtual_typedef(topo);
	stc_virtual_typedef(grid);
67

68
69
	stc_virtual_typedef(psite);
	stc_virtual_typedef(point);
70

71
72
73
	stc_virtual_typedef(piter);
	stc_virtual_typedef(fwd_piter);
	stc_virtual_typedef(bkd_piter);
74

75
76
	stc_virtual_typedef(value);
	stc_virtual_typedef(rvalue);
77

78
	stc_virtual_typedef(concrete);
79

80
81
	stc_virtual_typedef(morpher);

82
83
84
85
	decl() {
	  // FIXME: ...
	}
      };
86
87


88
    private:
89

90
91
92
93
      /// Typedefs.
      typedef oln_type_of(E, topo)   topo_t;
      typedef oln_type_of(E, psite)  psite_t;
      typedef oln_type_of(E, rvalue) rvalue_t;
94
95


96
    public:
97
98

      /*------------------*
99
       ! abstract methods !
100
101
       *------------------*/

102
103
104
      /*! \brief Return the topological information about the current
      **  image.  Nota bene: this method is abstract-like.it is a
      **  pseudo-abstract method.
105
      **
106
107
108
      ** \return An object deriving from abstract::topo.  Ex: if the
      ** image is an image2d<something>, the returned object is a
      ** topo2d.
109
110
      */

111
112
113
114
      const topo_t& topo() const
      {
	return this->exact().impl_topo();
      }
115
116
117


      /*! \brief Gives access to the value stored at \a p in the
118
      ** current image.
119
120
      */

121
      rvalue_t operator()(const psite_t& p) const
122
      {
123
	return this->exact().impl_op_read(p);
124
125
126
127
128
129
130
131
      }

    protected:

      /*! \brief Constructor (protected, empty).
      */
      image() {}

132
      /*! \brief Destructor.
133
      */
134
      virtual ~image() { decl(); }
135
136
137
138
139
140
141
142
143

    };


  } // end of namespace oln::abstract

} // end of namespace oln


144
# include <oln/core/abstract/image/hierarchies.hh>
145

146

147
#endif // ! OLN_CORE_ABSTRACT_IMAGE_HH