mirror of
https://github.com/zed-industries/zed.git
synced 2025-01-03 23:27:59 +00:00
WIP: stream ignored entries
This commit is contained in:
parent
1a6cc6f964
commit
23ca9dce2e
1 changed files with 32 additions and 1 deletions
|
@ -40,6 +40,7 @@ use std::{
|
||||||
ffi::{OsStr, OsString},
|
ffi::{OsStr, OsString},
|
||||||
fmt,
|
fmt,
|
||||||
future::Future,
|
future::Future,
|
||||||
|
mem,
|
||||||
ops::{Deref, DerefMut},
|
ops::{Deref, DerefMut},
|
||||||
os::unix::prelude::{OsStrExt, OsStringExt},
|
os::unix::prelude::{OsStrExt, OsStringExt},
|
||||||
path::{Path, PathBuf},
|
path::{Path, PathBuf},
|
||||||
|
@ -951,9 +952,39 @@ impl LocalWorktree {
|
||||||
})?;
|
})?;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Stream ignored entries in chunks.
|
||||||
|
{
|
||||||
|
let mut ignored_entries = prev_snapshot
|
||||||
|
.entries_by_path
|
||||||
|
.iter()
|
||||||
|
.filter(|e| e.is_ignored);
|
||||||
|
let mut ignored_entries_to_send = Vec::new();
|
||||||
|
loop {
|
||||||
|
const CHUNK_SIZE: usize = 256;
|
||||||
|
let entry = ignored_entries.next();
|
||||||
|
if ignored_entries_to_send.len() >= CHUNK_SIZE || entry.is_none() {
|
||||||
|
rpc.request(proto::UpdateWorktree {
|
||||||
|
project_id,
|
||||||
|
worktree_id,
|
||||||
|
root_name: prev_snapshot.root_name().to_string(),
|
||||||
|
updated_entries: mem::take(&mut ignored_entries_to_send),
|
||||||
|
removed_entries: Default::default(),
|
||||||
|
scan_id: prev_snapshot.scan_id as u64,
|
||||||
|
})
|
||||||
|
.await?;
|
||||||
|
}
|
||||||
|
|
||||||
|
if let Some(entry) = ignored_entries.next() {
|
||||||
|
ignored_entries_to_send.push(entry.into());
|
||||||
|
} else {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
while let Ok(snapshot) = snapshots_to_send_rx.recv().await {
|
while let Ok(snapshot) = snapshots_to_send_rx.recv().await {
|
||||||
let message =
|
let message =
|
||||||
snapshot.build_update(&prev_snapshot, project_id, worktree_id, false);
|
snapshot.build_update(&prev_snapshot, project_id, worktree_id, true);
|
||||||
rpc.request(message).await?;
|
rpc.request(message).await?;
|
||||||
prev_snapshot = snapshot;
|
prev_snapshot = snapshot;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue