Mercurial > vim
changeset 13616:b6998c6374e1 v8.0.1680
patch 8.0.1680: memory allocated by libvterm is not profiled
commit https://github.com/vim/vim/commit/756ef113d14428e598274f87672d7f0e34ff9781
Author: Bram Moolenaar <Bram@vim.org>
Date: Tue Apr 10 12:04:27 2018 +0200
patch 8.0.1680: memory allocated by libvterm is not profiled
Problem: Memory allocated by libvterm does not show up in profile.
Solution: Pass allocater functions to vterm_new().
author | Christian Brabandt <cb@256bit.org> |
---|---|
date | Tue, 10 Apr 2018 12:15:08 +0200 |
parents | 08035c9f650d |
children | 73b1401bf021 |
files | src/terminal.c src/version.c |
diffstat | 2 files changed, 24 insertions(+), 4 deletions(-) [+] |
line wrap: on
line diff
--- a/src/terminal.c +++ b/src/terminal.c @@ -39,14 +39,12 @@ * * TODO: * - Add a way to set the 16 ANSI colors, to be used for 'termguicolors' and in - * the GUI. + * the GUI. #2747 * - Win32: Make terminal used for :!cmd in the GUI work better. Allow for * redirection. Probably in call to channel_set_pipes(). * - implement term_setsize() * - Copy text in the vterm to the Vim buffer once in a while, so that * completion works. - * - Adding WinBar to terminal window doesn't display, text isn't shifted down. - * a job that uses 16 colors while Vim is using > 256. * - in GUI vertical split causes problems. Cursor is flickering. (Hirohito * Higashi, 2017 Sep 19) * - after resizing windows overlap. (Boris Staletic, #2164) @@ -3330,6 +3328,26 @@ static VTermParserCallbacks parser_fallb }; /* + * Use Vim's allocation functions for vterm so profiling works. + */ + static void * +vterm_malloc(size_t size, void *data UNUSED) +{ + return alloc_clear(size); +} + + static void +vterm_memfree(void *ptr, void *data UNUSED) +{ + vim_free(ptr); +} + +static VTermAllocatorFunctions vterm_allocator = { + &vterm_malloc, + &vterm_memfree +}; + +/* * Create a new vterm and initialize it. */ static void @@ -3340,7 +3358,7 @@ create_vterm(term_T *term, int rows, int VTermState *state; VTermValue value; - vterm = vterm_new(rows, cols); + vterm = vterm_new_with_allocator(rows, cols, &vterm_allocator, NULL); term->tl_vterm = vterm; screen = vterm_obtain_screen(vterm); vterm_screen_set_callbacks(screen, &screen_callbacks, term);