canola.nvim/perf/bootstrap.lua
Barrett Ruth e2cd1e66cf
Some checks are pending
quality / changes (push) Waiting to run
quality / Lua Format Check (push) Blocked by required conditions
quality / Lua Lint Check (push) Blocked by required conditions
quality / Lua Type Check (push) Blocked by required conditions
quality / Markdown Format Check (push) Blocked by required conditions
test / Test (Neovim nightly) (push) Waiting to run
test / Test (Neovim stable) (push) Waiting to run
refactor: revert canola namespace to oil and remove vim.g config (#120)
* 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.

* refactor: remove `vim.g.oil` declarative config

Problem: the `vim.g.oil` configuration path was added prematurely.
It adds a second config entrypoint before the plugin has stabilized
enough to justify it.

Solution: remove `vim.g.oil` support from `plugin/oil.lua`,
`config.setup()`, docs, and tests. Users configure via
`require("oil").setup({})`.
2026-03-10 22:49:56 -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