// $Id$ // // Copyright (C) 2006 // 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 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: