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:
There is 1 alternative - vote for the best!
If you can do better, submit your command here.
You must be signed in to comment.
cd -
@unixmonkey14106: You've misunderstood the meaning.
soulonfire's command will cd into the "most recently created" directory.
Your command will cd into the "user's previous location".
Very interesting. I can see it being very useful in log dirs.
However, we can improve on it with a bit of ls magic:
GNU ls has a "--group-directories-first" option which is just what we want.
Add to that, -1 (one entry per line) and we're ready.
alias cd1='cd $(ls -1t --group-directories-first | head -1)'Of course getopt (the options parser in ls) allows us to use the unique portion of long options, so we can abbreviate the command significantly!
alias cd1='cd $(ls -1t --g | head -1)'flatcap: `ls -lt --g |head -1` returns "total 58024". I think you should drop the '-l' parameter.
Also: both the original command, and flatcap's improvement will attempt to cd into a non-directory if there are no sub-directories in the cwd.
No, wait, sorry: the original won't because it uses 'grep -v ^d'. However, in *BOTH* cases, if no sub-directory is found, it will launch 'cd' with no arguments, which will change the cwd to $HOME instead of throwing an error, and that could be dangerous.
While I'm here: it's more efficient to use sed than to use `grep | cut`.
sed -n 's/^d.\{50\}//p'damnit, I wish I could edit or delete my comments, I keep misspeaking.
cd $(ls -lt | grep ^d | head -1 | cut -b 51- )... will go to $HOME if no subdir is found.
I mistook the '1' in flatcap's comment for a "l", so "total 58024" won't happen.
cd $(ls -1t --g | head -1)... will return "cd: mrubbit.png: Not a directory" or something similar if no subdir is found
This will work and it is safer, but it's not really a one-liner anymore, and it clobbers whatever you had set in $OD:
alias cd1='OD=$(ls -lt |sed -n "/^d/ {s/^.\{51\}//p;q;}"); [ "$OD" ] && cd "$OD" || echo "no subdirs" >&2'