diff --git a/apps/plasp-app/main.cpp b/apps/plasp-app/main.cpp index 9d2ba93..156ae14 100644 --- a/apps/plasp-app/main.cpp +++ b/apps/plasp-app/main.cpp @@ -106,8 +106,8 @@ int main(int argc, char **argv) if (language == plasp::Language::Type::PDDL) { const auto description = plasp::pddl::Description::fromParser(std::move(parser)); - const auto translator = plasp::pddl::TranslatorASP(description); - translator.translate(std::cout); + const auto translator = plasp::pddl::TranslatorASP(description, std::cout); + translator.translate(); } else if (language == plasp::Language::Type::SAS) { diff --git a/include/plasp/pddl/TranslatorASP.h b/include/plasp/pddl/TranslatorASP.h index 77e3faa..3180afe 100644 --- a/include/plasp/pddl/TranslatorASP.h +++ b/include/plasp/pddl/TranslatorASP.h @@ -19,17 +19,18 @@ namespace pddl class TranslatorASP { public: - explicit TranslatorASP(const Description &description); + explicit TranslatorASP(const Description &description, std::ostream &ostream); - void translate(std::ostream &ostream) const; + void translate() const; private: void checkSupport() const; - void translateDomain(std::ostream &ostream) const; - void translateProblem(std::ostream &ostream) const; + void translateDomain() const; + void translateProblem() const; const Description &m_description; + std::ostream &m_ostream; }; //////////////////////////////////////////////////////////////////////////////////////////////////// diff --git a/src/plasp/pddl/TranslatorASP.cpp b/src/plasp/pddl/TranslatorASP.cpp index 09527c2..1e05ddc 100644 --- a/src/plasp/pddl/TranslatorASP.cpp +++ b/src/plasp/pddl/TranslatorASP.cpp @@ -14,8 +14,9 @@ namespace pddl // //////////////////////////////////////////////////////////////////////////////////////////////////// -TranslatorASP::TranslatorASP(const Description &description) -: m_description(description) +TranslatorASP::TranslatorASP(const Description &description, std::ostream &ostream) +: m_description(description), + m_ostream(ostream) { } @@ -42,25 +43,25 @@ void TranslatorASP::checkSupport() const //////////////////////////////////////////////////////////////////////////////////////////////////// -void TranslatorASP::translate(std::ostream &ostream) const +void TranslatorASP::translate() const { checkSupport(); - translateDomain(ostream); + translateDomain(); if (m_description.containsProblem()) { - ostream << std::endl; + m_ostream << std::endl; - translateProblem(ostream); + translateProblem(); } } //////////////////////////////////////////////////////////////////////////////////////////////////// -void TranslatorASP::translateDomain(std::ostream &ostream) const +void TranslatorASP::translateDomain() const { - ostream + m_ostream << "%---------------------------------------" << std::endl << "% domain" << std::endl << "%---------------------------------------" << std::endl; @@ -70,24 +71,24 @@ void TranslatorASP::translateDomain(std::ostream &ostream) const // Types if (!domain.types().empty()) { - ostream << std::endl; - ostream << "% types"; + m_ostream << std::endl; + m_ostream << "% types"; const auto &types = domain.types(); std::for_each(types.cbegin(), types.cend(), [&](const auto &type) { - ostream << std::endl; + m_ostream << std::endl; - ostream << "type(" << type->name() << ")." << std::endl; + m_ostream << "type(" << type->name() << ")." << std::endl; const auto &parentTypes = type->parentTypes(); std::for_each(parentTypes.cbegin(), parentTypes.cend(), [&](const auto &parentType) { - ostream << "inherits(type(" << type->name() << "), type(" << parentType->name() << "))." << std::endl; + m_ostream << "inherits(type(" << type->name() << "), type(" << parentType->name() << "))." << std::endl; }); }); } @@ -95,81 +96,81 @@ void TranslatorASP::translateDomain(std::ostream &ostream) const // Constants if (!domain.constants().empty()) { - ostream << std::endl; - ostream << "% constants"; + m_ostream << std::endl; + m_ostream << "% constants"; const auto &constants = domain.constants(); std::for_each(constants.cbegin(), constants.cend(), [&](const auto &constant) { - ostream << std::endl; + m_ostream << std::endl; - ostream << "constant(" << constant->name() << ")." << std::endl; + m_ostream << "constant(" << constant->name() << ")." << std::endl; const auto *type = constant->type(); if (type == nullptr) return; - ostream << "hasType(constant(" << constant->name() << "), type(" << type->name() << "))." << std::endl; + m_ostream << "hasType(constant(" << constant->name() << "), type(" << type->name() << "))." << std::endl; }); } // Predicates if (!domain.predicates().empty()) { - ostream << std::endl; - ostream << "% predicates"; + m_ostream << std::endl; + m_ostream << "% predicates"; const auto &predicates = domain.predicates(); std::for_each(predicates.cbegin(), predicates.cend(), [&](const auto &predicate) { - ostream << std::endl; + m_ostream << std::endl; - ostream << "predicate(" << predicate->name(); + m_ostream << "predicate(" << predicate->name(); const auto &arguments = predicate->arguments(); if (arguments.empty()) { - ostream << ")."; + m_ostream << ")."; return; } - ostream << "("; + m_ostream << "("; for (auto i = arguments.cbegin(); i != arguments.cend(); i++) { if (i != arguments.cbegin()) - ostream << ", "; + m_ostream << ", "; - ostream << utils::escapeASPVariable((*i)->name()); + m_ostream << utils::escapeASPVariable((*i)->name()); } - ostream << ")) :- "; + m_ostream << ")) :- "; for (auto i = arguments.cbegin(); i != arguments.cend(); i++) { if (i != arguments.cbegin()) - ostream << ", "; + m_ostream << ", "; const auto &type = *dynamic_cast((*i)->type()); - ostream << "hasType(" << utils::escapeASPVariable((*i)->name()) << ", type(" << type.name() << "))"; + m_ostream << "hasType(" << utils::escapeASPVariable((*i)->name()) << ", type(" << type.name() << "))"; } - ostream << "."; + m_ostream << "."; }); } } //////////////////////////////////////////////////////////////////////////////////////////////////// -void TranslatorASP::translateProblem(std::ostream &ostream) const +void TranslatorASP::translateProblem() const { - ostream << std::endl + m_ostream << std::endl << "%---------------------------------------" << std::endl << "% problem" << std::endl << "%---------------------------------------" << std::endl;