X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Packets%2FPacketParser.cti;h=098908f71235a210d2c79dd9a3c7f749a693b678;hb=c45c112ae88196ea8da9c5a9efb0e167196744d2;hp=9b885e57f5e2adbb7970a7b1f0f296b19457fc13;hpb=47368f306a577d1e46df69a7f729bd3893cbe5e7;p=senf.git diff --git a/Packets/PacketParser.cti b/Packets/PacketParser.cti index 9b885e5..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 @@ -59,6 +72,7 @@ prefix_ senf::PacketParserBase::size_type senf::bytes(Parser p) return detail::packetParserSize(p,0); } +#ifndef DOXYGEN template prefix_ typename boost::enable_if_c < boost::is_base_of::value @@ -68,64 +82,35 @@ prefix_ typename boost::enable_if_c < target.value(value); return target; } - -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, ...) -{ - return p.bytes(); -} - -/////////////////////////////////////////////////////////////////////////// -// senf::SafePacketParser - -template -prefix_ senf::SafePacketParser::SafePacketParser() - : 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 +#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) { - BOOST_ASSERT( i_ ); - parser_->i_ = PacketParserBase::data_iterator(i_); - return *parser_; + if (value) + target.value(*value); + return target; } +#else +template +prefix_ Parser senf::operator<<(Parser target, Value const & value) +{} +#endif -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/////////////////////////////////////// @@ -138,4 +123,6 @@ prefix_ bool senf::SafePacketParser::boolean_test() // c-file-style: "senf" // indent-tabs-mode: nil // ispell-local-dictionary: "american" +// compile-command: "scons -u test" +// comment-column: 40 // End: