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_ZETA_HH 00029 # define OLENA_TOPO_COMBINATORIAL_MAP_INTERNAL_ZETA_HH 00030 00031 namespace oln { 00032 00033 namespace topo { 00034 00035 namespace combinatorial_map { 00036 00037 namespace internal { 00038 00039 /* zeta function. 00040 ** 00041 ** Tabular of 4 elements. 00042 ** 00043 ** \todo FIXME: Add doc. 00044 */ 00045 struct zeta 00046 { 00047 zeta() : empty_(true) 00048 { 00049 for (unsigned i = 0; i < 4; ++i) 00050 darts_[i] = 0; 00051 } 00052 00053 bool 00054 empty() const 00055 { 00056 return empty_; 00057 } 00058 00059 unsigned 00060 operator[](unsigned i) const 00061 { 00062 return darts_[i]; 00063 } 00064 unsigned& 00065 operator[](unsigned i) 00066 { 00067 empty_ = false; 00068 return darts_[i]; 00069 } 00070 00071 private: 00072 unsigned darts_[4]; 00073 bool empty_; 00074 }; 00075 00076 # define oln_zeta_type(ImgType) \ 00077 typename oln::mute< ImgType, oln::topo::combinatorial_map::internal::zeta>::ret 00078 00079 } // end of namespace internal 00080 00081 } // end of namespace combinatorial_map 00082 00083 } // end of namespace topo 00084 00085 } // end of namespace oln 00086 00087 #endif // ! OLENA_TOPO_COMBINATORIAL_MAP_INTERNAL_ZETA_HH