diff options
author | Loic Blot <loic.blot@unix-experience.fr> | 2015-01-26 15:52:02 +0100 |
---|---|---|
committer | Kahrl <kahrl@gmx.net> | 2015-01-27 16:55:25 +0100 |
commit | 80a7408e4d17e0e388f2d45fb90c5524a5dd7c89 (patch) | |
tree | 3bc5f712406c07192c085c0825d90ab0ade8f1af /src/mapblock.h | |
parent | eeea454bff0cfcda495c20029a0246f63f14393e (diff) | |
download | minetest-80a7408e4d17e0e388f2d45fb90c5524a5dd7c89.tar.gz minetest-80a7408e4d17e0e388f2d45fb90c5524a5dd7c89.tar.bz2 minetest-80a7408e4d17e0e388f2d45fb90c5524a5dd7c89.zip |
Fix a crash (assert) when client set serial version < 24 in INIT
When SER_FMT_VER_LOWEST is set to zero, then the test is stupid in INIT because all client works. In mapblock we check if client's serialization version is < 24, but if client sent serialization version < 24 (15 for example) the server set it and tried to send nodes, then BOOM
To resolve the problem:
* Create a different CLIENT_MIN_VERSION to handle this problem
* Remove the exception
* Use an assert in case of bad developer code
Diffstat (limited to 'src/mapblock.h')
-rw-r--r-- | src/mapblock.h | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/src/mapblock.h b/src/mapblock.h index 5cf2bc801..e7d7798b8 100644 --- a/src/mapblock.h +++ b/src/mapblock.h @@ -494,6 +494,7 @@ public: // These don't write or read version by itself // Set disk to true for on-disk format, false for over-the-network format + // Precondition: version >= SER_FMT_CLIENT_VER_LOWEST void serialize(std::ostream &os, u8 version, bool disk); // If disk == true: In addition to doing other things, will add // unknown blocks from id-name mapping to wndef |