Made option group parsing more uniform.
This commit is contained in:
@@ -1,36 +0,0 @@
|
||||
#include <plasp-app/Commands.h>
|
||||
|
||||
#include <map>
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// Commands
|
||||
//
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
static const std::map<std::string, Command> commandNames =
|
||||
{
|
||||
{"help", Command::Help},
|
||||
{"-h", Command::Help},
|
||||
{"--help", Command::Help},
|
||||
{"version", Command::Version},
|
||||
{"-v", Command::Version},
|
||||
{"--version", Command::Version},
|
||||
{"check-syntax", Command::CheckSyntax},
|
||||
{"requirements", Command::Requirements},
|
||||
{"pretty-print", Command::PrettyPrint},
|
||||
{"normalize", Command::Normalize},
|
||||
{"translate", Command::Translate},
|
||||
};
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
Command parseCommand(const std::string &commandString)
|
||||
{
|
||||
const auto matchingCommand = commandNames.find(commandString);
|
||||
|
||||
if (matchingCommand == commandNames.cend())
|
||||
throw std::runtime_error(std::string("“") + commandString + "” is not a plasp command");
|
||||
|
||||
return matchingCommand->second;
|
||||
}
|
@@ -1,22 +1,31 @@
|
||||
#include <plasp-app/CommonOptions.h>
|
||||
#include <plasp-app/OptionGroups.h>
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// Common Options
|
||||
// Option Groups
|
||||
//
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
void addBasicOptions(cxxopts::Options &options)
|
||||
void OptionGroupBasic::addTo(cxxopts::Options &options)
|
||||
{
|
||||
options.add_options("basic")
|
||||
("h,help", "Display this help message")
|
||||
("v,version", "Display version information")
|
||||
("warnings-as-errors", "Treat warnings as errors");
|
||||
("h,help", "Display this help message")
|
||||
("v,version", "Display version information")
|
||||
("warnings-as-errors", "Treat warnings as errors");
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
void addOutputOptions(cxxopts::Options &options)
|
||||
void OptionGroupBasic::parse(cxxopts::Options &options)
|
||||
{
|
||||
help = options["help"].as<bool>();
|
||||
version = options["version"].as<bool>();
|
||||
warningsAsErrors = options["warnings-as-errors"].as<bool>();
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
void OptionGroupOutput::addTo(cxxopts::Options &options)
|
||||
{
|
||||
options.add_options("output")
|
||||
("color", "Colorize output (always, never, auto)", cxxopts::value<std::string>()->default_value("auto"))
|
||||
@@ -25,7 +34,34 @@ void addOutputOptions(cxxopts::Options &options)
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
void addParserOptions(cxxopts::Options &options)
|
||||
void OptionGroupOutput::parse(cxxopts::Options &options)
|
||||
{
|
||||
const auto colorPolicyString = options["color"].as<std::string>();
|
||||
|
||||
if (colorPolicyString == "auto")
|
||||
colorPolicy = colorlog::ColorStream::ColorPolicy::Auto;
|
||||
else if (colorPolicyString == "never")
|
||||
colorPolicy = colorlog::ColorStream::ColorPolicy::Never;
|
||||
else if (colorPolicyString == "always")
|
||||
colorPolicy = colorlog::ColorStream::ColorPolicy::Always;
|
||||
else
|
||||
throw OptionException("unknown color policy “" + colorPolicyString + "”");
|
||||
|
||||
const auto logPriorityString = options["log-priority"].as<std::string>();
|
||||
|
||||
try
|
||||
{
|
||||
logPriority = colorlog::priorityFromName(logPriorityString.c_str());
|
||||
}
|
||||
catch (const std::exception &e)
|
||||
{
|
||||
throw OptionException(e.what());
|
||||
}
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
void OptionGroupParser::addTo(cxxopts::Options &options)
|
||||
{
|
||||
options.add_options("parser")
|
||||
("i,input", "Input files (in PDDL or SAS format)", cxxopts::value<std::vector<std::string>>())
|
||||
@@ -36,69 +72,21 @@ void addParserOptions(cxxopts::Options &options)
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
BasicOptions parseBasicOptions(cxxopts::Options &options)
|
||||
void OptionGroupParser::parse(cxxopts::Options &options)
|
||||
{
|
||||
BasicOptions basicOptions;
|
||||
|
||||
basicOptions.help = options["help"].as<bool>();
|
||||
basicOptions.version = options["version"].as<bool>();
|
||||
basicOptions.warningsAsErrors = options["warnings-as-errors"].as<bool>();
|
||||
|
||||
return basicOptions;
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
OutputOptions parseOutputOptions(cxxopts::Options &options)
|
||||
{
|
||||
OutputOptions outputOptions;
|
||||
|
||||
const auto colorPolicy = options["color"].as<std::string>();
|
||||
|
||||
if (colorPolicy == "auto")
|
||||
outputOptions.colorPolicy = colorlog::ColorStream::ColorPolicy::Auto;
|
||||
else if (colorPolicy == "never")
|
||||
outputOptions.colorPolicy = colorlog::ColorStream::ColorPolicy::Never;
|
||||
else if (colorPolicy == "always")
|
||||
outputOptions.colorPolicy = colorlog::ColorStream::ColorPolicy::Always;
|
||||
else
|
||||
throw OptionException("unknown color policy “" + colorPolicy + "”");
|
||||
|
||||
const auto logPriorityString = options["log-priority"].as<std::string>();
|
||||
|
||||
try
|
||||
{
|
||||
outputOptions.logPriority = colorlog::priorityFromName(logPriorityString.c_str());
|
||||
}
|
||||
catch (const std::exception &e)
|
||||
{
|
||||
throw OptionException(e.what());
|
||||
}
|
||||
|
||||
return outputOptions;
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
ParserOptions parseParserOptions(cxxopts::Options &options)
|
||||
{
|
||||
ParserOptions parserOptions;
|
||||
|
||||
const auto parsingModeString = options["parsing-mode"].as<std::string>();
|
||||
|
||||
if (parsingModeString == "compatibility")
|
||||
parserOptions.parsingMode = pddl::Mode::Compatibility;
|
||||
parsingMode = pddl::Mode::Compatibility;
|
||||
else if (parsingModeString != "strict")
|
||||
throw OptionException("unknown parsing mode “" + parsingModeString + "”");
|
||||
|
||||
if (options.count("input"))
|
||||
parserOptions.inputFiles = options["input"].as<std::vector<std::string>>();
|
||||
inputFiles = options["input"].as<std::vector<std::string>>();
|
||||
|
||||
const auto languageName = options["language"].as<std::string>();
|
||||
parserOptions.language = plasp::Language::fromString(languageName);
|
||||
language = plasp::Language::fromString(languageName);
|
||||
|
||||
if (parserOptions.language == plasp::Language::Type::Unknown)
|
||||
if (language == plasp::Language::Type::Unknown)
|
||||
throw OptionException("unknown input language “" + languageName + "”");
|
||||
|
||||
return parserOptions;
|
||||
}
|
@@ -1,4 +1,5 @@
|
||||
#include <plasp-app/commands/Translate.h>
|
||||
#include <plasp-app/commands/CommandTranslate.h>
|
||||
|
||||
#include <iostream>
|
||||
#include <string>
|
||||
|
||||
@@ -23,18 +24,19 @@
|
||||
#include <plasp/sas/Description.h>
|
||||
#include <plasp/sas/TranslatorASP.h>
|
||||
|
||||
#include <plasp-app/Commands.h>
|
||||
#include <plasp-app/CommonOptions.h>
|
||||
#include <plasp-app/Version.h>
|
||||
#include <plasp-app/commands/Translate.h>
|
||||
|
||||
int translate(int argc, char **argv)
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// Command Translate
|
||||
//
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
int CommandTranslate::run(int argc, char **argv)
|
||||
{
|
||||
cxxopts::Options options("plasp translate", "Translate PDDL to ASP.");
|
||||
|
||||
addBasicOptions(options);
|
||||
addOutputOptions(options);
|
||||
addParserOptions(options);
|
||||
addOptionGroupsTo(options);
|
||||
|
||||
const auto printHelp =
|
||||
[&]()
|
||||
@@ -44,9 +46,11 @@ int translate(int argc, char **argv)
|
||||
|
||||
options.parse(argc, argv);
|
||||
|
||||
const auto basicOptions = parseBasicOptions(options);
|
||||
const auto outputOptions = parseOutputOptions(options);
|
||||
const auto parserOptions = parseParserOptions(options);
|
||||
parseOptionGroups(options);
|
||||
|
||||
const auto &basicOptions = std::get<OptionGroupBasic>(m_optionGroups);
|
||||
const auto &outputOptions = std::get<OptionGroupOutput>(m_optionGroups);
|
||||
const auto &parserOptions = std::get<OptionGroupParser>(m_optionGroups);
|
||||
|
||||
if (basicOptions.help)
|
||||
{
|
@@ -7,9 +7,58 @@
|
||||
#include <colorlog/Logger.h>
|
||||
#include <colorlog/Priority.h>
|
||||
|
||||
#include <plasp-app/Commands.h>
|
||||
#include <plasp-app/Command.h>
|
||||
#include <plasp-app/Version.h>
|
||||
#include <plasp-app/commands/Translate.h>
|
||||
#include <plasp-app/commands/CommandTranslate.h>
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// Main
|
||||
//
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
enum class CommandType
|
||||
{
|
||||
Help,
|
||||
Version,
|
||||
CheckSyntax,
|
||||
Requirements,
|
||||
PrettyPrint,
|
||||
Normalize,
|
||||
Translate
|
||||
};
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
static const std::map<std::string, CommandType> commandNames =
|
||||
{
|
||||
{"help", CommandType::Help},
|
||||
{"-h", CommandType::Help},
|
||||
{"--help", CommandType::Help},
|
||||
{"version", CommandType::Version},
|
||||
{"-v", CommandType::Version},
|
||||
{"--version", CommandType::Version},
|
||||
{"check-syntax", CommandType::CheckSyntax},
|
||||
{"requirements", CommandType::Requirements},
|
||||
{"pretty-print", CommandType::PrettyPrint},
|
||||
{"normalize", CommandType::Normalize},
|
||||
{"translate", CommandType::Translate},
|
||||
};
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
const auto parseCommandType =
|
||||
[](const std::string &commandString)
|
||||
{
|
||||
const auto matchingCommand = commandNames.find(commandString);
|
||||
|
||||
if (matchingCommand == commandNames.cend())
|
||||
throw std::runtime_error(std::string("“") + commandString + "” is not a plasp command");
|
||||
|
||||
return matchingCommand->second;
|
||||
};
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
int main(int argc, char **argv)
|
||||
{
|
||||
@@ -19,8 +68,7 @@ int main(int argc, char **argv)
|
||||
// TODO: add list of available commands
|
||||
std::cout
|
||||
<< "ASP planning tools for PDDL." << std::endl
|
||||
<< "Usage: plasp <command> [<arguments>]" << std::endl
|
||||
<< "Translate PDDL to ASP." << std::endl;
|
||||
<< "Usage: plasp <command> [<arguments>]" << std::endl;
|
||||
};
|
||||
|
||||
const auto printVersion =
|
||||
@@ -39,16 +87,16 @@ int main(int argc, char **argv)
|
||||
|
||||
try
|
||||
{
|
||||
switch (parseCommand(argv[1]))
|
||||
switch (parseCommandType(argv[1]))
|
||||
{
|
||||
case Command::Help:
|
||||
case CommandType::Help:
|
||||
printHelp();
|
||||
return EXIT_SUCCESS;
|
||||
case Command::Version:
|
||||
case CommandType::Version:
|
||||
printVersion();
|
||||
return EXIT_SUCCESS;
|
||||
case Command::Translate:
|
||||
return translate(argc - 1, &argv[1]);
|
||||
case CommandType::Translate:
|
||||
return CommandTranslate().run(argc - 1, &argv[1]);
|
||||
default:
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
Reference in New Issue
Block a user