Hide

What's this?

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/

Get involved!

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.

Hide

Stay in the loop…

Follow the Tweets.

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

Subscribe to the feeds.

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:

Hide

News

2011-03-12 - Confoo 2011 presentation
Slides are available from the commandlinefu presentation at Confoo 2011: http://presentations.codeinthehole.com/confoo2011/
2011-01-04 - Moderation now required for new commands
To try and put and end to the spamming, new commands require moderation before they will appear on the site.
2010-12-27 - Apologies for not banning the trolls sooner
Have been away from the interwebs over Christmas. Will be more vigilant henceforth.
2010-09-24 - OAuth and pagination problems fixed
Apologies for the delay in getting Twitter's OAuth supported. Annoying pagination gremlin also fixed.
Hide

Tags

Hide

Functions

Save a file you edited in vim without the needed permissions

Terminal - Save a file you edited in vim without the needed permissions
:w !sudo tee %
2009-02-25 16:27:24
User: skinp
Functions: tee
634
Save a file you edited in vim without the needed permissions

I often forget to sudo before editing a file I don't have write permissions on. When you come to save that file and get the infamous "E212: Can't open file for writing", just issue that vim command in order to save the file without the need to save it to a temp file and then copy it back again.

Alternatives

There is 1 alternative - vote for the best!

Terminal - Alternatives
:w !sudo tee > /dev/null %
2010-03-24 20:04:26
User: idemal
Functions: tee
Tags: vim sudo tee
24

Write a file you edited in Vim but that you do not have the permissions to write to (unless you use sudo.) Same as #1204 but without the echo to stdout that I find annoying.

command W :execute ':silent w !sudo tee % > /dev/null' | :edit!
2011-10-06 20:37:54
Functions: command tee
Tags: vim sudo tee
7

Calls sudo tee like all the other lines, but also automatically reloads the file.

Optionally you can add

command Wq :execute ':W' | :q

and

command WQ :Wq

to make quitting easier

:w !pfexec tee %
:%!sudo tee %
2011-06-17 07:16:23
User: antone
Functions: tee
Tags: vim sudo tee
1

probably just like 1204, but uses tee as a filter (+ I actually understand how this one works)

w !sudo cat >%

Know a better way?

If you can do better, submit your command here.

What others think

this is just awesome! of course you have to have sudo rights...

Comment by nottings 295 weeks and 3 days ago

awe-some !

Comment by pyrho 295 weeks and 3 days ago

Unfortunately this does not work well in gvim.

Comment by trey 295 weeks ago

I wish I could vote this up more than once. Thanks!

Comment by Alanceil 295 weeks ago

nice - thanks!

Comment by waltharius 292 weeks and 5 days ago

I use

:w !cat > %

which is similar, but shorter (you can add sudo in there if you want).

Comment by spatz 288 weeks and 6 days ago

awesome!

Comment by Iany 285 weeks and 2 days ago

I always quit vi and sudo vi when I find I haven't write permission before. This command save me much time.

Comment by kylexlau 284 weeks and 2 days ago

!sudo cat > % won't work:

* the su-ed command is "cat" but

* > % isn't an argument for "cat", but a redirection

it's the same for sudo echo > myRootFile.txt

you could try with sudo sh -c "cat > %" but it's longer

so tee is ok.

comments welcome.

Comment by ioggstream 276 weeks and 3 days ago

greatest commend ever!!! tnx!

Comment by ilyxa 273 weeks and 3 days ago

how often did i miss this command, perfect!

+1 vote for greatest command ever

Comment by buergi 268 weeks and 2 days ago

i have added:

cmap w!! %!sudo tee > /dev/null %

to my .vimrc, so I can just use :w!! to write files with sudo

Comment by f3lix 259 weeks and 5 days ago

Pretty sweet. I'm an Emacs guy, but I'm impressed with the succinct way vi handles changing effective UID.

By the way, does this work for files that have spaces in the filenames? I would guess that it wouldn't. Is it fixable by double-quoting the %?

Comment by hackerb9 256 weeks and 3 days ago

You made me curious about filenames with spaces so I had to try it out. It only works with the "%". But as a general rule, I try not to name Unix files with spaces.

Comment by skinp 256 weeks and 2 days ago

Really nice! I just freaked out when I tried this with nvi (in Ubuntu 9.10)... it did not ask for my password and yet it wrote an /etc file. Please shed some light!

Comment by ez77 252 weeks and 3 days ago

Wow, this will come in handy. So will f3lix's :w!!

but I like to use abbreviations, i think they are cleaner than remapping:

ca w!! w !sudo tee "%"
Comment by jearsh 247 weeks and 3 days ago

Thanks for this. It will save me a lot of frustration.

Comment by idemal 239 weeks and 3 days ago

is this also possible for nano?

Comment by rubo77 229 weeks and 4 days ago

Cool.!

Comment by knityster 216 weeks and 6 days ago

Make sure to configure sudo properly to ask you for your ROOT password and not your USER password.

Otherwise it reduces the security of your system.

Comment by grep 194 weeks and 6 days ago

:w !sudo tee %

I'm hoping someone can elaborate on this command for me.

Not sure I understand what the "%" is doing, and where tee is getting its input from. Tee reads from standard input and outputs to the first argument (file), which in this case, is the "%". In VIM, the "%" is often used with regular expressions to mean "every line in the file".

So how is this working? Because using those definitions, the command doesn't make any sense.

Comment by yohhan 191 weeks and 3 days ago

...I should add, great command. This situation happens to me all of the time.

Comment by yohhan 191 weeks and 3 days ago

Have my babies? Just kidding. Awesome solution for a common derp.

Comment by SpaceKraken 190 weeks ago

I can not tell you how often i use this.

Comment by threv 150 weeks and 2 days ago

@yohhan % in vim command line mode , It represents current file, you can test it with :!echo % in vim

Comment by dfang 116 weeks and 5 days ago

@yohhan or :h cmdline-special

Comment by dfang 116 weeks and 5 days ago

Your point of view

You must be signed in to comment.

Related sites and podcasts