mirror of
https://github.com/servo/servo.git
synced 2025-07-29 10:10:34 +01:00
Remove lock around tokio-rt handle (#36762)
It seems sub-optimal to to sequentialise execution by grabbing a lock, each time we want to spawn a task onto the tokio runtime. We don't need the lock either, so it makes sense to just remove it, which also simplifies a bunch of the using code. Testing: Covered by existing tests Signed-off-by: Jonathan Schwender <schwenderjonathan@gmail.com>
This commit is contained in:
parent
955149b194
commit
c46402e222
5 changed files with 37 additions and 44 deletions
|
@ -418,24 +418,21 @@ fn connect(
|
|||
tls_config.alpn_protocols = vec!["http/1.1".to_string().into()];
|
||||
|
||||
let resource_event_sender2 = resource_event_sender.clone();
|
||||
match HANDLE.lock().unwrap().as_mut() {
|
||||
Some(handle) => handle.spawn(
|
||||
start_websocket(
|
||||
http_state,
|
||||
req_url.clone(),
|
||||
resource_event_sender,
|
||||
protocols,
|
||||
client,
|
||||
tls_config,
|
||||
dom_action_receiver,
|
||||
)
|
||||
.map_err(move |e| {
|
||||
warn!("Failed to establish a WebSocket connection: {:?}", e);
|
||||
let _ = resource_event_sender2.send(WebSocketNetworkEvent::Fail);
|
||||
}),
|
||||
),
|
||||
None => return Err("No runtime available".to_string()),
|
||||
};
|
||||
HANDLE.spawn(
|
||||
start_websocket(
|
||||
http_state,
|
||||
req_url.clone(),
|
||||
resource_event_sender,
|
||||
protocols,
|
||||
client,
|
||||
tls_config,
|
||||
dom_action_receiver,
|
||||
)
|
||||
.map_err(move |e| {
|
||||
warn!("Failed to establish a WebSocket connection: {:?}", e);
|
||||
let _ = resource_event_sender2.send(WebSocketNetworkEvent::Fail);
|
||||
}),
|
||||
);
|
||||
Ok(())
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue