canola.nvim/perf/bootstrap.lua
Barrett Ruth 8dd67f91e8
refactor: revert module namespace from canola back to oil
Problem: the canola rename creates unnecessary friction for users
migrating from stevearc/oil.nvim — every `require('oil')` call and
config reference must change.

Solution: revert all module paths, URL schemes, autocmd groups,
highlight groups, and filetype names back to `oil`. The repo stays
`canola.nvim` for identity; the code is a drop-in replacement.
2026-03-10 22:48:16 -04:00

66 lines
2 KiB
Lua

vim.opt.runtimepath:prepend('scripts/benchmark.nvim')
vim.opt.runtimepath:prepend('.')
local bm = require('benchmark')
bm.sandbox()
---@module 'oil'
---@type oil.SetupOpts
local setup_opts = {
-- columns = { "icon", "permissions", "size", "mtime" },
}
local DIR_SIZE = tonumber(vim.env.DIR_SIZE) or 100000
local ITERATIONS = tonumber(vim.env.ITERATIONS) or 10
local WARM_UP = tonumber(vim.env.WARM_UP) or 1
local OUTLIERS = tonumber(vim.env.OUTLIERS) or math.floor(ITERATIONS / 10)
local TEST_DIR = 'perf/tmp/test_' .. DIR_SIZE
vim.fn.mkdir(TEST_DIR, 'p')
require('benchmark.files').create_files(TEST_DIR, 'file %d.txt', DIR_SIZE)
-- selene: allow(global_usage)
function _G.jit_profile()
require('oil').setup(setup_opts)
local finish = bm.jit_profile({ filename = TEST_DIR .. '/profile.txt' })
bm.wait_for_user_event('OilEnter', function()
finish()
end)
require('oil').open(TEST_DIR)
end
-- selene: allow(global_usage)
function _G.flame_profile()
local start, stop = bm.flame_profile({
pattern = 'oil*',
filename = 'profile.json',
})
require('oil').setup(setup_opts)
start()
bm.wait_for_user_event('OilEnter', function()
stop(function()
vim.cmd.qall({ mods = { silent = true } })
end)
end)
require('oil').open(TEST_DIR)
end
-- selene: allow(global_usage)
function _G.benchmark()
require('oil').setup(setup_opts)
bm.run({ title = 'oil.nvim', iterations = ITERATIONS, warm_up = WARM_UP }, function(callback)
bm.wait_for_user_event('OilEnter', callback)
require('oil').open(TEST_DIR)
end, function(times)
local avg = bm.avg(times, { trim_outliers = OUTLIERS })
local std_dev = bm.std_dev(times, { trim_outliers = OUTLIERS })
local lines = {
table.concat(vim.tbl_map(bm.format_time, times), ' '),
string.format('Average: %s', bm.format_time(avg)),
string.format('Std deviation: %s', bm.format_time(std_dev)),
}
vim.fn.writefile(lines, 'perf/tmp/benchmark.txt')
vim.cmd.qall({ mods = { silent = true } })
end)
end