aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/server/game/AI/SmartScripts/SmartScript.cpp20
-rw-r--r--src/server/game/AI/SmartScripts/SmartScript.h1
-rw-r--r--src/server/game/AI/SmartScripts/SmartScriptMgr.cpp1
-rw-r--r--src/server/game/AI/SmartScripts/SmartScriptMgr.h10
4 files changed, 31 insertions, 1 deletions
diff --git a/src/server/game/AI/SmartScripts/SmartScript.cpp b/src/server/game/AI/SmartScripts/SmartScript.cpp
index 7fba67cacb3..4da25ce44ab 100644
--- a/src/server/game/AI/SmartScripts/SmartScript.cpp
+++ b/src/server/game/AI/SmartScripts/SmartScript.cpp
@@ -115,6 +115,14 @@ void SmartScript::StoreTargetList(ObjectVector const& targets, uint32 id)
_storedTargets.emplace(id, ObjectGuidVector(targets));
}
+void SmartScript::AddToStoredTargetList(ObjectVector const& targets, uint32 id)
+{
+ auto [itr, inserted] = _storedTargets.try_emplace(id, targets);
+ if (!inserted)
+ for (WorldObject* obj : targets)
+ itr->second.AddGuid(obj->GetGUID());
+}
+
ObjectVector const* SmartScript::GetStoredTargetVector(uint32 id, WorldObject const& ref) const
{
auto itr = _storedTargets.find(id);
@@ -2494,6 +2502,18 @@ void SmartScript::ProcessAction(SmartScriptHolder& e, Unit* unit, uint32 var0, u
}
break;
}
+ case SMART_ACTION_ADD_TO_STORED_TARGET_LIST:
+ {
+ if (!targets.empty())
+ AddToStoredTargetList(targets, e.action.addToStoredTargets.id);
+ else
+ {
+ WorldObject* baseObject = GetBaseObject();
+ TC_LOG_WARN("scripts.ai", "SmartScript::ProcessAction:: SMART_ACTION_ADD_TO_STORED_TARGET_LIST: var %u, baseObject %s, event %u - tried to add no targets to stored target list",
+ e.action.addToStoredTargets.id, !baseObject ? "" : baseObject->GetName().c_str(), e.event_id);
+ }
+ break;
+ }
default:
TC_LOG_ERROR("sql.sql", "SmartScript::ProcessAction: Entry " SI64FMTD " SourceType %u, Event %u, Unhandled Action type %u", e.entryOrGuid, e.GetScriptType(), e.event_id, e.GetActionType());
break;
diff --git a/src/server/game/AI/SmartScripts/SmartScript.h b/src/server/game/AI/SmartScripts/SmartScript.h
index 1f731f97609..2922e524449 100644
--- a/src/server/game/AI/SmartScripts/SmartScript.h
+++ b/src/server/game/AI/SmartScripts/SmartScript.h
@@ -78,6 +78,7 @@ class TC_GAME_API SmartScript
bool IsSmart(bool silent = false);
void StoreTargetList(ObjectVector const& targets, uint32 id);
+ void AddToStoredTargetList(ObjectVector const& targets, uint32 id);
ObjectVector const* GetStoredTargetVector(uint32 id, WorldObject const& ref) const;
void StoreCounter(uint32 id, uint32 value, uint32 reset);
diff --git a/src/server/game/AI/SmartScripts/SmartScriptMgr.cpp b/src/server/game/AI/SmartScripts/SmartScriptMgr.cpp
index 16af7d46ab9..69e72cf8c5b 100644
--- a/src/server/game/AI/SmartScripts/SmartScriptMgr.cpp
+++ b/src/server/game/AI/SmartScripts/SmartScriptMgr.cpp
@@ -1832,6 +1832,7 @@ bool SmartAIMgr::IsEventValid(SmartScriptHolder& e)
case SMART_ACTION_REMOVE_ALL_GAMEOBJECTS:
case SMART_ACTION_SPAWN_SPAWNGROUP:
case SMART_ACTION_DESPAWN_SPAWNGROUP:
+ case SMART_ACTION_ADD_TO_STORED_TARGET_LIST:
break;
default:
TC_LOG_ERROR("sql.sql", "SmartAIMgr: Not handled action_type(%u), event_type(%u), Entry " SI64FMTD " SourceType %u Event %u, skipped.", e.GetActionType(), e.GetEventType(), e.entryOrGuid, e.GetScriptType(), e.event_id);
diff --git a/src/server/game/AI/SmartScripts/SmartScriptMgr.h b/src/server/game/AI/SmartScripts/SmartScriptMgr.h
index ce15f52c04c..c962f1052f2 100644
--- a/src/server/game/AI/SmartScripts/SmartScriptMgr.h
+++ b/src/server/game/AI/SmartScripts/SmartScriptMgr.h
@@ -606,7 +606,8 @@ enum SMART_ACTION
SMART_ACTION_OVERRIDE_LIGHT = 138, // zoneId, overrideLightID, transitionMilliseconds
SMART_ACTION_OVERRIDE_WEATHER = 139, // zoneId, weatherId, intensity
SMART_ACTION_CREATE_CONVERSATION = 143, // conversation_template.id
- SMART_ACTION_END = 144
+ SMART_ACTION_ADD_TO_STORED_TARGET_LIST = 148, // varID
+ SMART_ACTION_END = 149
};
enum class SmartActionSummonCreatureFlags
@@ -1229,6 +1230,11 @@ struct SmartAction
uint32 id;
} conversation;
+ struct
+ {
+ uint32 id;
+ } addToStoredTargets;
+
//! Note for any new future actions
//! All parameters must have type uint32
@@ -1640,6 +1646,8 @@ class ObjectGuidVector
return &_objectVector;
}
+ void AddGuid(ObjectGuid const& guid) { _guidVector.push_back(guid); }
+
~ObjectGuidVector() { }
private: