summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2020-09-21 20:35:55 +0200
committerBram Moolenaar <Bram@vim.org>2020-09-21 20:35:55 +0200
commit078269bdce7e75d5693c7313d92a229786bb95ee (patch)
tree148a862c19fc9ae3d5d90f8c853ccaa090220705
parent10e4f12bf4cd08328618bbf4e57a15435296e586 (diff)
downloadvim-git-8.2.1720.tar.gz
patch 8.2.1720: Vim9: memory leak with heredoc that isn't executedv8.2.1720
Problem: Vim9: memory leak with heredoc that isn't executed. (Dominique Pellé) Solution: Don't clear the list items. (closes #6991)
-rw-r--r--src/testdir/test_vim9_script.vim8
-rw-r--r--src/version.c2
-rw-r--r--src/vim9compile.c17
3 files changed, 20 insertions, 7 deletions
diff --git a/src/testdir/test_vim9_script.vim b/src/testdir/test_vim9_script.vim
index 42eaab0ad..c00df6be2 100644
--- a/src/testdir/test_vim9_script.vim
+++ b/src/testdir/test_vim9_script.vim
@@ -259,6 +259,14 @@ def Test_assignment()
let w: number
w = 123
assert_equal(123, w)
+
+
+ # this should not leak
+ if 0
+ let text =<< trim END
+ some text
+ END
+ endif
enddef
def Test_vim9_single_char_vars()
diff --git a/src/version.c b/src/version.c
index 15c497671..a5cb6a881 100644
--- a/src/version.c
+++ b/src/version.c
@@ -751,6 +751,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 1720,
+/**/
1719,
/**/
1718,
diff --git a/src/vim9compile.c b/src/vim9compile.c
index 1edf48ce6..52651f36a 100644
--- a/src/vim9compile.c
+++ b/src/vim9compile.c
@@ -4622,15 +4622,18 @@ compile_assignment(char_u *arg, exarg_T *eap, cmdidx_T cmdidx, cctx_T *cctx)
eap->cookie = cctx;
l = heredoc_get(eap, op + 3, FALSE);
- // Push each line and the create the list.
- FOR_ALL_LIST_ITEMS(l, li)
+ if (cctx->ctx_skip != SKIP_YES)
{
- generate_PUSHS(cctx, li->li_tv.vval.v_string);
- li->li_tv.vval.v_string = NULL;
+ // Push each line and the create the list.
+ FOR_ALL_LIST_ITEMS(l, li)
+ {
+ generate_PUSHS(cctx, li->li_tv.vval.v_string);
+ li->li_tv.vval.v_string = NULL;
+ }
+ generate_NEWLIST(cctx, l->lv_len);
+ type = &t_list_string;
+ member_type = &t_list_string;
}
- generate_NEWLIST(cctx, l->lv_len);
- type = &t_list_string;
- member_type = &t_list_string;
list_free(l);
p += STRLEN(p);
end = p;