Don't assume that cloning on split will reuse the same underlying model

Co-Authored-By: Max Brunsfeld <max@zed.dev>
This commit is contained in:
Antonio Scandurra 2022-02-25 18:30:04 +01:00
parent 7123407f42
commit e278c423d3
5 changed files with 15 additions and 14 deletions

View file

@ -158,11 +158,11 @@ impl WeakItemHandle for WeakMultiBufferItemHandle {
}
impl ItemView for Editor {
fn item_id(&self, cx: &AppContext) -> usize {
fn item(&self, cx: &AppContext) -> Box<dyn ItemHandle> {
if let Some(buffer) = self.buffer.read(cx).as_singleton() {
buffer.id()
Box::new(BufferItemHandle(buffer))
} else {
self.buffer.id()
Box::new(MultiBufferItemHandle(self.buffer.clone()))
}
}