// $Id$ // // Copyright (C) 2007 // Fraunhofer Institute for Open Communication Systems (FOKUS) // Competence Center NETwork research (NET), St. Augustin, GERMANY // Stefan Bund // // This program is free software; you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation; either version 2 of the License, or // (at your option) any later version. // // 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. /** \file \brief ListParser inline template implementation */ #include "ListParser.ih" // Custom includes #include #define prefix_ inline ///////////////////////////////cti.p/////////////////////////////////////// /////////////////////////////////////////////////////////////////////////// // senf::ListParser template prefix_ senf::ListParser::ListParser(data_iterator i, state_type s) : PacketParserBase(i,s), ListPolicy() {} template prefix_ senf::ListParser::ListParser(ListPolicy policy, data_iterator i, state_type s) : PacketParserBase(i,s), ListPolicy(policy) {} template prefix_ senf::PacketParserBase::size_type senf::ListParser::bytes() const { return ListPolicy::bytes(i(),state()); } /////////////////////////////////////////////////////////////////////////// // Container interface template prefix_ senf::PacketParserBase::size_type senf::ListParser::size() const { return ListPolicy::size(i(),state()); } template prefix_ bool senf::ListParser::empty() const { container c (*this); return c.empty(); } template prefix_ typename senf::ListParser::value_type senf::ListParser::front() const { SENF_ASSERT( ! empty(), "front() called on empty list" ); container c(*this); return *(c.begin()); } template template prefix_ void senf::ListParser::push_back(Value const & value, size_type n) const { container c(*this); c.push_back(value,n); } template prefix_ typename senf::ListParser::value_type senf::ListParser::push_back_space(size_type n) const { container c(*this); return c.push_back_space(n); } template template prefix_ void senf::ListParser::push_front(Value const & value, size_type n) const { container c(*this); c.push_front(value,n); } template prefix_ typename senf::ListParser::value_type senf::ListParser::push_front_space(size_type n) const { container c(*this); return c.push_front_space(n); } template prefix_ void senf::ListParser::resize(size_type n) const { container c(*this); c.resize(n); } template template prefix_ void senf::ListParser::resize(size_type n, Value value) const { container c(*this); c.resize(n,value); } template prefix_ typename senf::ListParser & senf::ListParser::get(ListPolicy & p) { return static_cast(p); } template prefix_ typename senf::ListParser const & senf::ListParser::get(ListPolicy const & p) { return static_cast(p); } /////////////////////////////////////////////////////////////////////////// // senf::detail::ListParser_Iterator template prefix_ senf::detail::ListParser_Iterator::ListParser_Iterator() {} template prefix_ senf::detail::ListParser_Iterator::ListParser_Iterator(Container const & c) : c_ (&c) {} template prefix_ senf::PacketParserBase::data_iterator senf::detail::ListParser_Iterator::raw() const { return c_->Container::policy::raw(*c_, *this); } template prefix_ senf::PacketParserBase::data_iterator senf::detail::ListParser_Iterator::i() const { return i_; } template prefix_ typename senf::detail::ListParser_Iterator & senf::detail::ListParser_Iterator::get(typename Container::policy::iterator_data & d) { return static_cast(d); } template prefix_ typename senf::detail::ListParser_Iterator const & senf::detail::ListParser_Iterator:: get(typename Container::policy::iterator_data const & d) { return static_cast(d); } template prefix_ typename senf::detail::ListParser_Iterator::value_type senf::detail::ListParser_Iterator::dereference() const { return value_type(i_,c_->state()); } template prefix_ bool senf::detail::ListParser_Iterator::equal(ListParser_Iterator const & other) const { return i_ == other.i_; } template prefix_ void senf::detail::ListParser_Iterator::increment() { i_ = c_->Container::policy::next(*c_, *this); } /////////////////////////////////////////////////////////////////////////// // senf::ListParser_Container // Structors and default members template prefix_ senf::ListParser_Container:: ListParser_Container(parser_type const & list) : ListPolicy(static_cast(list)), state_(list.state()), i_(std::distance(data().begin(),list.i())) { ListPolicy::construct(*this); } template prefix_ senf::ListParser_Container::~ListParser_Container() { ListPolicy::update(*this); ListPolicy::destruct(*this); } // Accessors template prefix_ typename senf::ListParser_Container::size_type senf::ListParser_Container::size() const { ListPolicy::update(*this); return ListPolicy::size(i(),state()); } template prefix_ bool senf::ListParser_Container::empty() const { ListPolicy::update(*this); return begin() == end(); } template prefix_ typename senf::ListParser_Container::iterator senf::ListParser_Container::begin() const { ListPolicy::update(*this); iterator i (*this); i.i_ = ListPolicy::setBegin(*this, i); return i; } template prefix_ typename senf::ListParser_Container::iterator senf::ListParser_Container::end() const { ListPolicy::update(*this); iterator i (*this); i.i_ = ListPolicy::setEnd(*this, i); return i; } template prefix_ typename senf::ListParser_Container::value_type senf::ListParser_Container::front() const { SENF_ASSERT( ! empty(), "front() called on empty list" ); return *begin(); } // Mutators template template prefix_ void senf::ListParser_Container::insert(iterator pos, Value const & t) { insert(pos,1,t); } template prefix_ void senf::ListParser_Container::erase(iterator f, iterator l) { erase(f,std::distance(f,l)); } template template prefix_ void senf::ListParser_Container::push_back(Value const & value, size_type n) { insert(end(),n,value); } template prefix_ typename senf::ListParser_Container::value_type senf::ListParser_Container::push_back_space(size_type n) { return shift(end(),n); } template template prefix_ void senf::ListParser_Container::push_front(Value const & value, size_type n) { insert(begin(),n,value); } template prefix_ typename senf::ListParser_Container::value_type senf::ListParser_Container::push_front_space(size_type n) { return shift(begin(),n); } // Parser interface template prefix_ typename senf::ListParser_Container::parser_type senf::ListParser_Container::parser() const { ListPolicy::update(*this); return parser_type(i(),state()); } template prefix_ typename senf::ListParser_Container::data_iterator senf::ListParser_Container::i() const { return boost::next(data().begin(),i_); } template prefix_ typename senf::ListParser_Container::state_type senf::ListParser_Container::state() const { return state_; } template prefix_ senf::PacketData & senf::ListParser_Container::data() const { return *state_; } template prefix_ typename senf::ListParser_Container::size_type senf::ListParser_Container::bytes() const { ListPolicy::update(*this); return ListPolicy::bytes(i(),state()); } template prefix_ void senf::ListParser_Container::init() const { parser().init(); } ///////////////////////////////cti.e/////////////////////////////////////// #undef prefix_ // Local Variables: // mode: c++ // fill-column: 100 // comment-column: 40 // c-file-style: "senf" // indent-tabs-mode: nil // ispell-local-dictionary: "american" // compile-command: "scons -u test" // End: