Load diff base from correct relative path

This commit is contained in:
Julia 2022-10-04 20:42:01 -04:00
parent 836b536a90
commit 3f4be5521c
2 changed files with 15 additions and 8 deletions

View file

@ -4673,13 +4673,18 @@ impl Project {
None => return, None => return,
}; };
let relative_repo = match path.strip_prefix(repo.content_path) {
Ok(relative_repo) => relative_repo.to_owned(),
Err(_) => return,
};
let shared_remote_id = self.shared_remote_id(); let shared_remote_id = self.shared_remote_id();
let client = self.client.clone(); let client = self.client.clone();
cx.spawn(|_, mut cx| async move { cx.spawn(|_, mut cx| async move {
let diff_base = cx let diff_base = cx
.background() .background()
.spawn(async move { repo.repo.lock().load_index(&path) }) .spawn(async move { repo.repo.lock().load_index(&relative_repo) })
.await; .await;
let buffer_id = buffer.update(&mut cx, |buffer, cx| { let buffer_id = buffer.update(&mut cx, |buffer, cx| {

View file

@ -667,15 +667,17 @@ impl LocalWorktree {
cx.spawn(|this, mut cx| async move { cx.spawn(|this, mut cx| async move {
let text = fs.load(&abs_path).await?; let text = fs.load(&abs_path).await?;
let diff_base = if let Some(repo) = snapshot.repo_for(&abs_path) { let diff_base = if let Some(repo) = snapshot.repo_for(&path) {
if let Ok(repo_relative) = path.strip_prefix(repo.content_path) {
let repo_relative = repo_relative.to_owned();
cx.background() cx.background()
.spawn({ .spawn(async move { repo.repo.lock().load_index(&repo_relative) })
let path = path.clone();
async move { repo.repo.lock().load_index(&path) }
})
.await .await
} else { } else {
None None
}
} else {
None
}; };
// Eagerly populate the snapshot with an updated entry for the loaded file // Eagerly populate the snapshot with an updated entry for the loaded file