zig

fork of https://codeberg.org/ziglang/zig
Log | Files | Refs | README | LICENSE

commit aebccb06e774107d18c4259eafbf5eb3c642237a (tree)
parent 1a4c5837fedcad57f6c81301672e6246e0f0a8c1
Author: Andrew Kelley <andrew@ziglang.org>
Date:   Mon, 23 Dec 2024 18:29:16 -0800

fix missing missing entry symbol error when no zcu

Diffstat:
Msrc/link/Wasm/Flush.zig | 16++++++++--------
1 file changed, 8 insertions(+), 8 deletions(-)

diff --git a/src/link/Wasm/Flush.zig b/src/link/Wasm/Flush.zig @@ -69,6 +69,8 @@ pub fn finish(f: *Flush, wasm: *Wasm) !void { const is_obj = comp.config.output_mode == .Obj; const allow_undefined = is_obj or wasm.import_symbols; + const entry_name = if (wasm.entry_resolution.isNavOrUnresolved(wasm)) wasm.entry_name else .none; + if (comp.zcu) |zcu| { const ip: *const InternPool = &zcu.intern_pool; // No mutations allowed! @@ -88,8 +90,6 @@ pub fn finish(f: *Flush, wasm: *Wasm) !void { } } - const entry_name = if (wasm.entry_resolution.isNavOrUnresolved(wasm)) wasm.entry_name else .none; - for (wasm.nav_exports.keys()) |*nav_export| { if (ip.isFunctionType(ip.getNav(nav_export.nav_index).typeOf(ip))) { log.debug("flush export '{s}' nav={d}", .{ nav_export.name.slice(wasm), nav_export.nav_index }); @@ -115,13 +115,13 @@ pub fn finish(f: *Flush, wasm: *Wasm) !void { for (f.missing_exports.keys()) |exp_name| { diags.addError("manually specified export name '{s}' undefined", .{exp_name.slice(wasm)}); } + } - if (entry_name.unwrap()) |name| { - if (wasm.entry_resolution == .unresolved) { - var err = try diags.addErrorWithNotes(1); - try err.addMsg("entry symbol '{s}' missing", .{name.slice(wasm)}); - err.addNote("'-fno-entry' suppresses this error", .{}); - } + if (entry_name.unwrap()) |name| { + if (wasm.entry_resolution == .unresolved) { + var err = try diags.addErrorWithNotes(1); + try err.addMsg("entry symbol '{s}' missing", .{name.slice(wasm)}); + err.addNote("'-fno-entry' suppresses this error", .{}); } }