mirror of
https://github.com/neovim/neovim.git
synced 2025-09-23 19:48:32 +00:00
Merge pull request #17132 from zeertzjq/vim-8.2.3611
vim-patch:8.2.{3494,3611,3613}: two Visual mode crash fixes
This commit is contained in:
@@ -1433,7 +1433,11 @@ char_u *find_file_in_path_option(char_u *ptr, size_t len, int options, int first
|
|||||||
rel_fname = NULL;
|
rel_fname = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (first == TRUE) {
|
if (first == true) {
|
||||||
|
if (len == 0) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
// copy file name into NameBuff, expanding environment variables
|
// copy file name into NameBuff, expanding environment variables
|
||||||
save_char = ptr[len];
|
save_char = ptr[len];
|
||||||
ptr[len] = NUL;
|
ptr[len] = NUL;
|
||||||
|
@@ -4472,8 +4472,13 @@ bool get_visual_text(cmdarg_T *cap, char_u **pp, size_t *lenp)
|
|||||||
*pp = ml_get_pos(&VIsual);
|
*pp = ml_get_pos(&VIsual);
|
||||||
*lenp = (size_t)curwin->w_cursor.col - (size_t)VIsual.col + 1;
|
*lenp = (size_t)curwin->w_cursor.col - (size_t)VIsual.col + 1;
|
||||||
}
|
}
|
||||||
// Correct the length to include the whole last character.
|
if (**pp == NUL) {
|
||||||
*lenp += (size_t)(utfc_ptr2len(*pp + (*lenp - 1)) - 1);
|
*lenp = 0;
|
||||||
|
}
|
||||||
|
if (*lenp > 0) {
|
||||||
|
// Correct the length to include all bytes of the last character.
|
||||||
|
*lenp += (size_t)(utfc_ptr2len(*pp + (*lenp - 1)) - 1);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
reset_VIsual_and_resel();
|
reset_VIsual_and_resel();
|
||||||
return true;
|
return true;
|
||||||
@@ -5963,11 +5968,8 @@ static void nv_visual(cmdarg_T *cap)
|
|||||||
* was only one -- webb
|
* was only one -- webb
|
||||||
*/
|
*/
|
||||||
if (resel_VIsual_mode != 'v' || resel_VIsual_line_count > 1) {
|
if (resel_VIsual_mode != 'v' || resel_VIsual_line_count > 1) {
|
||||||
curwin->w_cursor.lnum +=
|
curwin->w_cursor.lnum += resel_VIsual_line_count * cap->count0 - 1;
|
||||||
resel_VIsual_line_count * cap->count0 - 1;
|
check_cursor();
|
||||||
if (curwin->w_cursor.lnum > curbuf->b_ml.ml_line_count) {
|
|
||||||
curwin->w_cursor.lnum = curbuf->b_ml.ml_line_count;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
VIsual_mode = resel_VIsual_mode;
|
VIsual_mode = resel_VIsual_mode;
|
||||||
if (VIsual_mode == 'v') {
|
if (VIsual_mode == 'v') {
|
||||||
|
@@ -1682,6 +1682,10 @@ char_u *find_file_name_in_path(char_u *ptr, size_t len, int options, long count,
|
|||||||
char_u *file_name;
|
char_u *file_name;
|
||||||
char_u *tofree = NULL;
|
char_u *tofree = NULL;
|
||||||
|
|
||||||
|
if (len == 0) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
if ((options & FNAME_INCL) && *curbuf->b_p_inex != NUL) {
|
if ((options & FNAME_INCL) && *curbuf->b_p_inex != NUL) {
|
||||||
tofree = (char_u *)eval_includeexpr((char *)ptr, len);
|
tofree = (char_u *)eval_includeexpr((char *)ptr, len);
|
||||||
if (tofree != NULL) {
|
if (tofree != NULL) {
|
||||||
|
@@ -1120,7 +1120,35 @@ func Test_visual_block_with_virtualedit()
|
|||||||
" clean up
|
" clean up
|
||||||
call term_sendkeys(buf, "\<Esc>")
|
call term_sendkeys(buf, "\<Esc>")
|
||||||
call StopVimInTerminal(buf)
|
call StopVimInTerminal(buf)
|
||||||
call delete('XTest_beval')
|
call delete('XTest_block')
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
func Test_visual_block_ctrl_w_f()
|
||||||
|
" Emtpy block selected in new buffer should not result in an error.
|
||||||
|
au! BufNew foo sil norm f
|
||||||
|
edit foo
|
||||||
|
|
||||||
|
au! BufNew
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
func Test_visual_reselect_with_count()
|
||||||
|
" this was causing an illegal memory access
|
||||||
|
let lines =<< trim END
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
:
|
||||||
|
r<sfile>
|
||||||
|
exe "%norm e3\<c-v>kr\t"
|
||||||
|
:
|
||||||
|
|
||||||
|
:
|
||||||
|
END
|
||||||
|
call writefile(lines, 'XvisualReselect')
|
||||||
|
source XvisualReselect
|
||||||
|
|
||||||
|
bwipe!
|
||||||
|
call delete('XvisualReselect')
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user