-
-
Notifications
You must be signed in to change notification settings - Fork 833
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
Alternate walk order - tree distance from 'center' directory #734
Comments
This is a cool idea. I think if you could get the walkers to prioritize candidates with smaller distances, you wouldn't need to run multiple walkers (also note that the walkers in |
I have the same use case. Using fzf, I'm often cd-ing into a directory that is only 2 levels down, but I have to wait for 1-2 seconds because there are many results much deeper that get returned first. I actually rather a flag that specifies the walker (like the Without the option, results ordering could change again, like how it was breadth-first and became an A* thing. For my specific usecase, this hack works, but it's not nice by any means:
|
@alanxoc3 From your example it seems like you just want breadth-first search. I wrote https://github.com/tavianator/bfs for the same reasons you mention it's desirable, if that helps :). It uses the |
Hey, that's a nice project you have there, and yep, a breadth first search works for my scenario. That said, I would expect the idea proposed by @orlp to do the same thing as a breadth first search if you pass in I also just read through #599. It makes sense that there is a performance concern, but if the user specifies that they want a certain walker (BFS, A*, DFS...), there could just be a comment in the man page mentioning there could be a memory concern if using BFS. And it sounds like if |
Yes, my idea is a strict superset of BFS as |
While waiting on this feature, here's a poor mans BFS that still uses fd: bfd() {
__index=-1 ; while [ "$__index" -lt 256 ]; do
__index=$((__index+1))
fd --exact-depth $__index "$@"
done
unset __index
} NOTE: if you have more than 256 nested folders.... first thats very impressive you might want to get that checked, but second this command will also not find stuff deeper than 256 directories down |
I have a feature request I believe to be quite useful when
fd
is combined with any sort of fuzzy-finder tool (e.g.fzf
), or when returning early results from a very large search.Suppose we wish to list all files in a directory, e.g. our home:
This works, and is relatively quick. However the order of files isn't always very useful. I propose the following:
What this would do is still output all the files in
~
, but ordered by the distance from~/programming/rust/fd/src
(which I'll refer to as the 'center') in the 'filesystem tree'. This would be the number ofcd
s you'd need to go from the specified 'center' to the target.E.g. the distance between
~/programming/rust/fd/src
and:From the brief look I took at the current walker code I don't believe you support walking up into parent directories. Luckily you don't have to, when a center has been specified you can simply recursively pass the distance (so a recursive call into a subdirectory would increase the distance by 1), and start parallel walkers (appropriately ignoring dirs to prevent double work) on:
You don't have to completely wait for all walkers to finish before you can output the final sorted order either. If you add each found file to a queue
d
for its respective distanced
, you can start outputting from a queued
as soon as no walker with current distanced' < d
exists anymore. This does assume a (rough) BFS walk order.Why is this useful? Well often we aren't just interested in 'a file somewhere', but in 'a file somewhere, but probably close to X'. E.g. if you are editing
~/programming/rust/fd/src/main.rs
in your editor and use a fuzzy finder plugin with a full listing of files in your home directory, and you type 'owner', you probably want to find~/programming/rust/fd/src/filter/owner.rs
, not~/.config/X11/owners
. Having the files listed in ascending order distance from the center makes this very easy (and allows early results to be found even with massive searches).The text was updated successfully, but these errors were encountered: