commandlinefu.com is the place to record those command-line gems that you return to again and again.
Delete that bloated snippets file you've been using and share your personal repository with the world. 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.
If you have a new feature suggestion or find a bug, please get in touch via http://commandlinefu.uservoice.com/
You can sign-in using OpenID credentials, or register a traditional username and password.
First-time OpenID users will be automatically assigned a username which can be changed after signing in.
Every new command is wrapped in a tweet and posted to Twitter. Following the stream is a great way of staying abreast of the latest commands. For the more discerning, there are Twitter accounts for commands that get a minimum of 3 and 10 votes - that way only the great commands get tweeted.
» http://twitter.com/commandlinefu
» http://twitter.com/commandlinefu3
» http://twitter.com/commandlinefu10
Use your favourite RSS aggregator to stay in touch with the latest commands. There are feeds mirroring the 3 Twitter streams as well as for virtually every other subset (users, tags, functions,…):
Subscribe to the feed for:
355 # from zsh-users
356 edit_command_line () {
357 # edit current line in $EDITOR
358 local tmpfile=${TMPPREFIX:-/tmp/zsh}ecl$$
359
360 print -R - "$PREBUFFER$BUFFER" >$tmpfile
361 exec
362 ${VISUAL:-${EDITOR:-vi}} $tmpfile
363 zle kill-buffer
364 BUFFER=${"$(
365 CURSOR=$#BUFFER
366
367 command rm -f $tmpfile
368 zle redisplay
369 }
370 zle -N edit_command_line
There are 2 alternatives - vote for the best!
I don't know if you've used sqsh before. But it has a handy feature that allows you to switch into vim to complete editing of whatever complicated SQL statement you are trying to run.
But I got to thinking -- why doesn't bash have that? Well, it does. It's called '|'!
Jk.
Seriously, I'm pretty sure this flow of commands will revolutionize how I administer files. And b/c everything is a file on *nx based distros, well, it's handy.
First, if your ls is aliased to ls --color=auto, then create another alias in your .bashrc:
alias lsp='ls --color=none'
Now, let's say you want to rename all files that begin with the prefix 'ras' to files that begin with a 'raster' prefix.
You could do it with some bash substitution. But who remembers that? I remember vim macros because I can remember to press 'qa' and how to move around in vim. Plus, it's more incremental. You can check things along the way. That is the secret to development and probably the universe. So type something like:
lsp | grep ras
Are those all the files you need to move? If not, modify and re-grep. If so, pipe it to vim.
lsp | grep ras | vim -
Now run your vim macros to modify the first line. Assuming you use 'w' and 'b' to move around, etc., it should work for all lines. Hold down '@@', etc., until your list of files has been modified from
ras_a.h
ras_a.cpp
ras_b.h
ras_b.cpp
to:
mv ras_a.h raster_a.h
mv ras_a.cpp raster_a.cpp
mv ras_b.h raster_b.h
mv ras_b.h raster_b.cpp
then run :%!bash
then run :q!
then be like, whaaaaa? as you realize your workflow got a little more continuous. maybe. YMMV.
If you can do better, submit your command here.
You must be signed in to comment.