diff options
author | A. Wilcox <AWilcox@Wilcox-Tech.com> | 2020-05-17 03:08:54 -0500 |
---|---|---|
committer | A. Wilcox <AWilcox@Wilcox-Tech.com> | 2020-05-17 03:08:54 -0500 |
commit | 6eba782291a999e4577bc8d3386f0dcb6945e6a4 (patch) | |
tree | 1c3d48203bc6d335df0b284c5a6f692c3fcbc5eb /tools | |
parent | a6b3b0f6cbaeb90995f5aa14eca7e27d9ff218e2 (diff) | |
download | horizon-6eba782291a999e4577bc8d3386f0dcb6945e6a4.tar.gz horizon-6eba782291a999e4577bc8d3386f0dcb6945e6a4.tar.bz2 horizon-6eba782291a999e4577bc8d3386f0dcb6945e6a4.tar.xz horizon-6eba782291a999e4577bc8d3386f0dcb6945e6a4.zip |
all: Add --version and --help support and unify output formats
Diffstat (limited to 'tools')
-rw-r--r-- | tools/hscript-fromjson/jsonconv.1 | 5 | ||||
-rw-r--r-- | tools/hscript-fromjson/jsonconv.cc | 16 | ||||
-rw-r--r-- | tools/hscript-simulate/simulator.1 | 6 | ||||
-rw-r--r-- | tools/hscript-simulate/simulator.cc | 76 | ||||
-rw-r--r-- | tools/hscript-validate/validator.1 | 6 | ||||
-rw-r--r-- | tools/hscript-validate/validator.cc | 84 |
6 files changed, 121 insertions, 72 deletions
diff --git a/tools/hscript-fromjson/jsonconv.1 b/tools/hscript-fromjson/jsonconv.1 index d8fe22e..a05a67f 100644 --- a/tools/hscript-fromjson/jsonconv.1 +++ b/tools/hscript-fromjson/jsonconv.1 @@ -8,6 +8,7 @@ .Nm .Op Fl fn .Op Fl h +.Op Fl v .Op Ar INSTALLFILE .Op Ar JSONFILE .Sh DESCRIPTION @@ -36,10 +37,12 @@ exists. By default, will display an error and quit without writing if a HorizonScript already exists at the specified path. .It Fl h -Display a help message, and then quit. +Displays a help message, and then exits. .It Fl n Disables colour output and ANSI escape sequences in any log messages. This is the default when not running from a terminal. +.It Fl v +Displays the version information for this utility, and then exits. .El .Sh EXIT STATUS .Ex -std diff --git a/tools/hscript-fromjson/jsonconv.cc b/tools/hscript-fromjson/jsonconv.cc index 3a5c564..b5c9504 100644 --- a/tools/hscript-fromjson/jsonconv.cc +++ b/tools/hscript-fromjson/jsonconv.cc @@ -146,7 +146,7 @@ bool parse_one_desc(json desc, std::ostream &out) { int main(int argc, char *argv[]) { using namespace boost::program_options; - bool needs_help{}, disable_pretty{}, force{}; + bool needs_help{}, disable_pretty{}, force{}, version_only{}; std::string if_path{"/etc/horizon/installfile"}, json_path; int exit_code = EXIT_SUCCESS; @@ -155,6 +155,7 @@ int main(int argc, char *argv[]) { options_description general{"General options"}; general.add_options() ("help,h", bool_switch(&needs_help), "Display this message.") + ("version,v", bool_switch(&version_only), "Show program version information") ("no-colour,n", bool_switch(&disable_pretty), "Do not 'prettify' output") ("force,f", bool_switch(&force), "Force writing, even if HorizonScript already exists") ; @@ -205,6 +206,19 @@ int main(int argc, char *argv[]) { json_path = "-"; } + if(version_only) { + bold_if_pretty(std::cout); + std::cout << "HorizonScript JSON Conversion Utility version " << VERSTR + << std::endl; + reset_if_pretty(std::cout); + std::cout << "Copyright (c) 2020 Adélie Linux and contributors." + << std::endl + << "This software is licensed to you under the terms of the " + << std::endl << "AGPL 3.0 license, unless otherwise noted." + << std::endl << std::endl; + return EXIT_SUCCESS; + } + if(!force && fs::exists(if_path)) { output_error("<option>", "installfile already exists", if_path); return EXIT_FAILURE; diff --git a/tools/hscript-simulate/simulator.1 b/tools/hscript-simulate/simulator.1 index d6a30b5..bad08a1 100644 --- a/tools/hscript-simulate/simulator.1 +++ b/tools/hscript-simulate/simulator.1 @@ -6,7 +6,7 @@ .Nd simulate execution of a HorizonScript, or create shell script .Sh SYNOPSIS .Nm -.Op Fl ns +.Op Fl hnsv .Ar INSTALLFILE .Sh DESCRIPTION The @@ -24,12 +24,16 @@ The .Nm utility supports the following options: .Bl -tag -width Ds +.It Fl h +Displays a help message, and then exits. .It Fl n Disables colour output and ANSI escape sequences in any log messages. This is the default when not running from a terminal. .It Fl s Enables Strict mode, which causes more potential issues to be errors instead of warnings. +.It Fl v +Displays the version information for this utility, and then exits. .El .Sh EXIT STATUS .Ex -std diff --git a/tools/hscript-simulate/simulator.cc b/tools/hscript-simulate/simulator.cc index 1731c62..ade54dc 100644 --- a/tools/hscript-simulate/simulator.cc +++ b/tools/hscript-simulate/simulator.cc @@ -14,19 +14,18 @@ #include "hscript/script.hh" #include "util/output.hh" + bool pretty = false; -static int cli_failure(boost::program_options::options_description cli) { - std::cout << cli << std::endl; - return EXIT_FAILURE; -} int main(int argc, char *argv[]) { const Horizon::Script *my_script; Horizon::ScriptOptions opts; int result_code = EXIT_SUCCESS; std::string installfile; + bool strict{}, needs_help{}, disable_pretty{}, version_only{}; using Horizon::ScriptOptionFlags; + using namespace boost::program_options; /* Default to pretty if we are using a TTY, unless -n specified. */ if(isatty(1) && isatty(2)) { @@ -35,42 +34,44 @@ int main(int argc, char *argv[]) { opts.set(ScriptOptionFlags::Simulate); - boost::program_options::options_description cli_hidden; + options_description cli_hidden; cli_hidden.add_options() ("installfile", "Installfile to load"); - boost::program_options::options_description cli_visible("Allowed options"); + options_description cli_visible("Allowed options"); cli_visible.add_options() - ("no-colour,n", "Do not 'prettify' output") - ("strict,s", "Strict parsing"); - boost::program_options::options_description cli; + ("help,h", bool_switch(&needs_help), "Display this message.") + ("version,v", bool_switch(&version_only), "Show program version information.") + ("no-colour,n", bool_switch(&disable_pretty), "Do not 'prettify' output.") + ("strict,s", bool_switch(&strict), "Use strict parsing mode (enable more warnings/errors)."); + options_description cli; cli.add(cli_visible).add(cli_hidden); - boost::program_options::positional_options_description cli_pos; + positional_options_description cli_pos; cli_pos.add("installfile", -1); - boost::program_options::variables_map args; + variables_map args; try { - boost::program_options::store( - boost::program_options::command_line_parser(argc, argv) + store( + command_line_parser(argc, argv) .options(cli) .positional(cli_pos) .run(), args); - boost::program_options::notify(args); + notify(args); } catch(const boost::program_options::error& cli_err) { - std::cout << "An invalid option was entered." << std::endl; - return cli_failure(cli_visible); + std::cerr << cli_err.what() << std::endl; + needs_help = true; + result_code = EXIT_FAILURE; } - if (args.count("installfile")) { - installfile = args["installfile"].as<std::string>(); - } else { - std::cout << "You must provide an installfile." << std::endl; - return cli_failure(cli_visible); + if(needs_help) { + std::cout << cli_visible << std::endl; + return result_code; } - if (args.count("no-colour")) { + if(disable_pretty) { pretty = false; } - if (args.count("strict")) { + + if(strict) { opts.set(ScriptOptionFlags::StrictMode); } @@ -86,28 +87,39 @@ int main(int argc, char *argv[]) { #ifdef NON_LIBRE_FIRMWARE colour_if_pretty(std::cout, "31"); std::cout << " (supports non-free firmware)"; - reset_if_pretty(std::cout); #endif + reset_if_pretty(std::cout); std::cout << std::endl; if(isatty(1)) { /* LCOV_EXCL_START */ - std::cout << "Copyright (c) 2019-2020 Adélie Linux and contributors."; - std::cout << std::endl; - std::cout << "This software is licensed to you under the terms of the " - << std::endl << "AGPL 3.0 license, unless otherwise noted."; - std::cout << std::endl << std::endl; + std::cout << "Copyright (c) 2019-2020 Adélie Linux and contributors." + << std::endl + << "This software is licensed to you under the terms of the " + << std::endl << "AGPL 3.0 license, unless otherwise noted." + << std::endl << std::endl; } /* LCOV_EXCL_STOP */ + if(version_only) { + return EXIT_SUCCESS; + } + + if(args.count("installfile")) { + installfile = args["installfile"].as<std::string>(); + } else { + output_error("<stdin>", "You must specify an installfile"); + return EXIT_FAILURE; + } + my_script = Horizon::Script::load(installfile, opts); if(my_script == nullptr) { - std::cout << "Could not load the specified script." << std::endl; + output_error(installfile, "Could not load the specified script"); return EXIT_FAILURE; } if(!my_script->execute()) { - output_error("internal", "Script failed. Stop.", ""); + output_error("internal", "Script failed. Stop."); result_code = EXIT_FAILURE; } else { - output_info("internal", "Script completed successfully.", ""); + output_info("internal", "Script completed successfully."); } delete my_script; diff --git a/tools/hscript-validate/validator.1 b/tools/hscript-validate/validator.1 index b57a227..9993a0b 100644 --- a/tools/hscript-validate/validator.1 +++ b/tools/hscript-validate/validator.1 @@ -6,7 +6,7 @@ .Nd ensure the validity of a HorizonScript .Sh SYNOPSIS .Nm -.Op Fl ikns +.Op Fl hiknsv .Ar INSTALLFILE .Sh DESCRIPTION The @@ -18,6 +18,8 @@ The .Nm utility supports the following options: .Bl -tag -width Ds +.It Fl h +Displays a help message, and then exits. .It Fl i Set the Installation Environment flag. This is VERY DANGEROUS, as it will treat your host system as the target for purposes of validation. Unless you @@ -31,6 +33,8 @@ is the default when not running from a terminal. .It Fl s Enables Strict mode, which causes more potential issues to be errors instead of warnings. +.It Fl v +Displays the version information for this utility, and then exits. .El .Sh EXIT STATUS .Ex -std diff --git a/tools/hscript-validate/validator.cc b/tools/hscript-validate/validator.cc index 77641c7..8277bea 100644 --- a/tools/hscript-validate/validator.cc +++ b/tools/hscript-validate/validator.cc @@ -14,69 +14,70 @@ #include "hscript/script.hh" #include "util/output.hh" + bool pretty = false; -static int cli_failure(boost::program_options::options_description cli) { - std::cout << cli << std::endl; - return EXIT_FAILURE; -} int main(int argc, char *argv[]) { const Horizon::Script *my_script; Horizon::ScriptOptions opts; int result_code = EXIT_SUCCESS; std::string installfile; + bool install{}, keep_going{}, strict{}, needs_help{}, version_only{}, + dont_pretty{}; using Horizon::ScriptOptionFlags; + using namespace boost::program_options; /* Default to pretty if we are using a TTY, unless -n specified. */ if(isatty(1) && isatty(2)) { pretty = true; /* LCOV_EXCL_LINE */ } - boost::program_options::options_description cli_hidden; + options_description cli_hidden; cli_hidden.add_options() ("installfile", "Installfile to load"); - boost::program_options::options_description cli_visible("Allowed options"); + options_description cli_visible("Allowed options"); cli_visible.add_options() - ("install,i", "Set Installation Environment flag (DANGEROUS)") - ("keep-going,k", "Continue parsing after errors") - ("no-colour,n", "Do not 'prettify' output") - ("strict,s", "Strict parsing"); - boost::program_options::options_description cli; + ("help,h", bool_switch(&needs_help), "Display this message.") + ("version,v", bool_switch(&version_only), "Show program version information.") + ("install,i", bool_switch(&install), "Set Installation Environment flag. (DANGEROUS!)") + ("keep-going,k", bool_switch(&keep_going), "Continue parsing after errors.") + ("no-colour,n", bool_switch(&dont_pretty), "Do not 'prettify' output.") + ("strict,s", bool_switch(&strict), "Use strict parsing mode (enable more warnings/errors)."); + options_description cli; cli.add(cli_visible).add(cli_hidden); - boost::program_options::positional_options_description cli_pos; + positional_options_description cli_pos; cli_pos.add("installfile", -1); - boost::program_options::variables_map args; + variables_map args; try { - boost::program_options::store( - boost::program_options::command_line_parser(argc, argv) + store( + command_line_parser(argc, argv) .options(cli) .positional(cli_pos) .run(), args); - boost::program_options::notify(args); + notify(args); } catch(const boost::program_options::error& cli_err) { std::cout << "An invalid option was entered." << std::endl; - return cli_failure(cli_visible); + needs_help = true; + result_code = EXIT_FAILURE; } - if (args.count("installfile")) { - installfile = args["installfile"].as<std::string>(); - } else { - std::cout << "You must provide an installfile." << std::endl; - return cli_failure(cli_visible); + if(needs_help) { + std::cout << cli_visible << std::endl; + return result_code; } - if (args.count("install")) { + if(install) { opts.set(ScriptOptionFlags::InstallEnvironment); } - if (args.count("keep-going")) { + if(keep_going) { opts.set(ScriptOptionFlags::KeepGoing); } - if (args.count("no-colour")) { + if(dont_pretty) { pretty = false; } - if (args.count("strict")) { + if(strict) { opts.set(ScriptOptionFlags::StrictMode); } @@ -88,26 +89,37 @@ int main(int argc, char *argv[]) { #ifdef NON_LIBRE_FIRMWARE colour_if_pretty(std::cout, "31"); std::cout << " (supports non-free firmware)"; - reset_if_pretty(std::cout); #endif - std::cout << std::endl; - std::cout << "Copyright (c) 2019-2020 Adélie Linux and contributors." - << std::endl; - std::cout << "This software is licensed to you under the terms of the " - << std::endl << "AGPL 3.0 license, unless otherwise noted."; - std::cout << std::endl << std::endl; + reset_if_pretty(std::cout); + std::cout << std::endl + << "Copyright (c) 2019-2020 Adélie Linux and contributors." + << std::endl + << "This software is licensed to you under the terms of the " + << std::endl << "AGPL 3.0 license, unless otherwise noted." + << std::endl << std::endl; + + if(version_only) { + return EXIT_SUCCESS; + } + + if(args.count("installfile")) { + installfile = args["installfile"].as<std::string>(); + } else { + output_error("<stdin>", "You must specify an installfile"); + return EXIT_FAILURE; + } my_script = Horizon::Script::load(installfile, opts); if(my_script == nullptr) { - std::cout << "Could not load the specified script." << std::endl; + output_error(installfile, "Could not load the specified script"); return EXIT_FAILURE; } if(!my_script->validate()) { - output_error("internal", "Script failed validation. Stop.", ""); + output_error("internal", "Script failed validation. Stop."); result_code = EXIT_FAILURE; } else { - output_info("internal", "Script passed validation.", ""); + output_info("internal", "Script passed validation."); } delete my_script; |