changeset 9707:be4aaef2651c v7.4.2129

commit https://github.com/vim/vim/commit/3ab14355ed93958433eec58e96ec9bd9a472f2b2 Author: Bram Moolenaar <Bram@vim.org> Date: Sat Jul 30 22:32:11 2016 +0200 patch 7.4.2129 Problem: Memory leak when using timer_start(). (Dominique Pelle) Solution: Don't copy the callback when using a partial.
author Christian Brabandt <cb@256bit.org>
date Sat, 30 Jul 2016 22:45:04 +0200
parents cfb88f2201d5
children 09d6c236da35
files src/evalfunc.c src/version.c
diffstat 2 files changed, 7 insertions(+), 1 deletions(-) [+]
line wrap: on
line diff
--- a/src/evalfunc.c
+++ b/src/evalfunc.c
@@ -11931,7 +11931,11 @@ f_timer_start(typval_T *argvars, typval_
     }
     else
     {
-	timer->tr_callback = vim_strsave(callback);
+	if (timer->tr_partial == NULL)
+	    timer->tr_callback = vim_strsave(callback);
+	else
+	    /* pointer into the partial */
+	    timer->tr_callback = callback;
 	rettv->vval.v_number = timer->tr_id;
     }
 }
--- a/src/version.c
+++ b/src/version.c
@@ -764,6 +764,8 @@ static char *(features[]) =
 static int included_patches[] =
 {   /* Add new patch number below this line */
 /**/
+    2129,
+/**/
     2128,
 /**/
     2127,