From d7db3791d550a45d26c792fdfcc26a0665e4a957 Mon Sep 17 00:00:00 2001 From: Antonio Scandurra Date: Tue, 22 Feb 2022 18:55:38 +0100 Subject: [PATCH] Show worktree root name for symbol when there are multiple worktrees Co-Authored-By: Nathan Sobo Co-Authored-By: Max Brunsfeld --- crates/project/src/project.rs | 15 +++++++ crates/project_symbols/src/project_symbols.rs | 42 ++++++++++++------- 2 files changed, 43 insertions(+), 14 deletions(-) diff --git a/crates/project/src/project.rs b/crates/project/src/project.rs index 3bd0ca4c26..4069704b0c 100644 --- a/crates/project/src/project.rs +++ b/crates/project/src/project.rs @@ -453,6 +453,21 @@ impl Project { .filter_map(move |worktree| worktree.upgrade(cx)) } + pub fn strong_worktrees<'a>( + &'a self, + cx: &'a AppContext, + ) -> impl 'a + Iterator> { + self.worktrees.iter().filter_map(|worktree| { + worktree.upgrade(cx).and_then(|worktree| { + if worktree.read(cx).is_weak() { + None + } else { + Some(worktree) + } + }) + }) + } + pub fn worktree_for_id( &self, id: WorktreeId, diff --git a/crates/project_symbols/src/project_symbols.rs b/crates/project_symbols/src/project_symbols.rs index b20a37b295..a5c3b2611f 100644 --- a/crates/project_symbols/src/project_symbols.rs +++ b/crates/project_symbols/src/project_symbols.rs @@ -14,6 +14,7 @@ use ordered_float::OrderedFloat; use postage::watch; use project::{Project, Symbol}; use std::{ + borrow::Cow, cmp::{self, Reverse}, sync::Arc, }; @@ -277,12 +278,12 @@ impl ProjectSymbolsView { let view = view.read(cx); let start = range.start; range.end = cmp::min(range.end, view.matches.len()); - items.extend( - view.matches[range] - .iter() - .enumerate() - .map(move |(ix, m)| view.render_match(m, start + ix)), - ); + + let show_worktree_root_name = + view.project.read(cx).strong_worktrees(cx).count() > 1; + items.extend(view.matches[range].iter().enumerate().map(move |(ix, m)| { + view.render_match(m, start + ix, show_worktree_root_name, cx) + })); }, ); @@ -291,7 +292,13 @@ impl ProjectSymbolsView { .named("matches") } - fn render_match(&self, string_match: &StringMatch, index: usize) -> ElementBox { + fn render_match( + &self, + string_match: &StringMatch, + index: usize, + show_worktree_root_name: bool, + cx: &AppContext, + ) -> ElementBox { let settings = self.settings.borrow(); let style = if index == self.selected_match_index { &settings.theme.selector.active_item @@ -305,6 +312,19 @@ impl ProjectSymbolsView { &settings.theme.editor.syntax, ); + let mut path = symbol.path.to_string_lossy(); + if show_worktree_root_name { + let project = self.project.read(cx); + if let Some(worktree) = project.worktree_for_id(symbol.worktree_id, cx) { + path = Cow::Owned(format!( + "{}{}{}", + worktree.read(cx).root_name(), + std::path::MAIN_SEPARATOR, + path.as_ref() + )); + } + } + Flex::column() .with_child( Text::new(symbol.label.text.clone(), style.label.text.clone()) @@ -317,13 +337,7 @@ impl ProjectSymbolsView { )) .boxed(), ) - .with_child( - Label::new( - symbol.path.to_string_lossy().to_string(), - style.label.clone(), - ) - .boxed(), - ) + .with_child(Label::new(path.to_string(), style.label.clone()).boxed()) .contained() .with_style(style.container) .boxed()