// $Id$ // // Copyright (C) 2007 // Fraunhofer Institute for Open Communication Systems (FOKUS) // // The contents of this file are subject to the Fraunhofer FOKUS Public License // Version 1.0 (the "License"); you may not use this file except in compliance // with the License. You may obtain a copy of the License at // http://senf.berlios.de/license.html // // The Fraunhofer FOKUS Public License Version 1.0 is based on, // but modifies the Mozilla Public License Version 1.1. // See the full license text for the amendments. // // Software distributed under the License is distributed on an "AS IS" basis, // WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License // for the specific language governing rights and limitations under the License. // // The Original Code is Fraunhofer FOKUS code. // // The Initial Developer of the Original Code is Fraunhofer-Gesellschaft e.V. // (registered association), Hansastraße 27 c, 80686 Munich, Germany. // All Rights Reserved. // // Contributor(s): // Stefan Bund /** \file \brief ListParser inline template implementation */ #include "ListParser.ih" // Custom includes #include #define prefix_ inline //-///////////////////////////////////////////////////////////////////////////////////////////////// //-///////////////////////////////////////////////////////////////////////////////////////////////// // 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(); } //-///////////////////////////////////////////////////////////////////////////////////////////////// #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: