Wikia

Vim Tips Wiki

Swap file "..."already exists! - so diff it

Talk0
1,610pages on
this wiki
Revision as of 23:46, May 31, 2013 by 103.1.70.96 (Talk)

Tip 1517 Printable Monobook Previous Next

created 2007 · complexity intermediate · author Richard Bronosky · version 7.0


When opening a file (in this example geocode.py) in Vim, I regularly encounter messages like:

E325: ATTENTION
Found a swap file by the name ".geocode.py.swp"
          owned by: rbronosky   dated: Fri Sep  7 17:17:37 2007
         file name: geocode.py
          modified: YES
         user name: rbronosky
        process ID: 6490
While opening file "geocode.py"
             dated: Fri Sep  7 17:17:04 2007
(1) Another program may be editing the same file.
    If this is the case, be careful not to end up with two
    different instances of the same file when making changes.
    Quit, or continue with caution.
(2) An edit session for this file crashed.
    If this is the case, use ":recover" or "vim -r geocode.py"
    to recover the changes (see ":help recovery").
    If you did this already, delete the swap file ".geocode.py.swp"
    to avoid this message.
Swap file ".geocode.py.swp" already exists!
[O]pen Read-Only, (E)dit anyway, (R)ecover, (D)elete it, (Q)uit, (A)bort:

This is the result of not properly closing an open buffer, usually because of a lost ssh connection. If there were unsaved changes, they can be recovered from this swap file. In order to know if this swap file is of value to me, I need to do some investigating. I have developed a system for resolving this quickly with as few keystrokes as possible.

  1. r # at the prompt hit "r" to recover the swap file
  2.  :sav! /tmp/%
  3.  :vs
  4.  :diffthis
  5. CTRL-W_l
  6.  :bp
  7. e # at the prompt hit "e" to edit anyway
  8.  :diffthis

The result will be a vertically split screen with the swap file on the left and the regular file on the right. You will be in diff mode and if the files are identical they will both be folded into one line.

Sure, this would make a good script, but I am a big fan of "learn to do it by hand". That way you can do it on any system, and you can use each of the little steps to aid your daily vimming.

If you want to know more about the commands used, use :help, for example:

See also

Comments

Losing swapfiles

After recovering a file from a swapfile and deleting the swapfile you will usually use swapname .swo (or similar). If something goes wrong again, vim will not detect the .swo swapfile on startup. It is useful to restart vim, or do the following trick:

:set swf!|set swf!

In this way vim will delete the .swo swapfile and make a new one ending with.swp (you can check this with :swapname command). Now you are completely safe.


Automatically deleting redundant swapfiles with a shellscript

This is a useful trick, but it would be better if it was automated. Also in the situation where the recovered swapfile turns out to be identical to the real file, there is no need for the diffing. I use a shellscript to help deal with swapfiles, before starting Vim:

# Expects variables realfile, swapfile, recoveryfile.
vim -r "$swapfile" -c ":wq! $recoveryfile" && rm "$swapfile"
if cmp "$recoveryfile" "$realfile"
then rm "$recoveryfile"
else vimdiff "$recoveryfile" "$realfile"
fi


Quick comparison with a little plugin

Instead of steps 2-8 above, I do a quick comparison with:

2. :DiffAgainstFileOnDisk

And after that I do :e<Enter>d to delete the swapfile, or :w! to overwrite the file.

For this shortcut you will need a system with diff, and this script in ~/.vim/plugin/diff_against_file_on_disk.vim

command! DiffAgainstFileOnDisk call DiffAgainstFileOnDisk()

function! DiffAgainstFileOnDisk()
  :w! /tmp/working_copy
  exec "!diff /tmp/working_copy %"
endfunction


Feature Request

For goodness sake, if the swapfile is identical to the file on disk, then Vim should just automatically drop it for us, and not give us a prompt at all...

Advertisement | Your ad here

Around Wikia's network

Random Wiki