mirror of
https://github.com/zed-industries/zed.git
synced 2025-01-25 03:16:01 +00:00
Make multi-server completion requests not serial
This commit is contained in:
parent
0e6c91818f
commit
e3a0252b04
1 changed files with 15 additions and 9 deletions
|
@ -4438,21 +4438,27 @@ impl Project {
|
|||
let position = position.to_point_utf16(buffer.read(cx));
|
||||
let server_ids: Vec<_> = self
|
||||
.language_servers_for_buffer(buffer.read(cx), cx)
|
||||
.filter(|(_, server)| server.capabilities().completion_provider.is_some())
|
||||
.map(|(_, server)| server.server_id())
|
||||
.collect();
|
||||
|
||||
let buffer = buffer.clone();
|
||||
cx.spawn(|this, mut cx| async move {
|
||||
let mut tasks = Vec::with_capacity(server_ids.len());
|
||||
this.update(&mut cx, |this, cx| {
|
||||
for server_id in server_ids {
|
||||
tasks.push(this.request_lsp(
|
||||
buffer.clone(),
|
||||
server_id,
|
||||
GetCompletions { position },
|
||||
cx,
|
||||
));
|
||||
}
|
||||
});
|
||||
|
||||
let mut completions = Vec::new();
|
||||
|
||||
for server_id in server_ids {
|
||||
let new_completions = this
|
||||
.update(&mut cx, |this, cx| {
|
||||
this.request_lsp(buffer.clone(), server_id, GetCompletions { position }, cx)
|
||||
})
|
||||
.await;
|
||||
|
||||
if let Ok(new_completions) = new_completions {
|
||||
for task in tasks {
|
||||
if let Ok(new_completions) = task.await {
|
||||
completions.extend_from_slice(&new_completions);
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue