X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Packets%2FDefaultBundle%2FEthernetPacket.cc;h=15ca8f4262e8f76c20350cf30eabe434b0b8a044;hb=a2d850e1e85a8c86ac60007a254383c1f2b19351;hp=9926efce3489146a66dd5aabec7af0569137ea39;hpb=03e6d8f7c983e22cdd021176a3190b7d34a2d8c5;p=senf.git diff --git a/Packets/DefaultBundle/EthernetPacket.cc b/Packets/DefaultBundle/EthernetPacket.cc index 9926efc..15ca8f4 100644 --- a/Packets/DefaultBundle/EthernetPacket.cc +++ b/Packets/DefaultBundle/EthernetPacket.cc @@ -1,8 +1,8 @@ // $Id$ // // Copyright (C) 2006 -// Fraunhofer Institute for Open Communication Systems (FOKUS) -// Competence Center NETwork research (NET), St. Augustin, GERMANY +// 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 @@ -60,24 +60,18 @@ prefix_ void senf::EthernetPacketType::dump(packet p, std::ostream & os) prefix_ senf::PacketInterpreterBase::factory_t senf::EthernetPacketType::nextPacketType(packet p) { - if (p->type_length() >= 1536) { - PkReg_Entry const * e; - e = PacketRegistry::lookup( p->type_length(), nothrow ); - return e ? e->factory() : no_factory(); - } - if (p->type_length() <= 1500) - return LlcSnapPacket::factory(); - return no_factory(); + if (p->type_length() >= 1536) return lookup(p->type_length()); + else if (p->type_length() <= 1500) return LlcSnapPacket::factory(); + else return no_factory(); } prefix_ void senf::EthernetPacketType::finalize(packet p) { - optional_registry_key_t k = key(p.next(nothrow)); + optional_key_t k (key(p.next(nothrow))); if (k) p->type_length() << k; - else - if (p.next().is()) - p->type_length() << p.next().data().size(); + else if (p.next().is()) + p->type_length() << p.next().data().size(); // Do NOT reset type_length if the type is not known ... doing this will destroy read packets }