diff options
Diffstat (limited to 'scratch/old_perf_debug')
| -rw-r--r-- | scratch/old_perf_debug | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/scratch/old_perf_debug b/scratch/old_perf_debug new file mode 100644 index 0000000..3561a98 --- /dev/null +++ b/scratch/old_perf_debug @@ -0,0 +1,36 @@ + + +-- Until I have better profiling stuff, this will have to do. +PERF = function(...) end +PERF_DEBUG = PERF_DEBUG or nil +START = nil + +if PERF_DEBUG then + PERF = function(...) + local new_time = (vim.loop.hrtime() - START) / 1E9 + if select('#', ...) == 0 then + vim.schedule(function() + vim.api.nvim_buf_set_lines(PERF_DEBUG, -1, -1, false, { '' }) + end) + return + end + + local to_insert = '' + if START then + to_insert = tostring(new_time) .. ' | ' + end + + for _, v in ipairs({...}) do + if type(v) == 'table' then + to_insert = to_insert .. tostring(#v) .. ' | ' + else + to_insert = to_insert .. tostring(v) .. ' | ' + end + end + + vim.schedule(function() + vim.api.nvim_buf_set_lines(PERF_DEBUG, -1, -1, false, { to_insert }) + end) + end +end + |
