diff options
| author | 2022-11-25 19:39:40 -0800 | |
|---|---|---|
| committer | 2022-11-25 19:39:40 -0800 | |
| commit | d0dbafb32fa0e50b9bcc5a55a2a5616ff67ccecf (patch) | |
| tree | 32062a192bcb7428cb7ae9a7aeb93e127238442b | |
| parent | b5bd98c0ef72da0bef35d2f13392aa65063dbd19 (diff) | |
| download | bun-d0dbafb32fa0e50b9bcc5a55a2a5616ff67ccecf.tar.gz bun-d0dbafb32fa0e50b9bcc5a55a2a5616ff67ccecf.tar.zst bun-d0dbafb32fa0e50b9bcc5a55a2a5616ff67ccecf.zip | |
Fix `Subprocess.prototype.killed`
| -rw-r--r-- | src/bun.js/api/bun/subprocess.zig | 22 | 
1 files changed, 18 insertions, 4 deletions
| diff --git a/src/bun.js/api/bun/subprocess.zig b/src/bun.js/api/bun/subprocess.zig index 43cb5cbd9..1b9682410 100644 --- a/src/bun.js/api/bun/subprocess.zig +++ b/src/bun.js/api/bun/subprocess.zig @@ -267,10 +267,15 @@ pub const Subprocess = struct {          return JSValue.jsUndefined();      } +    pub fn hasKilled(this: *const Subprocess) bool { +        return this.killed or this.hasExited(); +    } +      pub fn tryKill(this: *Subprocess, sig: i32) JSC.Node.Maybe(void) { -        if (this.killed) { +        if (this.hasKilled()) {              return .{ .result = {} };          } +        this.killed = true;          if (comptime Environment.isLinux) {              // should this be handled differently? @@ -283,12 +288,21 @@ pub const Subprocess = struct {              const rc = std.os.linux.pidfd_send_signal(this.pidfd, @intCast(u8, sig), null, 0);              if (rc != 0) { -                return .{ .err = JSC.Node.Syscall.Error.fromCode(std.os.linux.getErrno(rc), .kill) }; +                const errno = std.os.linux.getErrno(rc); +                // if the process was already killed don't throw +                if (errno == .SRCH) return .{ .result = {} }; + +                return .{ .err = JSC.Node.Syscall.Error.fromCode(errno, .kill) };              }          } else {              const err = std.c.kill(this.pid, sig);              if (err != 0) { -                return .{ .err = JSC.Node.Syscall.Error.fromCode(std.c.getErrno(err), .kill) }; +                const errno = std.c.getErrno(err); + +                // if the process was already killed don't throw +                if (errno == .SRCH) return .{ .result = {} }; + +                return .{ .err = JSC.Node.Syscall.Error.fromCode(errno, .kill) };              }          } @@ -334,7 +348,7 @@ pub const Subprocess = struct {          this: *Subprocess,          _: *JSGlobalObject,      ) callconv(.C) JSValue { -        return JSValue.jsBoolean(this.killed); +        return JSValue.jsBoolean(this.hasKilled());      }      pub const BufferedInput = struct { | 
