diff options
| author | 2022-07-04 16:34:08 -0700 | |
|---|---|---|
| committer | 2022-07-04 16:34:08 -0700 | |
| commit | abd9d8bcab2eb3bb33c0f1df73e71ecf188ef8f1 (patch) | |
| tree | e3fb482b6ec91ba8d645636d517cbed21459875a | |
| parent | 430532feec153628293e9e509cafe1c7886933c0 (diff) | |
| download | bun-abd9d8bcab2eb3bb33c0f1df73e71ecf188ef8f1.tar.gz bun-abd9d8bcab2eb3bb33c0f1df73e71ecf188ef8f1.tar.zst bun-abd9d8bcab2eb3bb33c0f1df73e71ecf188ef8f1.zip | |
[server] Clean up some of the logic for freeing ReadableStream
| -rw-r--r-- | src/bun.js/api/server.zig | 33 | 
1 files changed, 30 insertions, 3 deletions
| diff --git a/src/bun.js/api/server.zig b/src/bun.js/api/server.zig index 51b5e5715..2419a9e55 100644 --- a/src/bun.js/api/server.zig +++ b/src/bun.js/api/server.zig @@ -567,6 +567,7 @@ fn NewRequestContext(comptime ssl_enabled: bool, comptime debug_mode: bool, comp              _: *JSC.JSGlobalObject,              arguments: []const JSC.JSValue,          ) void { +            ctx.pending_promises_for_abort -|= 1;              if (ctx.aborted) {                  ctx.finalizeForAbort();                  return; @@ -608,6 +609,8 @@ fn NewRequestContext(comptime ssl_enabled: bool, comptime debug_mode: bool, comp              _: *JSC.JSGlobalObject,              arguments: []const JSC.JSValue,          ) void { +            ctx.pending_promises_for_abort -|= 1; +              if (ctx.aborted) {                  ctx.finalizeForAbort();                  return; @@ -1234,7 +1237,7 @@ fn NewRequestContext(comptime ssl_enabled: bool, comptime debug_mode: bool, comp                                  }                                  stream.value.ensureStillAlive(); -                                stream.value.unprotect(); +                                  var response_stream = this.allocator.create(ResponseStream.JSSink) catch unreachable;                                  response_stream.* = ResponseStream.JSSink{                                      .sink = .{ @@ -1262,6 +1265,7 @@ fn NewRequestContext(comptime ssl_enabled: bool, comptime debug_mode: bool, comp                                          @ptrCast(**anyopaque, &signal.ptr),                                      },                                  ); +                                  assignment_result.ensureStillAlive();                                  // assert that it was updated                                  std.debug.assert(!signal.isDead()); @@ -1280,6 +1284,7 @@ fn NewRequestContext(comptime ssl_enabled: bool, comptime debug_mode: bool, comp                                      response_stream.detach();                                      this.sink = null;                                      response_stream.sink.destroy(); +                                    stream.value.unprotect();                                      return this.handleReject(assignment_result);                                  } @@ -1303,6 +1308,7 @@ fn NewRequestContext(comptime ssl_enabled: bool, comptime debug_mode: bool, comp                                      }                                      this.finalize(); +                                    stream.value.unprotect();                                      return;                                  } @@ -1327,6 +1333,13 @@ fn NewRequestContext(comptime ssl_enabled: bool, comptime debug_mode: bool, comp                                                      wrapper.sink.destroy();                                                  } +                                                if (req.response_ptr) |resp| { +                                                    if (resp.body.value == .Locked) { +                                                        resp.body.value.Locked.readable.?.done(); +                                                        resp.body.value = .{ .Used = {} }; +                                                    } +                                                } +                                                  if (req.aborted) {                                                      req.finalizeForAbort();                                                      return; @@ -1359,6 +1372,13 @@ fn NewRequestContext(comptime ssl_enabled: bool, comptime debug_mode: bool, comp                                                      wrapper.sink.destroy();                                                  } +                                                if (req.response_ptr) |resp| { +                                                    if (resp.body.value == .Locked) { +                                                        resp.body.value.Locked.readable.?.done(); +                                                        resp.body.value = .{ .Used = {} }; +                                                    } +                                                } +                                                  streamLog("onReject({s})", .{wrote_anything});                                                  if (req.aborted) { @@ -1397,7 +1417,12 @@ fn NewRequestContext(comptime ssl_enabled: bool, comptime debug_mode: bool, comp                                              .Pending => {                                                  // TODO: should this timeout?                                                  this.resp.onAborted(*ResponseStream, ResponseStream.onAborted, &response_stream.sink); - +                                                this.response_ptr.?.body.value = .{ +                                                    .Locked = .{ +                                                        .readable = stream, +                                                        .global = this.server.globalThis, +                                                    }, +                                                };                                                  assignment_result.then(                                                      this.server.globalThis,                                                      RequestContext, @@ -1426,6 +1451,7 @@ fn NewRequestContext(comptime ssl_enabled: bool, comptime debug_mode: bool, comp                                      this.finalizeForAbort();                                      response_stream.sink.finalize(); +                                    stream.value.unprotect();                                      return;                                  } @@ -1440,6 +1466,7 @@ fn NewRequestContext(comptime ssl_enabled: bool, comptime debug_mode: bool, comp                                  this.resp.onAborted(*ResponseStream, ResponseStream.onAborted, &response_stream.sink);                                  streamLog("is in progress, but did not return a Promise. Finalizing request context", .{});                                  this.finalize(); +                                stream.value.unprotect();                                  return;                              },                          } @@ -2133,7 +2160,7 @@ pub fn NewServer(comptime ssl_enabled_: bool, comptime debug_mode_: bool) type {              if (wait_for_promise) {                  ctx.setAbortHandler(); -                request_value.protect(); +                ctx.pending_promises_for_abort += 1;                  RequestContext.PromiseHandler.then(ctx, response_value, this.globalThis);                  return; | 
