summaryrefslogtreecommitdiffstats
path: root/src/if_lua.c
diff options
context:
space:
mode:
authorzeertzjq <zeertzjq@outlook.com>2024-01-29 19:32:39 +0100
committerChristian Brabandt <cb@256bit.org>2024-01-29 19:32:39 +0100
commite99f0688785c3d56b1ee45a28fa6ce02b850a33b (patch)
treeaf86efdd7f5addf6e142e5f40712877429a60dff /src/if_lua.c
parente6d8b4662ddf9356da53f56e363b67b524fd8825 (diff)
patch 9.1.0062: Internal error when :luado/perldo/pydo etc delete linesv9.1.0062
Problem: Internal error when :luado/perldo/pydo etc delete lines Solution: Test that the line is still valid line number (zeertzjq) closes: #13931 Signed-off-by: zeertzjq <zeertzjq@outlook.com> Signed-off-by: Christian Brabandt <cb@256bit.org>
Diffstat (limited to 'src/if_lua.c')
-rw-r--r--src/if_lua.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/src/if_lua.c b/src/if_lua.c
index 159a6753e3..4d19c3ef52 100644
--- a/src/if_lua.c
+++ b/src/if_lua.c
@@ -2692,9 +2692,12 @@ ex_luado(exarg_T *eap)
luaV_emsg(L);
break;
}
+
// Catch the command switching to another buffer.
- if (curbuf != was_curbuf)
+ // Check the line number, the command may have deleted lines.
+ if (curbuf != was_curbuf || l > curbuf->b_ml.ml_line_count)
break;
+
if (lua_isstring(L, -1)) // update line?
{
#ifdef HAVE_SANDBOX