X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Packets%2FPacketParser.cti;h=098908f71235a210d2c79dd9a3c7f749a693b678;hb=fd3a0e8ac95d1158e9ea661ddf9187b67c70169f;hp=777531bf9d16cb4fbb8cc798f09cb74d4c94ff78;hpb=08d97ee2fd048ae883c297118145487517a31258;p=senf.git diff --git a/Packets/PacketParser.cti b/Packets/PacketParser.cti index 777531b..098908f 100644 --- a/Packets/PacketParser.cti +++ b/Packets/PacketParser.cti @@ -1,6 +1,8 @@ -// Copyright (C) 2007 -// Fraunhofer Institut fuer offene Kommunikationssysteme (FOKUS) -// Kompetenzzentrum fuer Satelitenkommunikation (SatCom) +// $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 @@ -24,6 +26,7 @@ #include "PacketParser.ih" // Custom includes +#include "../Utils/senfassert.hh" #include "PacketData.hh" #define prefix_ inline @@ -39,6 +42,13 @@ prefix_ Parser senf::PacketParserBase::parse(data_iterator i) return Parser(i,state()); } +template +prefix_ Parser senf::PacketParserBase::parse(Arg const & arg, data_iterator i) + const +{ + return Parser(arg, i, state()); +} + template prefix_ Parser senf::PacketParserBase::parse(size_type n) const @@ -46,9 +56,12 @@ prefix_ Parser senf::PacketParserBase::parse(size_type n) return Parser(boost::next(i(),n),state()); } -prefix_ void senf::PacketParserBase::defaultInit() +template +prefix_ Parser senf::PacketParserBase::parse(Arg const & arg, size_type n) const -{} +{ + return Parser(arg, boost::next(i(),n), state()); +} /////////////////////////////////////////////////////////////////////////// // namespace members @@ -75,63 +88,29 @@ prefix_ Parser senf::operator<<(Parser target, Value const & value) {} #endif -template -prefix_ senf::PacketParserBase::size_type -senf::detail::packetParserSize(Parser p, int, Parser_TakeNum *) -{ - return Parser::fixed_bytes; -} - -template -prefix_ senf::PacketParserBase::size_type senf::detail::packetParserSize(Parser p, ...) +#ifndef DOXYGEN +template +prefix_ typename boost::enable_if_c < + boost::is_base_of::value + && ! boost::is_base_of::value, + Parser >::type senf::operator<<(Parser target, boost::optional const & value) { - return p.bytes(); + if (value) + target.value(*value); + return target; } - -/////////////////////////////////////////////////////////////////////////// -// senf::SafePacketParser - -template -prefix_ senf::SafePacketParser::SafePacketParser() - : parser_(), i_() -{} - -template -prefix_ senf::SafePacketParser::SafePacketParser(Parser parser) - : parser_(parser), i_(parser) +#else +template +prefix_ Parser senf::operator<<(Parser target, Value const & value) {} +#endif -template -prefix_ senf::SafePacketParser & senf::SafePacketParser::operator=(Parser parser) -{ - parser_ = parser; - i_ = parser; - return *this; -} - -template -prefix_ Parser senf::SafePacketParser::operator*() - const -{ - BOOST_ASSERT( i_ ); - parser_->i_ = PacketParserBase::data_iterator(i_); - return *parser_; -} - -template -prefix_ Parser const * senf::SafePacketParser::operator->() - const -{ - BOOST_ASSERT( i_ ); - parser_->i_ = PacketParserBase::data_iterator(i_); - return & (*parser_); -} template -prefix_ bool senf::SafePacketParser::boolean_test() - const +prefix_ senf::PacketParserBase::size_type +senf::detail::packetParserSize(Parser p, int, senf::mpl::take_uint *) { - return i_; + return Parser::fixed_bytes; } ///////////////////////////////cti.e///////////////////////////////////////