From c38ce8cf68cb37ccbced429e76884488275c5332 Mon Sep 17 00:00:00 2001 From: TimQu Date: Fri, 17 Oct 2014 00:21:03 +0200 Subject: [PATCH 1/2] Small fix for autoParser Former-commit-id: f22b6031ce6c281f8d8acae0afe0685084697636 --- src/parser/AutoParser.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/parser/AutoParser.cpp b/src/parser/AutoParser.cpp index 697740a7f..fbcc0b393 100644 --- a/src/parser/AutoParser.cpp +++ b/src/parser/AutoParser.cpp @@ -85,7 +85,7 @@ namespace storm { // Find and read in the hint. std::string formatString = "%" + std::to_string(STORM_PARSER_AUTOPARSER_HINT_LENGTH) + "s"; - char hint[5]; + char hint[STORM_PARSER_AUTOPARSER_HINT_LENGTH + 1]; #ifdef WINDOWS sscanf_s(filehintBuffer, formatString.c_str(), hint, STORM_PARSER_AUTOPARSER_HINT_LENGTH + 1); #else From 484bbf3e83fabf886263d3dc1cebbd85aca482fe Mon Sep 17 00:00:00 2001 From: dehnert Date: Fri, 17 Oct 2014 11:26:14 +0200 Subject: [PATCH 2/2] Atomic propositions in formulas can now also be surrounded by quotation marks (to be compatible with the PRISM syntax). Former-commit-id: e31a8c832ac1019fc2c2488473b8c89f36ed732f --- src/parser/CslParser.cpp | 3 +-- src/parser/LtlParser.cpp | 3 +-- src/parser/PrctlParser.cpp | 3 +-- 3 files changed, 3 insertions(+), 6 deletions(-) diff --git a/src/parser/CslParser.cpp b/src/parser/CslParser.cpp index 4aa8f7d91..b16e441e8 100644 --- a/src/parser/CslParser.cpp +++ b/src/parser/CslParser.cpp @@ -80,8 +80,7 @@ struct CslParser::CslGrammar : qi::grammar> stateFormula >> qi::lit(")")) | (qi::lit("[") >> stateFormula >> qi::lit("]")); atomicStateFormula.name("atomic state formula"); - atomicProposition = (freeIdentifierName)[qi::_val = - MAKE(csl::Ap, qi::_1)]; + atomicProposition = (freeIdentifierName)[qi::_val = MAKE(csl::Ap, qi::_1)] | (qi::lit("\"") > (freeIdentifierName)[qi::_val = MAKE(csl::Ap, qi::_1)] > qi::lit("\"")); atomicProposition.name("atomic proposition"); probabilisticBoundOperator = ( (qi::lit("P") >> comparisonType > qi::double_ > pathFormula )[qi::_val = diff --git a/src/parser/LtlParser.cpp b/src/parser/LtlParser.cpp index 86fff3b03..79059e994 100644 --- a/src/parser/LtlParser.cpp +++ b/src/parser/LtlParser.cpp @@ -88,8 +88,7 @@ struct LtlParser::LtlGrammar : qi::grammar> formula >> qi::lit(")")| qi::lit("[") >> formula >> qi::lit("]"); atomicLtlFormula.name("Atomic LTL formula"); - atomicProposition = (freeIdentifierName)[qi::_val = - MAKE(ltl::Ap, qi::_1)]; + atomicProposition = (freeIdentifierName)[qi::_val = MAKE(ltl::Ap, qi::_1)] | (qi::lit("\"") > (freeIdentifierName)[qi::_val = MAKE(ltl::Ap, qi::_1)] > qi::lit("\"")); atomicProposition.name("Atomic Proposition"); //This block defines rules for parsing probabilistic path formulas diff --git a/src/parser/PrctlParser.cpp b/src/parser/PrctlParser.cpp index d2e6f06fa..d12fba12b 100644 --- a/src/parser/PrctlParser.cpp +++ b/src/parser/PrctlParser.cpp @@ -76,8 +76,7 @@ struct PrctlParser::PrctlGrammar : qi::grammar> stateFormula >> qi::lit(")") | qi::lit("[") >> stateFormula >> qi::lit("]"); atomicStateFormula.name("atomic state formula"); - atomicProposition = (freeIdentifierName)[qi::_val = - MAKE(prctl::Ap, qi::_1)]; + atomicProposition = (freeIdentifierName)[qi::_val = MAKE(prctl::Ap, qi::_1)] | (qi::lit("\"") > (freeIdentifierName)[qi::_val = MAKE(prctl::Ap, qi::_1)] > qi::lit("\"")); atomicProposition.name("atomic proposition"); probabilisticBoundOperator = ((qi::lit("P") >> comparisonType > qi::double_ > pathFormula)[qi::_val = MAKE(prctl::ProbabilisticBoundOperator, qi::_1, qi::_2, qi::_3)]);