X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Packets%2FPacket.cti;h=afae6069db5e853e17975d293110966a69f754b4;hb=f2f5d59e83863f3b513950173baee1b6da2aee3c;hp=b58b78374d8a3c254c8d5f6d20198836779e83c0;hpb=784b5901486e0bcb0eb5dadd3a2f4fc31810bd66;p=senf.git diff --git a/Packets/Packet.cti b/Packets/Packet.cti index b58b783..afae606 100644 --- a/Packets/Packet.cti +++ b/Packets/Packet.cti @@ -26,6 +26,7 @@ //#include "Packet.ih" // Custom includes +#include "../Utils/Exception.hh" #define prefix_ inline ///////////////////////////////cti.p/////////////////////////////////////// @@ -61,7 +62,7 @@ prefix_ OtherPacket senf::Packet::as() const { if (!is()) - throw std::bad_cast(); + throw WrapException(std::bad_cast()); return OtherPacket(ptr()->as()); } @@ -127,6 +128,26 @@ prefix_ OtherPacket senf::Packet::first() return first().as(); } +template +prefix_ void senf::Packet::finalizeTo() +{ + Packet p (find(nothrow)); + ptr()->finalizeTo(p ? p.ptr() : last().ptr()); +} + +template +prefix_ Annotation & senf::Packet::annotation() +{ + return ptr()->annotation(); +} + +template +prefix_ Annotation const & senf::Packet::annotation() + const +{ + return ptr()->annotation(); +} + /////////////////////////////////////////////////////////////////////////// // senf::ConcretePacket @@ -173,6 +194,8 @@ senf::ConcretePacket::create(size_type size, senf::NoInit_t) return ConcretePacket(interpreter::create(size,senf::noinit)); } +#ifndef DOXYGEN + template template prefix_ senf::ConcretePacket senf::ConcretePacket:: @@ -182,57 +205,64 @@ create(ForwardReadableRange const & range, return ConcretePacket(interpreter::create(range)); } +#endif + // Create packet as new packet after a given packet template prefix_ senf::ConcretePacket -senf::ConcretePacket::createAfter(Packet packet) +senf::ConcretePacket::createAfter(Packet const & packet) { return ConcretePacket(interpreter::createAfter(packet.ptr())); } template prefix_ senf::ConcretePacket -senf::ConcretePacket::createAfter(Packet packet, senf::NoInit_t) +senf::ConcretePacket::createAfter(Packet const & packet, senf::NoInit_t) { return ConcretePacket(interpreter::createAfter(packet.ptr(),senf::noinit)); } template prefix_ senf::ConcretePacket -senf::ConcretePacket::createAfter(Packet packet, size_type size) +senf::ConcretePacket::createAfter(Packet const & packet, size_type size) { return ConcretePacket(interpreter::createAfter(packet.ptr(), size)); } template prefix_ senf::ConcretePacket -senf::ConcretePacket::createAfter(Packet packet, size_type size, senf::NoInit_t) +senf::ConcretePacket::createAfter(Packet const & packet, size_type size, + senf::NoInit_t) { return ConcretePacket(interpreter::createAfter(packet.ptr(), size, senf::noinit)); } +#ifndef DOXYGEN + template template prefix_ senf::ConcretePacket senf::ConcretePacket:: -createAfter(Packet packet, ForwardReadableRange const & range, +createAfter(Packet const & packet, ForwardReadableRange const & range, typename boost::disable_if< boost::is_integral >::type *) { return ConcretePacket(interpreter::createAfter(packet.ptr(), range)); } +#endif + // Create packet as new packet (header) before a given packet template prefix_ senf::ConcretePacket -senf::ConcretePacket::createBefore(Packet packet) +senf::ConcretePacket::createBefore(Packet const & packet) { return ConcretePacket(interpreter::createBefore(packet.ptr())); } template prefix_ senf::ConcretePacket -senf::ConcretePacket::createBefore(Packet packet, senf::NoInit_t) +senf::ConcretePacket::createBefore(Packet const & packet, senf::NoInit_t) { return ConcretePacket(interpreter::createBefore(packet.ptr(), senf::noinit)); } @@ -250,19 +280,19 @@ senf::ConcretePacket::clone() // Field access template -prefix_ typename senf::ConcretePacket::Parser * -senf::ConcretePacket::operator->() +prefix_ typename senf::ConcretePacket::Parser +senf::ConcretePacket::parser() const { - return ptr()->fields_p(); + return ptr()->fields(); } template -prefix_ typename senf::ConcretePacket::Parser -senf::ConcretePacket::parser() +prefix_ typename senf::ConcretePacket::ParserProxy +senf::ConcretePacket::operator->() const { - return ptr()->fields(); + return ParserProxy(parser()); } // private members