* fix(#1480): break symlink cycle on find-file * fix(#1480): break symlink cycle on search-node * fix(#1480): break symlink cycle on search-node * fix(#1480): break symlink cycle on find-file
This commit is contained in:
committed by
GitHub
parent
a73d0d4800
commit
261a5c380c
@@ -27,12 +27,20 @@ function M.fn(fname)
|
||||
|
||||
local line = core.get_nodes_starting_line()
|
||||
|
||||
local absolute_paths_searched = {}
|
||||
|
||||
local found = Iterator.builder(core.get_explorer().nodes)
|
||||
:matcher(function(node)
|
||||
return node.absolute_path == fname_real or node.link_to == fname_real
|
||||
end)
|
||||
:applier(function(node)
|
||||
line = line + 1
|
||||
|
||||
if vim.tbl_contains(absolute_paths_searched, node.absolute_path) then
|
||||
return
|
||||
end
|
||||
table.insert(absolute_paths_searched, node.absolute_path)
|
||||
|
||||
local abs_match = vim.startswith(fname_real, node.absolute_path .. utils.path_separator)
|
||||
local link_match = node.link_to and vim.startswith(fname_real, node.link_to .. utils.path_separator)
|
||||
|
||||
|
||||
@@ -7,18 +7,27 @@ local find_file = require("nvim-tree.actions.finders.find-file").fn
|
||||
|
||||
local M = {}
|
||||
|
||||
local function search(dir, input_path)
|
||||
local path, name, stat, handle, _
|
||||
local function search(search_dir, input_path)
|
||||
local realpaths_searched = {}
|
||||
|
||||
if not dir then
|
||||
if not search_dir then
|
||||
return
|
||||
end
|
||||
|
||||
local function iter(dir)
|
||||
local realpath, path, name, stat, handle, _
|
||||
|
||||
handle, _ = uv.fs_scandir(dir)
|
||||
if not handle then
|
||||
return
|
||||
end
|
||||
|
||||
realpath, _ = uv.fs_realpath(dir)
|
||||
if not realpath or vim.tbl_contains(realpaths_searched, realpath) then
|
||||
return
|
||||
end
|
||||
table.insert(realpaths_searched, realpath)
|
||||
|
||||
name, _ = uv.fs_scandir_next(handle)
|
||||
while name do
|
||||
path = dir .. "/" .. name
|
||||
@@ -34,7 +43,7 @@ local function search(dir, input_path)
|
||||
end
|
||||
|
||||
if stat.type == "directory" then
|
||||
path = search(path, input_path)
|
||||
path = iter(path)
|
||||
if path then
|
||||
return path
|
||||
end
|
||||
@@ -45,6 +54,9 @@ local function search(dir, input_path)
|
||||
end
|
||||
end
|
||||
|
||||
return iter(search_dir)
|
||||
end
|
||||
|
||||
function M.fn()
|
||||
if not core.get_explorer() then
|
||||
return
|
||||
|
||||
Reference in New Issue
Block a user