Feature #17548
openNeed simple way to include symlink directories in Dir.glob
Description
I would like to suggest that Ruby provide a simple way to glob that includes the content of symlinked directories.
I have my Ruby projects in a ~/work directory that is symlinked to a directory an another partition.
For example, ~ is on /dev/sda1, whereas ~/work is a link to a directory on /dev/sda2. I need this because I want to operate on the same code bases regardless of which partition I boot from (they are various Linux distros).
The array returned by Dir.glob(Dir.home, '**', '*rb') does not include any files in ~/work. The size of that array is only 84. In contrast, when I use find ~ -name "*rb" | wc -l to get the number of files, I get 87,229 files.
I was hoping that one of the flags that can be passed to glob would help, but the only relevant one I found was to not follow links, which is the opposite of what I wanted.
There are arcane workarounds using fancy glob patterns, but I believe it's important that the language provide a simple way to accomplish this. (For example, the Unix find command has an -L option for this.) I understand that it may not be possible to retrofit it into the existing functions (glob and []), but even providing a different method (e.g. one named glob_include_links) would be ok. Or perhaps a glob2 method could be added that would include simple ways to specify that files in hidden directories should be included, in addition to the option to follow symlinks.
I admit that I have no idea how much effort this would be to implement, especially regarding Windows compatibility, but this would be nice to have.
Updated by keithrbennett (Keith Bennett) almost 5 years ago
A clarifying comment that corrects something in my original post but does not change my recommendation:
I wish there a way for me to correct my original post, but I don't see a way to do that. I wanted to delete this text:
"The size of that array is only 84. In contrast, when I use find ~ -name "*rb" | wc -l to get the number of files, I get 87,229 files."
I mistakenly believed that find's default behavior was to include symlinked directories, but that difference was instead due to the fact that it includes hidden directories by default. Specifically, the ~/.rvm directory.
The correct way to compare was to use find's -L option, which would have includes the symlinked directory and reports a greater number of files than the Dir.glob number.
Updated by keithrbennett (Keith Bennett) almost 5 years ago
By the way, this is what I was referring to when I mentioned "arcane workarounds":
https://stackoverflow.com/questions/357754/can-i-traverse-symlinked-directories-in-ruby-with-a-glob
(Dir.glob("**{,/*/**}/*.rb"))
Updated by Dan0042 (Daniel DeLorme) almost 5 years ago
For your specific case, a workaround might be to use a bind mount instead of symlink.
But in general I agree having a follow_symlink option would be nice to have, either in Dir.glob or in Find.find
Updated by mame (Yusuke Endoh) over 4 years ago
zsh uses *** as a wildcard that expands symlinks. And matz accepted ***. Maybe nobu will implement it.
Updated by Dan0042 (Daniel DeLorme) over 3 years ago
Bump.
Today I just came across a case where I wanted to use this feature.
@nobu (Nobuyoshi Nakada) according to dev meeting notes you said "will commit", which implies to me this was already coded? Not sure.