Removed left and rightmost character from variables/terminals
This commit is contained in:
parent
0983467774
commit
d609b69eb4
|
@ -8,7 +8,6 @@ namespace pds {
|
|||
const char* InputParserException::what() const throw() {
|
||||
return m_what.c_str();
|
||||
}
|
||||
|
||||
Config InputParser::parseInput(std::istream& is) {
|
||||
ParsodusLexer lex(is);
|
||||
Config config;
|
||||
|
@ -16,6 +15,7 @@ namespace pds {
|
|||
|
||||
bool readingTerminals = false;
|
||||
bool readingGrammar = false;
|
||||
bool readingPrecedences = false;
|
||||
|
||||
try {
|
||||
while(true) {
|
||||
|
@ -51,9 +51,15 @@ namespace pds {
|
|||
lexColon(lex, token, false);
|
||||
readingGrammar = true;
|
||||
break;
|
||||
/**/
|
||||
case ParsodusLexer::PRECEDENCES:
|
||||
lexColon(lex, token, false);
|
||||
readingPrecedences = true;
|
||||
break;
|
||||
/**/
|
||||
case ParsodusLexer::TERMINAL:
|
||||
if(readingTerminals) {
|
||||
config.grammar.terminals.insert(token.content);
|
||||
config.grammar.terminals.insert(token.content.substr(1, token.content.size - 1));
|
||||
} else {
|
||||
throw InputParserException("Found a terminal outside a grammar or terminals section: " + token.content);
|
||||
}
|
||||
|
@ -62,12 +68,12 @@ namespace pds {
|
|||
lexColon(lex, token);
|
||||
if(token.type != ParsodusLexer::VARIABLE)
|
||||
throw InputParserException("Expected to find a start variable, but found: " + token.content);
|
||||
config.grammar.start = token.content;
|
||||
config.grammar.start = token.content.substr(1, token.content.size - 1);
|
||||
break;
|
||||
case ParsodusLexer::VARIABLE:
|
||||
if(readingGrammar) {
|
||||
if(config.grammar.variables.find(token.content) == config.grammar.variables.end())
|
||||
config.grammar.variables.insert(token.content);
|
||||
config.grammar.variables.insert(token.content.substr(1, token.content.size - 1));
|
||||
|
||||
std::string current_head = token.content;
|
||||
// Parsing rule
|
||||
|
@ -79,6 +85,7 @@ namespace pds {
|
|||
bool parsing_head = true;
|
||||
while(parsing_head) {
|
||||
token = lex.nextToken();
|
||||
token.content = token.content.substr(1, token.content.size - 1);
|
||||
switch(token.type) {
|
||||
case ParsodusLexer::VARIABLE:
|
||||
rule->tail.push_back(token.content);
|
||||
|
@ -100,6 +107,38 @@ namespace pds {
|
|||
} else
|
||||
throw InputParserException("Found a variable outside a grammar section: " + token.content);
|
||||
break;
|
||||
/**/
|
||||
case ParsodusLexer::PRECEDENCE:
|
||||
if (readingPrecedences) {
|
||||
|
||||
pds::PrecedenceType precedence_type;
|
||||
switch(token.content) {
|
||||
case "left":
|
||||
precedence_type = pds::PrecedenceType::LEFT;
|
||||
break;
|
||||
case "nonassoc":
|
||||
precedence_type = pds::PrecedenceType::NONASSOC;
|
||||
break;
|
||||
case "right":
|
||||
precedence_type = pds::PrecedenceType::RIGHT;
|
||||
break;
|
||||
}
|
||||
|
||||
int counter = 0;
|
||||
while (true) {
|
||||
token = lex.nextToken();
|
||||
if (token.type == ParsodusLexer::SEMICOLON)
|
||||
break;
|
||||
if (token.type != ParsodusLexer::TERMINAL)
|
||||
throw InputParserException("Expecting to find a terminal, but found '" + token.content + "' instead'");
|
||||
if (config.grammar.precedence.find(token.type) == config.grammar.precedence)
|
||||
throw InputParserException("Found same terminal in multiple precedence rules");
|
||||
config.grammar.precedence.insert(make_pair(token.content.substr(1, token.content.size - 1), make_pair(counter++, precedence_type)));
|
||||
}
|
||||
|
||||
} else
|
||||
throw InputParserException("Found a precedence rule outside a precedence section: " + token.content);
|
||||
/**/
|
||||
default:
|
||||
break;
|
||||
|
||||
|
|
Loading…
Reference in New Issue