#include #include #include #include #include #include #include #include #include #include #include int main(int argc, char **argv) { namespace po = boost::program_options; bool warningsAsErrors; po::options_description description("Allowed options"); description.add_options() ("help,h", "Display this help message") ("version,v", "Display version information") ("input,i", po::value>(), "Input files (in PDDL or SAS format)") ("language,l", po::value()->default_value("auto"), "Input language (pddl, sas, auto)") ("color", po::value()->default_value("auto"), "Colorize output (always, never, auto)") ("log-priority,p", po::value()->default_value("warning"), "Log messages starting from this priority (debug, info, warning, error)") ("warnings-as-errors", po::bool_switch(&warningsAsErrors), "Treat warnings as errors"); po::positional_options_description positionalOptionsDescription; positionalOptionsDescription.add("input", -1); po::variables_map variablesMap; const auto printHelp = [&]() { std::cout << "Usage: plasp [options] file..." << std::endl; std::cout << "Translate PDDL to ASP." << std::endl << std::endl; std::cout << description; }; plasp::output::Logger logger; try { po::store(po::command_line_parser(argc, argv) .options(description) .positional(positionalOptionsDescription) .run(), variablesMap); po::notify(variablesMap); } catch (const po::error &e) { logger.log(plasp::output::Priority::Error, e.what()); std::cout << std::endl; printHelp(); return EXIT_FAILURE; } if (variablesMap.count("help")) { printHelp(); return EXIT_SUCCESS; } if (variablesMap.count("version")) { std::cout << "plasp version 3.0.3-git" << std::endl; return EXIT_SUCCESS; } if (warningsAsErrors) logger.setAbortPriority(plasp::output::Priority::Warning); const auto colorPolicy = variablesMap["color"].as(); if (colorPolicy == "auto") logger.setColorPolicy(plasp::output::ColorStream::ColorPolicy::Auto); else if (colorPolicy == "never") logger.setColorPolicy(plasp::output::ColorStream::ColorPolicy::Never); else if (colorPolicy == "always") logger.setColorPolicy(plasp::output::ColorStream::ColorPolicy::Always); else { logger.log(plasp::output::Priority::Error, "unknown color policy “" + colorPolicy + "”"); std::cout << std::endl; printHelp(); return EXIT_FAILURE; } const auto logPriorityString = variablesMap["log-priority"].as(); try { const auto logPriority = plasp::output::priorityFromName(logPriorityString.c_str()); logger.setLogPriority(logPriority); } catch (const std::exception &e) { logger.log(plasp::output::Priority::Error, ("unknown log priorty “" + logPriorityString + "”").c_str()); logger.errorStream() << std::endl; printHelp(); return EXIT_FAILURE; } try { plasp::input::Parser parser; if (variablesMap.count("input")) { const auto &inputFiles = variablesMap["input"].as>(); std::for_each(inputFiles.cbegin(), inputFiles.cend(), [&](const auto &inputFile) { parser.read(inputFile); }); } else parser.read("std::cin", std::cin); const auto detectLanguage = [&]() { const auto languageName = variablesMap["language"].as(); const auto language = plasp::Language::fromString(languageName); if (language == plasp::Language::Type::Automatic) return plasp::detectLanguage(parser); return language; }; const auto language = detectLanguage(); if (language == plasp::Language::Type::Unknown) { logger.log(plasp::output::Priority::Error, "unknown input language"); std::cout << std::endl; printHelp(); return EXIT_FAILURE; } if (language == plasp::Language::Type::PDDL) { auto context = plasp::pddl::Context(std::move(parser), logger); auto description = plasp::pddl::Description::fromContext(context); const auto translator = plasp::pddl::TranslatorASP(description, logger.outputStream()); translator.translate(); } else if (language == plasp::Language::Type::SAS) { const auto description = plasp::sas::Description::fromParser(std::move(parser)); const auto translator = plasp::sas::TranslatorASP(description, logger.outputStream()); translator.translate(); } } catch (const plasp::input::ParserException &e) { logger.log(plasp::output::Priority::Error, e.location(), e.message().c_str()); return EXIT_FAILURE; } catch (const plasp::output::TranslatorException &e) { logger.log(plasp::output::Priority::Error, e.what()); return EXIT_FAILURE; } catch (const std::exception &e) { logger.log(plasp::output::Priority::Error, e.what()); return EXIT_FAILURE; } return EXIT_SUCCESS; }