X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Packets%2FPacket.cci;h=35bd9313e23c1910a5a6f888f87cc48eae4da03f;hb=6a0836b7f462d3d77b79b35638cdbf4c9d4202fc;hp=ea4f54940e1bfefa2df7810b52dbbb85923283ec;hpb=03e6d8f7c983e22cdd021176a3190b7d34a2d8c5;p=senf.git diff --git a/Packets/Packet.cci b/Packets/Packet.cci index ea4f549..35bd931 100644 --- a/Packets/Packet.cci +++ b/Packets/Packet.cci @@ -1,8 +1,8 @@ // $Id$ // -// Copyright (C) 2007 -// Fraunhofer Institute for Open Communication Systems (FOKUS) -// Competence Center NETwork research (NET), St. Augustin, GERMANY +// 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 +24,7 @@ \brief Packet inline non-template implementation */ // Custom includes +#include "../Utils/senfassert.hh" #define prefix_ inline ///////////////////////////////cci.p/////////////////////////////////////// @@ -31,11 +32,26 @@ /////////////////////////////////////////////////////////////////////////// // senf::Packet +// protected members + +prefix_ senf::Packet::Packet(PacketInterpreterBase::ptr packet) + : packet_(packet) +{} + +prefix_ senf::PacketInterpreterBase::ptr senf::Packet::ptr() + const +{ + SENF_ASSERT(packet_); + return packet_; +} + // public structors prefix_ senf::Packet::Packet() {} +// public members + prefix_ senf::Packet senf::Packet::clone() const { @@ -44,6 +60,13 @@ prefix_ senf::Packet senf::Packet::clone() // Interpreter chain access +prefix_ senf::Packet senf::Packet::next(NoThrow_t) + const +{ + PacketInterpreterBase::ptr p (ptr()->next()); + return !p && ptr()->nextPacketRange() ? checkNext() : Packet(p); +} + prefix_ senf::Packet senf::Packet::next() const { @@ -52,11 +75,10 @@ prefix_ senf::Packet senf::Packet::next() return p; } -prefix_ senf::Packet senf::Packet::next(NoThrow_t) +prefix_ senf::Packet senf::Packet::prev(NoThrow_t) const { - PacketInterpreterBase::ptr p (ptr()->next()); - return !p && ptr()->nextPacketRange() ? checkNext() : Packet(p); + return Packet(ptr()->prev()); } prefix_ senf::Packet senf::Packet::prev() @@ -67,12 +89,6 @@ prefix_ senf::Packet senf::Packet::prev() return p; } -prefix_ senf::Packet senf::Packet::prev(NoThrow_t) - const -{ - return Packet(ptr()->prev()); -} - prefix_ senf::Packet senf::Packet::first() const { @@ -121,11 +137,19 @@ prefix_ bool senf::Packet::operator==(Packet other) return ptr() == other.ptr(); } -prefix_ void senf::Packet::finalize() - const +prefix_ void senf::Packet::finalizeThis() { - last(); // Make sure the packet is complete - ptr()->finalize(); + ptr()->finalizeThis(); +} + +prefix_ void senf::Packet::finalizeTo(Packet other) +{ + ptr()->finalizeTo(other.ptr()); +} + +prefix_ void senf::Packet::finalizeAll() +{ + ptr()->finalizeTo(last().ptr()); } prefix_ void senf::Packet::dump(std::ostream & os) @@ -153,19 +177,6 @@ prefix_ bool senf::Packet::boolean_test() return packet_ && packet_->valid(); } -// protected members - -prefix_ senf::Packet::Packet(PacketInterpreterBase::ptr packet) - : packet_(packet) -{} - -prefix_ senf::PacketInterpreterBase::ptr senf::Packet::ptr() - const -{ - BOOST_ASSERT(packet_); - return packet_; -} - ///////////////////////////////cci.e/////////////////////////////////////// #undef prefix_