X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fnet%2Fprotocol.cpp;h=cee18367b7cb254abf220e33eaad1f76958679f0;hb=9cc2493cd87e2419d3cfb432844a2bf45ec3178f;hp=9cba6382d307dcae861d3f4298c76ee4f86ac09b;hpb=62ea6954a91568c900ad8155999bea264dfa72f3;p=libs%2Fnet.git diff --git a/source/net/protocol.cpp b/source/net/protocol.cpp index 9cba638..cee1836 100644 --- a/source/net/protocol.cpp +++ b/source/net/protocol.cpp @@ -1,6 +1,5 @@ #include #include -#include #include #include #include @@ -15,7 +14,7 @@ Protocol::Protocol(unsigned npi): header_def(0), next_packet_id(npi) { - PacketDefBuilder >(*this, header_def, NullSerializer()) + PacketDefBuilder>(*this, header_def, Serializer()) (&PacketHeader::type)(&PacketHeader::length); } @@ -76,10 +75,13 @@ size_t Protocol::get_packet_size(const char *buf, size_t size) const uint64_t Protocol::get_hash() const { - string description; + uint64_t result = hash<64>(packet_id_defs.size()); for(auto &kvp: packet_id_defs) - description += format("%d:%s\n", kvp.first, kvp.second->describe()); - return hash<64>(description); + { + hash_update<64>(result, kvp.first); + hash_update<64>(result, kvp.second->get_hash()); + } + return result; } @@ -164,11 +166,6 @@ Protocol::PacketDefBase::PacketDefBase(unsigned i): { } -Protocol::PacketHeader::PacketHeader(): - type(0), - length(0) -{ } - Protocol::PacketHeader::PacketHeader(uint16_t t, uint16_t l): type(t), length(l)