// $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 ListNParser internal header */ #ifndef IH_SENF_Packets_ListNParser_ #define IH_SENF_Packets_ListNParser_ 1 // Custom includes #include "ListParser.ih" //-///////////////////////////////////////////////////////////////////////////////////////////////// namespace senf { namespace detail { /** \brief Internal: ListPolicy defining the ListNParser parser \internal \see \ref ListParser */ template struct ListNParser_Policy : public AuxPolicy { typedef ListNParser_Policy< ElementParser, typename AuxPolicy::ParserPolicy> parser_policy; typedef ListNParser_Policy< ElementParser, typename AuxPolicy::WrapperPolicy> container_policy; typedef PacketParserBase::data_iterator data_iterator; typedef PacketParserBase::state_type state_type; typedef PacketParserBase::size_type size_type; typedef ElementParser element_type; typedef ListParser parser_type; typedef ListParser_Container container_type; static const size_type init_bytes = AuxPolicy::aux_bytes; ListNParser_Policy(); template ListNParser_Policy(Arg const & aux); ListNParser_Policy(parser_policy const & policy); size_type bytes (data_iterator i, state_type s) const; size_type size (data_iterator i, state_type s) const; void init (data_iterator i, state_type s) const; void construct (container_type & c) const; void destruct (container_type & c) const; void erase (container_type & c, data_iterator p) const; void insert (container_type & c, data_iterator p) const; void update (container_type const & c) const; /** Internal: ListNParser iterator specific data */ struct iterator_data { size_type n_; }; data_iterator setBegin (container_type const & c, iterator_data & d) const; data_iterator setEnd (container_type const & c, iterator_data & d) const; void setFromPosition (container_type const & c, iterator_data & d, data_iterator p) const; data_iterator next (container_type const & c, iterator_data & d) const; data_iterator raw (container_type const & c, iterator_data const & d) const; }; #ifndef DOXYGEN template struct ListParserPolicy { typedef ListNParser_Policy type; }; template struct ListParserPolicy > { typedef ListNParser_Policy< ElementParser, TransformAuxParserPolicy > type; }; #endif }} //-///////////////////////////////////////////////////////////////////////////////////////////////// #endif // 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: