Merge pull request #786 from lifecrisis/find-hidden

Here, a more accurate method of determining whether or not to show
hidden files is used.  A new method, "isHiddenUnder()" is defined
for "Path" objects.  This method is then used to set the flag for
hidden files in the ":NERDTreeFind" command.  Note that this
function is likely to be useful elsewhere.

Fixes #189.
This commit is contained in:
Jason Franklin 2018-01-05 08:10:21 -05:00 committed by Jason Franklin
commit fa65ec60ea
2 changed files with 24 additions and 11 deletions

View File

@ -277,11 +277,6 @@ function! s:findAndRevealPath(pathStr)
return return
endtry endtry
if l:pathObj.isUnixHiddenPath()
let l:showHidden = g:NERDTreeShowHidden
let g:NERDTreeShowHidden = 1
endif
if !g:NERDTree.ExistsForTab() if !g:NERDTree.ExistsForTab()
try try
let l:cwd = g:NERDTreePath.New(getcwd()) let l:cwd = g:NERDTreePath.New(getcwd())
@ -298,19 +293,18 @@ function! s:findAndRevealPath(pathStr)
else else
NERDTreeFocus NERDTreeFocus
if !l:pathObj.isUnder(g:NERDTreeFileNode.GetRootForTab().path) if !l:pathObj.isUnder(b:NERDTree.root.path)
call b:NERDTree.ui.setShowHidden(g:NERDTreeShowHidden)
call s:chRoot(g:NERDTreeDirNode.New(l:pathObj.getParent(), b:NERDTree)) call s:chRoot(g:NERDTreeDirNode.New(l:pathObj.getParent(), b:NERDTree))
endif endif
endif endif
if l:pathObj.isHiddenUnder(b:NERDTree.root.path)
call b:NERDTree.ui.setShowHidden(1)
endif
let l:node = b:NERDTree.root.reveal(l:pathObj) let l:node = b:NERDTree.root.reveal(l:pathObj)
call b:NERDTree.render() call b:NERDTree.render()
call l:node.putCursorHere(1, 0) call l:node.putCursorHere(1, 0)
if l:pathObj.isUnixHiddenFile()
let g:NERDTreeShowHidden = l:showHidden
endif
endfunction endfunction
"FUNCTION: s:handleLeftClick() {{{1 "FUNCTION: s:handleLeftClick() {{{1

View File

@ -405,6 +405,25 @@ function! s:Path.getSortKey()
return self._sortKey return self._sortKey
endfunction endfunction
" FUNCTION: Path.isHiddenUnder(path) {{{1
function! s:Path.isHiddenUnder(path)
if !self.isUnder(a:path)
return 0
endif
let l:startIndex = len(a:path.pathSegments)
let l:segments = self.pathSegments[l:startIndex : ]
for l:segment in l:segments
if l:segment =~# '^\.'
return 1
endif
endfor
return 0
endfunction
" FUNCTION: Path.isUnixHiddenFile() {{{1 " FUNCTION: Path.isUnixHiddenFile() {{{1
" check for unix hidden files " check for unix hidden files