chore: resolve undefined-field warnings, fix link git statuses, rewrite devicons (#2968)
* add todo * refactor(#2886): multi instance: node class refactoring: extract links, *_git_status (#2944) * extract DirectoryLinkNode and FileLinkNode, move Node methods to children * temporarily move DirectoryNode methods into BaseNode for easier reviewing * move mostly unchanged DirectoryNode methods back to BaseNode * tidy * git.git_status_file takes an array * update git status of links * luacheck hack * safer git_status_dir * refactor(#2886): multi instance: node class refactoring: DirectoryNode:expand_or_collapse (#2957) move expand_or_collapse to DirectoryNode * refactor(#2886): multi instance: node group functions refactoring (#2959) * move last_group_node to DirectoryNode * move add BaseNode:as and more doc * revert parameter name changes * revert parameter name changes * add Class * move group methods into DN * tidy group methods * tidy group methods * tidy group methods * tidy group methods * parent is DirectoryNode * tidy expand all * BaseNode -> Node * move watcher to DirectoryNode * last_group_node is DirectoryNode only * simplify create-file * simplify parent * simplify collapse-all * simplify live-filter * style * move lib.get_cursor_position to Explorer * move lib.get_node_at_cursor to Explorer * move lib.get_nodes to Explorer * move place_cursor_on_node to Explorer * resolve resource leak in purge_all_state * move many autocommands into Explorer * post merge tidy * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * Revert "chore: resolve undefined-field" This reverts commit be546ff18d41f28466b065c857e1e041659bd2c8. * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * Revert "chore: resolve undefined-field" This reverts commite82db1c44d. * chore: resolve undefined-field * chore: class new is now generic * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * Revert "chore: resolve undefined-field" This reverts commit0e9b844d22. * move icon builders into node classes * move icon builders into node classes * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * chore: resolve undefined-field * move folder specifics from icons to Directory * move folder specifics from icons to Directory * move folder specifics from icons to Directory * move folder specifics from icons to Directory * move file specifics from icons to File * clean up sorters * chore: resolve undefined-field * tidy hl icon name * file devicon uses library to fall back * file devicon uses library to fall back * file devicon uses library to fall back
This commit is contained in:
committed by
GitHub
parent
c22124b374
commit
610a1c189b
@@ -1,7 +1,12 @@
|
||||
local M = {
|
||||
config = nil,
|
||||
path = nil,
|
||||
}
|
||||
---@alias LogTypes "all" | "config" | "copy_paste" | "dev" | "diagnostics" | "git" | "profile" | "watcher"
|
||||
|
||||
---@type table<LogTypes, boolean>
|
||||
local types = {}
|
||||
|
||||
---@type string
|
||||
local file_path
|
||||
|
||||
local M = {}
|
||||
|
||||
--- Write to log file
|
||||
---@param typ string as per log.types config
|
||||
@@ -13,7 +18,7 @@ function M.raw(typ, fmt, ...)
|
||||
end
|
||||
|
||||
local line = string.format(fmt, ...)
|
||||
local file = io.open(M.path, "a")
|
||||
local file = io.open(file_path, "a")
|
||||
if file then
|
||||
io.output(file)
|
||||
io.write(line)
|
||||
@@ -22,7 +27,7 @@ function M.raw(typ, fmt, ...)
|
||||
end
|
||||
|
||||
--- Write to a new file
|
||||
---@param typ string as per log.types config
|
||||
---@param typ LogTypes as per log.types config
|
||||
---@param path string absolute path
|
||||
---@param fmt string for string.format
|
||||
---@param ... any arguments for string.format
|
||||
@@ -71,7 +76,7 @@ end
|
||||
|
||||
--- Write to log file
|
||||
--- time and typ are prefixed and a trailing newline is added
|
||||
---@param typ string as per log.types config
|
||||
---@param typ LogTypes as per log.types config
|
||||
---@param fmt string for string.format
|
||||
---@param ... any arguments for string.format
|
||||
function M.line(typ, fmt, ...)
|
||||
@@ -88,7 +93,7 @@ function M.set_inspect_opts(opts)
|
||||
end
|
||||
|
||||
--- Write to log file the inspection of a node
|
||||
---@param typ string as per log.types config
|
||||
---@param typ LogTypes as per log.types config
|
||||
---@param node Node node to be inspected
|
||||
---@param fmt string for string.format
|
||||
---@param ... any arguments for string.format
|
||||
@@ -99,20 +104,20 @@ function M.node(typ, node, fmt, ...)
|
||||
end
|
||||
|
||||
--- Logging is enabled for typ or all
|
||||
---@param typ string as per log.types config
|
||||
---@param typ LogTypes as per log.types config
|
||||
---@return boolean
|
||||
function M.enabled(typ)
|
||||
return M.path ~= nil and (M.config.types[typ] or M.config.types.all)
|
||||
return file_path ~= nil and (types[typ] or types.all)
|
||||
end
|
||||
|
||||
function M.setup(opts)
|
||||
M.config = opts.log
|
||||
if M.config and M.config.enable and M.config.types then
|
||||
M.path = string.format("%s/nvim-tree.log", vim.fn.stdpath("log"), os.date("%H:%M:%S"), vim.env.USER)
|
||||
if M.config.truncate then
|
||||
os.remove(M.path)
|
||||
if opts.log and opts.log.enable and opts.log.types then
|
||||
types = opts.log.types
|
||||
file_path = string.format("%s/nvim-tree.log", vim.fn.stdpath("log"), os.date("%H:%M:%S"), vim.env.USER)
|
||||
if opts.log.truncate then
|
||||
os.remove(file_path)
|
||||
end
|
||||
require("nvim-tree.notify").debug("nvim-tree.lua logging to " .. M.path)
|
||||
require("nvim-tree.notify").debug("nvim-tree.lua logging to " .. file_path)
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
Reference in New Issue
Block a user