1*404b540aSrobert // Backward-compat support -*- C++ -*- 2*404b540aSrobert 3*404b540aSrobert // Copyright (C) 2001 Free Software Foundation, Inc. 4*404b540aSrobert // 5*404b540aSrobert // This file is part of the GNU ISO C++ Library. This library is free 6*404b540aSrobert // software; you can redistribute it and/or modify it under the 7*404b540aSrobert // terms of the GNU General Public License as published by the 8*404b540aSrobert // Free Software Foundation; either version 2, or (at your option) 9*404b540aSrobert // any later version. 10*404b540aSrobert 11*404b540aSrobert // This library is distributed in the hope that it will be useful, 12*404b540aSrobert // but WITHOUT ANY WARRANTY; without even the implied warranty of 13*404b540aSrobert // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 14*404b540aSrobert // GNU General Public License for more details. 15*404b540aSrobert 16*404b540aSrobert // You should have received a copy of the GNU General Public License along 17*404b540aSrobert // with this library; see the file COPYING. If not, write to the Free 18*404b540aSrobert // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, 19*404b540aSrobert // USA. 20*404b540aSrobert 21*404b540aSrobert // As a special exception, you may use this file as part of a free software 22*404b540aSrobert // library without restriction. Specifically, if other files instantiate 23*404b540aSrobert // templates or use macros or inline functions from this file, or you compile 24*404b540aSrobert // this file and link it with other files to produce an executable, this 25*404b540aSrobert // file does not by itself cause the resulting executable to be covered by 26*404b540aSrobert // the GNU General Public License. This exception does not however 27*404b540aSrobert // invalidate any other reasons why the executable file might be covered by 28*404b540aSrobert // the GNU General Public License. 29*404b540aSrobert 30*404b540aSrobert /* 31*404b540aSrobert * 32*404b540aSrobert * Copyright (c) 1994 33*404b540aSrobert * Hewlett-Packard Company 34*404b540aSrobert * 35*404b540aSrobert * Permission to use, copy, modify, distribute and sell this software 36*404b540aSrobert * and its documentation for any purpose is hereby granted without fee, 37*404b540aSrobert * provided that the above copyright notice appear in all copies and 38*404b540aSrobert * that both that copyright notice and this permission notice appear 39*404b540aSrobert * in supporting documentation. Hewlett-Packard Company makes no 40*404b540aSrobert * representations about the suitability of this software for any 41*404b540aSrobert * purpose. It is provided "as is" without express or implied warranty. 42*404b540aSrobert * 43*404b540aSrobert * 44*404b540aSrobert * Copyright (c) 1996,1997 45*404b540aSrobert * Silicon Graphics Computer Systems, Inc. 46*404b540aSrobert * 47*404b540aSrobert * Permission to use, copy, modify, distribute and sell this software 48*404b540aSrobert * and its documentation for any purpose is hereby granted without fee, 49*404b540aSrobert * provided that the above copyright notice appear in all copies and 50*404b540aSrobert * that both that copyright notice and this permission notice appear 51*404b540aSrobert * in supporting documentation. Silicon Graphics makes no 52*404b540aSrobert * representations about the suitability of this software for any 53*404b540aSrobert * purpose. It is provided "as is" without express or implied warranty. 54*404b540aSrobert */ 55*404b540aSrobert 56*404b540aSrobert #ifndef _BACKWARD_ALGO_H 57*404b540aSrobert #define _BACKWARD_ALGO_H 1 58*404b540aSrobert 59*404b540aSrobert #include "backward_warning.h" 60*404b540aSrobert #include "algobase.h" 61*404b540aSrobert #include "tempbuf.h" 62*404b540aSrobert #include "iterator.h" 63*404b540aSrobert #include <bits/stl_algo.h> 64*404b540aSrobert #include <bits/stl_numeric.h> 65*404b540aSrobert #include <ext/algorithm> 66*404b540aSrobert #include <ext/numeric> 67*404b540aSrobert 68*404b540aSrobert // Names from <stl_algo.h> 69*404b540aSrobert using std::for_each; 70*404b540aSrobert using std::find; 71*404b540aSrobert using std::find_if; 72*404b540aSrobert using std::adjacent_find; 73*404b540aSrobert using std::count; 74*404b540aSrobert using std::count_if; 75*404b540aSrobert using std::search; 76*404b540aSrobert using std::search_n; 77*404b540aSrobert using std::swap_ranges; 78*404b540aSrobert using std::transform; 79*404b540aSrobert using std::replace; 80*404b540aSrobert using std::replace_if; 81*404b540aSrobert using std::replace_copy; 82*404b540aSrobert using std::replace_copy_if; 83*404b540aSrobert using std::generate; 84*404b540aSrobert using std::generate_n; 85*404b540aSrobert using std::remove; 86*404b540aSrobert using std::remove_if; 87*404b540aSrobert using std::remove_copy; 88*404b540aSrobert using std::remove_copy_if; 89*404b540aSrobert using std::unique; 90*404b540aSrobert using std::unique_copy; 91*404b540aSrobert using std::reverse; 92*404b540aSrobert using std::reverse_copy; 93*404b540aSrobert using std::rotate; 94*404b540aSrobert using std::rotate_copy; 95*404b540aSrobert using std::random_shuffle; 96*404b540aSrobert using std::partition; 97*404b540aSrobert using std::stable_partition; 98*404b540aSrobert using std::sort; 99*404b540aSrobert using std::stable_sort; 100*404b540aSrobert using std::partial_sort; 101*404b540aSrobert using std::partial_sort_copy; 102*404b540aSrobert using std::nth_element; 103*404b540aSrobert using std::lower_bound; 104*404b540aSrobert using std::upper_bound; 105*404b540aSrobert using std::equal_range; 106*404b540aSrobert using std::binary_search; 107*404b540aSrobert using std::merge; 108*404b540aSrobert using std::inplace_merge; 109*404b540aSrobert using std::includes; 110*404b540aSrobert using std::set_union; 111*404b540aSrobert using std::set_intersection; 112*404b540aSrobert using std::set_difference; 113*404b540aSrobert using std::set_symmetric_difference; 114*404b540aSrobert using std::min_element; 115*404b540aSrobert using std::max_element; 116*404b540aSrobert using std::next_permutation; 117*404b540aSrobert using std::prev_permutation; 118*404b540aSrobert using std::find_first_of; 119*404b540aSrobert using std::find_end; 120*404b540aSrobert 121*404b540aSrobert // Names from stl_heap.h 122*404b540aSrobert using std::push_heap; 123*404b540aSrobert using std::pop_heap; 124*404b540aSrobert using std::make_heap; 125*404b540aSrobert using std::sort_heap; 126*404b540aSrobert 127*404b540aSrobert // Names from stl_numeric.h 128*404b540aSrobert using std::accumulate; 129*404b540aSrobert using std::inner_product; 130*404b540aSrobert using std::partial_sum; 131*404b540aSrobert using std::adjacent_difference; 132*404b540aSrobert 133*404b540aSrobert // Names from ext/algorithm 134*404b540aSrobert using __gnu_cxx::random_sample; 135*404b540aSrobert using __gnu_cxx::random_sample_n; 136*404b540aSrobert using __gnu_cxx::is_sorted; 137*404b540aSrobert using __gnu_cxx::is_heap; 138*404b540aSrobert using __gnu_cxx::count; // Extension returning void 139*404b540aSrobert using __gnu_cxx::count_if; // Extension returning void 140*404b540aSrobert 141*404b540aSrobert // Names from ext/numeric 142*404b540aSrobert using __gnu_cxx::power; 143*404b540aSrobert using __gnu_cxx::iota; 144*404b540aSrobert 145*404b540aSrobert #endif /* _BACKWARD_ALGO_H */ 146