83 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			C++
		
	
	
	
		
		
			
		
	
	
			83 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			C++
		
	
	
	
|  | // (C) Copyright Jeremy Siek 2001.
 | ||
|  | // Distributed under the Boost Software License, Version 1.0. (See accompany-
 | ||
|  | // ing file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
 | ||
|  | 
 | ||
|  | /*
 | ||
|  |  * | ||
|  |  * Copyright (c) 1994 | ||
|  |  * Hewlett-Packard Company | ||
|  |  * | ||
|  |  * Permission to use, copy, modify, distribute and sell this software | ||
|  |  * and its documentation for any purpose is hereby granted without fee, | ||
|  |  * provided that the above copyright notice appear in all copies and | ||
|  |  * that both that copyright notice and this permission notice appear | ||
|  |  * in supporting documentation.  Hewlett-Packard Company makes no | ||
|  |  * representations about the suitability of this software for any | ||
|  |  * purpose.  It is provided "as is" without express or implied warranty. | ||
|  |  * | ||
|  |  * | ||
|  |  * Copyright (c) 1996 | ||
|  |  * Silicon Graphics Computer Systems, Inc. | ||
|  |  * | ||
|  |  * Permission to use, copy, modify, distribute and sell this software | ||
|  |  * and its documentation for any purpose is hereby granted without fee, | ||
|  |  * provided that the above copyright notice appear in all copies and | ||
|  |  * that both that copyright notice and this permission notice appear | ||
|  |  * in supporting documentation.  Silicon Graphics makes no | ||
|  |  * representations about the suitability of this software for any | ||
|  |  * purpose.  It is provided "as is" without express or implied warranty. | ||
|  |  */ | ||
|  | 
 | ||
|  | #ifndef BOOST_ALGORITHM_HPP
 | ||
|  | # define BOOST_ALGORITHM_HPP
 | ||
|  | # include <boost/detail/iterator.hpp>
 | ||
|  | // Algorithms on sequences
 | ||
|  | //
 | ||
|  | // The functions in this file have not yet gone through formal
 | ||
|  | // review, and are subject to change. This is a work in progress.
 | ||
|  | // They have been checked into the detail directory because
 | ||
|  | // there are some graph algorithms that use these functions.
 | ||
|  | 
 | ||
|  | #include <algorithm>
 | ||
|  | #include <vector>
 | ||
|  | #include <boost/range/begin.hpp>
 | ||
|  | #include <boost/range/end.hpp>
 | ||
|  | #include <boost/range/algorithm/copy.hpp>
 | ||
|  | #include <boost/range/algorithm/equal.hpp>
 | ||
|  | #include <boost/range/algorithm/sort.hpp>
 | ||
|  | #include <boost/range/algorithm/stable_sort.hpp>
 | ||
|  | #include <boost/range/algorithm/find_if.hpp>
 | ||
|  | #include <boost/range/algorithm/count.hpp>
 | ||
|  | #include <boost/range/algorithm/count_if.hpp>
 | ||
|  | #include <boost/range/algorithm_ext/is_sorted.hpp>
 | ||
|  | #include <boost/range/algorithm_ext/iota.hpp>
 | ||
|  | 
 | ||
|  | namespace boost { | ||
|  | 
 | ||
|  |   template <typename InputIterator, typename Predicate> | ||
|  |   bool any_if(InputIterator first, InputIterator last, Predicate p) | ||
|  |   { | ||
|  |     return std::find_if(first, last, p) != last; | ||
|  |   } | ||
|  | 
 | ||
|  |   template <typename Container, typename Predicate> | ||
|  |   bool any_if(const Container& c, Predicate p) | ||
|  |   { | ||
|  |     return any_if(boost::begin(c), boost::end(c), p); | ||
|  |   } | ||
|  | 
 | ||
|  |   template <typename InputIterator, typename T> | ||
|  |   bool container_contains(InputIterator first, InputIterator last, T value) | ||
|  |   { | ||
|  |     return std::find(first, last, value) != last; | ||
|  |   } | ||
|  |   template <typename Container, typename T> | ||
|  |   bool container_contains(const Container& c, const T& value) | ||
|  |   { | ||
|  |     return container_contains(boost::begin(c), boost::end(c), value); | ||
|  |   } | ||
|  | 
 | ||
|  | } // namespace boost
 | ||
|  | 
 | ||
|  | #endif // BOOST_ALGORITHM_HPP
 |