Fixed parsing of types.

This commit is contained in:
Patrick Lühne 2017-06-16 04:21:19 +02:00
parent 30a092b365
commit 1876d1fe0b
Signed by: patrick
GPG Key ID: 05F3611E97A70ABF
5 changed files with 51 additions and 35 deletions

View File

@ -128,16 +128,6 @@ At<Argument> deepCopy(At<Argument> &other)
return At<Argument>(other.timePoint, std::move(argument)); return At<Argument>(other.timePoint, std::move(argument));
} }
////////////////////////////////////////////////////////////////////////////////////////////////////
/*
template<class Argument>
Either<Argument> deepCopy(Either<Argument> &other)
{
auto argument{deepCopy(other.argument)};
return Not<Argument>(std::move(argument));
}*/
//////////////////////////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////////////////////////
template<class Argument> template<class Argument>
@ -152,20 +142,9 @@ Not<Argument> deepCopy(Not<Argument> &other)
// Variants // Variants
//////////////////////////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////////////////////////
struct DeepCopyVisitor
{
template<class Argument>
Argument visit(Argument &other)
{
return deepCopy(other);
}
};
////////////////////////////////////////////////////////////////////////////////////////////////////
ast::Type deepCopy(ast::Type &other) ast::Type deepCopy(ast::Type &other)
{ {
return other.match([](auto &x){deepCopy(x); return std::make_unique<ast::PrimitiveType>(nullptr);}); return other.match([](auto &x) -> ast::Type {return deepCopy(x);});
} }
//////////////////////////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////////////////////////

View File

@ -23,9 +23,8 @@ ast::Type parseType(Context &context, ast::Domain &domain)
if (tokenizer.testAndReturn<char>('(')) if (tokenizer.testAndReturn<char>('('))
{ {
// TODO: put into Type parsing unit
// TODO: refactor // TODO: refactor
auto p = auto parsePrimitiveTypeWrapper =
[](auto &context, auto &astContext, auto &) -> std::experimental::optional<ast::PrimitiveTypePointer> [](auto &context, auto &astContext, auto &) -> std::experimental::optional<ast::PrimitiveTypePointer>
{ {
return parsePrimitiveType(context, *astContext.domain); return parsePrimitiveType(context, *astContext.domain);
@ -35,7 +34,7 @@ ast::Type parseType(Context &context, ast::Domain &domain)
ASTContext astContext(domain); ASTContext astContext(domain);
VariableStack variableStack; VariableStack variableStack;
auto eitherType = parseEither<ast::PrimitiveTypePointer>(context, astContext, variableStack, p); auto eitherType = parseEither<ast::PrimitiveTypePointer>(context, astContext, variableStack, parsePrimitiveTypeWrapper);
if (!eitherType) if (!eitherType)
throw ParserException(tokenizer.location(), "expected primitive type or “either” expression"); throw ParserException(tokenizer.location(), "expected primitive type or “either” expression");

View File

@ -49,13 +49,12 @@ ast::VariableDeclarations parseVariableDeclarations(Context &context, ast::Domai
continue; continue;
auto parentType = parseType(context, domain); auto parentType = parseType(context, domain);
parentType = ast::deepCopy(parentType);
for (size_t i = inheritanceIndex; i < variableDeclarations.size(); i++) for (size_t i = inheritanceIndex; i < variableDeclarations.size(); i++)
variableDeclarations[i]->type = ast::deepCopy(parentType); variableDeclarations[i]->type = ast::deepCopy(parentType);
// All types up to now are labeled with their parent types // All types up to now are labeled with their parent types
inheritanceIndex = variableDeclarations.size() + 1; inheritanceIndex = variableDeclarations.size();
tokenizer.skipWhiteSpace(); tokenizer.skipWhiteSpace();
} }

View File

@ -7,13 +7,14 @@
namespace fs = std::experimental::filesystem; namespace fs = std::experimental::filesystem;
const pddl::Context::WarningCallback ignoreWarnings = [](const auto &, const auto &){};
const auto pddlInstanceBasePath = fs::path("data") / "pddl-instances";
//////////////////////////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////////////////////////
TEST_CASE("[PDDL parser acceptance] All the IPC domains are parsed without errors", "[PDDL parser acceptance]") TEST_CASE("[PDDL parser acceptance] All official PDDL domains are parsed without errors", "[PDDL parser acceptance]")
{ {
const pddl::Context::WarningCallback ignoreWarnings = [](const auto &, const auto &){}; for (const auto &competitionDirectory : fs::directory_iterator(pddlInstanceBasePath))
for (const auto &competitionDirectory : fs::directory_iterator("data/pddl-instances"))
{ {
if (!fs::is_directory(competitionDirectory)) if (!fs::is_directory(competitionDirectory))
continue; continue;
@ -36,11 +37,9 @@ TEST_CASE("[PDDL parser acceptance] All the IPC domains are parsed without error
//////////////////////////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////////////////////////
TEST_CASE("[PDDL parser acceptance] The first instance of every IPC domain is parsed without errors", "[PDDL parser acceptance]") TEST_CASE("[PDDL parser acceptance] The first instance for all official PDDL domains is parsed without errors", "[PDDL parser acceptance]")
{ {
const pddl::Context::WarningCallback ignoreWarnings = [](const auto &, const auto &){}; for (const auto &competitionDirectory : fs::directory_iterator(pddlInstanceBasePath))
for (const auto &competitionDirectory : fs::directory_iterator("data/pddl-instances"))
{ {
if (!fs::is_directory(competitionDirectory)) if (!fs::is_directory(competitionDirectory))
continue; continue;

View File

@ -0,0 +1,40 @@
#include <catch.hpp>
#include <experimental/filesystem>
#include <pddlparse/AST.h>
#include <pddlparse/Parse.h>
namespace fs = std::experimental::filesystem;
const pddl::Context::WarningCallback ignoreWarnings = [](const auto &, const auto &){};
const auto pddlInstanceBasePath = fs::path("data") / "pddl-instances";
////////////////////////////////////////////////////////////////////////////////////////////////////
TEST_CASE("[PDDL parser] The official PDDL instances are parsed correctly", "[PDDL parser]")
{
std::cout << std::endl;
pddl::Tokenizer tokenizer;
pddl::Context context(std::move(tokenizer), ignoreWarnings);
SECTION("“either” type in zenotravel domain")
{
const auto domainFile = pddlInstanceBasePath / "ipc-2002" / "domains" / "zenotravel-numeric-hand-coded" / "domain.pddl";
context.tokenizer.read(domainFile);
auto description = pddl::parseDescription(context);
const auto &predicates = description.domain->predicates;
REQUIRE(predicates.size() == 2);
REQUIRE(predicates[0]->name == "at");
REQUIRE(predicates[0]->parameters.size() == 2);
REQUIRE(predicates[0]->parameters[0]->name == "x");
REQUIRE(predicates[0]->parameters[0]->type);
CHECK(predicates[0]->parameters[0]->type.value().is<pddl::ast::EitherPointer<pddl::ast::PrimitiveTypePointer>>());
REQUIRE(predicates[0]->parameters[1]->name == "c");
REQUIRE(predicates[0]->parameters[1]->type);
CHECK(predicates[0]->parameters[1]->type.value().is<pddl::ast::PrimitiveTypePointer>());
}
}