Mercurial > vim
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; } }