### Commands by quintic (4) the last day the last week the last month all time sorted by date votes

• Suppose you have 11 marbles, 4 of which are red, the rest being blue. The marbles are indistinguishable, apart from colour. How many different ways are there to arrange the marbles in a line? And how many ways are there to arrange them so that no two red marbles are adjacent? There are simple mathematical solutions to these questions, but it's also possible to generate and count all possibilities directly on the command line, using little more than brace expansion, grep and wc! The answer to the question posed above is that there are 330 ways of arranging the marbles in a line, 70 of which have no two red marbles adjacent. See the sample output. To follow the call to marbles 11 4: after c=''; for i in \$(seq \$1); do c+='{b,r}'; done;, \$c equals {b,r}{b,r}{b,r}{b,r}{b,r}{b,r}{b,r}{b,r}{b,r}{b,r}{b,r} After x=\$(eval echo \$c), and brace expansion, \$x equals bbbbbbbbbbb bbbbbbbbbbr ... rrrrrrrrrrb rrrrrrrrrrr, which is all 2^11 = 2048 strings of 11 b's and r's. After p=''; for i in \$(seq \$2); do p+='b*r'; done;, \$p equals b*rb*rb*rb*r Next, after y=\$(grep -wo "\${p}b*" Finally, grep -vc 'rr' Show Sample Output

-4
marbles () { c=''; for i in \$(seq \$1); do c+='{b,r}'; done; x=\$(eval echo \$c); p=''; for i in \$(seq \$2); do p+='b*r'; done; y=\$(grep -wo "\${p}b*" <<< \$x); wc -l <<< "\$y"; grep -vc 'rr' <<< "\$y"; }
· 2010-08-27 23:04:33
• If the return code from the last command was greater than zero, colour part of your prompt red. The commands give a prompt like this: [user current_directory]\$ After an error, the "[user" part is automatically coloured red. Tested using bash on xterm and terminal. Place in your .bashrc or .bash_profile.

3
export PROMPT_COMMAND='if ((\$? > 0)); then echo -ne "\033[1;31m"; fi'; export PS1='[\[\]\u\[\033[0m\] \[\033[1;34m\]\w\[\033[0m\]]\\$ '
· 2010-08-25 21:19:30
• tail -c 1 "\$1" returns the last byte in the file. Command substitution deletes any trailing newlines, so if the file ended in a newline \$(tail -c 1 "\$1") is now empty, and the -z test succeeds. However, \$a will also be empty for an empty file, so we add -s "\$1" to check that the file has a size greater than zero. Finally, -f "\$1" checks that the file is a regular file -- not a directory or a socket, etc. Show Sample Output

1
endnl () { [[ -f "\$1" && -s "\$1" && -z \$(tail -c 1 "\$1") ]]; }
· 2010-08-25 12:06:10

• -3
(cd /bin; set -- *; x=\$((1+(\$RANDOM % \$#))); man \${!x})
· 2010-08-20 17:19:56

### What's this?

commandlinefu.com is the place to record those command-line gems that you return to again and again. That way others can gain from your CLI wisdom and you from theirs too. All commands can be commented on, discussed and voted up or down.

### Check These Out

Yet Another Large Screen Clock

Print a row of characters across the terminal
Print a row of characters across the terminal. Uses tput to establish the current terminal width, and generates a line of characters just long enough to cross it. In the example '#' is used. It's possible to use a repeating sequence by dividing the columns by the number of characters in the sequence like this: \$ seq -s'~-' 0 \$(( \$(tput cols) /2 )) | tr -d '[:digit:]' or \$ seq -s'-~?' 0 \$(( \$(tput cols) /3 )) | tr -d '[:digit:]' You will lose chararacters at the end if the length isn't cleanly divisible.

Which processes are listening on a specific port (e.g. port 80)
swap out "80" for your port of interest. Can use port number or named ports e.g. "http"

Most used command

follow the content of all files in a directory
The `-q' arg forces tail to not output the name of the current file

find co-ordinates of a location
Just add this to your .bashrc file. Use quotes when query has multiple word length.

Repeatedly send a string to stdout-- useful for going through "yes I agree" screens

Gets all videos in your boxee queue with a URL associated with them and attempts to download each using get_flash_videos

List all execs in \$PATH, usefull for grepping the resulting list
While it seems (to me at least) a little counter-intuitive to filter on name first, this requires less work for find, as it allows it to immediately discount any files that do not match the name directly from the directory listing on disk. Querying against file attributes requires reading the file attributes, which is performed for all files matching any name based predicates.