| 1 | //
|
|---|
| 2 | //=======================================================================
|
|---|
| 3 | // Author: Philipp Moeller
|
|---|
| 4 | //
|
|---|
| 5 | // Copyright 2012, Philipp Moeller
|
|---|
| 6 | //
|
|---|
| 7 | // Distributed under the Boost Software License, Version 1.0. (See
|
|---|
| 8 | // accompanying file LICENSE_1_0.txt or copy at
|
|---|
| 9 | // http://www.boost.org/LICENSE_1_0.txt)
|
|---|
| 10 | //=======================================================================
|
|---|
| 11 | //
|
|---|
| 12 |
|
|---|
| 13 | #ifndef BOOST_PROPERTY_MAP_FUNCTION_PROPERTY_MAP_H
|
|---|
| 14 | #define BOOST_PROPERTY_MAP_FUNCTION_PROPERTY_MAP_H
|
|---|
| 15 |
|
|---|
| 16 | #include <boost/config.hpp>
|
|---|
| 17 | #include <boost/property_map/property_map.hpp>
|
|---|
| 18 | #include <boost/type_traits.hpp>
|
|---|
| 19 | #include <boost/utility/result_of.hpp>
|
|---|
| 20 | #include <boost/mpl/and.hpp>
|
|---|
| 21 | #include <boost/mpl/not.hpp>
|
|---|
| 22 | #include <utility>
|
|---|
| 23 |
|
|---|
| 24 | namespace boost {
|
|---|
| 25 |
|
|---|
| 26 | template<typename Func, typename Key, typename Ret = typename boost::result_of<Func(Key)>::type>
|
|---|
| 27 | class function_property_map: public put_get_helper<Ret, function_property_map<Func, Key, Ret> > {
|
|---|
| 28 | public:
|
|---|
| 29 | typedef Key key_type;
|
|---|
| 30 | typedef Ret reference;
|
|---|
| 31 | typedef typename boost::remove_cv<typename boost::remove_reference<Ret>::type>::type value_type;
|
|---|
| 32 |
|
|---|
| 33 | typedef typename boost::mpl::if_<
|
|---|
| 34 | boost::mpl::and_<
|
|---|
| 35 | boost::is_reference<Ret>,
|
|---|
| 36 | boost::mpl::not_<boost::is_const<Ret> >
|
|---|
| 37 | >,
|
|---|
| 38 | boost::lvalue_property_map_tag,
|
|---|
| 39 | boost::readable_property_map_tag>::type
|
|---|
| 40 | category;
|
|---|
| 41 |
|
|---|
| 42 | function_property_map(Func f = Func()) : f(f) {}
|
|---|
| 43 |
|
|---|
| 44 | reference operator[](const Key& k) const {
|
|---|
| 45 | return f(k);
|
|---|
| 46 | }
|
|---|
| 47 |
|
|---|
| 48 | reference operator[](const Key& k) {
|
|---|
| 49 | return f(k);
|
|---|
| 50 | }
|
|---|
| 51 |
|
|---|
| 52 | private:
|
|---|
| 53 | Func f;
|
|---|
| 54 | };
|
|---|
| 55 |
|
|---|
| 56 | template<typename Key, typename Func>
|
|---|
| 57 | function_property_map<Func, Key>
|
|---|
| 58 | make_function_property_map(const Func& f) {
|
|---|
| 59 | return function_property_map<Func, Key>(f);
|
|---|
| 60 | }
|
|---|
| 61 |
|
|---|
| 62 | template<typename Key, typename Ret, typename Func>
|
|---|
| 63 | function_property_map<Func, Key, Ret>
|
|---|
| 64 | make_function_property_map(const Func& f) {
|
|---|
| 65 | return function_property_map<Func, Key, Ret>(f);
|
|---|
| 66 | }
|
|---|
| 67 |
|
|---|
| 68 | } // boost
|
|---|
| 69 |
|
|---|
| 70 | #endif /* BOOST_PROPERTY_MAP_FUNCTION_PROPERTY_MAP_H */
|
|---|