#include #include #include #include #include #include #include #include #include #include namespace anthem { //////////////////////////////////////////////////////////////////////////////////////////////////// // // Translation // //////////////////////////////////////////////////////////////////////////////////////////////////// void translate(const std::vector &fileNames, Context &context) { for (const auto &fileName : fileNames) { std::ifstream file(fileName, std::ios::in); if (!file.is_open()) throw LogicException("could not read file “" + fileName + "”"); translate(fileName.c_str(), file, context); } } //////////////////////////////////////////////////////////////////////////////////////////////////// void translate(const char *fileName, std::istream &stream, Context &context) { context.logger.log(output::Priority::Info) << "reading " << fileName; auto fileContent = std::string(std::istreambuf_iterator(stream), {}); std::vector scopedFormulas; const auto translateStatement = [&scopedFormulas, &context](const Clingo::AST::Statement &statement) { statement.data.accept(StatementVisitor(), statement, scopedFormulas, context); }; const auto logger = [&context](const Clingo::WarningCode, const char *text) { context.logger.log(output::Priority::Error) << text; }; Clingo::parse_program(fileContent.c_str(), translateStatement, logger); if (context.simplify) for (auto &scopedFormula : scopedFormulas) simplify(scopedFormula.formula); ast::PrintContext printContext; if (!context.complete) { for (const auto &scopedFormula : scopedFormulas) { ast::print(context.logger.outputStream(), scopedFormula.formula, printContext); context.logger.outputStream() << std::endl; } return; } auto completedFormulas = complete(std::move(scopedFormulas)); for (const auto &completedFormula : completedFormulas) { ast::print(context.logger.outputStream(), completedFormula, printContext); context.logger.outputStream() << std::endl; } } //////////////////////////////////////////////////////////////////////////////////////////////////// }