This is a repost of a review that is timely, given this week’s focus on setting up your Linux server and changing all your computers over to Linux and so on.
Time for another installment of our look at the book Learning the bash Shell (In a Nutshell (O’Reilly)). Today’s foray into Linux Land: Unix Command Substitution.
There is more than one way to do this, but here is a sensible way to look at the format. In command substitution you stick something that comes out to be a valid UNIX command insice parentheses preceded with a dollar sign:
The unix command is evaluated and then the result replaces the $() bit.
For example, say you wanted to edit all of the files in the current directory that included the letters “html”. You could use the “grep” command to parse out all of the files to get a look at them. Grep goes through files and searches for a string, and by default spits out the line containing the string. There is an option (-l) that tells grep to spit out only the filename. So, for instance, I can do this:
greg@greg-desktop:~/Desktop$ cd markdown
greg@greg-desktop:~/Desktop/markdown$ grep -l 'html' *
Then I could type these names into the text editor command.
Or, I can turn this list of phrases into part of a command line. If I use “getdit” as the text editor, I can type”
gedit grep -l 'html' *
But that would not work! -l is not an available option for gedit, and there are other confusing things on this line to cause gedit to not get it. Get it? Good.
BUt, if I put the mojo that spits out the list of files (which I tried above and know works) into the command sbustitution command, then then that will convert “grep -l ‘html’ *” into a a list of files.
So this works:
greg@greg-desktop:~/Desktop/markdown$ gedit $(grep -l html *) &
This is the same as typing:
greg@greg-desktop:~/Desktop/markdown$ gedit 4sh.html blog2.html blog2.txt …. and so on. The “and” sign at the end puts the operation into the background so I can keep using the same command line.