Add more default impls to the item trait

Change pane to not split if the underlying item cannot be cloned
This commit is contained in:
Mikayla Maki 2023-02-21 17:25:28 -08:00
parent ebf1da1de8
commit cae9e733a1
2 changed files with 50 additions and 28 deletions

View file

@ -49,9 +49,11 @@ pub trait Item: View {
} }
fn tab_content(&self, detail: Option<usize>, style: &theme::Tab, cx: &AppContext) fn tab_content(&self, detail: Option<usize>, style: &theme::Tab, cx: &AppContext)
-> ElementBox; -> ElementBox;
fn for_each_project_item(&self, _: &AppContext, _: &mut dyn FnMut(usize, &dyn project::Item)); fn for_each_project_item(&self, _: &AppContext, _: &mut dyn FnMut(usize, &dyn project::Item)) {}
fn is_singleton(&self, cx: &AppContext) -> bool; fn is_singleton(&self, _cx: &AppContext) -> bool {
fn set_nav_history(&mut self, _: ItemNavHistory, _: &mut ViewContext<Self>); false
}
fn set_nav_history(&mut self, _: ItemNavHistory, _: &mut ViewContext<Self>) {}
fn clone_on_split(&self, _workspace_id: WorkspaceId, _: &mut ViewContext<Self>) -> Option<Self> fn clone_on_split(&self, _workspace_id: WorkspaceId, _: &mut ViewContext<Self>) -> Option<Self>
where where
Self: Sized, Self: Sized,
@ -64,23 +66,31 @@ pub trait Item: View {
fn has_conflict(&self, _: &AppContext) -> bool { fn has_conflict(&self, _: &AppContext) -> bool {
false false
} }
fn can_save(&self, cx: &AppContext) -> bool; fn can_save(&self, _cx: &AppContext) -> bool {
false
}
fn save( fn save(
&mut self, &mut self,
project: ModelHandle<Project>, _project: ModelHandle<Project>,
cx: &mut ViewContext<Self>, _cx: &mut ViewContext<Self>,
) -> Task<Result<()>>; ) -> Task<Result<()>> {
unimplemented!("save() must be implemented if can_save() returns true")
}
fn save_as( fn save_as(
&mut self, &mut self,
project: ModelHandle<Project>, _project: ModelHandle<Project>,
abs_path: PathBuf, _abs_path: PathBuf,
cx: &mut ViewContext<Self>, _cx: &mut ViewContext<Self>,
) -> Task<Result<()>>; ) -> Task<Result<()>> {
unimplemented!("save_as() must be implemented if can_save() returns true")
}
fn reload( fn reload(
&mut self, &mut self,
project: ModelHandle<Project>, _project: ModelHandle<Project>,
cx: &mut ViewContext<Self>, _cx: &mut ViewContext<Self>,
) -> Task<Result<()>>; ) -> Task<Result<()>> {
unimplemented!("reload() must be implemented if can_save() returns true")
}
fn git_diff_recalc( fn git_diff_recalc(
&mut self, &mut self,
_project: ModelHandle<Project>, _project: ModelHandle<Project>,
@ -88,7 +98,9 @@ pub trait Item: View {
) -> Task<Result<()>> { ) -> Task<Result<()>> {
Task::ready(Ok(())) Task::ready(Ok(()))
} }
fn to_item_events(event: &Self::Event) -> SmallVec<[ItemEvent; 2]>; fn to_item_events(_event: &Self::Event) -> SmallVec<[ItemEvent; 2]> {
SmallVec::new()
}
fn should_close_item_on_event(_: &Self::Event) -> bool { fn should_close_item_on_event(_: &Self::Event) -> bool {
false false
} }
@ -124,15 +136,21 @@ pub trait Item: View {
fn added_to_workspace(&mut self, _workspace: &mut Workspace, _cx: &mut ViewContext<Self>) {} fn added_to_workspace(&mut self, _workspace: &mut Workspace, _cx: &mut ViewContext<Self>) {}
fn serialized_item_kind() -> Option<&'static str>; fn serialized_item_kind() -> Option<&'static str> {
None
}
fn deserialize( fn deserialize(
project: ModelHandle<Project>, _project: ModelHandle<Project>,
workspace: WeakViewHandle<Workspace>, _workspace: WeakViewHandle<Workspace>,
workspace_id: WorkspaceId, _workspace_id: WorkspaceId,
item_id: ItemId, _item_id: ItemId,
cx: &mut ViewContext<Pane>, _cx: &mut ViewContext<Pane>,
) -> Task<Result<ViewHandle<Self>>>; ) -> Task<Result<ViewHandle<Self>>> {
unimplemented!(
"deserialize() must be implemented if serialized_item_kind() returns Some(_)"
)
}
} }
pub trait ItemHandle: 'static + fmt::Debug { pub trait ItemHandle: 'static + fmt::Debug {

View file

@ -1589,13 +1589,17 @@ impl Workspace {
} }
let item = pane.read(cx).active_item()?; let item = pane.read(cx).active_item()?;
let new_pane = self.add_pane(cx); let maybe_pane_handle =
if let Some(clone) = item.clone_on_split(self.database_id(), cx.as_mut()) { if let Some(clone) = item.clone_on_split(self.database_id(), cx.as_mut()) {
Pane::add_item(self, &new_pane, clone, true, true, None, cx); let new_pane = self.add_pane(cx);
} Pane::add_item(self, &new_pane, clone, true, true, None, cx);
self.center.split(&pane, &new_pane, direction).unwrap(); self.center.split(&pane, &new_pane, direction).unwrap();
Some(new_pane)
} else {
None
};
cx.notify(); cx.notify();
Some(new_pane) maybe_pane_handle
} }
pub fn split_pane_with_item(&mut self, action: &SplitWithItem, cx: &mut ViewContext<Self>) { pub fn split_pane_with_item(&mut self, action: &SplitWithItem, cx: &mut ViewContext<Self>) {