88 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			C++
		
	
	
	
		
		
			
		
	
	
			88 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			C++
		
	
	
	
|  | //
 | ||
|  | //=======================================================================
 | ||
|  | // Copyright 1997, 1998, 1999, 2000 University of Notre Dame.
 | ||
|  | // Authors: Andrew Lumsdaine, Lie-Quan Lee, Jeremy G. Siek
 | ||
|  | //
 | ||
|  | // Distributed under the Boost Software License, Version 1.0. (See
 | ||
|  | // accompanying file LICENSE_1_0.txt or copy at
 | ||
|  | // http://www.boost.org/LICENSE_1_0.txt)
 | ||
|  | //=======================================================================
 | ||
|  | //
 | ||
|  | 
 | ||
|  | #ifndef BOOST_INDIRECT_CMP_HPP
 | ||
|  | #define BOOST_INDIRECT_CMP_HPP
 | ||
|  | 
 | ||
|  | #include <functional>
 | ||
|  | #include <boost/config.hpp>
 | ||
|  | #include <boost/property_map/property_map.hpp>
 | ||
|  | 
 | ||
|  | namespace boost { | ||
|  | 
 | ||
|  |   //: indirect_cmp
 | ||
|  |   //
 | ||
|  |   // could also do this with compose_f_gx_hx, and the member binder...
 | ||
|  |   //
 | ||
|  |   //!category: functors
 | ||
|  |   //!component: type
 | ||
|  |   //!tparam: ReadablePropertyMap - a model of ReadablePropertyMap
 | ||
|  |   //!definition: functor.h
 | ||
|  |   template <class ReadablePropertyMap, class Compare> | ||
|  |   class indirect_cmp { | ||
|  |   public: | ||
|  |     typedef typename boost::property_traits<ReadablePropertyMap>::value_type T; | ||
|  |     typedef typename boost::property_traits<ReadablePropertyMap>::key_type K; | ||
|  |     typedef K first_argument_type; | ||
|  |     typedef K second_argument_type; | ||
|  |     typedef bool result_type; | ||
|  |     inline indirect_cmp(const ReadablePropertyMap& df, const Compare& c = Compare()) | ||
|  |       : d(df), cmp(c) { } | ||
|  | 
 | ||
|  |     template <class A, class B> | ||
|  |     inline bool  | ||
|  |     operator()(const A& u, const B& v) const { | ||
|  |       const T& du = get(d, u); | ||
|  |       const T& dv = get(d, v); | ||
|  |       return cmp(du, dv); | ||
|  |     } | ||
|  |   protected: | ||
|  |     ReadablePropertyMap d; | ||
|  |     Compare cmp; | ||
|  |   }; | ||
|  | 
 | ||
|  |   template <typename Compare, typename ReadablePropertyMap> | ||
|  |   indirect_cmp<ReadablePropertyMap, Compare> | ||
|  |   make_indirect_cmp(const Compare& cmp, ReadablePropertyMap pmap) { | ||
|  |     indirect_cmp<ReadablePropertyMap, Compare> p(pmap, cmp); | ||
|  |     return p; | ||
|  |   } | ||
|  | 
 | ||
|  |   template <class ReadablePropertyMap> | ||
|  |   class indirect_pmap { | ||
|  |   public: | ||
|  |     typedef typename boost::property_traits<ReadablePropertyMap>::value_type T; | ||
|  |     typedef typename boost::property_traits<ReadablePropertyMap>::key_type K; | ||
|  |     typedef K argument_type; | ||
|  |     typedef T result_type; | ||
|  |     inline indirect_pmap(const ReadablePropertyMap& df) | ||
|  |       : d(df) { } | ||
|  | 
 | ||
|  |     inline T operator()(const K& u) const { | ||
|  |       return get(d, u); | ||
|  |     } | ||
|  |   protected: | ||
|  |     ReadablePropertyMap d; | ||
|  |   }; | ||
|  | 
 | ||
|  |   template <typename ReadablePropertyMap> | ||
|  |   indirect_pmap<ReadablePropertyMap> | ||
|  |   make_indirect_pmap(ReadablePropertyMap pmap) { | ||
|  |     indirect_pmap<ReadablePropertyMap> f(pmap); | ||
|  |     return f; | ||
|  |   } | ||
|  | 
 | ||
|  | 
 | ||
|  | } // namespace boost
 | ||
|  | 
 | ||
|  | 
 | ||
|  | #endif // GGCL_INDIRECT_CMP_HPP
 |