anyfunc.hh

00001 // Copyright (C) 2001, 2002, 2003, 2004  EPITA Research and Development Laboratory
00002 //
00003 // This file is part of the Olena Library.  This library is free
00004 // software; you can redistribute it and/or modify it under the terms
00005 // of the GNU General Public License version 2 as published by the
00006 // Free Software Foundation.
00007 //
00008 // This library is distributed in the hope that it will be useful,
00009 // but WITHOUT ANY WARRANTY; without even the implied warranty of
00010 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00011 // General Public License for more details.
00012 //
00013 // You should have received a copy of the GNU General Public License
00014 // along with this library; see the file COPYING.  If not, write to
00015 // the Free Software Foundation, 59 Temple Place - Suite 330, Boston,
00016 // MA 02111-1307, USA.
00017 //
00018 // As a special exception, you may use this file as part of a free
00019 // software library without restriction.  Specifically, if other files
00020 // instantiate templates or use macros or inline functions from this
00021 // file, or you compile this file and link it with other files to
00022 // produce an executable, this file does not by itself cause the
00023 // resulting executable to be covered by the GNU General Public
00024 // License.  This exception does not however invalidate any other
00025 // reasons why the executable file might be covered by the GNU General
00026 // Public License.
00027 
00028 #ifndef OLENA_TOPO_COMBINATORIAL_MAP_INTERNAL_ANYFUNC_HH
00029 # define OLENA_TOPO_COMBINATORIAL_MAP_INTERNAL_ANYFUNC_HH
00030 
00031 # include <mlc/contract.hh>
00032 
00033 # include <vector>
00034 namespace oln {
00035 
00036   namespace topo {
00037 
00038     namespace combinatorial_map {
00039 
00041       namespace internal {
00042 
00047         template <class Inf>
00048         class any
00049         {
00050         public:
00051           const Inf & self() const { return static_cast<const Inf &>(*this); }
00052           Inf & self() { return static_cast<Inf &>(*this); }
00053         };
00054 
00060         template <class U, class V, class Inf>
00061         class anyfunc : public any<Inf>
00062         {
00063         protected:
00064           anyfunc() : f_(1) {}
00066           anyfunc(unsigned n) : f_(n+1) { assertion(n); }
00067 
00068         public:
00070           V operator()(const U & e) const
00071           {
00072             assertion(e < f_.size());
00073             return f_[e];
00074           }
00075 
00077           void resize(unsigned n)
00078           {
00079             self().resize_(n);
00080           }
00082           void assign(const U & i, const V & e)
00083           {
00084             assertion(i < f_.size());
00085             self().assign_(i, e);
00086           }
00087 
00089           void erase(const U & i)
00090           {
00091             assertion(i < f_.size());
00092             self().erase_(i);
00093           }
00095           std::ostream & print(std::ostream & ostr) const
00096           {
00097             for (unsigned i = 1; i < f_.size(); ++i)
00098               ostr << self().name() << "(" << i << ") = " << f_[i] << std::endl;
00099             return ostr;
00100           }
00101 
00102         protected:
00103           std::vector<V> f_;
00104         };
00105 
00106       } // end of namespace internal
00107 
00108     } // end of namespace combinatorial_map
00109 
00110   } // end of namespace topo
00111 
00112 } // end of namespace oln
00113 
00114 template <class U, class V, class Inf>
00115 inline std::ostream &
00116 operator<<(std::ostream & ostr,
00117            const oln::topo::combinatorial_map::internal::anyfunc<U,V,Inf> & f)
00118 {
00119   return f.exact().print(ostr);
00120 }
00121 
00122 #endif // ! OLENA_TOPO_COMBINATORIAL_MAP_INTERNAL_ANYFUNC_HH

Generated on Thu Apr 15 20:13:04 2004 for Olena by doxygen 1.3.6-20040222