Put PDDL translation sections into separate methods.
This commit is contained in:
parent
49002ac52d
commit
9c2f49e4a0
@ -27,6 +27,10 @@ class TranslatorASP
|
||||
void checkSupport() const;
|
||||
|
||||
void translateDomain() const;
|
||||
void translateTypes() const;
|
||||
void translateConstants() const;
|
||||
void translatePredicates() const;
|
||||
|
||||
void translateProblem() const;
|
||||
|
||||
const Description &m_description;
|
||||
|
@ -72,9 +72,31 @@ void TranslatorASP::translateDomain() const
|
||||
if (!domain.types().empty())
|
||||
{
|
||||
m_ostream << std::endl;
|
||||
translateTypes();
|
||||
}
|
||||
|
||||
// Constants
|
||||
if (!domain.constants().empty())
|
||||
{
|
||||
m_ostream << std::endl;
|
||||
translateConstants();
|
||||
}
|
||||
|
||||
// Predicates
|
||||
if (!domain.predicates().empty())
|
||||
{
|
||||
m_ostream << std::endl;
|
||||
translatePredicates();
|
||||
}
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
void TranslatorASP::translateTypes() const
|
||||
{
|
||||
m_ostream << "% types";
|
||||
|
||||
const auto &types = domain.types();
|
||||
const auto &types = m_description.domain().types();
|
||||
|
||||
std::for_each(types.cbegin(), types.cend(),
|
||||
[&](const auto &type)
|
||||
@ -91,15 +113,15 @@ void TranslatorASP::translateDomain() const
|
||||
m_ostream << "inherits(type(" << type->name() << "), type(" << parentType->name() << "))." << std::endl;
|
||||
});
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
// Constants
|
||||
if (!domain.constants().empty())
|
||||
{
|
||||
m_ostream << std::endl;
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
void TranslatorASP::translateConstants() const
|
||||
{
|
||||
m_ostream << "% constants";
|
||||
|
||||
const auto &constants = domain.constants();
|
||||
const auto &constants = m_description.domain().constants();
|
||||
|
||||
std::for_each(constants.cbegin(), constants.cend(),
|
||||
[&](const auto &constant)
|
||||
@ -115,15 +137,15 @@ void TranslatorASP::translateDomain() const
|
||||
|
||||
m_ostream << "hasType(constant(" << constant->name() << "), type(" << type->name() << "))." << std::endl;
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
// Predicates
|
||||
if (!domain.predicates().empty())
|
||||
{
|
||||
m_ostream << std::endl;
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
void TranslatorASP::translatePredicates() const
|
||||
{
|
||||
m_ostream << "% predicates";
|
||||
|
||||
const auto &predicates = domain.predicates();
|
||||
const auto &predicates = m_description.domain().predicates();
|
||||
|
||||
std::for_each(predicates.cbegin(), predicates.cend(),
|
||||
[&](const auto &predicate)
|
||||
@ -163,7 +185,6 @@ void TranslatorASP::translateDomain() const
|
||||
|
||||
m_ostream << ".";
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
Reference in New Issue
Block a user