1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-06 22:35:51 -05:00
This commit is contained in:
Satya Rohith 2024-09-14 20:53:16 +05:30
parent 95ad0faddb
commit f9c1219f7c
No known key found for this signature in database
GPG key ID: B2705CF40523EB05
8 changed files with 26 additions and 5 deletions

View file

@ -100,10 +100,12 @@ impl Resource for TcpStreamResource {
} }
fn shutdown(self: Rc<Self>) -> AsyncResult<()> { fn shutdown(self: Rc<Self>) -> AsyncResult<()> {
eprintln!("shutdown TcpStreamResource");
Box::pin(self.shutdown()) Box::pin(self.shutdown())
} }
fn close(self: Rc<Self>) { fn close(self: Rc<Self>) {
eprintln!("close TcpStreamResource");
self.cancel_read_ops(); self.cancel_read_ops();
} }
} }

View file

@ -328,6 +328,7 @@ where
let rid = state_ let rid = state_
.resource_table .resource_table
.add(TcpStreamResource::new(tcp_stream.into_split())); .add(TcpStreamResource::new(tcp_stream.into_split()));
eprintln!("adding TcpStreamResource in op_net_connect_tcp: {rid}");
Ok((rid, IpAddr::from(local_addr), IpAddr::from(remote_addr))) Ok((rid, IpAddr::from(local_addr), IpAddr::from(remote_addr)))
} }
@ -654,6 +655,7 @@ pub fn op_set_nodelay_inner(
) -> Result<(), AnyError> { ) -> Result<(), AnyError> {
let resource: Rc<TcpStreamResource> = let resource: Rc<TcpStreamResource> =
state.resource_table.get::<TcpStreamResource>(rid)?; state.resource_table.get::<TcpStreamResource>(rid)?;
println!("setting nodelay (rid: {rid}): {nodelay}");
resource.set_nodelay(nodelay) resource.set_nodelay(nodelay)
} }
@ -674,6 +676,7 @@ pub fn op_set_keepalive_inner(
) -> Result<(), AnyError> { ) -> Result<(), AnyError> {
let resource: Rc<TcpStreamResource> = let resource: Rc<TcpStreamResource> =
state.resource_table.get::<TcpStreamResource>(rid)?; state.resource_table.get::<TcpStreamResource>(rid)?;
eprintln!("setting keepalive (rid: {rid}): {keepalive}");
resource.set_keepalive(keepalive) resource.set_keepalive(keepalive)
} }

View file

@ -293,6 +293,7 @@ where
.borrow::<DefaultTlsOptions>() .borrow::<DefaultTlsOptions>()
.root_cert_store()?; .root_cert_store()?;
println!("used in op_tls_start");
let resource_rc = state let resource_rc = state
.borrow_mut() .borrow_mut()
.resource_table .resource_table

View file

@ -329,7 +329,7 @@ pub fn take_network_stream_resource(
// The stream we're attempting to unwrap may be in use somewhere else. If that's the case, we cannot proceed // The stream we're attempting to unwrap may be in use somewhere else. If that's the case, we cannot proceed
// with the process of unwrapping this connection, so we just return a bad resource error. // with the process of unwrapping this connection, so we just return a bad resource error.
// See also: https://github.com/denoland/deno/pull/16242 // See also: https://github.com/denoland/deno/pull/16242
println!("used in take_network_stream_resource");
if let Ok(resource_rc) = resource_table.take::<TcpStreamResource>(stream_rid) if let Ok(resource_rc) = resource_table.take::<TcpStreamResource>(stream_rid)
{ {
// This TCP connection might be used somewhere else. // This TCP connection might be used somewhere else.

View file

@ -107,8 +107,15 @@ where
.borrow_mut() .borrow_mut()
.resource_table .resource_table
.take::<TcpStreamResource>(conn_rid)?; .take::<TcpStreamResource>(conn_rid)?;
let resource = Rc::try_unwrap(resource_rc) eprintln!(
.map_err(|_| bad_resource("TCP stream is currently in use"))?; "rc: strong_count: {strong_count} weak_count: {weak_count}",
strong_count = Rc::strong_count(&resource_rc),
weak_count = Rc::weak_count(&resource_rc)
);
let resource = Rc::try_unwrap(resource_rc).map_err(|e| {
eprintln!("error: {:?}", e);
bad_resource("TCP stream is currently in use")
})?;
let (read_half, write_half) = resource.into_inner(); let (read_half, write_half) = resource.into_inner();
let tcp_stream = read_half.reunite(write_half)?; let tcp_stream = read_half.reunite(write_half)?;
let io = TokioIo::new(tcp_stream); let io = TokioIo::new(tcp_stream);

View file

@ -524,7 +524,7 @@ Object.defineProperties(
_send(data: any, encoding?: string | null, callback?: () => void) { _send(data: any, encoding?: string | null, callback?: () => void) {
// if socket is ready, write the data after headers are written. // if socket is ready, write the data after headers are written.
// if socket is not ready, buffer data in outputbuffer. // if socket is not ready, buffer data in outputbuffer.
if (this.socket) { if (this.socket && !this.socket.connecting) {
console.log("im never invoked"); console.log("im never invoked");
if (!this._headerSent && this._header !== null) { if (!this._headerSent && this._header !== null) {
this._writeHeader(); this._writeHeader();

View file

@ -640,13 +640,20 @@ class ClientRequest extends OutgoingMessage {
if (chunk) { if (chunk) {
this.write_(chunk, encoding, null, true); this.write_(chunk, encoding, null, true);
} else if (!this._headerSent) { } else if (!this._headerSent) {
if (this.socket) { if (this.socket && !this.socket.connecting) {
this._contentLength = 0; this._contentLength = 0;
console.log(
"end: _implicitHeader; socket.rid",
this.socket.rid,
"socket.connecting",
this.socket.connecting,
);
this._implicitHeader(); this._implicitHeader();
this._send("", "latin1"); this._send("", "latin1");
} else { } else {
this.on("socket", (socket) => { this.on("socket", (socket) => {
socket.on("connect", () => { socket.on("connect", () => {
console.log("connect emitted - sending implicit header");
this._contentLength = 0; this._contentLength = 0;
this._implicitHeader(); this._implicitHeader();
this._send("", "latin1"); this._send("", "latin1");

View file

@ -22,6 +22,7 @@ fn op_http_start(
state: &mut OpState, state: &mut OpState,
#[smi] tcp_stream_rid: ResourceId, #[smi] tcp_stream_rid: ResourceId,
) -> Result<ResourceId, AnyError> { ) -> Result<ResourceId, AnyError> {
println!("used in op_http_start");
if let Ok(resource_rc) = state if let Ok(resource_rc) = state
.resource_table .resource_table
.take::<TcpStreamResource>(tcp_stream_rid) .take::<TcpStreamResource>(tcp_stream_rid)