diff options
| author | Taylan Kammer <taylan.kammer@gmail.com> | 2026-05-31 17:35:35 +0200 |
|---|---|---|
| committer | Taylan Kammer <taylan.kammer@gmail.com> | 2026-05-31 17:35:35 +0200 |
| commit | a6040abeac8cdcba8a139a9d5b52ce28e94a14ef (patch) | |
| tree | f912bad73ae644b9f3c9042b95e2ea1aea09df7a /src | |
| parent | a779b91e730ba68c1f38cfdadbcb0fa3de041597 (diff) | |
Allow blanks after hash-bang; update grammar files.
Diffstat (limited to 'src')
| -rw-r--r-- | src/zisp/io/Parser.zig | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/src/zisp/io/Parser.zig b/src/zisp/io/Parser.zig index a57652b..8e2908d 100644 --- a/src/zisp/io/Parser.zig +++ b/src/zisp/io/Parser.zig @@ -156,7 +156,7 @@ fn readNoEof(p: *Parser, comptime emsg: []const u8) !u8 { return try p.read() orelse p.err(.UnexpectedEof, emsg); } -// Fake optional, for use in: while (readToEof()) |c| { } +// Fake optional, for use in: while (readNoEof2()) |c| { } fn readNoEof2(p: *Parser, comptime emsg: []const u8) !?u8 { return try p.read() orelse p.err(.UnexpectedEof, emsg); } @@ -620,9 +620,11 @@ fn endRuneDatum(p: *Parser) !void { } fn parseHashBang(p: *Parser, next: Fn) !void { - const c = try p.readNoEof("hash-bang"); - const s = try p.getBareString(c); - return p.jump(next, p.cons(SHBANG, s)); + while (try p.readNoEof2("hash-bang")) |c| { + if (c == ' ' or c == '\t') continue; + const s = try p.getBareString(c); + return p.jump(next, p.cons(SHBANG, s)); + } } fn parseLabel(p: *Parser, next: Fn) !void { |
