Mercurial > vim
diff src/profiler.c @ 33119:bede81965821 v9.0.1842
patch 9.0.1842: Need more accurate profiling
Commit: https://github.com/vim/vim/commit/21d3212361f687704acb52cad7c1b9228e7c83f0
Author: Ernie Rael <errael@raelity.com>
Date: Sat Sep 2 15:09:18 2023 +0200
patch 9.0.1842: Need more accurate profiling
Problem: Need more accurate profiling
Solution: Improve profiling results
closes: #12192
Reduce overhead of checking if a function should be profiled,
by caching results of checking (which are done with regexp).
Cache uf_hash for uf_name in ufunc_T.
Cache cleared when regexps are changed.
Break at first match for has_profiling lookup.
Signed-off-by: Christian Brabandt <cb@256bit.org>
Co-authored-by: Ernie Rael <errael@raelity.com>
author | Christian Brabandt <cb@256bit.org> |
---|---|
date | Sat, 02 Sep 2023 15:15:06 +0200 |
parents | 695b50472e85 |
children | d7cfd8fb1d75 |
line wrap: on
line diff
--- a/src/profiler.c +++ b/src/profiler.c @@ -664,7 +664,8 @@ script_prof_save( void profile_may_start_func(profinfo_T *info, ufunc_T *fp, ufunc_T *caller) { - if (!fp->uf_profiling && has_profiling(FALSE, fp->uf_name, NULL)) + if (!fp->uf_profiling && has_profiling(FALSE, fp->uf_name, NULL, + &fp->uf_hash)) { info->pi_started_profiling = TRUE; func_do_profile(fp);