00001 // This file is a part of Aurelia. 00002 // Copyright (C) 2010 Valentin David 00003 // Copyright (C) 2010 University of Bergen 00004 // 00005 // This program is free software: you can redistribute it and/or modify 00006 // it under the terms of the GNU General Public License as published by 00007 // the Free Software Foundation, either version 3 of the License, or 00008 // (at your option) any later version. 00009 // 00010 // This program is distributed in the hope that it will be useful, 00011 // but WITHOUT ANY WARRANTY; without even the implied warranty of 00012 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00013 // GNU General Public License for more details. 00014 // 00015 // You should have received a copy of the GNU General Public License 00016 // along with this program. If not, see <http://www.gnu.org/licenses/>. 00017 #ifndef __SIZE_HH 00018 # define __SIZE_HH 00019 00020 # include "../strategies.hh" 00021 00022 namespace aurelia { 00023 00026 struct size_strategy { 00027 template <typename Pool> 00028 int operator()(const untyped_term<Pool>& t) const { 00029 typedef untyped_term<Pool> T; 00030 typedef untyped_constructor<Pool> C; 00031 00032 try { 00033 if (t.constructor() != C::AS_EMPTY_LIST) 00034 throw failure(); 00035 return 0; 00036 } catch (failure) { 00037 if (t.constructor() == C::AS_LIST) { 00038 return (*this)(t[1]) + 1; 00039 } else 00040 throw failure(); 00041 } 00042 } 00043 }; 00044 00048 size_strategy size; 00049 00050 } 00051 00052 #endif