diff options
| author | Felix Morgner <felix.morgner@gmail.com> | 2024-05-17 17:58:38 +0200 |
|---|---|---|
| committer | Felix Morgner <felix.morgner@gmail.com> | 2024-05-17 17:58:38 +0200 |
| commit | 577fc0845718ed8ad5bebf02a277c0579a817f77 (patch) | |
| tree | 3d1cdc53c426a0ba60a7996619a7b787850bb3b3 /source/apps/src/wandac | |
| parent | de5bf7ca3b7a2bf6be35b86486b00dc6a071b950 (diff) | |
| download | wanda-577fc0845718ed8ad5bebf02a277c0579a817f77.tar.xz wanda-577fc0845718ed8ad5bebf02a277c0579a817f77.zip | |
Diffstat (limited to 'source/apps/src/wandac')
| -rw-r--r-- | source/apps/src/wandac/cli.cpp | 30 | ||||
| -rw-r--r-- | source/apps/src/wandac/listener.cpp | 29 | ||||
| -rw-r--r-- | source/apps/src/wandac/main.cpp | 43 |
3 files changed, 102 insertions, 0 deletions
diff --git a/source/apps/src/wandac/cli.cpp b/source/apps/src/wandac/cli.cpp new file mode 100644 index 0000000..6be1e18 --- /dev/null +++ b/source/apps/src/wandac/cli.cpp @@ -0,0 +1,30 @@ +#include "wanda/wandac/cli.hpp" + +#include <lyra/arg.hpp> +#include <lyra/help.hpp> + +#include <ostream> + +namespace wandac +{ + + auto cli::parse(lyra::args arguments, std::ostream & error_stream) -> bool + { + parser |= // + lyra::help(help) | // + lyra::arg{command, "command"}("The command to send to the deamon").required(); + + auto result = parser.parse(arguments); + + if (!result) + { + error_stream << "Error while processing command line arguments: " << result.message() << '\n' << parser << '\n'; + return false; + } + + return true; + } + + auto cli::print_usage(std::ostream & output_stream) -> void { output_stream << parser << '\n'; } + +} // namespace wandac diff --git a/source/apps/src/wandac/listener.cpp b/source/apps/src/wandac/listener.cpp new file mode 100644 index 0000000..29ccace --- /dev/null +++ b/source/apps/src/wandac/listener.cpp @@ -0,0 +1,29 @@ +#include "wanda/wandac/listener.hpp" + +#include "wanda/wandac/cli.hpp" + +#include <wanda/control/commander.hpp> +#include <wanda/proto/command.hpp> + +#include <boost/asio/io_context.hpp> + +namespace wandac +{ + + listener::listener(wandac::cli const & cli, boost::asio::io_context & service) + : m_cli{cli} + , m_service{service} + { + } + + auto listener::on_connected(wanda::control::commander & commander) -> void + { + if (m_cli.command == "change") + { + commander.send(wanda::proto::make_change_command()); + + post(m_service, [&] { commander.stop(); }); + } + } + +} // namespace wandac diff --git a/source/apps/src/wandac/main.cpp b/source/apps/src/wandac/main.cpp new file mode 100644 index 0000000..1533a62 --- /dev/null +++ b/source/apps/src/wandac/main.cpp @@ -0,0 +1,43 @@ +#include "wanda/wandac/cli.hpp" +#include "wanda/wandac/listener.hpp" + +#include <wanda/control/commander.hpp> +#include <wanda/system/environment.hpp> +#include <wanda/system/logging.hpp> +#include <wanda/system/xdg.hpp> + +#include <boost/asio/io_context.hpp> +#include <spdlog/sinks/stdout_color_sinks.h> + +#include <cstdlib> +#include <filesystem> +#include <iostream> + +int main(int argc, char const * const * argv) +{ + auto cli = wandac::cli{}; + if (!cli.parse({argc, argv}, std::cerr)) + { + return EXIT_FAILURE; + } + else if (cli.help) + { + cli.print_usage(std::cout); + return EXIT_SUCCESS; + } + + wanda::system::initialize_logger(std::make_shared<spdlog::sinks::stderr_color_sink_st>()); + + auto environment = wanda::system::environment{}; + auto runtime_dir = wanda::system::xdg_path_for(wanda::system::xdg_directory::runtime_dir, environment); + auto interface = runtime_dir / ".wanda_interface"; + auto service = boost::asio::io_context{}; + auto listener = wandac::listener{cli, service}; + + auto commander = wanda::control::commander{service, interface, listener}; + + wanda::system::get_logger()->info("trying to connect to wanda control interface on '{}'", interface.native()); + commander.start(); + + service.run(); +} |
