From 4232dfc4110332c862877a626fca9a99eda84330 Mon Sep 17 00:00:00 2001 From: killerwife Date: Sun, 31 Dec 2023 19:10:01 +0100 Subject: [PATCH] [s2472] Creature/Gameobject: Upgrade precision of GO and creature positions Loss during dumping --- sql/base/mangos.sql | 26 +++++++++---------- .../s2472_01_mangos_precision_decimal.sql | 15 +++++++++++ src/game/Globals/ObjectMgr.cpp | 8 +++--- src/shared/revision_sql.h | 2 +- 4 files changed, 33 insertions(+), 18 deletions(-) create mode 100644 sql/updates/mangos/s2472_01_mangos_precision_decimal.sql diff --git a/sql/base/mangos.sql b/sql/base/mangos.sql index c5706ea576..fc33fb944f 100644 --- a/sql/base/mangos.sql +++ b/sql/base/mangos.sql @@ -23,7 +23,7 @@ DROP TABLE IF EXISTS `db_version`; CREATE TABLE `db_version` ( `version` varchar(120) DEFAULT NULL, `creature_ai_version` varchar(120) DEFAULT NULL, - `required_s2471_01_mangos_pursuit` bit(1) DEFAULT NULL + `required_s2472_01_mangos_precision_decimal` bit(1) DEFAULT NULL ) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='Used DB version notes'; -- @@ -761,10 +761,10 @@ CREATE TABLE `creature` ( `id` mediumint(8) unsigned NOT NULL DEFAULT '0' COMMENT 'Creature Identifier', `map` smallint(5) unsigned NOT NULL DEFAULT '0' COMMENT 'Map Identifier', `spawnMask` tinyint(3) unsigned NOT NULL DEFAULT '1', - `position_x` float NOT NULL DEFAULT '0', - `position_y` float NOT NULL DEFAULT '0', - `position_z` float NOT NULL DEFAULT '0', - `orientation` float NOT NULL DEFAULT '0', + `position_x` DECIMAL(40,20) NOT NULL DEFAULT '0', + `position_y` DECIMAL(40,20) NOT NULL DEFAULT '0', + `position_z` DECIMAL(40,20) NOT NULL DEFAULT '0', + `orientation` DECIMAL(40,20) NOT NULL DEFAULT '0', `spawntimesecsmin` int(10) unsigned NOT NULL DEFAULT '120' COMMENT 'Creature respawn time minimum', `spawntimesecsmax` int(10) unsigned NOT NULL DEFAULT '120' COMMENT 'Creature respawn time maximum', `spawndist` float NOT NULL DEFAULT '5', @@ -2020,14 +2020,14 @@ CREATE TABLE `gameobject` ( `id` mediumint(8) unsigned NOT NULL DEFAULT '0' COMMENT 'Gameobject Identifier', `map` smallint(5) unsigned NOT NULL DEFAULT '0' COMMENT 'Map Identifier', `spawnMask` tinyint(3) unsigned NOT NULL DEFAULT '1', - `position_x` float NOT NULL DEFAULT '0', - `position_y` float NOT NULL DEFAULT '0', - `position_z` float NOT NULL DEFAULT '0', - `orientation` float NOT NULL DEFAULT '0', - `rotation0` float NOT NULL DEFAULT '0', - `rotation1` float NOT NULL DEFAULT '0', - `rotation2` float NOT NULL DEFAULT '0', - `rotation3` float NOT NULL DEFAULT '0', + `position_x` DECIMAL(40,20) NOT NULL DEFAULT '0', + `position_y` DECIMAL(40,20) NOT NULL DEFAULT '0', + `position_z` DECIMAL(40,20) NOT NULL DEFAULT '0', + `orientation` DECIMAL(40,20) NOT NULL DEFAULT '0', + `rotation0` DECIMAL(40,20) NOT NULL DEFAULT '0', + `rotation1` DECIMAL(40,20) NOT NULL DEFAULT '0', + `rotation2` DECIMAL(40,20) NOT NULL DEFAULT '0', + `rotation3` DECIMAL(40,20) NOT NULL DEFAULT '0', `spawntimesecsmin` int(11) NOT NULL DEFAULT '0' COMMENT 'GameObject respawn time minimum', `spawntimesecsmax` int(11) NOT NULL DEFAULT '0' COMMENT 'Gameobject respawn time maximum', PRIMARY KEY (`guid`), diff --git a/sql/updates/mangos/s2472_01_mangos_precision_decimal.sql b/sql/updates/mangos/s2472_01_mangos_precision_decimal.sql new file mode 100644 index 0000000000..d650c3d5fe --- /dev/null +++ b/sql/updates/mangos/s2472_01_mangos_precision_decimal.sql @@ -0,0 +1,15 @@ +ALTER TABLE db_version CHANGE COLUMN required_s2471_01_mangos_pursuit required_s2472_01_mangos_precision_decimal bit; + +ALTER TABLE gameobject CHANGE position_x position_x DECIMAL(40,20) NOT NULL DEFAULT 0; +ALTER TABLE gameobject CHANGE position_y position_y DECIMAL(40,20) NOT NULL DEFAULT 0; +ALTER TABLE gameobject CHANGE position_z position_z DECIMAL(40,20) NOT NULL DEFAULT 0; +ALTER TABLE gameobject CHANGE orientation orientation DECIMAL(40,20) NOT NULL DEFAULT 0; +ALTER TABLE gameobject CHANGE rotation0 rotation0 DECIMAL(40,20) NOT NULL DEFAULT 0; +ALTER TABLE gameobject CHANGE rotation1 rotation1 DECIMAL(40,20) NOT NULL DEFAULT 0; +ALTER TABLE gameobject CHANGE rotation2 rotation2 DECIMAL(40,20) NOT NULL DEFAULT 0; +ALTER TABLE gameobject CHANGE rotation3 rotation3 DECIMAL(40,20) NOT NULL DEFAULT 0; + +ALTER TABLE creature CHANGE position_x position_x DECIMAL(40,20) NOT NULL DEFAULT 0; +ALTER TABLE creature CHANGE position_y position_y DECIMAL(40,20) NOT NULL DEFAULT 0; +ALTER TABLE creature CHANGE position_z position_z DECIMAL(40,20) NOT NULL DEFAULT 0; +ALTER TABLE creature CHANGE orientation orientation DECIMAL(40,20) NOT NULL DEFAULT 0; diff --git a/src/game/Globals/ObjectMgr.cpp b/src/game/Globals/ObjectMgr.cpp index d128bc7c3b..dcea8576d3 100644 --- a/src/game/Globals/ObjectMgr.cpp +++ b/src/game/Globals/ObjectMgr.cpp @@ -2222,10 +2222,10 @@ void ObjectMgr::LoadGameObjects() { uint32 count = 0; - // 0 1 2 3 4 5 6 - auto queryResult = WorldDatabase.Query("SELECT gameobject.guid, gameobject.id, map, round(position_x, 20), round(position_y, 20), round(position_z, 20), round(orientation, 20)," - // 7 8 9 10 11 12 13 14 - "round(rotation0, 20), round(rotation1, 20), round(rotation2, 20), round(rotation3, 20), spawntimesecsmin, spawntimesecsmax, spawnMask, event," + // 0 1 2 3 4 5 6 + auto queryResult = WorldDatabase.Query("SELECT gameobject.guid, gameobject.id, map, position_x, position_y, position_z, orientation," + // 7 8 9 10 11 12 13 14 + "rotation0, rotation1, rotation2, rotation3, spawntimesecsmin, spawntimesecsmax, spawnMask, event," // 15 16 "pool_gameobject.pool_entry, pool_gameobject_template.pool_entry " "FROM gameobject " diff --git a/src/shared/revision_sql.h b/src/shared/revision_sql.h index 7974c0da7f..9f0acf9b42 100644 --- a/src/shared/revision_sql.h +++ b/src/shared/revision_sql.h @@ -3,5 +3,5 @@ #define REVISION_DB_REALMD "required_s2455_01_realmd_platform" #define REVISION_DB_LOGS "required_s2433_01_logs_anticheat" #define REVISION_DB_CHARACTERS "required_s2452_01_characters_fishingSteps" - #define REVISION_DB_MANGOS "required_s2471_01_mangos_pursuit" + #define REVISION_DB_MANGOS "required_s2472_01_mangos_precision_decimal" #endif // __REVISION_SQL_H__