From afdd7e9b69b26aa7fadb65a0da6aa9a21341bc4c Mon Sep 17 00:00:00 2001 From: Niklas Halle Date: Wed, 26 Aug 2020 14:38:20 +0200 Subject: :( --- src/Handler.cpp | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) (limited to 'src/Handler.cpp') diff --git a/src/Handler.cpp b/src/Handler.cpp index 1c0cd12..b5ed9f0 100644 --- a/src/Handler.cpp +++ b/src/Handler.cpp @@ -14,3 +14,19 @@ std::vector Handler::tokenizeArguments(const std::string &arguments return tokens; } + +Handler::CommandHandler::CommandHandler(Handler::CommandHandler &&o) noexcept { + // this is a copy constructor, disguised as a move constructor.. I am sorry + command = o.command; + func = o.func; + description = o.description; // this is the main problem, any "moved" object will point to the same description TODO: maybe smart pointer can help? + payload = o.payload; +} + +Handler::json Handler::CommandHandler::exec(const std::string &arguments, const std::string &session) const { + return func(arguments, session, payload); +} + +Handler::CommandHandler::CommandHandler(std::string command, Handler::handler_function func, + std::vector *description, void *payload) + : command{std::move(command)}, func{std::move(func)}, description{description}, payload{payload} {} -- cgit v1.2.3-54-g00ecf