summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/bundle.hpp11
-rw-r--r--src/commands/command.cpp7
-rw-r--r--src/commands/command.hpp9
-rw-r--r--src/modules/ping.hpp6
4 files changed, 26 insertions, 7 deletions
diff --git a/src/bundle.hpp b/src/bundle.hpp
new file mode 100644
index 0000000..fa8d80a
--- /dev/null
+++ b/src/bundle.hpp
@@ -0,0 +1,11 @@
+#pragma once
+
+#include "irc/client.hpp"
+#include "localization/localization.hpp"
+
+namespace bot {
+ struct InstanceBundle {
+ const irc::Client &irc_client;
+ const bot::loc::Localization &localization;
+ };
+}
diff --git a/src/commands/command.cpp b/src/commands/command.cpp
index b6852cc..9d6ec6a 100644
--- a/src/commands/command.cpp
+++ b/src/commands/command.cpp
@@ -4,6 +4,7 @@
#include <memory>
#include <optional>
+#include "../bundle.hpp"
#include "../modules/ping.hpp"
namespace bot {
@@ -17,10 +18,12 @@ namespace bot {
}
std::optional<std::variant<std::vector<std::string>, std::string>>
- CommandLoader::run(const irc::Message<irc::MessageType::Privmsg> &msg) {
+ CommandLoader::run(
+ const InstanceBundle &bundle,
+ const irc::Message<irc::MessageType::Privmsg> &msg) const {
for (const std::unique_ptr<Command> &command : this->commands) {
if (command->get_name() == msg.message) {
- return command->run(msg);
+ return command->run(bundle, msg);
}
}
diff --git a/src/commands/command.hpp b/src/commands/command.hpp
index 0266301..5f69788 100644
--- a/src/commands/command.hpp
+++ b/src/commands/command.hpp
@@ -6,15 +6,17 @@
#include <variant>
#include <vector>
+#include "../bundle.hpp"
#include "../irc/message.hpp"
namespace bot {
namespace command {
class Command {
public:
- virtual std::string get_name() = 0;
+ virtual std::string get_name() const = 0;
virtual std::variant<std::vector<std::string>, std::string> run(
- const irc::Message<irc::MessageType::Privmsg> &msg) = 0;
+ const InstanceBundle &bundle,
+ const irc::Message<irc::MessageType::Privmsg> &msg) const = 0;
};
class CommandLoader {
@@ -24,7 +26,8 @@ namespace bot {
void add_command(std::unique_ptr<Command> cmd);
std::optional<std::variant<std::vector<std::string>, std::string>> run(
- const irc::Message<irc::MessageType::Privmsg> &msg);
+ const InstanceBundle &bundle,
+ const irc::Message<irc::MessageType::Privmsg> &msg) const;
const std::vector<std::unique_ptr<Command>> &get_commands() const {
return this->commands;
diff --git a/src/modules/ping.hpp b/src/modules/ping.hpp
index cf59d66..033f93a 100644
--- a/src/modules/ping.hpp
+++ b/src/modules/ping.hpp
@@ -4,15 +4,17 @@
#include <variant>
#include <vector>
+#include "../bundle.hpp"
#include "../commands/command.hpp"
namespace bot {
namespace mod {
class Ping : public command::Command {
- std::string get_name() override { return "ping"; }
+ std::string get_name() const override { return "ping"; }
std::variant<std::vector<std::string>, std::string> run(
- const irc::Message<irc::MessageType::Privmsg> &msg) override {
+ const InstanceBundle &bundle,
+ const irc::Message<irc::MessageType::Privmsg> &msg) const override {
return "pong";
}
};