runtime(netrw): handle file/dir symlinks specifically in tree mode

fixes: #2386
related: #3609

Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
Christian Brabandt
2024-02-29 17:48:14 +01:00
parent 062141b1a7
commit 56b7da3c05

View File

@ -9476,7 +9476,7 @@ fun! s:NetrwTreeDir(islocal)
" call Decho("treedir<".treedir.">",'~'.expand("<slnum>")) " call Decho("treedir<".treedir.">",'~'.expand("<slnum>"))
elseif curline =~ '@$' elseif curline =~ '@$'
" call Decho("handle symbolic link from current line",'~'.expand("<slnum>")) " call Decho("handle symbolic link from current line",'~'.expand("<slnum>"))
let treedir= resolve(substitute(substitute(getline('.'),'@.*$','','e'),'^|*\s*','','e')) let potentialdir= resolve(substitute(substitute(getline('.'),'@.*$','','e'),'^|*\s*','','e'))
" call Decho("treedir<".treedir.">",'~'.expand("<slnum>")) " call Decho("treedir<".treedir.">",'~'.expand("<slnum>"))
else else
" call Decho("do not extract tree subdirectory from current line and set treedir to empty",'~'.expand("<slnum>")) " call Decho("do not extract tree subdirectory from current line and set treedir to empty",'~'.expand("<slnum>"))
@ -9501,7 +9501,6 @@ fun! s:NetrwTreeDir(islocal)
" call Decho("COMBAK#23 : mod=".&mod." win#".winnr()) " call Decho("COMBAK#23 : mod=".&mod." win#".winnr())
" call Decho("islocal=".a:islocal." curline<".curline.">",'~'.expand("<slnum>")) " call Decho("islocal=".a:islocal." curline<".curline.">",'~'.expand("<slnum>"))
let potentialdir= s:NetrwFile(substitute(curline,'^'.s:treedepthstring.'\+ \(.*\)@$','\1',''))
" call Decho("potentialdir<".potentialdir."> isdir=".isdirectory(potentialdir),'~'.expand("<slnum>")) " call Decho("potentialdir<".potentialdir."> isdir=".isdirectory(potentialdir),'~'.expand("<slnum>"))
" call Decho("COMBAK#24 : mod=".&mod." win#".winnr()) " call Decho("COMBAK#24 : mod=".&mod." win#".winnr())
@ -9514,8 +9513,15 @@ fun! s:NetrwTreeDir(islocal)
" " call Decho("newdir <".newdir.">",'~'.expand("<slnum>")) " " call Decho("newdir <".newdir.">",'~'.expand("<slnum>"))
" else " else
" call Decho("apply NetrwTreePath to treetop<".w:netrw_treetop.">",'~'.expand("<slnum>")) " call Decho("apply NetrwTreePath to treetop<".w:netrw_treetop.">",'~'.expand("<slnum>"))
if a:islocal && curline =~ '@$'
if isdirectory(s:NetrwFile(potentialdir))
let treedir = w:netrw_treetop.'/'.potentialdir.'/'
let w:netrw_treetop = treedir
endif
else
let potentialdir= s:NetrwFile(substitute(curline,'^'.s:treedepthstring.'\+ \(.*\)@$','\1',''))
let treedir = s:NetrwTreePath(w:netrw_treetop) let treedir = s:NetrwTreePath(w:netrw_treetop)
" endif endif
endif endif
" call Decho("COMBAK#25 : mod=".&mod." win#".winnr()) " call Decho("COMBAK#25 : mod=".&mod." win#".winnr())