// $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 #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 { return begin() == end(); } template prefix_ typename senf::ListParser::iterator senf::ListParser::begin() const { return iterator(i(),state(),iterator::Begin); } template prefix_ typename senf::ListParser::iterator senf::ListParser::end() const { return iterator(i(),state(),iterator::End); } template prefix_ typename senf::ListParser::value_type senf::ListParser::front() const { BOOST_ASSERT( ! empty() ); return *begin(); } template template prefix_ void senf::ListParser::push_back(Value value, size_type n) const { container c(*this); c.push_back(value,n); } template prefix_ void senf::ListParser::push_back_space(size_type n) const { container c(*this); c.push_back_space(n); } template template prefix_ void senf::ListParser::push_front(Value value, size_type n) const { container c(*this); c.push_front(value,n); } template prefix_ void senf::ListParser::push_front_space(size_type n) const { container c(*this); 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); } /////////////////////////////////////////////////////////////////////////// // senf::detail::ListParser_Iterator template prefix_ senf::detail::ListParser_Iterator::ListParser_Iterator() {} template prefix_ senf::detail::ListParser_Iterator:: ListParser_Iterator(PacketParserBase::data_iterator i, PacketParserBase::state_type s, Begin_t) : IteratorPolicy(), i_(IteratorPolicy::setBegin(i,s)), s_(s) {} template prefix_ senf::detail::ListParser_Iterator:: ListParser_Iterator(PacketParserBase::data_iterator i, PacketParserBase::state_type s, End_t) : IteratorPolicy(), i_(IteratorPolicy::setEnd(i,s)), s_(s) {} template prefix_ senf::detail::ListParser_Iterator:: ListParser_Iterator(PacketParserBase::data_iterator i, PacketParserBase::state_type s, PacketParserBase::data_iterator p) : IteratorPolicy(), i_(p), s_(s) { IteratorPolicy::setFromPosition(i,s,p); } template prefix_ senf::PacketParserBase::data_iterator senf::detail::ListParser_Iterator::raw() const { return IteratorPolicy::raw(i_,s_); } template prefix_ ElementParser senf::detail::ListParser_Iterator::dereference() const { return ElementParser(i_,s_); } 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_ = IteratorPolicy::next(i_,s_); } /////////////////////////////////////////////////////////////////////////// // senf::ListParser_Container // Structors and default members template prefix_ senf::ListParser_Container:: ListParser_Container(parser_type const & list) : ListPolicy(list), state_(list.state()), i_(std::distance(data().begin(),list.i())) {} template prefix_ senf::ListParser_Container::~ListParser_Container() { ListPolicy::update(i(),state()); } // Accessors template prefix_ typename senf::ListParser_Container::size_type senf::ListParser_Container::size() const { ListPolicy::update(i(),state()); return ListPolicy::size(i(),state()); } template prefix_ bool senf::ListParser_Container::empty() const { ListPolicy::update(i(),state()); return begin() == end(); } template prefix_ typename senf::ListParser_Container::iterator senf::ListParser_Container::begin() const { ListPolicy::update(i(),state()); return iterator(i(),state(),iterator::Begin); } template prefix_ typename senf::ListParser_Container::iterator senf::ListParser_Container::end() const { ListPolicy::update(i(),state()); return iterator(i(),state(),iterator::End); } template prefix_ typename senf::ListParser_Container::value_type senf::ListParser_Container::front() const { BOOST_ASSERT( ! empty() ); 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 value, size_type n) { insert(end(),n,value); } template prefix_ void senf::ListParser_Container::push_back_space(size_type n) { shift(end(),n); } template template prefix_ void senf::ListParser_Container::push_front(Value value, size_type n) { insert(begin(),n,value); } template prefix_ void senf::ListParser_Container::push_front_space(size_type n) { shift(begin(),n); } // Parser interface template prefix_ typename senf::ListParser_Container::parser_type senf::ListParser_Container::parser() const { ListPolicy::update(i(),state()); 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(i(),state()); 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: