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_CORE_FOLD_HH 00029 # define OLENA_CORE_FOLD_HH 00030 00031 # include <oln/core/abstract/image.hh> 00032 # include <oln/core/abstract/iter.hh> 00033 # include <oln/core/macros.hh> 00034 # include <mlc/typeadj.hh> 00035 # include <oln/core/macros.hh> 00036 00037 namespace oln { 00038 00039 00047 template<class AdaptableBinaryFun, class I> inline 00048 typename AdaptableBinaryFun::result_type 00049 fold(AdaptableBinaryFun f, 00050 typename mlc::typeadj< 00051 typename AdaptableBinaryFun::result_type>::mutable_val val, 00052 const abstract::image<I>& input) 00053 { 00054 oln_iter_type(I) p(input); 00055 for_all(p) 00056 val = f(val, input[p]); 00057 return val; 00058 } 00059 00060 00067 template<class AdaptableBinaryFun, class I> inline 00068 typename AdaptableBinaryFun::result_type 00069 fold(AdaptableBinaryFun f, const abstract::image<I>& input) 00070 { 00071 oln_iter_type(I) p(input); 00072 p = begin; 00073 typename mlc::typeadj< 00074 typename AdaptableBinaryFun::result_type>::mutable_val val 00075 = input[p]; 00076 for_all_remaining(p) 00077 val = f(val, input[p]); 00078 return val; 00079 } 00080 00081 } // end of oln 00082 00083 #endif // ! OLENA_CORE_FOLD_HH