From 65d7ae71c822fd4adcd098c4c1f7753fa28e34d3 Mon Sep 17 00:00:00 2001 From: Baitinq Date: Mon, 19 May 2025 23:12:24 +0200 Subject: Feature: Add support for != --- src/parser.zig | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) (limited to 'src/parser.zig') diff --git a/src/parser.zig b/src/parser.zig index 6e07491..510726f 100644 --- a/src/parser.zig +++ b/src/parser.zig @@ -99,6 +99,7 @@ pub const Node = union(enum) { pub const EqualityExpressionType = enum { EQ, + NE, GE, LE, LT, @@ -409,7 +410,7 @@ pub const Parser = struct { return ParserError.ParsingError; } - // EqualityExpression ::= AdditiveExpression ("==" | "<=" | ">=" | "<" | ">") AdditiveExpression + // EqualityExpression ::= AdditiveExpression ("==" | "!=" | "<=" | ">=" | "<" | ">") AdditiveExpression fn parse_equality_expression(self: *Parser) ParserError!*Node { errdefer if (!self.try_context) std.debug.print("Error parsing equality expression {any}\n", .{self.peek_token()}); @@ -427,6 +428,16 @@ pub const Parser = struct { } }.parse) != null) { typ = .EQ; + } else if (self.accept_parse(struct { + fn parse(iself: *Parser) ParserError!*Node { + _ = try iself.parse_token(tokenizer.TokenType.BANG); + _ = try iself.parse_token(tokenizer.TokenType.EQUALS); + return try iself.create_node(.{ .PROGRAM = .{ + .statements = &[_]*Node{}, + } }); + } + }.parse) != null) { + typ = .NE; } else if (self.accept_parse(struct { fn parse(iself: *Parser) ParserError!*Node { _ = try iself.parse_token(tokenizer.TokenType.LESS); -- cgit 1.4.1