From ef55dcae675dd2048e5e404eb8bb6833d153f653 Mon Sep 17 00:00:00 2001 From: Andrew Kelley Date: Mon, 27 Oct 2025 14:57:01 -0700 Subject: [PATCH] start: fix logic for signal hanlding when SIG.POLL does not exist fixes a compilation failure on FreeBSD --- lib/std/start.zig | 16 +++++++++++++--- 1 file changed, 13 insertions(+), 3 deletions(-) diff --git a/lib/std/start.zig b/lib/std/start.zig index 09c1f3b5c4..20dd981707 100644 --- a/lib/std/start.zig +++ b/lib/std/start.zig @@ -784,9 +784,19 @@ fn maybeIgnoreSignals() void { .mask = posix.sigemptyset(), .flags = 0, }; - if (!std.options.keep_sigpoll) posix.sigaction(posix.SIG.POLL, &act, null); - if (@hasField(posix.SIG, "IO") and posix.SIG.IO != posix.SIG.POLL and !std.options.keep_sigio) posix.sigaction(posix.SIG.IO, &act, null); - if (!std.options.keep_sigpipe) posix.sigaction(posix.SIG.PIPE, &act, null); + + if (@hasField(posix.SIG, "POLL") and !std.options.keep_sigpoll) + posix.sigaction(posix.SIG.POLL, &act, null); + + if (@hasField(posix.SIG, "IO") and + (!@hasField(posix.SIG, "POLL") or posix.SIG.IO != posix.SIG.POLL) and + !std.options.keep_sigio) + { + posix.sigaction(posix.SIG.IO, &act, null); + } + + if (@hasField(posix.SIG, "PIPE") and !std.options.keep_sigpipe) + posix.sigaction(posix.SIG.PIPE, &act, null); } fn noopSigHandler(_: i32) callconv(.c) void {}