Skip to content

Commit

Permalink
feat: use natural sort order by default (#328)
Browse files Browse the repository at this point in the history
* Sort entries with natural sorting

* refactor: move natural ordering logic and add config option

---------

Co-authored-by: Steven Arcangeli <stevearc@stevearc.com>
  • Loading branch information
lucaseras and stevearc authored Mar 13, 2024
1 parent e045ee3 commit 71b076b
Show file tree
Hide file tree
Showing 3 changed files with 20 additions and 2 deletions.
10 changes: 9 additions & 1 deletion lua/oil/columns.lua
Original file line number Diff line number Diff line change
Expand Up @@ -279,6 +279,10 @@ M.register("type", {
end,
})

local function pad_number(int)
return string.format("%012d", int)
end

M.register("name", {
render = function(entry, conf)
error("Do not use the name column. It is for sorting only")
Expand All @@ -289,7 +293,11 @@ M.register("name", {
end,

get_sort_value = function(entry)
return entry[FIELD_NAME]
if config.view_options.natural_order then
return entry[FIELD_NAME]:gsub("%d+", pad_number)
else
return entry[FIELD_NAME]
end
end,
})

Expand Down
3 changes: 3 additions & 0 deletions lua/oil/config.lua
Original file line number Diff line number Diff line change
Expand Up @@ -90,6 +90,9 @@ local default_config = {
is_always_hidden = function(name, bufnr)
return false
end,
-- Sort file names in a more intuitive order for humans. Is less performant,
-- so you may want to set to false if you work with large directories.
natural_order = true,
sort = {
-- sort order can be "asc" or "desc"
-- see :help oil-columns to see which columns are sortable
Expand Down
9 changes: 8 additions & 1 deletion lua/oil/view.lua
Original file line number Diff line number Diff line change
Expand Up @@ -519,7 +519,14 @@ end
---@return fun(a: oil.InternalEntry, b: oil.InternalEntry): boolean
local function get_sort_function(adapter)
local idx_funs = {}
for _, sort_pair in ipairs(config.view_options.sort) do
local sort_config = config.view_options.sort

-- If empty, default to type + name sorting
if vim.tbl_isempty(sort_config) then
sort_config = { { "type", "asc" }, { "name", "asc" } }
end

for _, sort_pair in ipairs(sort_config) do
local col_name, order = unpack(sort_pair)
if order ~= "asc" and order ~= "desc" then
vim.notify_once(
Expand Down

0 comments on commit 71b076b

Please sign in to comment.