X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fnet%2FConnectionHandler.hpp;h=942826b4329349a9b58f8bd1dad2cccf93ed17be;hb=e821b85cf13376b11d125bdf5da4f16b20acf2e2;hp=d0172fd2f87eeb07c30c1a43334abea0f02a6ca8;hpb=8507332e2d0c54aec4045fb6f0021bdc3bd57750;p=blank.git diff --git a/src/net/ConnectionHandler.hpp b/src/net/ConnectionHandler.hpp index d0172fd..942826b 100644 --- a/src/net/ConnectionHandler.hpp +++ b/src/net/ConnectionHandler.hpp @@ -11,16 +11,25 @@ namespace blank { class ConnectionHandler { public: + ConnectionHandler(); + + float PacketLoss() const noexcept { return packet_loss; } + + void PacketLost(std::uint16_t); + void PacketReceived(std::uint16_t); + void Handle(const UDPpacket &); + virtual void OnTimeout() { } + +private: + void UpdatePacketLoss() noexcept; + // called as soon as the remote end ack'd given packet virtual void OnPacketReceived(std::uint16_t) { } // called if the remote end probably didn't get given packet virtual void OnPacketLost(std::uint16_t) { } - virtual void OnTimeout() { } - -private: virtual void On(const Packet::Ping &) { } virtual void On(const Packet::Login &) { } virtual void On(const Packet::Join &) { } @@ -30,6 +39,13 @@ private: virtual void On(const Packet::DespawnEntity &) { } virtual void On(const Packet::EntityUpdate &) { } virtual void On(const Packet::PlayerCorrection &) { } + virtual void On(const Packet::ChunkBegin &) { } + virtual void On(const Packet::ChunkData &) { } + +private: + unsigned int packets_lost; + unsigned int packets_received; + float packet_loss; };