Globstar: New Bash Globbing Option
In shell-speak, globbing is what the shell does when you use a wildcard in a command (e.g. * or ?). Globbing is matching the wildcard pattern and returning the file and directory names that match and then replacing the wildcard pattern in the command with the matched items. Bash version 4.0 adds a new globbing option called globstar which treats the pattern ** differently when it's set.
Normally, if you use the pattern ** on the command line it acts the same as the * pattern. For example, given the following directory:
$ ls -l total 8 -rw-r--r-- 1 mitch users 0 2010-05-05 10:36 a -rw-r--r-- 1 mitch users 0 2010-05-05 10:36 b drwxr-xr-x 2 mitch users 4096 2010-05-05 10:36 c drwxr-xr-x 2 mitch users 4096 2010-05-05 10:36 d
if you execute the following commands:
$ for i in ** > do > echo $i > done
you get the following output:
a b c d
If you now set the globstar option with the following command:
$ shopt -s globstar
and then re-run the for loop from above, you now get:
a b c c/e d d/f
With globstar set, bash recurses all the directories. Note that this will recurse all directory levels, not just one level.
You can see if globstar is set by issuing the shopt command without any arguments:
$ shopt ... force_fignore on globstar on gnu_errfmt off ...
or if you want to test it in a script you can use the -q option to shopt and test the exit status, for example:
if shopt -q globstar; then ... if
Mitch Frazier is an Associate Editor for Linux Journal.
|Speed Up Your Web Site with Varnish||Jun 19, 2013|
|Non-Linux FOSS: libnotify, OS X Style||Jun 18, 2013|
|Containers—Not Virtual Machines—Are the Future Cloud||Jun 17, 2013|
|Lock-Free Multi-Producer Multi-Consumer Queue on Ring Buffer||Jun 12, 2013|
|Weechat, Irssi's Little Brother||Jun 11, 2013|
|One Tail Just Isn't Enough||Jun 07, 2013|
- Speed Up Your Web Site with Varnish
- Containers—Not Virtual Machines—Are the Future Cloud
- Linux Systems Administrator
- Lock-Free Multi-Producer Multi-Consumer Queue on Ring Buffer
- Senior Perl Developer
- Technical Support Rep
- RSS Feeds
- Non-Linux FOSS: libnotify, OS X Style
- UX Designer
- So when they found it hard to
41 min 46 sec ago
1 hour 3 min ago
- Reply to comment | Linux Journal
1 hour 26 min ago
- Android has been dominating
1 hour 30 min ago
- It is quiet helping
4 hours 16 min ago
4 hours 33 min ago
- Reachli - Amplifying your
5 hours 50 min ago
6 hours 38 min ago
- good point!
6 hours 41 min ago
- Varnish works!
6 hours 50 min ago
Free Webinar: Hadoop
How to Build an Optimal Hadoop Cluster to Store and Maintain Unlimited Amounts of Data Using Microservers
Realizing the promise of Apache® Hadoop® requires the effective deployment of compute, memory, storage and networking to achieve optimal results. With its flexibility and multitude of options, it is easy to over or under provision the server infrastructure, resulting in poor performance and high TCO. Join us for an in depth, technical discussion with industry experts from leading Hadoop and server companies who will provide insights into the key considerations for designing and deploying an optimal Hadoop cluster.
Some of key questions to be discussed are:
- What is the “typical” Hadoop cluster and what should be installed on the different machine types?
- Why should you consider the typical workload patterns when making your hardware decisions?
- Are all microservers created equal for Hadoop deployments?
- How do I plan for expansion if I require more compute, memory, storage or networking?