Patch 8.2.1970

12 views
Skip to first unread message

Bram Moolenaar

unread,
Nov 9, 2020, 3:07:09 PM11/9/20
to vim...@googlegroups.com

Patch 8.2.1970
Problem: It is easy to make mistakes when cleaning up swap files after the
system crashed.
Solution: Warn for the process still running after recovery. Do not
automatically delete a swap file created on another system.
(David Fries, closes #7273)
Files: src/memline.c, src/testdir/test_swap.vim


*** ../vim-8.2.1969/src/memline.c 2020-10-24 20:49:37.498683038 +0200
--- src/memline.c 2020-11-09 20:25:42.550671331 +0100
***************
*** 1690,1696 ****
}
else
msg(_("Recovery completed. Buffer contents equals file contents."));
! msg_puts(_("\nYou may want to delete the .swp file now.\n\n"));
cmdline_row = msg_row;
}
#ifdef FEAT_CRYPT
--- 1690,1706 ----
}
else
msg(_("Recovery completed. Buffer contents equals file contents."));
! msg_puts(_("\nYou may want to delete the .swp file now."));
! #if defined(UNIX) || defined(MSWIN)
! if (mch_process_running(char_to_long(b0p->b0_pid)))
! {
! // Warn there could be an active Vim on the same file, the user may
! // want to kill it.
! msg_puts(_("\nNote: process STILL RUNNING: "));
! msg_outnum(char_to_long(b0p->b0_pid));
! }
! #endif
! msg_puts("\n\n");
cmdline_row = msg_row;
}
#ifdef FEAT_CRYPT
***************
*** 2230,2243 ****
ret = FALSE;

#if defined(UNIX) || defined(MSWIN)
// process must be known and not be running
pid = char_to_long(b0.b0_pid);
if (pid == 0L || mch_process_running(pid))
ret = FALSE;
#endif

! // TODO: Should we check if the swap file was created on the current
! // system? And the current user?

close(fd);
return ret;
--- 2240,2269 ----
ret = FALSE;

#if defined(UNIX) || defined(MSWIN)
+ // Host name must be known and must equal the current host name, otherwise
+ // comparing pid is meaningless.
+ if (*(b0.b0_hname) == NUL)
+ {
+ ret = FALSE;
+ }
+ else
+ {
+ char_u hostname[B0_HNAME_SIZE];
+
+ mch_get_host_name(hostname, B0_HNAME_SIZE);
+ hostname[B0_HNAME_SIZE - 1] = NUL;
+ if (STRICMP(b0.b0_hname, hostname) != 0)
+ ret = FALSE;
+ }
+
// process must be known and not be running
pid = char_to_long(b0.b0_pid);
if (pid == 0L || mch_process_running(pid))
ret = FALSE;
#endif

! // We do not check the user, it should be irrelevant for whether the swap
! // file is still useful.

close(fd);
return ret;
*** ../vim-8.2.1969/src/testdir/test_swap.vim 2020-08-12 18:50:31.887655765 +0200
--- src/testdir/test_swap.vim 2020-11-09 20:56:24.753178270 +0100
***************
*** 403,406 ****
--- 403,452 ----
call delete('Xswapdir', 'rf')
endfunc

+ func Test_swap_auto_delete()
+ " Create a valid swapfile by editing a file with a special extension.
+ split Xtest.scr
+ call setline(1, ['one', 'two', 'three'])
+ write " file is written, not modified
+ write " write again to make sure the swapfile is created
+ " read the swapfile as a Blob
+ let swapfile_name = swapname('%')
+ let swapfile_bytes = readfile(swapfile_name, 'B')
+
+ " Forget about the file, recreate the swap file, then edit it again. The
+ " swap file should be automatically deleted.
+ bwipe!
+ " change the process ID to avoid the "still running" warning
+ let swapfile_bytes[24] = 0x99
+ call writefile(swapfile_bytes, swapfile_name)
+ edit Xtest.scr
+ " will end up using the same swap file after deleting the existing one
+ call assert_equal(swapfile_name, swapname('%'))
+ bwipe!
+
+ " create the swap file again, but change the host name so that it won't be
+ " deleted
+ autocmd! SwapExists
+ augroup test_swap_recover_ext
+ autocmd!
+ autocmd SwapExists * let v:swapchoice = 'e'
+ augroup END
+
+ " change the host name
+ let swapfile_bytes[28 + 40] = 0x89
+ call writefile(swapfile_bytes, swapfile_name)
+ edit Xtest.scr
+ call assert_equal(1, filereadable(swapfile_name))
+ " will use another same swap file name
+ call assert_notequal(swapfile_name, swapname('%'))
+ bwipe!
+
+ call delete('Xtest.scr')
+ call delete(swapfile_name)
+ augroup test_swap_recover_ext
+ autocmd!
+ augroup END
+ augroup! test_swap_recover_ext
+ endfunc
+
" vim: shiftwidth=2 sts=2 expandtab
*** ../vim-8.2.1969/src/version.c 2020-11-09 18:31:30.548791857 +0100
--- src/version.c 2020-11-09 20:56:59.881091542 +0100
***************
*** 752,753 ****
--- 752,755 ----
{ /* Add new patch number below this line */
+ /**/
+ 1970,
/**/

--
hundred-and-one symptoms of being an internet addict:
224. You set up your own Web page. You set up a Web page for each
of your kids... and your pets.

/// Bram Moolenaar -- Br...@Moolenaar.net -- http://www.Moolenaar.net \\\
/// sponsor Vim, vote for features -- http://www.Vim.org/sponsor/ \\\
\\\ an exciting new programming language -- http://www.Zimbu.org ///
\\\ help me help AIDS victims -- http://ICCF-Holland.org ///
Reply all
Reply to author
Forward
0 new messages