X-Git-Url: http://git.tdb.fi/?p=libs%2Fnet.git;a=blobdiff_plain;f=source%2Fnet%2Fprotocol.cpp;fp=source%2Fnet%2Fprotocol.cpp;h=402b84a0633cdeb4dbe45c463e2f9676af911709;hp=ce200a2c0ea49afed1f320b0914c252a094669bd;hb=ede42d5bb352841e2e425972e12b8ef31ddf2123;hpb=1565dec0f4a86e4bda7095dd7415234f7c7a84e9 diff --git a/source/net/protocol.cpp b/source/net/protocol.cpp index ce200a2..402b84a 100644 --- a/source/net/protocol.cpp +++ b/source/net/protocol.cpp @@ -18,29 +18,20 @@ Protocol::Protocol(unsigned npi): .fields(&PacketHeader::type, &PacketHeader::length); } -Protocol::~Protocol() -{ - for(auto &kvp: packet_class_defs) - delete kvp.second; -} - unsigned Protocol::get_next_packet_class_id() { static unsigned next_id = 1; return next_id++; } -void Protocol::add_packet(PacketDefBase *pdef) +void Protocol::add_packet(unique_ptr pdef) { - PacketDefBase *&ptr = packet_class_defs[pdef->get_class_id()]; + unique_ptr &ptr = packet_class_defs[pdef->get_class_id()]; if(ptr) - { packet_id_defs.erase(ptr->get_id()); - delete ptr; - } - ptr = pdef; - if(unsigned id = pdef->get_id()) - packet_id_defs[id] = pdef; + ptr = move(pdef); + if(unsigned id = ptr->get_id()) + packet_id_defs[id] = ptr.get(); } const Protocol::PacketDefBase &Protocol::get_packet_by_class_id(unsigned id) const