diff options
author | zeertzjq <zeertzjq@outlook.com> | 2024-01-29 19:32:39 +0100 |
---|---|---|
committer | Christian Brabandt <cb@256bit.org> | 2024-01-29 19:32:39 +0100 |
commit | e99f0688785c3d56b1ee45a28fa6ce02b850a33b (patch) | |
tree | af86efdd7f5addf6e142e5f40712877429a60dff /src/if_lua.c | |
parent | e6d8b4662ddf9356da53f56e363b67b524fd8825 (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.c | 5 |
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 |