HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux ip-172-31-42-149 5.15.0-1084-aws #91~20.04.1-Ubuntu SMP Fri May 2 07:00:04 UTC 2025 aarch64
User: ubuntu (1000)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: //home/ubuntu/neovim/test/benchmark/extmark_spec.lua
local n = require('test.functional.testnvim')()

local clear = n.clear
local exec_lua = n.exec_lua

describe('extmark perf', function()
  before_each(function()
    clear()

    exec_lua([[
      out = {}
      function start()
        ts = vim.uv.hrtime()
      end
      function stop(name)
        out[#out+1] = ('%14.6f ms - %s'):format((vim.uv.hrtime() - ts) / 1000000, name)
      end
    ]])
  end)

  after_each(function()
    for _, line in ipairs(exec_lua([[return out]])) do
      print(line)
    end
  end)

  it('repeatedly calling nvim_buf_clear_namespace #28615', function()
    exec_lua([[
      vim.api.nvim_buf_set_lines(0, 0, -1, true, { 'foo', 'bar' })
      local ns0 = vim.api.nvim_create_namespace('ns0')
      local ns1 = vim.api.nvim_create_namespace('ns1')

      for _ = 1, 10000 do
        vim.api.nvim_buf_set_extmark(0, ns0, 0, 0, {})
      end
      vim.api.nvim_buf_set_extmark(0, ns1, 1, 0, {})

      start()
      for _ = 1, 10000 do
        vim.api.nvim_buf_clear_namespace(0, ns1, 0, -1)
      end
      stop('nvim_buf_clear_namespace')
    ]])
  end)
end)