really fix the previous buffer issue when closing a tree win

So :bprev was failing to jump back to the right buffer. I dont fully
understand this yet, but I'm fairly sure this is because there is a
magic <directory> buffer that we delete when creating a wintree :-/

Anyway, we are explicitly storing the prev buffer again - and updating
it when reusing treewins. It's worky, but there may be a superior way...
This commit is contained in:
Martin Grenfell 2016-10-21 14:47:09 +01:00
parent 48df6bfd6e
commit eee431dbd4
2 changed files with 5 additions and 0 deletions

View File

@ -37,6 +37,7 @@ function! s:reuseWin(dir) abort
endif endif
if nt.isWinTree() && nt.root.path.equals(path) if nt.isWinTree() && nt.root.path.equals(path)
call nt.setPreviousBuf(bufnr("#"))
exec "buffer " . i exec "buffer " . i
return 1 return 1
endif endif

View File

@ -186,6 +186,10 @@ function! s:NERDTree.previousBuf()
return self._previousBuf return self._previousBuf
endfunction endfunction
function! s:NERDTree.setPreviousBuf(bnum)
let self._previousBuf = a:bnum
endfunction
"FUNCTION: s:NERDTree.render() {{{1 "FUNCTION: s:NERDTree.render() {{{1
"A convenience function - since this is called often "A convenience function - since this is called often
function! s:NERDTree.render() function! s:NERDTree.render()