mirror of
https://github.com/mangosfour/server.git
synced 2025-12-13 22:37:03 +00:00
[7915] Implement more stricted checks and limitations at loading creature addon data.
Signed-off-by: VladimirMangos <vladimir@getmangos.com>
This commit is contained in:
parent
c7c480f6ba
commit
27057843ac
3 changed files with 44 additions and 3 deletions
|
|
@ -1869,10 +1869,33 @@ bool Creature::LoadCreaturesAddon(bool reload)
|
||||||
Mount(cainfo->mount);
|
Mount(cainfo->mount);
|
||||||
|
|
||||||
if (cainfo->bytes1 != 0)
|
if (cainfo->bytes1 != 0)
|
||||||
SetUInt32Value(UNIT_FIELD_BYTES_1, cainfo->bytes1);
|
{
|
||||||
|
// 0 StandState
|
||||||
|
// 1 FreeTalentPoints Pet only, so always 0 for default creature
|
||||||
|
// 2 StandFlags
|
||||||
|
// 3 StandMiscFlags
|
||||||
|
|
||||||
|
SetByteValue(UNIT_FIELD_BYTES_1, 0, uint8(cainfo->bytes1 & 0xFF));
|
||||||
|
//SetByteValue(UNIT_FIELD_BYTES_1, 1, uint8((cainfo->bytes1 >> 8) & 0xFF));
|
||||||
|
SetByteValue(UNIT_FIELD_BYTES_1, 1, 0);
|
||||||
|
SetByteValue(UNIT_FIELD_BYTES_1, 2, uint8((cainfo->bytes1 >> 16) & 0xFF));
|
||||||
|
SetByteValue(UNIT_FIELD_BYTES_1, 3, uint8((cainfo->bytes1 >> 24) & 0xFF));
|
||||||
|
}
|
||||||
|
|
||||||
if (cainfo->bytes2 != 0)
|
if (cainfo->bytes2 != 0)
|
||||||
SetUInt32Value(UNIT_FIELD_BYTES_2, cainfo->bytes2);
|
{
|
||||||
|
// 0 SheathState
|
||||||
|
// 1 Bytes2Flags
|
||||||
|
// 2 UnitRename Pet only, so always 0 for default creature
|
||||||
|
// 3 ShapeshiftForm Must be determined/set by shapeshift spell/aura
|
||||||
|
|
||||||
|
SetByteValue(UNIT_FIELD_BYTES_2, 0, uint8(cainfo->bytes2 & 0xFF));
|
||||||
|
SetByteValue(UNIT_FIELD_BYTES_2, 1, uint8((cainfo->bytes2 >> 8) & 0xFF));
|
||||||
|
//SetByteValue(UNIT_FIELD_BYTES_2, 2, uint8((cainfo->bytes2 >> 16) & 0xFF));
|
||||||
|
SetByteValue(UNIT_FIELD_BYTES_2, 2, 0);
|
||||||
|
//SetByteValue(UNIT_FIELD_BYTES_2, 3, uint8((cainfo->bytes2 >> 24) & 0xFF));
|
||||||
|
SetByteValue(UNIT_FIELD_BYTES_2, 3, 0);
|
||||||
|
}
|
||||||
|
|
||||||
if (cainfo->emote != 0)
|
if (cainfo->emote != 0)
|
||||||
SetUInt32Value(UNIT_NPC_EMOTESTATE, cainfo->emote);
|
SetUInt32Value(UNIT_NPC_EMOTESTATE, cainfo->emote);
|
||||||
|
|
|
||||||
|
|
@ -723,6 +723,15 @@ void ObjectMgr::LoadCreatureAddons()
|
||||||
if(!addon)
|
if(!addon)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
if (addon->mount)
|
||||||
|
{
|
||||||
|
if (!sCreatureDisplayInfoStore.LookupEntry(addon->mount))
|
||||||
|
sLog.outErrorDb("Creature (Entry %u) have invalid displayInfoId for mount (%u) defined in `creature_template_addon`.",addon->guidOrEntry, addon->mount);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!sEmotesStore.LookupEntry(addon->emote))
|
||||||
|
sLog.outErrorDb("Creature (Entry %u) have invalid emote (%u) defined in `creature_template_addon`.",addon->guidOrEntry, addon->emote);
|
||||||
|
|
||||||
ConvertCreatureAddonAuras(const_cast<CreatureDataAddon*>(addon), "creature_template_addon", "Entry");
|
ConvertCreatureAddonAuras(const_cast<CreatureDataAddon*>(addon), "creature_template_addon", "Entry");
|
||||||
|
|
||||||
if(!sCreatureStorage.LookupEntry<CreatureInfo>(addon->guidOrEntry))
|
if(!sCreatureStorage.LookupEntry<CreatureInfo>(addon->guidOrEntry))
|
||||||
|
|
@ -741,6 +750,15 @@ void ObjectMgr::LoadCreatureAddons()
|
||||||
if(!addon)
|
if(!addon)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
if (addon->mount)
|
||||||
|
{
|
||||||
|
if (!sCreatureDisplayInfoStore.LookupEntry(addon->mount))
|
||||||
|
sLog.outErrorDb("Creature (GUID %u) have invalid displayInfoId for mount (%u) defined in `creature_addon`.",addon->guidOrEntry, addon->mount);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!sEmotesStore.LookupEntry(addon->emote))
|
||||||
|
sLog.outErrorDb("Creature (GUID %u) have invalid emote (%u) defined in `creature_addon`.",addon->guidOrEntry, addon->emote);
|
||||||
|
|
||||||
ConvertCreatureAddonAuras(const_cast<CreatureDataAddon*>(addon), "creature_addon", "GUIDLow");
|
ConvertCreatureAddonAuras(const_cast<CreatureDataAddon*>(addon), "creature_addon", "GUIDLow");
|
||||||
|
|
||||||
if(mCreatureDataMap.find(addon->guidOrEntry)==mCreatureDataMap.end())
|
if(mCreatureDataMap.find(addon->guidOrEntry)==mCreatureDataMap.end())
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
#ifndef __REVISION_NR_H__
|
#ifndef __REVISION_NR_H__
|
||||||
#define __REVISION_NR_H__
|
#define __REVISION_NR_H__
|
||||||
#define REVISION_NR "7914"
|
#define REVISION_NR "7915"
|
||||||
#endif // __REVISION_NR_H__
|
#endif // __REVISION_NR_H__
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue