mirror of
https://github.com/neovim/neovim.git
synced 2025-02-25 18:55:25 -06:00
Merge pull request #13497 from seandewar/vim-8.2.2121
vim-patch:8.2.{2121,2123}
This commit is contained in:
commit
638f5d5b95
@ -742,6 +742,7 @@ static int pum_set_selected(int n, int repeat)
|
|||||||
// Edit a new, empty buffer. Set options for a "wipeout"
|
// Edit a new, empty buffer. Set options for a "wipeout"
|
||||||
// buffer.
|
// buffer.
|
||||||
set_option_value("swf", 0L, NULL, OPT_LOCAL);
|
set_option_value("swf", 0L, NULL, OPT_LOCAL);
|
||||||
|
set_option_value("bl", 0L, NULL, OPT_LOCAL);
|
||||||
set_option_value("bt", 0L, "nofile", OPT_LOCAL);
|
set_option_value("bt", 0L, "nofile", OPT_LOCAL);
|
||||||
set_option_value("bh", 0L, "wipe", OPT_LOCAL);
|
set_option_value("bh", 0L, "wipe", OPT_LOCAL);
|
||||||
set_option_value("diff", 0L, NULL, OPT_LOCAL);
|
set_option_value("diff", 0L, NULL, OPT_LOCAL);
|
||||||
|
@ -3605,6 +3605,22 @@ theend:
|
|||||||
if (backpos.ga_maxlen > BACKPOS_INITIAL)
|
if (backpos.ga_maxlen > BACKPOS_INITIAL)
|
||||||
ga_clear(&backpos);
|
ga_clear(&backpos);
|
||||||
|
|
||||||
|
// Make sure the end is never before the start. Can happen when \zs and
|
||||||
|
// \ze are used.
|
||||||
|
if (REG_MULTI) {
|
||||||
|
const lpos_T *const start = &rex.reg_mmatch->startpos[0];
|
||||||
|
const lpos_T *const end = &rex.reg_mmatch->endpos[0];
|
||||||
|
|
||||||
|
if (end->lnum < start->lnum
|
||||||
|
|| (end->lnum == start->lnum && end->col < start->col)) {
|
||||||
|
rex.reg_mmatch->endpos[0] = rex.reg_mmatch->startpos[0];
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (rex.reg_match->endp[0] < rex.reg_match->startp[0]) {
|
||||||
|
rex.reg_match->endp[0] = rex.reg_match->startp[0];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -6591,6 +6591,22 @@ static long nfa_regexec_both(char_u *line, colnr_T startcol,
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
theend:
|
theend:
|
||||||
|
// Make sure the end is never before the start. Can happen when \zs and
|
||||||
|
// \ze are used.
|
||||||
|
if (REG_MULTI) {
|
||||||
|
const lpos_T *const start = &rex.reg_mmatch->startpos[0];
|
||||||
|
const lpos_T *const end = &rex.reg_mmatch->endpos[0];
|
||||||
|
|
||||||
|
if (end->lnum < start->lnum
|
||||||
|
|| (end->lnum == start->lnum && end->col < start->col)) {
|
||||||
|
rex.reg_mmatch->endpos[0] = rex.reg_mmatch->startpos[0];
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (rex.reg_match->endp[0] < rex.reg_match->startp[0]) {
|
||||||
|
rex.reg_match->endp[0] = rex.reg_match->startp[0];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -755,6 +755,13 @@ func Test_start_end_of_buffer_match()
|
|||||||
bwipe!
|
bwipe!
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func Test_ze_before_zs()
|
||||||
|
call assert_equal('', matchstr(' ', '\%#=1\ze \zs'))
|
||||||
|
call assert_equal('', matchstr(' ', '\%#=2\ze \zs'))
|
||||||
|
call assert_equal(repeat([''], 10), matchlist(' ', '\%#=1\ze \zs'))
|
||||||
|
call assert_equal(repeat([''], 10), matchlist(' ', '\%#=2\ze \zs'))
|
||||||
|
endfunc
|
||||||
|
|
||||||
" Check for detecting error
|
" Check for detecting error
|
||||||
func Test_regexp_error()
|
func Test_regexp_error()
|
||||||
set regexpengine=2
|
set regexpengine=2
|
||||||
|
Loading…
Reference in New Issue
Block a user