vim-patch:8.2.3919: Vim9: wrong argument for append() results in two errors

Problem:    Vim9: wrong argument for append() results in two errors.
Solution:   Check did_emsg.  Also for setline().  Adjust the help for
            appendbufline().

8b6256f6ec

Co-authored-by: Bram Moolenaar <Bram@vim.org>
This commit is contained in:
zeertzjq 2022-11-05 14:31:40 +08:00
parent 5731f406fa
commit 48405df046
3 changed files with 27 additions and 10 deletions

View File

@ -654,9 +654,10 @@ appendbufline({buf}, {lnum}, {text}) *appendbufline()*
For the use of {buf}, see |bufname()|. For the use of {buf}, see |bufname()|.
{lnum} is used like with |append()|. Note that using |line()| {lnum} is the line number to append below. Note that using
would use the current buffer, not the one appending to. |line()| would use the current buffer, not the one appending
Use "$" to append at the end of the buffer. to. Use "$" to append at the end of the buffer. Other string
values are not supported.
On success 0 is returned, on failure 1 is returned. On success 0 is returned, on failure 1 is returned.

View File

@ -5200,6 +5200,7 @@ linenr_T tv_get_lnum_buf(const typval_T *const tv, const buf_T *const buf)
if (tv->v_type == VAR_STRING if (tv->v_type == VAR_STRING
&& tv->vval.v_string != NULL && tv->vval.v_string != NULL
&& tv->vval.v_string[0] == '$' && tv->vval.v_string[0] == '$'
&& tv->vval.v_string[1] == NUL
&& buf != NULL) { && buf != NULL) {
return buf->b_ml.ml_line_count; return buf->b_ml.ml_line_count;
} }

View File

@ -365,20 +365,25 @@ static void f_api_info(typval_T *argvars, typval_T *rettv, EvalFuncData fptr)
/// "append(lnum, string/list)" function /// "append(lnum, string/list)" function
static void f_append(typval_T *argvars, typval_T *rettv, EvalFuncData fptr) static void f_append(typval_T *argvars, typval_T *rettv, EvalFuncData fptr)
{ {
const int did_emsg_before = did_emsg;
const linenr_T lnum = tv_get_lnum(&argvars[0]); const linenr_T lnum = tv_get_lnum(&argvars[0]);
if (did_emsg == did_emsg_before) {
set_buffer_lines(curbuf, lnum, true, &argvars[1], rettv); set_buffer_lines(curbuf, lnum, true, &argvars[1], rettv);
}
} }
/// Set or append lines to a buffer. /// Set or append lines to a buffer.
static void buf_set_append_line(typval_T *argvars, typval_T *rettv, bool append) static void buf_set_append_line(typval_T *argvars, typval_T *rettv, bool append)
{ {
const int did_emsg_before = did_emsg;
buf_T *const buf = tv_get_buf(&argvars[0], false); buf_T *const buf = tv_get_buf(&argvars[0], false);
if (buf == NULL) { if (buf == NULL) {
rettv->vval.v_number = 1; // FAIL rettv->vval.v_number = 1; // FAIL
} else { } else {
const linenr_T lnum = tv_get_lnum_buf(&argvars[1], buf); const linenr_T lnum = tv_get_lnum_buf(&argvars[1], buf);
set_buffer_lines(buf, lnum, append, &argvars[2], rettv); if (did_emsg == did_emsg_before) {
set_buffer_lines(buf, lnum, append, &argvars[2], rettv);
}
} }
} }
@ -1476,9 +1481,10 @@ static void f_dictwatcherdel(typval_T *argvars, typval_T *rettv, EvalFuncData fp
/// "deletebufline()" function /// "deletebufline()" function
static void f_deletebufline(typval_T *argvars, typval_T *rettv, EvalFuncData fptr) static void f_deletebufline(typval_T *argvars, typval_T *rettv, EvalFuncData fptr)
{ {
const int did_emsg_before = did_emsg;
rettv->vval.v_number = 1; // FAIL by default
buf_T *const buf = tv_get_buf(&argvars[0], false); buf_T *const buf = tv_get_buf(&argvars[0], false);
if (buf == NULL) { if (buf == NULL) {
rettv->vval.v_number = 1; // FAIL
return; return;
} }
const bool is_curbuf = buf == curbuf; const bool is_curbuf = buf == curbuf;
@ -1486,6 +1492,9 @@ static void f_deletebufline(typval_T *argvars, typval_T *rettv, EvalFuncData fpt
linenr_T last; linenr_T last;
const linenr_T first = tv_get_lnum_buf(&argvars[1], buf); const linenr_T first = tv_get_lnum_buf(&argvars[1], buf);
if (did_emsg > did_emsg_before) {
return;
}
if (argvars[2].v_type != VAR_UNKNOWN) { if (argvars[2].v_type != VAR_UNKNOWN) {
last = tv_get_lnum_buf(&argvars[2], buf); last = tv_get_lnum_buf(&argvars[2], buf);
} else { } else {
@ -1494,7 +1503,6 @@ static void f_deletebufline(typval_T *argvars, typval_T *rettv, EvalFuncData fpt
if (buf->b_ml.ml_mfp == NULL || first < 1 if (buf->b_ml.ml_mfp == NULL || first < 1
|| first > buf->b_ml.ml_line_count || last < first) { || first > buf->b_ml.ml_line_count || last < first) {
rettv->vval.v_number = 1; // FAIL
return; return;
} }
@ -1547,6 +1555,7 @@ static void f_deletebufline(typval_T *argvars, typval_T *rettv, EvalFuncData fpt
curwin = curwin_save; curwin = curwin_save;
VIsual_active = save_VIsual_active; VIsual_active = save_VIsual_active;
} }
rettv->vval.v_number = 0; // OK
} }
/// "did_filetype()" function /// "did_filetype()" function
@ -2581,9 +2590,12 @@ static void get_buffer_lines(buf_T *buf, linenr_T start, linenr_T end, int retli
/// "getbufline()" function /// "getbufline()" function
static void f_getbufline(typval_T *argvars, typval_T *rettv, EvalFuncData fptr) static void f_getbufline(typval_T *argvars, typval_T *rettv, EvalFuncData fptr)
{ {
const int did_emsg_before = did_emsg;
buf_T *const buf = tv_get_buf_from_arg(&argvars[0]); buf_T *const buf = tv_get_buf_from_arg(&argvars[0]);
const linenr_T lnum = tv_get_lnum_buf(&argvars[1], buf); const linenr_T lnum = tv_get_lnum_buf(&argvars[1], buf);
if (did_emsg > did_emsg_before) {
return;
}
const linenr_T end = (argvars[2].v_type == VAR_UNKNOWN const linenr_T end = (argvars[2].v_type == VAR_UNKNOWN
? lnum ? lnum
: tv_get_lnum_buf(&argvars[2], buf)); : tv_get_lnum_buf(&argvars[2], buf));
@ -7636,8 +7648,11 @@ static void f_setfperm(typval_T *argvars, typval_T *rettv, EvalFuncData fptr)
/// "setline()" function /// "setline()" function
static void f_setline(typval_T *argvars, typval_T *rettv, EvalFuncData fptr) static void f_setline(typval_T *argvars, typval_T *rettv, EvalFuncData fptr)
{ {
const int did_emsg_before = did_emsg;
linenr_T lnum = tv_get_lnum(&argvars[0]); linenr_T lnum = tv_get_lnum(&argvars[0]);
set_buffer_lines(curbuf, lnum, false, &argvars[1], rettv); if (did_emsg == did_emsg_before) {
set_buffer_lines(curbuf, lnum, false, &argvars[1], rettv);
}
} }
/// "setpos()" function /// "setpos()" function