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 __REPEAT_HH 00018 # define __REPEAT_HH 00019 00020 # include "../strategies.hh" 00021 00022 namespace aurelia { 00023 00026 template <typename S> 00027 struct repeat_strategy { 00028 private: 00029 S s; 00030 public: 00031 repeat_strategy(const S& s): s(s) {} 00032 repeat_strategy(const repeat_strategy& o): s(o.s) {} 00033 00034 //FIXME: we must check that S is T -> T 00035 template <typename T> 00036 T operator()(T t) const { 00037 while (true) { 00038 try { 00039 t = s(t); 00040 } catch (failure) { 00041 return t; 00042 } 00043 } 00044 } 00045 }; 00046 00052 template <typename S> 00053 repeat_strategy<S> repeat(const S& s) { 00054 return repeat_strategy<S>(s); 00055 } 00056 00057 } 00058 00059 #endif