aboutsummaryrefslogtreecommitdiff
path: root/src/server/game/AI/SmartScripts
diff options
context:
space:
mode:
authorMeji <alvaro.megias@outlook.com>2024-05-03 15:58:05 +0200
committerGitHub <noreply@github.com>2024-05-03 15:58:05 +0200
commit2238844f567b63de1edd394b654b62ac4ddeb666 (patch)
tree88e5ccf8744fe8964a86047864d03c48e74717e9 /src/server/game/AI/SmartScripts
parent24bda9c73dcd89d4da4e871e00fd83a24b8275d2 (diff)
Core/Creatures: Allow profession tools to be used as equipment (#29915)
Diffstat (limited to 'src/server/game/AI/SmartScripts')
-rw-r--r--src/server/game/AI/SmartScripts/SmartScriptMgr.cpp27
1 files changed, 27 insertions, 0 deletions
diff --git a/src/server/game/AI/SmartScripts/SmartScriptMgr.cpp b/src/server/game/AI/SmartScripts/SmartScriptMgr.cpp
index fed55249eba..c9e1cb072fe 100644
--- a/src/server/game/AI/SmartScripts/SmartScriptMgr.cpp
+++ b/src/server/game/AI/SmartScripts/SmartScriptMgr.cpp
@@ -2054,6 +2054,33 @@ bool SmartAIMgr::IsEventValid(SmartScriptHolder& e)
return false;
}
}
+
+ auto isValidEquipmentSlot = [&](uint32 itemEntry, uint8 slot)
+ {
+ ItemEntry const* dbcItem = sItemStore.LookupEntry(itemEntry);
+ if (!dbcItem)
+ {
+ TC_LOG_ERROR("sql.sql", "SmartScript: SMART_ACTION_EQUIP uses unknown item {} (slot {}) for creature {}, skipped.", itemEntry, slot, e.entryOrGuid);
+ return false;
+ }
+
+ if (std::ranges::none_of(InventoryTypesEquipable, [dbcItem](InventoryType inventoryType) { return inventoryType == dbcItem->InventoryType; }))
+ {
+ TC_LOG_ERROR("sql.sql", "SmartScript: SMART_ACTION_EQUIP uses item {} (slot {}) not equipable in a hand for creature {}, skipped.", itemEntry, slot, e.entryOrGuid);
+ return false;
+ }
+
+ return true;
+ };
+
+ if (e.action.equip.slot1 && !isValidEquipmentSlot(e.action.equip.slot1, 0))
+ return false;
+
+ if (e.action.equip.slot2 && !isValidEquipmentSlot(e.action.equip.slot2, 1))
+ return false;
+
+ if (e.action.equip.slot3 && !isValidEquipmentSlot(e.action.equip.slot3, 2))
+ return false;
}
break;
}