From fcf31a258f2925650cf51f15d0280c0efb67c6a2 Mon Sep 17 00:00:00 2001 From: mekolat Date: Sun, 10 Apr 2016 14:14:51 -0400 Subject: consolidate client version handling --- src/mmo/fwd.hpp | 1 + src/mmo/ids.hpp | 1 + src/mmo/ids.py | 1 + src/mmo/version.hpp | 8 +++++--- 4 files changed, 8 insertions(+), 3 deletions(-) (limited to 'src/mmo') diff --git a/src/mmo/fwd.hpp b/src/mmo/fwd.hpp index 434885e..d98bd33 100644 --- a/src/mmo/fwd.hpp +++ b/src/mmo/fwd.hpp @@ -44,6 +44,7 @@ class PartyId; class ItemNameId; class BlockId; class GmLevel; +class ClientVersion; class AccountName; class AccountPass; diff --git a/src/mmo/ids.hpp b/src/mmo/ids.hpp index 28b146a..22f5eae 100644 --- a/src/mmo/ids.hpp +++ b/src/mmo/ids.hpp @@ -41,6 +41,7 @@ class ItemNameId : public Wrapped { public: constexpr ItemNameId() : W class BlockId : public Wrapped { public: constexpr BlockId() : Wrapped() {} protected: constexpr explicit BlockId(uint32_t a) : Wrapped(a) {} }; class QuestId : public Wrapped { public: constexpr QuestId() : Wrapped() {} protected: constexpr explicit QuestId(uint16_t a) : Wrapped(a) {} }; +class ClientVersion : public Wrapped{ public: constexpr ClientVersion() : Wrapped() {} protected: constexpr explicit ClientVersion(uint32_t a) : Wrapped(a) {} }; bool impl_extract(XString str, GmLevel *lvl); class GmLevel diff --git a/src/mmo/ids.py b/src/mmo/ids.py index a98920f..0d39aae 100644 --- a/src/mmo/ids.py +++ b/src/mmo/ids.py @@ -6,6 +6,7 @@ for s in [ 'ItemNameId', 'BlockId', 'QuestId', + 'ClientVersion', ]: class OtherId(object): __slots__ = ('_value') diff --git a/src/mmo/version.hpp b/src/mmo/version.hpp index 459b500..79d67fe 100644 --- a/src/mmo/version.hpp +++ b/src/mmo/version.hpp @@ -37,9 +37,11 @@ namespace tmwa // increase the min version when the protocol is incompatible with old m+ versions // 1 = latest mana, old manaplus, bots -// 2 = manaplus 1.5.5.9 and above -// 3 = manaplus 1.5.5.23 and above -// 4 = manaplus 1.5.8.15 and above +// 2 = manaplus 1.5.5.9 to manaplus 1.5.5.23 +// 3 = manaplus 1.5.5.23 to manaplus 1.5.8.15 +// 4 = manaplus 1.5.8.15 to manaplus 1.6.3.15 +// 5 = manaplus 1.6.3.15 to 1.6.4.23 (adds SMSG_SCRIPT_MESSAGE) +// 6 = manaplus 1.6.4.23 and above #define MIN_CLIENT_VERSION 1 // TODO now that I generate the protocol, split 'flags' out of the struct -- cgit v1.2.3-70-g09d2