summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorTaylan Kammer <taylan.kammer@gmail.com>2026-05-31 17:35:35 +0200
committerTaylan Kammer <taylan.kammer@gmail.com>2026-05-31 17:35:35 +0200
commita6040abeac8cdcba8a139a9d5b52ce28e94a14ef (patch)
treef912bad73ae644b9f3c9042b95e2ea1aea09df7a /src
parenta779b91e730ba68c1f38cfdadbcb0fa3de041597 (diff)
Allow blanks after hash-bang; update grammar files.
Diffstat (limited to 'src')
-rw-r--r--src/zisp/io/Parser.zig10
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 {