Blame boost/pending/indirect_cmp.hpp

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