00001 // Copyright (C) 2001, 2002, 2003 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 NTG_CORE_ABSTRACT_HIERARCHY_HH 00029 # define NTG_CORE_ABSTRACT_HIERARCHY_HH 00030 00031 namespace ntg 00032 { 00033 00034 /* 00035 Abstract hierarchy is useful to easily check the properties of 00036 each types. type_traits<T>::abstract_type gives the abstract type 00037 associated to T. The macro ntg_is_a(T, abstract_type) is a simple 00038 way to ensure a given type has good properties. 00039 00040 Examples: 00041 00042 ntg_is_a(int, integer)::ensure(); 00043 mlc_is_a(type_traits<int_u8>::abstract_type, unsigned_integer)::ensure(); 00044 */ 00045 00047 class data_type {}; 00048 00049 // Single valued data types 00050 class non_vectorial {}; 00051 00052 /*------. 00053 | reals | 00054 `------*/ 00055 00056 class real : public non_vectorial {}; 00057 00058 // int, unsigned, int_u, int_s, etc. 00059 class integer : public real {}; 00060 class unsigned_integer : public integer {}; 00061 class signed_integer : public integer {}; 00062 00063 // float_s, float_d, etc. 00064 class decimal : public real {}; 00065 00066 /*-----------. 00067 | enumerated | 00068 `-----------*/ 00069 00070 class enumerated : public non_vectorial {}; 00071 00072 // bin, bool, etc. 00073 class binary : public enumerated {}; 00074 00075 /*----------. 00076 | vectorial | 00077 `----------*/ 00078 00079 // vec, cplx, etc. 00080 class vectorial : public data_type {}; 00081 00082 } // end of ntg. 00083 00084 #endif // !NTG_CORE_ABSTRACT_HIERARCHY_HH