aboutsummaryrefslogtreecommitdiff
path: root/src/bun.js
diff options
context:
space:
mode:
authorGravatar Ai Hoshino <ambiguous404@gmail.com> 2023-08-28 14:58:31 +0800
committerGravatar GitHub <noreply@github.com> 2023-08-27 23:58:31 -0700
commitefe987e8d12e824dde840b56cbb704feabe26ed1 (patch)
treea01daf0092aca085cafcd6a4a6d95d9ad7b2e7fe /src/bun.js
parented5dc5bbf922777acd3f637125a1978b6f2c391a (diff)
downloadbun-efe987e8d12e824dde840b56cbb704feabe26ed1.tar.gz
bun-efe987e8d12e824dde840b56cbb704feabe26ed1.tar.zst
bun-efe987e8d12e824dde840b56cbb704feabe26ed1.zip
Fix some edge cases in the `env` param of `spawn`. (#4364)
Close: #4362
Diffstat (limited to 'src/bun.js')
-rw-r--r--src/bun.js/api/bun/subprocess.zig16
1 files changed, 8 insertions, 8 deletions
diff --git a/src/bun.js/api/bun/subprocess.zig b/src/bun.js/api/bun/subprocess.zig
index 6cd6d9016..f2e33cf78 100644
--- a/src/bun.js/api/bun/subprocess.zig
+++ b/src/bun.js/api/bun/subprocess.zig
@@ -1041,6 +1041,7 @@ pub const Subprocess = struct {
var env: [*:null]?[*:0]const u8 = undefined;
+ var override_env = false;
var env_array = std.ArrayListUnmanaged(?[*:0]const u8){
.items = &.{},
.capacity = 0,
@@ -1168,6 +1169,7 @@ pub const Subprocess = struct {
return .zero;
}
+ override_env = true;
var object_iter = JSC.JSPropertyIterator(.{
.skip_empty_name = false,
.include_value = true,
@@ -1257,7 +1259,7 @@ pub const Subprocess = struct {
}
defer actions.deinit();
- if (env_array.items.len == 0) {
+ if (!override_env and env_array.items.len == 0) {
env_array.items = jsc_vm.bundler.env.map.createNullDelimitedEnvMap(allocator) catch |err| return globalThis.handleError(err, "in posix_spawn");
env_array.capacity = env_array.items.len;
}
@@ -1302,13 +1304,11 @@ pub const Subprocess = struct {
return .zero;
};
- if (env_array.items.len > 0) {
- env_array.append(allocator, null) catch {
- globalThis.throw("out of memory", .{});
- return .zero;
- };
- env = @as(@TypeOf(env), @ptrCast(env_array.items.ptr));
- }
+ env_array.append(allocator, null) catch {
+ globalThis.throw("out of memory", .{});
+ return .zero;
+ };
+ env = @as(@TypeOf(env), @ptrCast(env_array.items.ptr));
const pid = brk: {
defer {