mirror of
https://github.com/vim/vim.git
synced 2025-09-27 04:14: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:
@@ -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.
|
||||||
|
@@ -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.
|
||||||
|
@@ -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)
|
||||||
|
|
||||||
|
@@ -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,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user