diff --git a/lib/std/zig/parse.zig b/lib/std/zig/parse.zig index 5e745dd424..d36bf55ecd 100644 --- a/lib/std/zig/parse.zig +++ b/lib/std/zig/parse.zig @@ -2701,11 +2701,17 @@ const Parser = struct { return &node.base; } - if (p.token_ids[p.tok_i] == .Invalid_periodasterisks) { + if (p.eatToken(.Invalid_periodasterisks)) |period_asterisk| { try p.errors.append(p.gpa, .{ - .AsteriskAfterPointerDereference = .{ .token = p.tok_i }, + .AsteriskAfterPointerDereference = .{ .token = period_asterisk }, }); - return null; + const node = try p.arena.allocator.create(Node.SimpleSuffixOp); + node.* = .{ + .base = .{ .tag = .Deref }, + .lhs = lhs, + .rtoken = period_asterisk, + }; + return &node.base; } if (p.eatToken(.Period)) |period| { diff --git a/lib/std/zig/parser_test.zig b/lib/std/zig/parser_test.zig index 9495f536d1..71642da453 100644 --- a/lib/std/zig/parser_test.zig +++ b/lib/std/zig/parser_test.zig @@ -226,7 +226,14 @@ test "recovery: invalid asterisk after pointer dereference" { \\} , &[_]Error{ .AsteriskAfterPointerDereference, - .ExpectedToken, + }); + try testError( + \\test "" { + \\ var sequence = "repeat".** 10&&a; + \\} + , &[_]Error{ + .AsteriskAfterPointerDereference, + .InvalidAnd, }); }