X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Packets%2FPacketParser.cci;h=ca796280b50527c51b132ebd5b40242469162d74;hb=41fe0d795abca302db24e7a955df6ef15ffed722;hp=d18cf3a93f9347bc11bc8fd400446ceb2dd7f030;hpb=47368f306a577d1e46df69a7f729bd3893cbe5e7;p=senf.git diff --git a/Packets/PacketParser.cci b/Packets/PacketParser.cci index d18cf3a..ca79628 100644 --- a/Packets/PacketParser.cci +++ b/Packets/PacketParser.cci @@ -53,6 +53,19 @@ prefix_ void senf::PacketParserBase::init() const {} +prefix_ void senf::PacketParserBase::defaultInit() + const +{} + +prefix_ senf::Packet senf::PacketParserBase::packet() + const +{ + // OUCH ... I hate this but for some awkward packet types, access to the packet + // from the parser is really needed (e.g. UDP when building the pseudo-header + // for calculating the checksum). + return Packet(PacketInterpreterBase::ptr(static_cast(&data()))); +} + //////////////////////////////////////// // protected members @@ -68,11 +81,13 @@ prefix_ senf::PacketParserBase::PacketParserBase(data_iterator i, state_type s, } prefix_ bool senf::PacketParserBase::check(size_type size) + const { return size <= size_type(std::distance(i(),end())); } prefix_ void senf::PacketParserBase::validate(size_type size) + const { if (! check(size)) throw TruncatedPacketException(); @@ -82,6 +97,7 @@ prefix_ void senf::PacketParserBase::validate(size_type size) // private members prefix_ senf::PacketParserBase::data_iterator senf::PacketParserBase::end() + const { return data_->end(); } @@ -96,4 +112,6 @@ prefix_ senf::PacketParserBase::data_iterator senf::PacketParserBase::end() // c-file-style: "senf" // indent-tabs-mode: nil // ispell-local-dictionary: "american" +// compile-command: "scons -u test" +// comment-column: 40 // End: