#include #include #include #include #include #include #include #include #include #include #include int main(int argc, char **argv) { namespace po = boost::program_options; po::options_description description("Allowed options"); description.add_options() ("help,h", "Display this help message.") ("version,v", "Display version information.") ("input,i", po::value>(), "Specify the PDDL or SAS input file.") ("language,l", po::value(), "Specify the input language (sas or pddl). Omit for automatic detection.") ("warning-level", po::value()->default_value("normal"), "Specify whether to output warnings normally (normal), to treat them as critical errors (error), or to ignore them (ignore).") ("color", po::value()->default_value("auto"), "Specify whether to colorize the output (always, never, or auto)."); po::positional_options_description positionalOptionsDescription; positionalOptionsDescription.add("input", -1); po::variables_map variablesMap; const auto printHelp = [&]() { std::cout << "Usage: plasp [files] [options]" << std::endl; std::cout << "Translate PDDL instances to ASP facts." << std::endl << std::endl; std::cout << description; }; plasp::utils::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.logError(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.0" << std::endl; return EXIT_SUCCESS; } const auto warningLevel = variablesMap["warning-level"].as(); if (warningLevel == "error") logger.setWarningLevel(plasp::utils::Logger::WarningLevel::Error); else if (warningLevel == "ignore") logger.setWarningLevel(plasp::utils::Logger::WarningLevel::Ignore); else if (warningLevel == "normal") logger.setWarningLevel(plasp::utils::Logger::WarningLevel::Normal); else { logger.logError("unknown warning level “" + warningLevel + "”"); std::cout << std::endl; printHelp(); return EXIT_FAILURE; } const auto colorPolicy = variablesMap["color"].as(); if (colorPolicy == "auto") logger.setColorPolicy(plasp::utils::LogStream::ColorPolicy::Auto); else if (colorPolicy == "never") logger.setColorPolicy(plasp::utils::LogStream::ColorPolicy::Never); else if (colorPolicy == "always") logger.setColorPolicy(plasp::utils::LogStream::ColorPolicy::Always); else { logger.logError("unknown color policy “" + colorPolicy + "”"); std::cout << std::endl; printHelp(); return EXIT_FAILURE; } try { plasp::utils::Parser parser; parser.setCaseSensitive(false); if (variablesMap.count("input")) { const auto &inputFiles = variablesMap["input"].as>(); std::for_each(inputFiles.cbegin(), inputFiles.cend(), [&](const auto &inputFile) { parser.readFile(inputFile); }); } else parser.readStream("std::cin", std::cin); const auto detectLanguage = [&]() { if (variablesMap.count("language") == 0) return plasp::detectLanguage(parser); const auto languageName = variablesMap["language"].as(); return plasp::Language::fromString(languageName); }; const auto language = detectLanguage(); if (language == plasp::Language::Type::Unknown) { logger.logError("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), std::move(logger)); auto description = plasp::pddl::Description::fromContext(std::move(context)); const auto translator = plasp::pddl::TranslatorASP(description, description.context().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::utils::ParserException &e) { plasp::utils::Logger logger; logger.logError(e.coordinate(), e.message()); return EXIT_FAILURE; } catch (const plasp::utils::TranslatorException &e) { plasp::utils::Logger logger; logger.logError(e.what()); return EXIT_FAILURE; } catch (const std::exception &e) { plasp::utils::Logger logger; logger.logError(e.what()); return EXIT_FAILURE; } return EXIT_SUCCESS; }