X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Packets%2FDefaultBundle%2FIPv6Packet.cc;h=8240f5b2c1fcfcd80dae9b25bb457d5c942a96e2;hb=5fc9de05bf3449d30a17f6e4c05115e7e101d228;hp=2f3fe8bfacd63f5d7b01f4027abaf847a2782a53;hpb=f73fa16ed5abdce272ac77f8b8b9ef2b9922c266;p=senf.git diff --git a/Packets/DefaultBundle/IPv6Packet.cc b/Packets/DefaultBundle/IPv6Packet.cc index 2f3fe8b..8240f5b 100644 --- a/Packets/DefaultBundle/IPv6Packet.cc +++ b/Packets/DefaultBundle/IPv6Packet.cc @@ -42,9 +42,6 @@ namespace { senf::PacketRegistry::RegistrationProxy registerIPv6Packet2 (41); // IP6-in-IP(6) encapsulation - - senf::PacketRegistry::RegistrationProxy - registerNoNextHeader (59); } prefix_ void senf::IPv6PacketType::dump(packet p, std::ostream & os) @@ -66,7 +63,12 @@ prefix_ void senf::IPv6PacketType::dump(packet p, std::ostream & os) prefix_ void senf::IPv6PacketType::finalize(packet p) { p->length() << (p.size() - IPv6PacketParser::fixed_bytes); - p->nextHeader() << key(p.next()); + try { + p->nextHeader() << key(p.next()); + } + catch (InvalidPacketChainException & ex) { + p->nextHeader() << 59; // No next header + } } ///////////////////////////////cc.e////////////////////////////////////////