|
|
@@ -68,6 +68,7 @@ func New(l *lexer.Lexer) *Parser {
|
|
|
p.registerPrefix(token.MINUS, p.parsePrefixExpression)
|
|
|
p.registerPrefix(token.TRUE, p.parseBoolean)
|
|
|
p.registerPrefix(token.FALSE, p.parseBoolean)
|
|
|
+ p.registerPrefix(token.LPAREN, p.parseGroupedExpression)
|
|
|
|
|
|
p.infixParseFns = make(map[token.TypeToken]infixParseFn)
|
|
|
p.registerInfix(token.PLUS, p.parseInfixExpression)
|
|
|
@@ -93,6 +94,18 @@ func (p *Parser) parseIdentifier() ast.Expression {
|
|
|
func (p *Parser) parseBoolean() ast.Expression {
|
|
|
return &ast.Boolean{Token: p.curToken, Value: p.curTokenIs(token.TRUE)}
|
|
|
}
|
|
|
+func (p *Parser) parseGroupedExpression() ast.Expression {
|
|
|
+ defer untrace(trace("parseGroupedExpression"))
|
|
|
+ p.nextToken()
|
|
|
+
|
|
|
+ exp := p.parseExpression(LOWEST)
|
|
|
+
|
|
|
+ if !p.expectPeek(token.RPAREN) {
|
|
|
+ return nil
|
|
|
+ }
|
|
|
+
|
|
|
+ return exp
|
|
|
+}
|
|
|
func (p *Parser) parseIntegerLiteral() ast.Expression {
|
|
|
defer untrace(trace("parseIntegerLiteral"))
|
|
|
|