| /* -*- Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil; -*- */ |
| /* |
| * Copyright (c) 2011 University of California, Los Angeles |
| * |
| * This program is free software; you can redistribute it and/or modify |
| * it under the terms of the GNU General Public License version 2 as |
| * published by the Free Software Foundation; |
| * |
| * This program is distributed in the hope that it will be useful, |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| * GNU General Public License for more details. |
| * |
| * You should have received a copy of the GNU General Public License |
| * along with this program; if not, write to the Free Software |
| * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
| * |
| * Author: Alexander Afanasyev <alexander.afanasyev@ucla.edu> |
| */ |
| |
| #ifndef MULTI_POLICY_CONTAINER_H_ |
| #define MULTI_POLICY_CONTAINER_H_ |
| |
| #include <boost/mpl/inherit_linearly.hpp> |
| #include <boost/mpl/at.hpp> |
| |
| namespace ns3 { |
| namespace ndn { |
| namespace ndnSIM { |
| namespace detail { |
| |
| template<class Base, class Value> |
| struct policy_wrap { |
| policy_wrap(Base& base) |
| : value_(base) |
| { |
| } |
| Value value_; |
| }; |
| |
| template<class Base, class Super /*empy_wrap/previous level*/, |
| class Value /*policy_wrap< element in vector >*/> |
| struct inherit_with_base : Super, Value { |
| inherit_with_base(Base& base) |
| : Super(base) |
| , Value(base) |
| { |
| } |
| |
| void |
| update(typename Base::iterator item) |
| { |
| Value::value_.update(item); |
| Super::update(item); |
| } |
| |
| bool |
| insert(typename Base::iterator item) |
| { |
| bool ok = Value::value_.insert(item); |
| if (!ok) |
| return false; |
| |
| ok = Super::insert(item); |
| if (!ok) { |
| Value::value_.erase(item); |
| return false; |
| } |
| return true; |
| } |
| |
| void |
| lookup(typename Base::iterator item) |
| { |
| Value::value_.lookup(item); |
| Super::lookup(item); |
| } |
| |
| void |
| erase(typename Base::iterator item) |
| { |
| Value::value_.erase(item); |
| Super::erase(item); |
| } |
| |
| void |
| clear() |
| { |
| Value::value_.clear(); |
| Super::clear(); |
| } |
| }; |
| |
| template<class Base> |
| struct empty_policy_wrap { |
| empty_policy_wrap(Base& base) |
| { |
| } |
| |
| void |
| update(typename Base::iterator item) |
| { |
| } |
| bool |
| insert(typename Base::iterator item) |
| { |
| return true; |
| } |
| void |
| lookup(typename Base::iterator item) |
| { |
| } |
| void |
| erase(typename Base::iterator item) |
| { |
| } |
| void |
| clear() |
| { |
| } |
| }; |
| |
| template<class Base, class Vector> |
| struct multi_policy_container |
| : public boost::mpl:: |
| fold<Vector, empty_policy_wrap<Base>, |
| inherit_with_base<Base, boost::mpl::_1 /*empty/previous*/, |
| policy_wrap<Base, boost::mpl::_2> /*element in vector*/>>::type { |
| typedef typename boost::mpl:: |
| fold<Vector, empty_policy_wrap<Base>, |
| inherit_with_base<Base, boost::mpl::_1 /*empty/previous*/, |
| policy_wrap<Base, boost::mpl::_2> /*element in vector*/>>::type super; |
| |
| typedef typename boost::mpl::at_c<Vector, 0>::type::iterator iterator; |
| typedef typename boost::mpl::at_c<Vector, 0>::type::const_iterator const_iterator; |
| |
| iterator |
| begin() |
| { |
| return this->get<0>().begin(); |
| } |
| const_iterator |
| begin() const |
| { |
| return this->get<0>().begin(); |
| } |
| |
| iterator |
| end() |
| { |
| return this->get<0>().end(); |
| } |
| const_iterator |
| end() const |
| { |
| return this->get<0>().end(); |
| } |
| |
| size_t |
| size() const |
| { |
| return this->get<0>().size(); |
| } |
| |
| multi_policy_container(Base& base) |
| : super(base) |
| { |
| } |
| |
| template<int N> |
| struct index { |
| typedef typename boost::mpl::at_c<Vector, N>::type type; |
| }; |
| |
| template<class T> |
| T& |
| get() |
| { |
| return static_cast<policy_wrap<Base, T>&>(*this).value_; |
| } |
| |
| template<class T> |
| const T& |
| get() const |
| { |
| return static_cast<const policy_wrap<Base, T>&>(*this).value_; |
| } |
| |
| template<int N> |
| typename boost::mpl::at_c<Vector, N>::type& |
| get() |
| { |
| typedef typename boost::mpl::at_c<Vector, N>::type T; |
| return static_cast<policy_wrap<Base, T>&>(*this).value_; |
| } |
| |
| template<int N> |
| const typename boost::mpl::at_c<Vector, N>::type& |
| get() const |
| { |
| typedef typename boost::mpl::at_c<Vector, N>::type T; |
| return static_cast<const policy_wrap<Base, T>&>(*this).value_; |
| } |
| }; |
| |
| } // detail |
| } // ndnSIM |
| } // ndn |
| } // ns3 |
| |
| #endif // MULTI_POLICY_CONTAINER_H_ |