X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Packets%2FPacket.cti;h=ed032da0160e70bf22d74929bec68ac5b752a058;hb=be4e99b96b305cb8f8c6a00a0098392483089812;hp=c17dc6fa9b406dfd9833aac1a7155f6ad79821d5;hpb=47368f306a577d1e46df69a7f729bd3893cbe5e7;p=senf.git diff --git a/Packets/Packet.cti b/Packets/Packet.cti index c17dc6f..ed032da 100644 --- a/Packets/Packet.cti +++ b/Packets/Packet.cti @@ -1,6 +1,8 @@ +// $Id$ +// // Copyright (C) 2007 -// Fraunhofer Institut fuer offene Kommunikationssysteme (FOKUS) -// Kompetenzzentrum fuer Satelitenkommunikation (SatCom) +// 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 @@ -58,6 +60,8 @@ template prefix_ OtherPacket senf::Packet::as() const { + if (!is()) + throw std::bad_cast(); return OtherPacket(ptr()->as()); } @@ -65,81 +69,30 @@ template prefix_ OtherPacket senf::Packet::next() const { - OtherPacket p (next(nothrow)); - if (!p) throw InvalidPacketChainException(); - return p; -} - - -template -prefix_ OtherPacket senf::Packet::next(NoThrow_t) - const -{ - Packet p (next()); - return p ? p.findNext(nothrow) : OtherPacket(); + Packet p (next()) + return p ? p.as() : OtherPacket(); } template prefix_ OtherPacket senf::Packet::prev() const { - OtherPacket p (prev(nothrow)); - if (!p) throw InvalidPacketChainException(); - return p; -} - -template -prefix_ OtherPacket senf::Packet::prev(NoThrow_t) - const -{ Packet p (prev()); - return p ? p.findPrev(nothrow) : OtherPacket(); -} - -template -prefix_ OtherPacket senf::Packet::findNext() - const -{ - OtherPacket p (findNext(nothrow)); - if (!p) throw InvalidPacketChainException(); - return p; -} - -template -prefix_ OtherPacket senf::Packet::findPrev() - const -{ - OtherPacket p (findPrev(nothrow)); - if (!p) throw InvalidPacketChainException(); - return p; + return p ? p.as() : OtherPacket(); } template prefix_ OtherPacket senf::Packet::last() const { - return last().findPrev(); -} - -template -prefix_ OtherPacket senf::Packet::last(NoThrow_t) - const -{ - return last().findPrev(nothrow); + return last().as(); } template prefix_ OtherPacket senf::Packet::first() const { - return first().findNext(); -} - -template -prefix_ OtherPacket senf::Packet::first(NoThrow_t) - const -{ - return first().findNext(nothrow); + return first().as(); } /////////////////////////////////////////////////////////////////////////// @@ -263,7 +216,7 @@ senf::ConcretePacket::clone() // Field access template -prefix_ typename senf::ConcretePacket::interpreter::parser * +prefix_ typename senf::ConcretePacket::type::parser * senf::ConcretePacket::operator->() const { @@ -296,4 +249,5 @@ senf::ConcretePacket::ptr() // indent-tabs-mode: nil // ispell-local-dictionary: "american" // compile-command: "scons -u test" +// comment-column: 40 // End: