Implemented recognition of comments in PDDL.
This commit is contained in:
parent
168fcc874e
commit
9f0e784a4a
@ -15,12 +15,8 @@ namespace plasp
|
|||||||
|
|
||||||
Language::Type detectLanguage(utils::Parser &parser)
|
Language::Type detectLanguage(utils::Parser &parser)
|
||||||
{
|
{
|
||||||
// PDDL contains sections starting with "(define"
|
parser.setCaseSensitive(false);
|
||||||
if (parser.probe<std::string>("(") && parser.probe<std::string>("define"))
|
parser.skipWhiteSpace();
|
||||||
{
|
|
||||||
parser.seek(std::ios::beg);
|
|
||||||
return Language::Type::PDDL;
|
|
||||||
}
|
|
||||||
|
|
||||||
// SAS begins with "begin_version"
|
// SAS begins with "begin_version"
|
||||||
if (parser.probe<std::string>("begin"))
|
if (parser.probe<std::string>("begin"))
|
||||||
@ -29,6 +25,20 @@ Language::Type detectLanguage(utils::Parser &parser)
|
|||||||
return Language::Type::SAS;
|
return Language::Type::SAS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Skip potential PDDL comments
|
||||||
|
while (parser.currentCharacter() == ';')
|
||||||
|
{
|
||||||
|
parser.skipLine();
|
||||||
|
parser.skipWhiteSpace();
|
||||||
|
}
|
||||||
|
|
||||||
|
// PDDL contains sections starting with "(define"
|
||||||
|
if (parser.probe<std::string>("(") && parser.probe<std::string>("define"))
|
||||||
|
{
|
||||||
|
parser.seek(std::ios::beg);
|
||||||
|
return Language::Type::PDDL;
|
||||||
|
}
|
||||||
|
|
||||||
parser.seek(std::ios::beg);
|
parser.seek(std::ios::beg);
|
||||||
return Language::Type::Unknown;
|
return Language::Type::Unknown;
|
||||||
}
|
}
|
||||||
|
@ -62,6 +62,8 @@ class Parser
|
|||||||
void advance();
|
void advance();
|
||||||
bool atEndOfStream() const;
|
bool atEndOfStream() const;
|
||||||
|
|
||||||
|
void removeComments(const std::string &startSequence, const std::string &endSequence, bool removeEnd);
|
||||||
|
|
||||||
template<typename Type>
|
template<typename Type>
|
||||||
Type parse();
|
Type parse();
|
||||||
|
|
||||||
|
@ -26,17 +26,17 @@ Description::Description()
|
|||||||
m_problemPosition{-1},
|
m_problemPosition{-1},
|
||||||
m_problem{std::make_unique<Problem>(Problem(m_context, *m_domain))}
|
m_problem{std::make_unique<Problem>(Problem(m_context, *m_domain))}
|
||||||
{
|
{
|
||||||
m_parser.setCaseSensitive(false);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
Description Description::fromParser(utils::Parser &&parser)
|
Description Description::fromParser(utils::Parser &&parser)
|
||||||
{
|
{
|
||||||
parser.setCaseSensitive(false);
|
|
||||||
|
|
||||||
Description description;
|
Description description;
|
||||||
|
|
||||||
|
parser.setCaseSensitive(false);
|
||||||
|
parser.removeComments(";", "\n", false);
|
||||||
|
|
||||||
description.m_parser = std::move(parser);
|
description.m_parser = std::move(parser);
|
||||||
|
|
||||||
description.parseContent();
|
description.parseContent();
|
||||||
@ -53,6 +53,9 @@ Description Description::fromStream(std::istream &istream)
|
|||||||
|
|
||||||
description.m_parser.readStream("std::cin", istream);
|
description.m_parser.readStream("std::cin", istream);
|
||||||
|
|
||||||
|
description.m_parser.setCaseSensitive(false);
|
||||||
|
description.m_parser.removeComments(";", "\n", false);
|
||||||
|
|
||||||
description.parseContent();
|
description.parseContent();
|
||||||
description.checkConsistency();
|
description.checkConsistency();
|
||||||
|
|
||||||
@ -67,6 +70,9 @@ Description Description::fromFile(const std::string &path)
|
|||||||
|
|
||||||
description.m_parser.readFile(path);
|
description.m_parser.readFile(path);
|
||||||
|
|
||||||
|
description.m_parser.setCaseSensitive(false);
|
||||||
|
description.m_parser.removeComments(";", "\n", false);
|
||||||
|
|
||||||
description.parseContent();
|
description.parseContent();
|
||||||
description.checkConsistency();
|
description.checkConsistency();
|
||||||
|
|
||||||
@ -87,6 +93,9 @@ Description Description::fromFiles(const std::vector<std::string> &paths)
|
|||||||
description.m_parser.readFile(path);
|
description.m_parser.readFile(path);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
description.m_parser.setCaseSensitive(false);
|
||||||
|
description.m_parser.removeComments(";", "\n", false);
|
||||||
|
|
||||||
description.parseContent();
|
description.parseContent();
|
||||||
description.checkConsistency();
|
description.checkConsistency();
|
||||||
|
|
||||||
|
@ -276,11 +276,10 @@ std::string Parser::parse<std::string>()
|
|||||||
template<>
|
template<>
|
||||||
bool Parser::probe<std::string>(const std::string &expectedValue)
|
bool Parser::probe<std::string>(const std::string &expectedValue)
|
||||||
{
|
{
|
||||||
BOOST_ASSERT(!std::isspace(expectedValue[0]));
|
|
||||||
|
|
||||||
const auto previousPosition = position();
|
const auto previousPosition = position();
|
||||||
|
|
||||||
skipWhiteSpace();
|
if (!std::iswspace(expectedValue.front()))
|
||||||
|
skipWhiteSpace();
|
||||||
|
|
||||||
const auto match = std::find_if(expectedValue.cbegin(), expectedValue.cend(),
|
const auto match = std::find_if(expectedValue.cbegin(), expectedValue.cend(),
|
||||||
[&](const auto &expectedCharacter)
|
[&](const auto &expectedCharacter)
|
||||||
@ -529,5 +528,75 @@ void Parser::expect<bool>(const bool &expectedValue)
|
|||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
void Parser::removeComments(const std::string &startSequence, const std::string &endSequence, bool removeEnd)
|
||||||
|
{
|
||||||
|
const auto inPosition = m_stream.tellg();
|
||||||
|
const auto outPosition = m_stream.tellp();
|
||||||
|
|
||||||
|
m_stream.seekg(0);
|
||||||
|
|
||||||
|
const auto removeRange =
|
||||||
|
[&](const auto &start, const auto &end)
|
||||||
|
{
|
||||||
|
BOOST_ASSERT(start != -1);
|
||||||
|
|
||||||
|
m_stream.clear();
|
||||||
|
m_stream.seekp(start);
|
||||||
|
m_stream.seekg(start);
|
||||||
|
|
||||||
|
auto position = start;
|
||||||
|
|
||||||
|
while (end == -1 || position < end)
|
||||||
|
{
|
||||||
|
m_stream.ignore(1);
|
||||||
|
|
||||||
|
if (atEndOfStream())
|
||||||
|
return;
|
||||||
|
|
||||||
|
m_stream.put(' ');
|
||||||
|
position += static_cast<std::streamoff>(1);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
while (!atEndOfStream())
|
||||||
|
{
|
||||||
|
Position startPosition = m_stream.tellg();
|
||||||
|
|
||||||
|
while (!atEndOfStream())
|
||||||
|
{
|
||||||
|
startPosition = m_stream.tellg();
|
||||||
|
|
||||||
|
if (probe(startSequence))
|
||||||
|
break;
|
||||||
|
|
||||||
|
advance();
|
||||||
|
}
|
||||||
|
|
||||||
|
Position endPosition = m_stream.tellg();
|
||||||
|
|
||||||
|
while (!atEndOfStream())
|
||||||
|
{
|
||||||
|
endPosition = m_stream.tellg();
|
||||||
|
|
||||||
|
if (probe(endSequence))
|
||||||
|
break;
|
||||||
|
|
||||||
|
advance();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (removeEnd)
|
||||||
|
endPosition = m_stream.tellg();
|
||||||
|
|
||||||
|
removeRange(startPosition, endPosition);
|
||||||
|
}
|
||||||
|
|
||||||
|
m_stream.clear();
|
||||||
|
|
||||||
|
m_stream.seekg(inPosition);
|
||||||
|
m_stream.seekp(outPosition);
|
||||||
|
}
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -177,6 +177,57 @@ TEST(UtilsTests, ParserPosition)
|
|||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
TEST(UtilsTests, ParserRemoveComments)
|
||||||
|
{
|
||||||
|
std::stringstream s1("; comment at beginning\ntest1; comment in between\ntest2; comment at end");
|
||||||
|
plasp::utils::Parser p1("input", s1);
|
||||||
|
|
||||||
|
p1.removeComments(";", "\n", false);
|
||||||
|
|
||||||
|
plasp::utils::Parser::Coordinate c;
|
||||||
|
|
||||||
|
ASSERT_NO_THROW(p1.expect<std::string>("test1"));
|
||||||
|
|
||||||
|
c = p1.coordinate();
|
||||||
|
ASSERT_EQ(c.row, 2u);
|
||||||
|
ASSERT_EQ(c.column, 6u);
|
||||||
|
|
||||||
|
ASSERT_NO_THROW(p1.expect<std::string>("test2"));
|
||||||
|
|
||||||
|
c = p1.coordinate();
|
||||||
|
ASSERT_EQ(c.row, 3u);
|
||||||
|
ASSERT_EQ(c.column, 6u);
|
||||||
|
|
||||||
|
p1.skipWhiteSpace();
|
||||||
|
|
||||||
|
ASSERT_TRUE(p1.atEndOfStream());
|
||||||
|
|
||||||
|
std::stringstream s2("test;");
|
||||||
|
plasp::utils::Parser p2("input", s2);
|
||||||
|
|
||||||
|
p2.removeComments(";", "\n", false);
|
||||||
|
|
||||||
|
ASSERT_NO_THROW(p2.expect<std::string>("test"));
|
||||||
|
|
||||||
|
p2.skipWhiteSpace();
|
||||||
|
|
||||||
|
ASSERT_TRUE(p2.atEndOfStream());
|
||||||
|
|
||||||
|
std::stringstream s3("/* comment at start */ test1 /* comment in between */ test2 /*");
|
||||||
|
plasp::utils::Parser p3("input", s3);
|
||||||
|
|
||||||
|
p3.removeComments("/*", "*/", true);
|
||||||
|
|
||||||
|
ASSERT_NO_THROW(p3.expect<std::string>("test1"));
|
||||||
|
ASSERT_NO_THROW(p3.expect<std::string>("test2"));
|
||||||
|
|
||||||
|
p3.skipWhiteSpace();
|
||||||
|
|
||||||
|
ASSERT_TRUE(p3.atEndOfStream());
|
||||||
|
}
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
TEST(UtilsTests, EscapeASP)
|
TEST(UtilsTests, EscapeASP)
|
||||||
{
|
{
|
||||||
const std::string predicate = "action(stack_on(block-1, block-2, value@3, value@4))";
|
const std::string predicate = "action(stack_on(block-1, block-2, value@3, value@4))";
|
||||||
|
Reference in New Issue
Block a user