X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Packets%2FPacketParser.cti;h=098908f71235a210d2c79dd9a3c7f749a693b678;hb=bd9f9d3fd6fbcff0112a7bf48ab9284da9576b11;hp=28b71c2efd93c62aaf2b946c8317590d070bbd08;hpb=a18d131c38ffe7178ea4736ed3f584125e9903ae;p=senf.git diff --git a/Packets/PacketParser.cti b/Packets/PacketParser.cti index 28b71c2..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 @@ -100,58 +113,6 @@ senf::detail::packetParserSize(Parser p, int, senf::mpl::take_uint -prefix_ senf::PacketParserBase::size_type senf::detail::packetParserSize(Parser p, ...) -{ - return p.bytes(); -} - -/////////////////////////////////////////////////////////////////////////// -// senf::SafePacketParser - -template -prefix_ senf::SafePacketParser::SafePacketParser() - : parser_(), i_() -{} - -template -prefix_ senf::SafePacketParser::SafePacketParser(Parser parser) - : parser_(parser), i_(parser) -{} - -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 -{ - return i_; -} - ///////////////////////////////cti.e/////////////////////////////////////// #undef prefix_