mirror of
https://github.com/jtgans/g13gui.git
synced 2025-06-20 16:33:54 -04:00
This is the first half of some major rework of the g13d codebase to make things a bit more manageable. This splits out a great deal of stuff from helper.h into separate translation units, and also breaks out a great deal of the g13.h header into separate translation units as well. Doing this saves in compilation time as we make changes to the system, and also helps to clean up a whole bunch of leaking symbols.
69 lines
1.8 KiB
C++
69 lines
1.8 KiB
C++
#include <iostream>
|
|
|
|
#include <boost/program_options.hpp>
|
|
#include <boost/foreach.hpp>
|
|
|
|
#include "g13.h"
|
|
#include "manager.h"
|
|
|
|
namespace po = boost::program_options;
|
|
|
|
extern "C" {
|
|
|
|
int main(int argc, char *argv[]) {
|
|
G13::G13_Manager manager;
|
|
manager.set_log_level("info");
|
|
|
|
// Declare the supported options.
|
|
po::options_description desc("Allowed options");
|
|
desc.add_options()("help", "produce help message");
|
|
std::vector<std::string> sopt_names;
|
|
|
|
auto add_string_option = [&sopt_names, &desc](const char *name,
|
|
const char *description) {
|
|
desc.add_options()(name, po::value<std::string>(), description);
|
|
sopt_names.push_back(name);
|
|
};
|
|
|
|
add_string_option("logo", "set logo from file");
|
|
add_string_option("config", "load config commands from file");
|
|
add_string_option("pipe_in", "specify name for input pipe");
|
|
add_string_option("pipe_out", "specify name for output pipe");
|
|
add_string_option("log_level", "logging level");
|
|
// add_string_option( "logfile", "write log to logfile" );
|
|
|
|
po::positional_options_description p;
|
|
p.add("logo", -1);
|
|
po::variables_map vm;
|
|
po::store(
|
|
po::command_line_parser(argc, argv).options(desc).positional(p).run(),
|
|
vm);
|
|
po::notify(vm);
|
|
|
|
if (vm.count("help")) {
|
|
std::cout << argv[0] << " : user space G13 driver" << std::endl
|
|
<< desc << "\n";
|
|
return 1;
|
|
}
|
|
|
|
BOOST_FOREACH (const std::string &tag, sopt_names) {
|
|
if (vm.count(tag)) {
|
|
manager.set_string_config_value(tag, vm[tag].as<std::string>());
|
|
}
|
|
}
|
|
|
|
if (vm.count("logo")) {
|
|
manager.set_logo(vm["logo"].as<std::string>());
|
|
}
|
|
|
|
if (vm.count("log_level")) {
|
|
manager.set_log_level(manager.string_config_value("log_level"));
|
|
}
|
|
|
|
manager.run();
|
|
|
|
return 0;
|
|
}
|
|
|
|
}
|