-
Notifications
You must be signed in to change notification settings - Fork 3.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
workspace::Open
: Add trailing /
to directories on completion
#25045
base: main
Are you sure you want to change the base?
Conversation
/
to directories on completion/
to directories on completion
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can you elaborate why is it needed and what problem does this PR try to solve?
Maybe, there's a way to create a test to illustrate this?
If I understand correctly, file finder can only show files in the results:
data:image/s3,"s3://crabby-images/42aba/42aba2aa1ee4ee17d2fc482e0d04d0bd49f57edf" alt="image"
those do not need any trailing /
.
Directories that correspond to files have the trailing path separator already.
Last but not least, this change does not make any sense on Windows as a different kind of a separator has to be used there.
@SomeoneToIgnore Sorry for the poor explanation, i just updated the description. I was referring to Zed's open workspace prompt (workspace::Open with I was worried about windows backslash too, but it looks like most of the code uses / as well. But it is looking like windows is failing so i am probably wrong. zed/crates/file_finder/src/open_path_prompt.rs Lines 96 to 97 in 5f1f3f1
|
/
to directories on completionworkspace::Open
: Add trailing /
to directories on completion
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you, this is much more clear now, I have forgotten entirely about this corner.
It has issues with Windows indeed, as
zed/crates/file_finder/src/open_path_prompt.rs
Lines 96 to 97 in adb0d32
// todo(windows) | |
// Is this method woring correctly on Windows? This method uses `/` for path separator. |
notes, placeholder_text
, confirm_completion
and update_matches
use /
(and some other Zed corners, I bet).
This results in the quite odd path handling:
windows.mp4
Given the context, the PR is a nice improvement indeed.
-
Let's use
std::path::MAIN_SEPARATOR
instead of/
in the related code as we're touching it. -
Not insisting on this, but I also think it should be relatively straightforward to copy a test like
zed/crates/file_finder/src/file_finder_tests.rs
Lines 149 to 185 in adb0d32
#[gpui::test] | |
async fn test_complex_path(cx: &mut TestAppContext) { | |
let app_state = init_test(cx); | |
app_state | |
.fs | |
.as_fake() | |
.insert_tree( | |
path!("/root"), | |
json!({ | |
"其他": { | |
"S数据表格": { | |
"task.xlsx": "some content", | |
}, | |
} | |
}), | |
) | |
.await; | |
let project = Project::test(app_state.fs.clone(), [path!("/root").as_ref()], cx).await; | |
let (picker, workspace, cx) = build_find_picker(project, cx); | |
cx.simulate_input("t"); | |
picker.update(cx, |picker, _| { | |
assert_eq!(picker.delegate.matches.len(), 1); | |
assert_eq!( | |
collect_search_matches(picker).search_paths_only(), | |
vec![PathBuf::from("其他/S数据表格/task.xlsx")], | |
) | |
}); | |
cx.dispatch_action(SelectNext); | |
cx.dispatch_action(Confirm); | |
cx.read(|cx| { | |
let active_editor = workspace.read(cx).active_item_as::<Editor>(cx).unwrap(); | |
assert_eq!(active_editor.read(cx).title(cx), "task.xlsx"); | |
}); | |
} |
and adjust it to check that we auto add /
to directories — this way, we'll ensure Windows is not broken in this corner.
I see, looks like the |
Problem: It takes two keys to view subdirectories in Zed's open workspace prompt. (tab to complete and / )
Fix: Append / to directories in the Zed workspace::Open.
To reproduce:
mod-o
orworkspace::Open
with"use_system_path_prompts": false
.Right now, using Zed's open workspace prompt instead of the system prompt requires a / input after every tab complete, if trying to navigate into subdirectories multiple folders deep from home folder.
For example:
data:image/s3,"s3://crabby-images/ae616/ae616f947dff3fe914eef0ff0160f84820a44bf2" alt="image"
Trying to open foo/bar/folder, home directory is foo
Previous path autocompletes: foo/bar
data:image/s3,"s3://crabby-images/449bc/449bcd135252306579687ab112a277dd65636805" alt="image"
The prompt does not show subdirectories in bar yet. Still needs an / input afterwards.
New changes: Checks if path is a directory and appends / to the completion if so.
data:image/s3,"s3://crabby-images/71183/71183798c271bcf403b98dd63b131fa74b74f1dd" alt="image"
Results in seeing the subdirectories right after autocomplete.
Helps save a few keys but not that big of a deal overall, looks like it wont work since windows uses backslash?
Zsh:
data:image/s3,"s3://crabby-images/a40d5/a40d5e775d2012c3a814dd47f47ee4f4c56a59a5" alt="image"
Zsh does it too (with oh my zsh i think). I didn't add it to the render_matches so Zed's prompt would still look the same as before.
Release Notes: