summaryrefslogtreecommitdiff
path: root/src/server/game/Scripting/ScriptDefines
diff options
context:
space:
mode:
author天鹿 <18535853+PkllonG@users.noreply.github.com>2024-04-12 21:59:37 +0800
committerGitHub <noreply@github.com>2024-04-12 10:59:37 -0300
commitd87af546755367df08df088ee7e5611fe8b0c86d (patch)
treef5a8c8557602210236e9ff8ec2fb73c07a053603 /src/server/game/Scripting/ScriptDefines
parent170817e66dc95cc9c0bc3dcc9bc9fb9191b4ff27 (diff)
feat(Core/Scripts): Optimize AllSpellScript (#18702)
* Add files via upload * Update AllSpellScript.h
Diffstat (limited to 'src/server/game/Scripting/ScriptDefines')
-rw-r--r--src/server/game/Scripting/ScriptDefines/AllSpellScript.cpp111
-rw-r--r--src/server/game/Scripting/ScriptDefines/AllSpellScript.h21
2 files changed, 41 insertions, 91 deletions
diff --git a/src/server/game/Scripting/ScriptDefines/AllSpellScript.cpp b/src/server/game/Scripting/ScriptDefines/AllSpellScript.cpp
index b0f4948bba..f7e057911e 100644
--- a/src/server/game/Scripting/ScriptDefines/AllSpellScript.cpp
+++ b/src/server/game/Scripting/ScriptDefines/AllSpellScript.cpp
@@ -21,147 +21,78 @@
void ScriptMgr::OnCalcMaxDuration(Aura const* aura, int32& maxDuration)
{
- ExecuteScript<AllSpellScript>([&](AllSpellScript* script)
- {
- script->OnCalcMaxDuration(aura, maxDuration);
- });
+ CALL_ENABLED_HOOKS(AllSpellScript, ALLSPELLHOOK_ON_CALC_MAX_DURATION, script->OnCalcMaxDuration(aura, maxDuration));
}
bool ScriptMgr::CanModAuraEffectDamageDone(AuraEffect const* auraEff, Unit* target, AuraApplication const* aurApp, uint8 mode, bool apply)
{
- auto ret = IsValidBoolScript<AllSpellScript>([&](AllSpellScript* script)
- {
- return !script->CanModAuraEffectDamageDone(auraEff, target, aurApp, mode, apply);
- });
-
- if (ret && *ret)
- {
- return false;
- }
-
- return true;
+ CALL_ENABLED_BOOLEAN_HOOKS(AllSpellScript, ALLSPELLHOOK_CAN_MOD_AURA_EFFECT_DAMAGE_DONE, !script->CanModAuraEffectDamageDone(auraEff, target, aurApp, mode, apply));
}
bool ScriptMgr::CanModAuraEffectModDamagePercentDone(AuraEffect const* auraEff, Unit* target, AuraApplication const* aurApp, uint8 mode, bool apply)
{
- auto ret = IsValidBoolScript<AllSpellScript>([&](AllSpellScript* script)
- {
- return !script->CanModAuraEffectModDamagePercentDone(auraEff, target, aurApp, mode, apply);
- });
-
- if (ret && *ret)
- {
- return false;
- }
-
- return true;
+ CALL_ENABLED_BOOLEAN_HOOKS(AllSpellScript, ALLSPELLHOOK_CAN_MOD_AURA_EFFECT_MOD_DAMAGE_PERCENT_DONE, !script->CanModAuraEffectModDamagePercentDone(auraEff, target, aurApp, mode, apply));
}
void ScriptMgr::OnSpellCheckCast(Spell* spell, bool strict, SpellCastResult& res)
{
- ExecuteScript<AllSpellScript>([&](AllSpellScript* script)
- {
- script->OnSpellCheckCast(spell, strict, res);
- });
+ CALL_ENABLED_HOOKS(AllSpellScript, ALLSPELLHOOK_ON_SPELL_CHECK_CAST, script->OnSpellCheckCast(spell, strict, res));
}
bool ScriptMgr::CanPrepare(Spell* spell, SpellCastTargets const* targets, AuraEffect const* triggeredByAura)
{
- auto ret = IsValidBoolScript<AllSpellScript>([&](AllSpellScript* script)
- {
- return !script->CanPrepare(spell, targets, triggeredByAura);
- });
-
- if (ret && *ret)
- {
- return false;
- }
-
- return true;
+ CALL_ENABLED_BOOLEAN_HOOKS(AllSpellScript, ALLSPELLHOOK_CAN_PREPARE, !script->CanPrepare(spell, targets, triggeredByAura));
}
bool ScriptMgr::CanScalingEverything(Spell* spell)
{
- auto ret = IsValidBoolScript<AllSpellScript>([&](AllSpellScript* script)
- {
- return script->CanScalingEverything(spell);
- });
-
- if (ret && *ret)
- {
- return true;
- }
-
- return false;
+ CALL_ENABLED_BOOLEAN_HOOKS(AllSpellScript, ALLSPELLHOOK_CAN_SCALING_EVERYTHING, script->CanScalingEverything(spell));
}
bool ScriptMgr::CanSelectSpecTalent(Spell* spell)
{
- auto ret = IsValidBoolScript<AllSpellScript>([&](AllSpellScript* script)
- {
- return !script->CanSelectSpecTalent(spell);
- });
-
- if (ret && *ret)
- {
- return false;
- }
-
- return true;
+ CALL_ENABLED_BOOLEAN_HOOKS(AllSpellScript, ALLSPELLHOOK_CAN_SELECT_SPEC_TALENT, !script->CanSelectSpecTalent(spell));
}
void ScriptMgr::OnScaleAuraUnitAdd(Spell* spell, Unit* target, uint32 effectMask, bool checkIfValid, bool implicit, uint8 auraScaleMask, TargetInfo& targetInfo)
{
- ExecuteScript<AllSpellScript>([&](AllSpellScript* script)
- {
- script->OnScaleAuraUnitAdd(spell, target, effectMask, checkIfValid, implicit, auraScaleMask, targetInfo);
- });
+ CALL_ENABLED_HOOKS(AllSpellScript, ALLSPELLHOOK_ON_SCALE_AURA_UNIT_ADD, script->OnScaleAuraUnitAdd(spell, target, effectMask, checkIfValid, implicit, auraScaleMask, targetInfo));
}
void ScriptMgr::OnRemoveAuraScaleTargets(Spell* spell, TargetInfo& targetInfo, uint8 auraScaleMask, bool& needErase)
{
- ExecuteScript<AllSpellScript>([&](AllSpellScript* script)
- {
- script->OnRemoveAuraScaleTargets(spell, targetInfo, auraScaleMask, needErase);
- });
+ CALL_ENABLED_HOOKS(AllSpellScript, ALLSPELLHOOK_ON_REMOVE_AURA_SCALE_TARGETS, script->OnRemoveAuraScaleTargets(spell, targetInfo, auraScaleMask, needErase));
}
void ScriptMgr::OnBeforeAuraRankForLevel(SpellInfo const* spellInfo, SpellInfo const* latestSpellInfo, uint8 level)
{
- ExecuteScript<AllSpellScript>([&](AllSpellScript* script)
- {
- script->OnBeforeAuraRankForLevel(spellInfo, latestSpellInfo, level);
- });
+ CALL_ENABLED_HOOKS(AllSpellScript, ALLSPELLHOOK_ON_BEFORE_AURA_RANK_FOR_LEVEL, script->OnBeforeAuraRankForLevel(spellInfo, latestSpellInfo, level));
}
void ScriptMgr::OnDummyEffect(WorldObject* caster, uint32 spellID, SpellEffIndex effIndex, GameObject* gameObjTarget)
{
- ExecuteScript<AllSpellScript>([&](AllSpellScript* script)
- {
- script->OnDummyEffect(caster, spellID, effIndex, gameObjTarget);
- });
+ CALL_ENABLED_HOOKS(AllSpellScript, ALLSPELLHOOK_ON_DUMMY_EFFECT_GAMEOBJECT, script->OnDummyEffect(caster, spellID, effIndex, gameObjTarget));
}
void ScriptMgr::OnDummyEffect(WorldObject* caster, uint32 spellID, SpellEffIndex effIndex, Creature* creatureTarget)
{
- ExecuteScript<AllSpellScript>([&](AllSpellScript* script)
- {
- script->OnDummyEffect(caster, spellID, effIndex, creatureTarget);
- });
+ CALL_ENABLED_HOOKS(AllSpellScript, ALLSPELLHOOK_ON_DUMMY_EFFECT_CREATURE, script->OnDummyEffect(caster, spellID, effIndex, creatureTarget));
}
void ScriptMgr::OnDummyEffect(WorldObject* caster, uint32 spellID, SpellEffIndex effIndex, Item* itemTarget)
{
- ExecuteScript<AllSpellScript>([&](AllSpellScript* script)
- {
- script->OnDummyEffect(caster, spellID, effIndex, itemTarget);
- });
+ CALL_ENABLED_HOOKS(AllSpellScript, ALLSPELLHOOK_ON_DUMMY_EFFECT_ITEM, script->OnDummyEffect(caster, spellID, effIndex, itemTarget));
}
-AllSpellScript::AllSpellScript(char const* name)
- : ScriptObject(name)
+AllSpellScript::AllSpellScript(char const* name, std::vector<uint16> enabledHooks)
+ : ScriptObject(name, ALLSPELLHOOK_END)
{
- ScriptRegistry<AllSpellScript>::AddScript(this);
+ // If empty - enable all available hooks.
+ if (enabledHooks.empty())
+ for (uint16 i = 0; i < ALLSPELLHOOK_END; ++i)
+ enabledHooks.emplace_back(i);
+
+ ScriptRegistry<AllSpellScript>::AddScript(this, std::move(enabledHooks));
}
template class AC_GAME_API ScriptRegistry<AllSpellScript>;
diff --git a/src/server/game/Scripting/ScriptDefines/AllSpellScript.h b/src/server/game/Scripting/ScriptDefines/AllSpellScript.h
index 2e1899403b..9f1682f2f7 100644
--- a/src/server/game/Scripting/ScriptDefines/AllSpellScript.h
+++ b/src/server/game/Scripting/ScriptDefines/AllSpellScript.h
@@ -19,6 +19,25 @@
#define SCRIPT_OBJECT_ALL_SPELL_SCRIPT_H_
#include "ScriptObject.h"
+#include <vector>
+
+enum AllSpellHook
+{
+ ALLSPELLHOOK_ON_CALC_MAX_DURATION,
+ ALLSPELLHOOK_CAN_MOD_AURA_EFFECT_DAMAGE_DONE,
+ ALLSPELLHOOK_CAN_MOD_AURA_EFFECT_MOD_DAMAGE_PERCENT_DONE,
+ ALLSPELLHOOK_ON_SPELL_CHECK_CAST,
+ ALLSPELLHOOK_CAN_PREPARE,
+ ALLSPELLHOOK_CAN_SCALING_EVERYTHING,
+ ALLSPELLHOOK_CAN_SELECT_SPEC_TALENT,
+ ALLSPELLHOOK_ON_SCALE_AURA_UNIT_ADD,
+ ALLSPELLHOOK_ON_REMOVE_AURA_SCALE_TARGETS,
+ ALLSPELLHOOK_ON_BEFORE_AURA_RANK_FOR_LEVEL,
+ ALLSPELLHOOK_ON_DUMMY_EFFECT_GAMEOBJECT,
+ ALLSPELLHOOK_ON_DUMMY_EFFECT_CREATURE,
+ ALLSPELLHOOK_ON_DUMMY_EFFECT_ITEM,
+ ALLSPELLHOOK_END
+};
enum SpellCastResult : uint8;
enum SpellEffIndex : uint8;
@@ -26,7 +45,7 @@ enum SpellEffIndex : uint8;
class AllSpellScript : public ScriptObject
{
protected:
- AllSpellScript(const char* name);
+ AllSpellScript(const char* name, std::vector<uint16> enabledHooks = std::vector<uint16>());
public:
[[nodiscard]] bool IsDatabaseBound() const override { return false; }