Skip to content

Commit 5ef0616

Browse files
committed
Renderer and Builder use classic, tidy opts
1 parent 9af0dc4 commit 5ef0616

File tree

3 files changed

+53
-64
lines changed

3 files changed

+53
-64
lines changed

lua/nvim-tree/explorer/init.lua

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -58,7 +58,7 @@ function Explorer:new(args)
5858
self.opts = config
5959

6060
self.sorters = Sorter(config)
61-
self.renderer = Renderer:new(config, self)
61+
self.renderer = Renderer({ explorer = self })
6262
self.filters = Filters:new(config, self)
6363
self.live_filter = LiveFilter:new(config, self)
6464
self.marks = Marks:new(config, self)

lua/nvim-tree/renderer/builder.lua

Lines changed: 37 additions & 42 deletions
Original file line numberDiff line numberDiff line change
@@ -2,6 +2,7 @@ local notify = require("nvim-tree.notify")
22
local utils = require("nvim-tree.utils")
33
local view = require("nvim-tree.view")
44

5+
local Class = require("nvim-tree.classic")
56
local DirectoryNode = require("nvim-tree.node.directory")
67

78
local DecoratorBookmarks = require("nvim-tree.renderer.decorator.bookmarks")
@@ -33,50 +34,44 @@ local pad = require("nvim-tree.renderer.components.padding")
3334
---@field extmarks table[] extra marks for right icon placement
3435
---@field virtual_lines table[] virtual lines for hidden count display
3536
---@field private explorer Explorer
36-
---@field private opts table
3737
---@field private index number
3838
---@field private depth number
3939
---@field private combined_groups table<string, boolean> combined group names
4040
---@field private markers boolean[] indent markers
4141
---@field private decorators Decorator[]
4242
---@field private hidden_display fun(node: Node): string|nil
43-
local Builder = {}
44-
45-
---@param opts table user options
46-
---@param explorer Explorer
47-
---@return Builder
48-
function Builder:new(opts, explorer)
49-
---@type Builder
50-
local o = {
51-
opts = opts,
52-
explorer = explorer,
53-
index = 0,
54-
depth = 0,
55-
hl_args = {},
56-
combined_groups = {},
57-
lines = {},
58-
markers = {},
59-
signs = {},
60-
extmarks = {},
61-
virtual_lines = {},
62-
decorators = {
63-
-- priority order
64-
DecoratorCut({ explorer = explorer }),
65-
DecoratorCopied({ explorer = explorer }),
66-
DecoratorDiagnostics({ explorer = explorer }),
67-
DecoratorBookmarks({ explorer = explorer }),
68-
DecoratorModified({ explorer = explorer }),
69-
DecoratorHidden({ explorer = explorer }),
70-
DecoratorOpened({ explorer = explorer }),
71-
DecoratorGit({ explorer = explorer })
72-
},
73-
hidden_display = Builder:setup_hidden_display_function(opts),
43+
local Builder = Class:extend()
44+
45+
---@class Builder
46+
---@overload fun(args: BuilderArgs): Builder
47+
48+
---@class (exact) BuilderArgs
49+
---@field explorer Explorer
50+
51+
---@param args BuilderArgs
52+
function Builder:new(args)
53+
self.explorer = args.explorer
54+
self.index = 0
55+
self.depth = 0
56+
self.hl_args = {}
57+
self.combined_groups = {}
58+
self.lines = {}
59+
self.markers = {}
60+
self.signs = {}
61+
self.extmarks = {}
62+
self.virtual_lines = {}
63+
self.decorators = {
64+
-- priority order
65+
DecoratorCut({ explorer = args.explorer }),
66+
DecoratorCopied({ explorer = args.explorer }),
67+
DecoratorDiagnostics({ explorer = args.explorer }),
68+
DecoratorBookmarks({ explorer = args.explorer }),
69+
DecoratorModified({ explorer = args.explorer }),
70+
DecoratorHidden({ explorer = args.explorer }),
71+
DecoratorOpened({ explorer = args.explorer }),
72+
DecoratorGit({ explorer = args.explorer })
7473
}
75-
76-
setmetatable(o, self)
77-
self.__index = self
78-
79-
return o
74+
self.hidden_display = Builder:setup_hidden_display_function(args.explorer.opts)
8075
end
8176

8277
---Insert ranged highlight groups into self.highlights
@@ -123,7 +118,7 @@ function Builder:format_line(indent_markers, arrows, icon, name, node)
123118
end
124119
for _, v in ipairs(t2) do
125120
if added_len > 0 then
126-
table.insert(t1, { str = self.opts.renderer.icons.padding })
121+
table.insert(t1, { str = self.explorer.opts.renderer.icons.padding })
127122
end
128123
table.insert(t1, v)
129124
end
@@ -284,7 +279,7 @@ function Builder:add_hidden_count_string(node, idx, num_children)
284279
local hidden_count_string = self.hidden_display(node.hidden_stats)
285280
if hidden_count_string and hidden_count_string ~= "" then
286281
local indent_markers = pad.get_indent_markers(self.depth, idx or 0, num_children or 0, node, self.markers, 1)
287-
local indent_width = self.opts.renderer.indent_width
282+
local indent_width = self.explorer.opts.renderer.indent_width
288283

289284
local indent_padding = string.rep(" ", indent_width)
290285
local indent_string = indent_padding .. indent_markers.str
@@ -354,16 +349,16 @@ end
354349
---@private
355350
function Builder:build_header()
356351
if view.is_root_folder_visible(self.explorer.absolute_path) then
357-
local root_name = self:format_root_name(self.opts.renderer.root_folder_label)
352+
local root_name = self:format_root_name(self.explorer.opts.renderer.root_folder_label)
358353
table.insert(self.lines, root_name)
359354
self:insert_highlight({ "NvimTreeRootFolder" }, 0, string.len(root_name))
360355
self.index = 1
361356
end
362357

363358
if self.explorer.live_filter.filter then
364-
local filter_line = string.format("%s/%s/", self.opts.live_filter.prefix, self.explorer.live_filter.filter)
359+
local filter_line = string.format("%s/%s/", self.explorer.opts.live_filter.prefix, self.explorer.live_filter.filter)
365360
table.insert(self.lines, filter_line)
366-
local prefix_length = string.len(self.opts.live_filter.prefix)
361+
local prefix_length = string.len(self.explorer.opts.live_filter.prefix)
367362
self:insert_highlight({ "NvimTreeLiveFilterPrefix" }, 0, prefix_length)
368363
self:insert_highlight({ "NvimTreeLiveFilterValue" }, prefix_length, string.len(filter_line))
369364
self.index = self.index + 1

lua/nvim-tree/renderer/init.lua

Lines changed: 15 additions & 21 deletions
Original file line numberDiff line numberDiff line change
@@ -2,6 +2,7 @@ local log = require("nvim-tree.log")
22
local view = require("nvim-tree.view")
33
local events = require("nvim-tree.events")
44

5+
local Class = require("nvim-tree.classic")
56
local Builder = require("nvim-tree.renderer.builder")
67

78
local SIGN_GROUP = "NvimTreeRendererSigns"
@@ -10,26 +11,19 @@ local namespace_highlights_id = vim.api.nvim_create_namespace("NvimTreeHighlight
1011
local namespace_extmarks_id = vim.api.nvim_create_namespace("NvimTreeExtmarks")
1112
local namespace_virtual_lines_id = vim.api.nvim_create_namespace("NvimTreeVirtualLines")
1213

13-
---@class (exact) Renderer
14-
---@field private __index? table
15-
---@field private opts table user options
16-
---@field private explorer Explorer
17-
local Renderer = {}
18-
19-
---@param opts table user options
20-
---@param explorer Explorer
21-
---@return Renderer
22-
function Renderer:new(opts, explorer)
23-
---@type Renderer
24-
local o = {
25-
opts = opts,
26-
explorer = explorer,
27-
}
28-
29-
setmetatable(o, self)
30-
self.__index = self
31-
32-
return o
14+
---@class (exact) Renderer: Class
15+
---@field explorer Explorer
16+
local Renderer = Class:extend()
17+
18+
---@class Renderer
19+
---@overload fun(args: RendererArgs): Renderer
20+
21+
---@class (exact) RendererArgs
22+
---@field explorer Explorer
23+
24+
---@param args RendererArgs
25+
function Renderer:new(args)
26+
self.explorer = args.explorer
3327
end
3428

3529
---@private
@@ -106,7 +100,7 @@ function Renderer:draw()
106100

107101
local cursor = vim.api.nvim_win_get_cursor(view.get_winnr() or 0)
108102

109-
local builder = Builder:new(self.opts, self.explorer):build()
103+
local builder = Builder(self.explorer):build()
110104

111105
self:_draw(bufnr, builder.lines, builder.hl_args, builder.signs, builder.extmarks, builder.virtual_lines)
112106

0 commit comments

Comments
 (0)