mirror of
https://github.com/neovim/neovim.git
synced 2026-04-30 19:24:09 +00:00
Merge pull request #13581 from janlazo/vim-8.2.2174
vim-patch:8.2.{2174,2175,2176,2177,2181}
This commit is contained in:
@@ -902,8 +902,9 @@ int foldMoveTo(
|
||||
bool last = false;
|
||||
for (;; ) {
|
||||
if (!foldFind(gap, curwin->w_cursor.lnum - lnum_off, &fp)) {
|
||||
if (!updown)
|
||||
if (!updown || gap->ga_len == 0) {
|
||||
break;
|
||||
}
|
||||
|
||||
/* When moving up, consider a fold above the cursor; when
|
||||
* moving down consider a fold below the cursor. */
|
||||
|
||||
@@ -3605,19 +3605,21 @@ theend:
|
||||
if (backpos.ga_maxlen > BACKPOS_INITIAL)
|
||||
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 (retval > 0) {
|
||||
// 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];
|
||||
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];
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -5243,9 +5243,12 @@ static int nfa_regmatch(nfa_regprog_T *prog, nfa_state_T *start,
|
||||
switch (t->state->c) {
|
||||
case NFA_MATCH:
|
||||
{
|
||||
// If the match ends before a composing characters and
|
||||
// rex.reg_icombine is not set, that is not really a match.
|
||||
if (!rex.reg_icombine && utf_iscomposing(curc)) {
|
||||
// If the match is not at the start of the line, ends before a
|
||||
// composing characters and rex.reg_icombine is not set, that
|
||||
// is not really a match.
|
||||
if (!rex.reg_icombine
|
||||
&& rex.input != rex.line
|
||||
&& utf_iscomposing(curc)) {
|
||||
break;
|
||||
}
|
||||
nfa_match = true;
|
||||
@@ -6591,19 +6594,21 @@ static long nfa_regexec_both(char_u *line, colnr_T startcol,
|
||||
#endif
|
||||
|
||||
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 (retval > 0) {
|
||||
// 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 (retval > 0) {
|
||||
if (rex.reg_match->endp[0] < rex.reg_match->startp[0]) {
|
||||
rex.reg_match->endp[0] = rex.reg_match->startp[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];
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -815,4 +815,11 @@ func Test_fold_create_delete_create()
|
||||
bwipe!
|
||||
endfunc
|
||||
|
||||
" this was crashing
|
||||
func Test_fold_create_delete()
|
||||
new
|
||||
norm zFzFzdzj
|
||||
bwipe!
|
||||
endfunc
|
||||
|
||||
" vim: shiftwidth=2 sts=2 expandtab
|
||||
|
||||
@@ -533,4 +533,15 @@ func Test_search_with_end_offset()
|
||||
close!
|
||||
endfunc
|
||||
|
||||
" Check that "^" matches even when the line starts with a combining char
|
||||
func Test_match_start_of_line_combining()
|
||||
new
|
||||
call setline(1, ['', "\u05ae", ''])
|
||||
exe "normal gg/^\<CR>"
|
||||
call assert_equal(2, getcurpos()[1])
|
||||
bwipe!
|
||||
endfunc
|
||||
|
||||
|
||||
|
||||
" vim: shiftwidth=2 sts=2 expandtab
|
||||
|
||||
Reference in New Issue
Block a user