Basic expression parsing
This commit is contained in:
@@ -1,24 +1,61 @@
|
||||
#include "Parser.h"
|
||||
|
||||
Parser::Parser(std::vector<Token> tokens) : tokens(tokens) {
|
||||
Parser::Parser(vector<Token> tokens): tokens(tokens) {
|
||||
}
|
||||
|
||||
/*Expression Parser::getExpression() {
|
||||
shared_ptr<Expression> Parser::getExpression() {
|
||||
return term();
|
||||
}*/
|
||||
}
|
||||
|
||||
/*Expression Parser::term() {
|
||||
shared_ptr<Expression> Parser::term() {
|
||||
shared_ptr<Expression> expression = factor();
|
||||
|
||||
}*/
|
||||
while (tokens.at(currentIndex).isOneOf({Token::Kind::PLUS, Token::Kind::MINUS})) {
|
||||
expression = matchBinary(expression);
|
||||
}
|
||||
|
||||
/*Expression Parser::primary() {
|
||||
return expression;
|
||||
}
|
||||
|
||||
}*/
|
||||
shared_ptr<Expression> Parser::factor() {
|
||||
shared_ptr<Expression> expression = primary();
|
||||
|
||||
Expression Parser::matchInteger() {
|
||||
//Token token = tokens.at(currentIndex);
|
||||
//if (token.getKind() == Token::Kind::INTEGER)
|
||||
// ExpressionInteger(token);
|
||||
while (tokens.at(currentIndex).isOneOf({Token::Kind::STAR, Token::Kind::SLASH, Token::Kind::PERCENT})) {
|
||||
expression = matchBinary(expression);
|
||||
}
|
||||
|
||||
return expression;
|
||||
}
|
||||
|
||||
shared_ptr<Expression> Parser::primary() {
|
||||
shared_ptr<Expression> expression = Expression::Invalid;
|
||||
|
||||
do {
|
||||
if((expression = matchInteger()) != Expression::Invalid)
|
||||
break;
|
||||
|
||||
} while(false);
|
||||
|
||||
return expression;
|
||||
}
|
||||
|
||||
shared_ptr<Expression> Parser::matchInteger() {
|
||||
Token token = tokens.at(currentIndex);
|
||||
if (token.getKind() == Token::Kind::INTEGER) {
|
||||
currentIndex++;
|
||||
return make_shared<Expression>(Expression::Kind::LITERAL, token, nullptr, nullptr);
|
||||
}
|
||||
|
||||
return Expression::Invalid;
|
||||
}
|
||||
|
||||
shared_ptr<Expression> Parser::matchBinary(shared_ptr<Expression> left) {
|
||||
Token token = tokens.at(currentIndex);
|
||||
if (token.isOneOf({Token::Kind::PLUS, Token::Kind::MINUS, Token::Kind::STAR, Token::Kind::SLASH, Token::Kind::PERCENT})) {
|
||||
currentIndex++;
|
||||
shared_ptr<Expression> right = factor();
|
||||
return make_shared<Expression>(Expression::Kind::BINARY, token, left, right);
|
||||
}
|
||||
|
||||
return Expression::Invalid;
|
||||
}
|
||||
Reference in New Issue
Block a user