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:
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 }),
}
}
}