// $Id$ // // Copyright (C) 2006 // 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 ArrayParser inline template implementation */ #include "ArrayParser.ih" // Custom includes #include #define prefix_ inline //-///////////////////////////////////////////////////////////////////////////////////////////////// //-///////////////////////////////////////////////////////////////////////////////////////////////// // senf::ArrayParser template prefix_ senf::ArrayParser::ArrayParser(data_iterator i, state_type s) : PacketParserBase(i,s,fixed_bytes) {} // Container interface template prefix_ typename senf::ArrayParser::size_type senf::ArrayParser::size() { return elements; } template prefix_ typename senf::ArrayParser::iterator senf::ArrayParser::begin() const { return iterator(i(),state()); } template prefix_ typename senf::ArrayParser::iterator senf::ArrayParser::end() const { return iterator(boost::next(i(),fixed_bytes),state()); } template prefix_ typename senf::ArrayParser::value_type senf::ArrayParser::operator[](difference_type i) const { // Access out of range element SENF_ASSERT( i>=0 && i < difference_type(elements), "Access to out-of-range array element" ); return begin()[i]; } //-///////////////////////////////////////////////////////////////////////////////////////////////// // senf::detail::ArrayParser_iterator template prefix_ senf::detail::ArrayParser_iterator::ArrayParser_iterator() : i_() {} template prefix_ senf::detail::ArrayParser_iterator:: ArrayParser_iterator(PacketParserBase::data_iterator const & i, PacketParserBase::state_type s) : i_(i), s_(s) {} template prefix_ ElementParser senf::detail::ArrayParser_iterator::operator[](int i) const { return (*this+i).dereference(); } template prefix_ senf::PacketParserBase::data_iterator senf::detail::ArrayParser_iterator::raw() const { return i_; } // iterator_facade interface template prefix_ ElementParser senf::detail::ArrayParser_iterator::dereference() const { return ElementParser(i_,s_); } template prefix_ bool senf::detail::ArrayParser_iterator:: equal(ArrayParser_iterator const & other) const { return i_==other.i_; } template prefix_ int senf::detail::ArrayParser_iterator:: distance_to(ArrayParser_iterator const & other) const { return (other.i_-i_)/ElementParser::fixed_bytes; } template prefix_ void senf::detail::ArrayParser_iterator::increment() { i_ += ElementParser::fixed_bytes; } template prefix_ void senf::detail::ArrayParser_iterator::decrement() { i_ -= ElementParser::fixed_bytes; } template prefix_ void senf::detail::ArrayParser_iterator::advance(int n) { i_ += n*ElementParser::fixed_bytes; } //-///////////////////////////////////////////////////////////////////////////////////////////////// #undef prefix_ // Local Variables: // mode: c++ // fill-column: 100 // c-file-style: "senf" // indent-tabs-mode: nil // ispell-local-dictionary: "american" // compile-command: "scons -u test" // comment-column: 40 // End: