zig

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

commit 1bca158c6e0a4f301cef18db705d89de78c86bcb (tree)
parent 6bf5b7f2b40be1a92c66fed05e53815b3ab07733
Author: GasInfinity <me@gasinfinity.dev>
Date:   Sat, 18 Oct 2025 19:23:19 +0200

fix(std): don't add the default `_start` and `panic` in homebrew targets

* even if std supported those targets, they're not posixy to be in that codepath.

Diffstat:
Mlib/std/debug.zig | 2+-
Mlib/std/start.zig | 5+++--
2 files changed, 4 insertions(+), 3 deletions(-)

diff --git a/lib/std/debug.zig b/lib/std/debug.zig @@ -481,7 +481,7 @@ pub fn defaultPanic( if (use_trap_panic) @trap(); switch (builtin.os.tag) { - .freestanding, .other => { + .freestanding, .other, .@"3ds", .vita => { @trap(); }, .uefi => { diff --git a/lib/std/start.zig b/lib/std/start.zig @@ -91,8 +91,9 @@ comptime { // Only call main when defined. For WebAssembly it's allowed to pass `-fno-entry` in which // case it's not required to provide an entrypoint such as main. if (!@hasDecl(root, start_sym_name) and @hasDecl(root, "main")) @export(&wasm_freestanding_start, .{ .name = start_sym_name }); - } else if (native_os != .other and native_os != .freestanding) { - if (!@hasDecl(root, start_sym_name)) @export(&_start, .{ .name = start_sym_name }); + } else switch (native_os) { + .other, .freestanding, .@"3ds", .vita => {}, + else => if (!@hasDecl(root, start_sym_name)) @export(&_start, .{ .name = start_sym_name }), } } }