Implemented And expressions.
This commit is contained in:
@@ -6,6 +6,9 @@ file(GLOB core_headers "../include/plasp/*.h")
|
||||
file(GLOB pddl_sources "plasp/pddl/*.cpp")
|
||||
file(GLOB pddl_headers "../include/plasp/pddl/*.h")
|
||||
|
||||
file(GLOB pddl_expressions_sources "plasp/pddl/expressions/*.cpp")
|
||||
file(GLOB pddl_expressions_headers "../include/plasp/pddl/expressions/*.h")
|
||||
|
||||
file(GLOB sas_sources "plasp/sas/*.cpp")
|
||||
file(GLOB sas_headers "../include/plasp/sas/*.h")
|
||||
|
||||
@@ -27,6 +30,9 @@ set(sources
|
||||
${pddl_sources}
|
||||
${pddl_headers}
|
||||
|
||||
${pddl_expressions_sources}
|
||||
${pddl_expressions_headers}
|
||||
|
||||
${sas_sources}
|
||||
${sas_headers}
|
||||
|
||||
|
@@ -51,7 +51,7 @@ Action &Action::parseDeclaration(utils::Parser &parser, Context &context)
|
||||
const auto sectionIdentifier = parser.parseIdentifier(isIdentifier);
|
||||
|
||||
if (sectionIdentifier == "precondition")
|
||||
action->m_precondition = parsePreconditionExpression(parser, context);
|
||||
action->m_precondition = parsePreconditionExpression(parser, context, action->m_parameters);
|
||||
//else if (sectionIdentifier == "effect")
|
||||
// action->m_effect = parseEffectExpression(parser, context);
|
||||
}
|
||||
|
@@ -2,7 +2,7 @@
|
||||
|
||||
#include <plasp/pddl/Context.h>
|
||||
#include <plasp/pddl/Identifier.h>
|
||||
#include <plasp/pddl/expressions/NAryExpression.h>
|
||||
#include <plasp/pddl/expressions/AndExpression.h>
|
||||
#include <plasp/utils/ParserException.h>
|
||||
|
||||
namespace plasp
|
||||
@@ -16,7 +16,7 @@ namespace pddl
|
||||
//
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
std::unique_ptr<Expression> parsePreconditionExpression(utils::Parser &parser, Context &context)
|
||||
std::unique_ptr<Expression> parsePreconditionExpression(utils::Parser &parser, Context &context, const Variables ¶meters)
|
||||
{
|
||||
parser.skipWhiteSpace();
|
||||
|
||||
@@ -24,16 +24,30 @@ std::unique_ptr<Expression> parsePreconditionExpression(utils::Parser &parser, C
|
||||
|
||||
const auto expressionIdentifier = parser.parseIdentifier(isIdentifier);
|
||||
|
||||
std::cout << "Parsing identifier " << expressionIdentifier << std::endl;
|
||||
|
||||
std::unique_ptr<Expression> expression;
|
||||
|
||||
throw utils::ParserException(parser.row(), parser.column(), "Expression of type \"" + expressionIdentifier + "\" not allowed in preference declaration");
|
||||
const auto throwNotAllowed =
|
||||
[&]()
|
||||
{
|
||||
throw utils::ParserException(parser.row(), parser.column(), "Expression of type \"" + expressionIdentifier + "\" not allowed in preference declaration");
|
||||
};
|
||||
|
||||
//if (expressionIdentifier == "and")
|
||||
// expression = NAry
|
||||
if (expressionIdentifier == "and")
|
||||
expression = expressions::AndExpression::parse(parser, context, parameters, parsePreconditionExpression);
|
||||
else if (expressionIdentifier == "or")
|
||||
throwNotAllowed();
|
||||
else if (expressionIdentifier == "not")
|
||||
throwNotAllowed();
|
||||
else if (expressionIdentifier == "exists")
|
||||
throwNotAllowed();
|
||||
else
|
||||
throw utils::ParserException(parser.row(), parser.column(), "Undeclared expression \"" + expressionIdentifier + "\"");
|
||||
|
||||
parser.expect<std::string>(")");
|
||||
|
||||
return std::move(expression);
|
||||
return expression;
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
29
src/plasp/pddl/expressions/AndExpression.cpp
Normal file
29
src/plasp/pddl/expressions/AndExpression.cpp
Normal file
@@ -0,0 +1,29 @@
|
||||
#include <plasp/pddl/expressions/AndExpression.h>
|
||||
|
||||
#include <plasp/pddl/Context.h>
|
||||
#include <plasp/pddl/ExpressionVisitor.h>
|
||||
#include <plasp/utils/Parser.h>
|
||||
|
||||
namespace plasp
|
||||
{
|
||||
namespace pddl
|
||||
{
|
||||
namespace expressions
|
||||
{
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// AndExpression
|
||||
//
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
void AndExpression::accept(plasp::pddl::ExpressionVisitor &expressionVisitor) const
|
||||
{
|
||||
expressionVisitor.visit(*this);
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
}
|
||||
}
|
||||
}
|
31
src/plasp/pddl/expressions/NAryExpression.cpp
Normal file
31
src/plasp/pddl/expressions/NAryExpression.cpp
Normal file
@@ -0,0 +1,31 @@
|
||||
#include <plasp/pddl/expressions/NAryExpression.h>
|
||||
|
||||
#include <algorithm>
|
||||
|
||||
#include <plasp/pddl/Context.h>
|
||||
#include <plasp/pddl/ExpressionVisitor.h>
|
||||
#include <plasp/pddl/Identifier.h>
|
||||
|
||||
namespace plasp
|
||||
{
|
||||
namespace pddl
|
||||
{
|
||||
namespace expressions
|
||||
{
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// NAryExpression
|
||||
//
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
const std::vector<std::unique_ptr<Expression>> &NAryExpression::arguments() const
|
||||
{
|
||||
return m_arguments;
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
}
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user