0
0
mirror of https://github.com/vim/vim.git synced 2025-09-28 04:24:06 -04:00

patch 8.2.1384: no ATTENTION prompt for :vimgrep first match file

Problem:    No ATTENTION prompt for :vimgrep first match file.
Solution:   When there is an existing swap file do not keep the dummy buffer.
            (closes #6649)
This commit is contained in:
Bram Moolenaar
2020-08-07 18:12:18 +02:00
parent 9470a4d88a
commit 8ce4b7ed85
4 changed files with 44 additions and 1 deletions

View File

@@ -6015,6 +6015,23 @@ vgr_process_args(
return OK; return OK;
} }
/*
* Return TRUE if "buf" had an existing swap file, the current swap file does
* not end in ".swp".
*/
static int
existing_swapfile(buf_T *buf)
{
if (buf->b_ml.ml_mfp != NULL)
{
char_u *fname = buf->b_ml.ml_mfp->mf_fname;
size_t len = STRLEN(fname);
return fname[len - 1] != 'p' || fname[len - 2] != 'w';
}
return FALSE;
}
/* /*
* Search for a pattern in a list of files and populate the quickfix list with * Search for a pattern in a list of files and populate the quickfix list with
* the matches. * the matches.
@@ -6125,7 +6142,8 @@ vgr_process_files(
buf = NULL; buf = NULL;
} }
else if (buf != *first_match_buf else if (buf != *first_match_buf
|| (cmd_args->flags & VGR_NOJUMP)) || (cmd_args->flags & VGR_NOJUMP)
|| existing_swapfile(buf))
{ {
unload_dummy_buffer(buf, dirname_start); unload_dummy_buffer(buf, dirname_start);
// Keeping the buffer, remove the dummy flag. // Keeping the buffer, remove the dummy flag.

View File

@@ -91,6 +91,9 @@ set encoding=utf-8
let s:test_script_fname = expand('%') let s:test_script_fname = expand('%')
au! SwapExists * call HandleSwapExists() au! SwapExists * call HandleSwapExists()
func HandleSwapExists() func HandleSwapExists()
if exists('g:ignoreSwapExists')
return
endif
" Ignore finding a swap file for the test script (the user might be " Ignore finding a swap file for the test script (the user might be
" editing it and do ":make test_name") and the output file. " editing it and do ":make test_name") and the output file.
" Report finding another swap file and chose 'q' to avoid getting stuck. " Report finding another swap file and chose 'q' to avoid getting stuck.

View File

@@ -2837,6 +2837,26 @@ func Test_vimgrep_with_no_last_search_pat()
call delete('Xresult') call delete('Xresult')
endfunc endfunc
func Test_vimgrep_existing_swapfile()
call writefile(['match apple with apple'], 'Xapple')
call writefile(['swapfile'], '.Xapple.swp')
let g:foundSwap = 0
let g:ignoreSwapExists = 1
augroup grep
au SwapExists * let foundSwap = 1 | let v:swapchoice = 'e'
augroup END
vimgrep apple Xapple
call assert_equal(1, g:foundSwap)
call assert_match('.Xapple.swo', swapname(''))
call delete('Xapple')
call delete('Xapple.swp')
augroup grep
au! SwapExists
augroup END
unlet g:ignoreSwapExists
endfunc
func XfreeTests(cchar) func XfreeTests(cchar)
call s:setup_commands(a:cchar) call s:setup_commands(a:cchar)

View File

@@ -754,6 +754,8 @@ static char *(features[]) =
static int included_patches[] = static int included_patches[] =
{ /* Add new patch number below this line */ { /* Add new patch number below this line */
/**/
1384,
/**/ /**/
1383, 1383,
/**/ /**/