summaryrefslogtreecommitdiffstats
path: root/sigencore/Arena.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'sigencore/Arena.cpp')
-rw-r--r--sigencore/Arena.cpp30
1 files changed, 30 insertions, 0 deletions
diff --git a/sigencore/Arena.cpp b/sigencore/Arena.cpp
index 357cbc30..7556d1d7 100644
--- a/sigencore/Arena.cpp
+++ b/sigencore/Arena.cpp
@@ -29,6 +29,7 @@
#include "../sigscript/RulesWrapper.h"
#include "../sigscript/SigmodWrapper.h"
#include "../sigscript/SpeciesWrapper.h"
+#include "../sigscript/WeatherWrapper.h"
// Sigcore includes
#include "../sigcore/Script.h"
@@ -131,6 +132,35 @@ Sigencore::Arena::State Sigencore::Arena::state() const
return m_state;
}
+QList<Sigscript::WeatherWrapper*> Sigencore::Arena::weathers() const
+{
+ return m_weathers.keys();
+}
+
+bool Sigencore::Arena::setWeather(TeamMember* teamMember, Sigscript::WeatherWrapper* weather)
+{
+ ObjectMap objects;
+ objects["arena"] = this;
+ objects["weather"] = weather;
+ objects["sigmod"] = m_sigmod;
+ objects["owner"] = teamMember;
+ objects["client"] = teamMember->client();
+ Kross::Action* action = runScript(QString("arena-weather-%1").arg(QUuid::createUuid().toString()), weather->script(), objects, m_actions);
+ m_weathers[weather] = action;
+ action->trigger();
+ emit(weatherStarted(teamMember, weather));
+}
+
+bool Sigencore::Arena::unsetWeather(Sigscript::WeatherWrapper* weather)
+{
+ if (m_weathers.contains(weather))
+ {
+ delete m_weathers[weather];
+ m_weathers.remove(weather);
+ emit(weatherEnded(weather));
+ }
+}
+
Sigscript::SigmodWrapper* Sigencore::Arena::sigmod() const
{
return m_sigmod;