00001 /* ///////////////////////////////////////////////////////////////////////// 00002 * File: stlsoft/algorithms/debug.hpp 00003 * 00004 * Purpose: Debug algorithms. 00005 * 00006 * Created: 17th January 2002 00007 * Updated: 26th March 2010 00008 * 00009 * Home: http://stlsoft.org/ 00010 * 00011 * Copyright (c) 2002-2010, Matthew Wilson and Synesis Software 00012 * All rights reserved. 00013 * 00014 * Redistribution and use in source and binary forms, with or without 00015 * modification, are permitted provided that the following conditions are met: 00016 * 00017 * - Redistributions of source code must retain the above copyright notice, this 00018 * list of conditions and the following disclaimer. 00019 * - Redistributions in binary form must reproduce the above copyright notice, 00020 * this list of conditions and the following disclaimer in the documentation 00021 * and/or other materials provided with the distribution. 00022 * - Neither the name(s) of Matthew Wilson and Synesis Software nor the names of 00023 * any contributors may be used to endorse or promote products derived from 00024 * this software without specific prior written permission. 00025 * 00026 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 00027 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00028 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 00029 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE 00030 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 00031 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 00032 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 00033 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 00034 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 00035 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 00036 * POSSIBILITY OF SUCH DAMAGE. 00037 * 00038 * ////////////////////////////////////////////////////////////////////////// */ 00039 00040 00047 #ifndef STLSOFT_INCL_STLSOFT_ALGORITHMS_HPP_DEBUG 00048 #define STLSOFT_INCL_STLSOFT_ALGORITHMS_HPP_DEBUG 00049 00050 #ifndef STLSOFT_DOCUMENTATION_SKIP_SECTION 00051 # define STLSOFT_VER_STLSOFT_ALGORITHMS_HPP_DEBUG_MAJOR 3 00052 # define STLSOFT_VER_STLSOFT_ALGORITHMS_HPP_DEBUG_MINOR 1 00053 # define STLSOFT_VER_STLSOFT_ALGORITHMS_HPP_DEBUG_REVISION 1 00054 # define STLSOFT_VER_STLSOFT_ALGORITHMS_HPP_DEBUG_EDIT 68 00055 #endif /* !STLSOFT_DOCUMENTATION_SKIP_SECTION */ 00056 00057 /* ///////////////////////////////////////////////////////////////////////// 00058 * Compatibility 00059 */ 00060 00061 /* ///////////////////////////////////////////////////////////////////////// 00062 * Includes 00063 */ 00064 00065 #ifndef STLSOFT_INCL_STLSOFT_H_STLSOFT 00066 # include <stlsoft/stlsoft.h> 00067 #endif /* !STLSOFT_INCL_STLSOFT_H_STLSOFT */ 00068 00069 /* ///////////////////////////////////////////////////////////////////////// 00070 * Namespace 00071 */ 00072 00073 #ifndef _STLSOFT_NO_NAMESPACE 00074 namespace stlsoft 00075 { 00076 #endif /* _STLSOFT_NO_NAMESPACE */ 00077 00078 /* ///////////////////////////////////////////////////////////////////////// 00079 * Algorithms 00080 */ 00081 00082 template< ss_typename_param_k I 00083 , ss_typename_param_k O 00084 > 00085 // [[synesis:function:algorithm: copy_preinc(T<I> first, T<I> last, T<O> o)]] 00086 inline O copy_preinc( 00087 I first 00088 , I last 00089 , O o 00090 ) 00091 { 00092 for(; first != last; ++o, ++first) 00093 { 00094 *o = *first; 00095 } 00096 00097 return o; 00098 } 00099 00100 // [[synesis:function:algorithm: copy_postinc(T<I> first, T<I> last, T<O> o)]] 00101 template< ss_typename_param_k I 00102 , ss_typename_param_k O 00103 > 00104 inline O copy_postinc( 00105 I first 00106 , I last 00107 , O o 00108 ) 00109 { 00110 for(; first != last; o++, first++) 00111 { 00112 *o = *first; 00113 } 00114 00115 return o; 00116 } 00117 00118 00119 00128 // [[synesis:function:algorithm: for_each_preinc(T<I> first, T<I> last, T<UF> func)]] 00129 template< ss_typename_param_k I 00130 , ss_typename_param_k UF 00131 > 00132 inline UF for_each_preinc(I first, I last, UF func) 00133 { 00134 for(; first != last; ++first) 00135 { 00136 func(*first); 00137 } 00138 00139 return func; 00140 } 00141 00150 // [[synesis:function:algorithm: for_each_postinc(T<I> first, T<I> last, T<UF> func)]] 00151 template< ss_typename_param_k I 00152 , ss_typename_param_k UF 00153 > 00154 inline UF for_each_postinc(I first, I last, UF func) 00155 { 00156 for(; first != last; first++) 00157 { 00158 func(*first); 00159 } 00160 00161 return func; 00162 } 00163 00165 // Unit-testing 00166 00167 #ifdef STLSOFT_UNITTEST 00168 # include "./unittest/debug_unittest_.h" 00169 #endif /* STLSOFT_UNITTEST */ 00170 00171 /* ////////////////////////////////////////////////////////////////////// */ 00172 00173 #ifndef _STLSOFT_NO_NAMESPACE 00174 } // namespace stlsoft 00175 #endif /* _STLSOFT_NO_NAMESPACE */ 00176 00177 /* ////////////////////////////////////////////////////////////////////// */ 00178 00179 #endif /* !STLSOFT_INCL_STLSOFT_ALGORITHMS_HPP_DEBUG */ 00180 00181 /* ///////////////////////////// end of file //////////////////////////// */