aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.Server/Console/commands/weather/CliCommandWeather.cpp
diff options
context:
space:
mode:
authorqwasdrizzel <145519042+qwasdrizzel@users.noreply.github.com>2026-03-16 21:44:26 -0500
committerGitHub <noreply@github.com>2026-03-16 21:44:26 -0500
commitce739f6045ec72127491286ea3f3f21e537c1b55 (patch)
treef33bd42a47c1b4a7b2153a7fb77127ee3b407db9 /Minecraft.Server/Console/commands/weather/CliCommandWeather.cpp
parent255a18fe8e9b57377975f82e2b227afe2a12eda0 (diff)
parent5a59f5d146b43811dde6a5a0245ee9875d7b5cd1 (diff)
Merge branch 'smartcmd:main' into main
Diffstat (limited to 'Minecraft.Server/Console/commands/weather/CliCommandWeather.cpp')
-rw-r--r--Minecraft.Server/Console/commands/weather/CliCommandWeather.cpp49
1 files changed, 49 insertions, 0 deletions
diff --git a/Minecraft.Server/Console/commands/weather/CliCommandWeather.cpp b/Minecraft.Server/Console/commands/weather/CliCommandWeather.cpp
new file mode 100644
index 00000000..e7f01954
--- /dev/null
+++ b/Minecraft.Server/Console/commands/weather/CliCommandWeather.cpp
@@ -0,0 +1,49 @@
+#include "stdafx.h"
+
+#include "CliCommandWeather.h"
+
+#include "..\..\ServerCliEngine.h"
+#include "..\..\ServerCliParser.h"
+#include "..\..\..\..\Minecraft.World\GameCommandPacket.h"
+#include "..\..\..\..\Minecraft.World\ToggleDownfallCommand.h"
+
+namespace ServerRuntime
+{
+ namespace
+ {
+ constexpr const char *kWeatherUsage = "weather";
+ }
+
+ const char *CliCommandWeather::Name() const
+ {
+ return "weather";
+ }
+
+ const char *CliCommandWeather::Usage() const
+ {
+ return kWeatherUsage;
+ }
+
+ const char *CliCommandWeather::Description() const
+ {
+ return "Toggle weather via Minecraft.World command dispatcher.";
+ }
+
+ bool CliCommandWeather::Execute(const ServerCliParsedLine &line, ServerCliEngine *engine)
+ {
+ if (line.tokens.size() != 1)
+ {
+ engine->LogWarn(std::string("Usage: ") + kWeatherUsage);
+ return false;
+ }
+
+ std::shared_ptr<GameCommandPacket> packet = ToggleDownfallCommand::preparePacket();
+ if (packet == nullptr)
+ {
+ engine->LogError("Failed to build weather command packet.");
+ return false;
+ }
+
+ return engine->DispatchWorldCommand(packet->command, packet->data);
+ }
+}