aboutsummaryrefslogtreecommitdiff
path: root/src/nvim/eval/typval.c
diff options
context:
space:
mode:
authorzeertzjq <zeertzjq@outlook.com>2022-10-11 00:24:52 +0800
committerGitHub <noreply@github.com>2022-10-11 00:24:52 +0800
commit26c653718097955dc4dfbeb45ab602c8dbe9dea5 (patch)
tree9ae12e34472a4aa6dae4cfb381a0648705b1351d /src/nvim/eval/typval.c
parent8781213f00a22e20abeb4282204e900db799f4b5 (diff)
parent62a0c9f8c24b9115155cd4551976353ace3e2c5e (diff)
downloadrneovim-26c653718097955dc4dfbeb45ab602c8dbe9dea5.tar.gz
rneovim-26c653718097955dc4dfbeb45ab602c8dbe9dea5.tar.bz2
rneovim-26c653718097955dc4dfbeb45ab602c8dbe9dea5.zip
Merge pull request #20574 from zeertzjq/vim-8.2.2184
vim-patch:8.2.{1465,2184,2670,2671},9.0.{0712,partial:0715}
Diffstat (limited to 'src/nvim/eval/typval.c')
-rw-r--r--src/nvim/eval/typval.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/src/nvim/eval/typval.c b/src/nvim/eval/typval.c
index 961c963170..a0b06aaaf4 100644
--- a/src/nvim/eval/typval.c
+++ b/src/nvim/eval/typval.c
@@ -3750,9 +3750,11 @@ varnumber_T tv_get_number_chk(const typval_T *const tv, bool *const ret_error)
linenr_T tv_get_lnum(const typval_T *const tv)
FUNC_ATTR_NONNULL_ALL FUNC_ATTR_WARN_UNUSED_RESULT
{
+ const int did_emsg_before = did_emsg;
linenr_T lnum = (linenr_T)tv_get_number_chk(tv, NULL);
- if (lnum == 0) { // No valid number, try using same function as line() does.
+ if (lnum <= 0 && did_emsg_before == did_emsg && tv->v_type != VAR_NUMBER) {
int fnum;
+ // No valid number, try using same function as line() does.
pos_T *const fp = var2fpos(tv, true, &fnum, false);
if (fp != NULL) {
lnum = fp->lnum;