mirror of
https://github.com/preservim/nerdtree.git
synced 2025-11-09 11:53:48 -05:00
Compare commits
11 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
496b61ead1 | ||
|
|
5af6859846 | ||
|
|
bd744eab8d | ||
|
|
9193962ad8 | ||
|
|
2eaedd8bf4 | ||
|
|
60ec10b477 | ||
|
|
51fc75efdb | ||
|
|
79ef87b009 | ||
|
|
3d508aedce | ||
|
|
9afab6257b | ||
|
|
877f41e243 |
10
.github/PULL_REQUEST_TEMPLATE.md
vendored
10
.github/PULL_REQUEST_TEMPLATE.md
vendored
@@ -9,11 +9,5 @@ Closes # <!-- Issue number this PR addresses. If none, remove this line. -->
|
|||||||
- [ ] `MAJOR` version when you make incompatible API changes
|
- [ ] `MAJOR` version when you make incompatible API changes
|
||||||
- [ ] `MINOR` version when you add functionality in a backwards-compatible manner
|
- [ ] `MINOR` version when you add functionality in a backwards-compatible manner
|
||||||
- [ ] `PATCH` version when you make backwards-compatible bug fixes
|
- [ ] `PATCH` version when you make backwards-compatible bug fixes
|
||||||
- [ ] Update [CHANGELOG.md](https://github.com/scrooloose/nerdtree/blob/master/CHANGELOG.md).
|
- [ ] Update [CHANGELOG.md](https://github.com/scrooloose/nerdtree/blob/master/CHANGELOG.md), following the established pattern.
|
||||||
<!--
|
- [ ] Tag the merge commit, e.g. `git tag -a 3.1.4 -m "v3.1.4" && git push origin --tags`
|
||||||
Use this format in CHANGELOG.md. Use the existing text as a template.
|
|
||||||
|
|
||||||
#### MAJOR.MINOR...
|
|
||||||
- **.PATCH**: PR Title (Author) [#PR Number](link to PR)
|
|
||||||
|
|
||||||
-->
|
|
||||||
|
|||||||
14
CHANGELOG.md
14
CHANGELOG.md
@@ -1,12 +1,18 @@
|
|||||||
# Change Log
|
# Change Log
|
||||||
|
|
||||||
|
#### 6.0...
|
||||||
|
- **.1**: Reintroduce necessary variable mistakenly removed. (PhilRunninger) [#1040](https://github.com/scrooloose/nerdtree/pull/1040)
|
||||||
|
- **.0**: Make the behavior of window splits consistent (dragonxlwang, PhilRunninger) [#1035](https://github.com/scrooloose/nerdtree/pull/1035)
|
||||||
#### 5.3...
|
#### 5.3...
|
||||||
- **.0**: Add file extension and size to sorting capabilities [#1029](https://github.com/scrooloose/nerdtree/pull/1029)
|
- **.3**: Fix (p)ath not displaying in the minimal menu (tuzz) [#1038](https://github.com/scrooloose/nerdtree/pull/1038)
|
||||||
|
- **.2**: Enable events when closing NerdTree window. (PhilRunninger) [#1037](https://github.com/scrooloose/nerdtree/pull/1037)
|
||||||
|
- **.1**: Fix the `e` key mapping to use netrw if desired (PhilRunninger) [#1031](https://github.com/scrooloose/nerdtree/pull/1031)
|
||||||
|
- **.0**: Add file extension and size to sorting capabilities (PhilRunninger) [#1029](https://github.com/scrooloose/nerdtree/pull/1029)
|
||||||
#### 5.2...
|
#### 5.2...
|
||||||
- **.9**: Suppress events for intermediate window/tab/buffer changes [#1026](https://github.com/scrooloose/nerdtree/pull/1026)
|
- **.9**: Suppress events for intermediate window/tab/buffer changes (PhilRunninger) [#1026](https://github.com/scrooloose/nerdtree/pull/1026)
|
||||||
- **.8**: Revert [#1019](https://github.com/scrooloose/nerdtree/pull/1019) to fix nvim artifacts and flickering. (PhilRunninger) [#1021](https://github.com/scrooloose/nerdtree/pull/1021)
|
- **.8**: Revert [#1019](https://github.com/scrooloose/nerdtree/pull/1019) to fix nvim artifacts and flickering. (PhilRunninger) [#1021](https://github.com/scrooloose/nerdtree/pull/1021)
|
||||||
- **.7**: Use :mode only in neovim. MacVim still needs to use :redraw! [#1019](https://github.com/scrooloose/nerdtree/pull/1019)
|
- **.7**: Use :mode only in neovim. MacVim still needs to use :redraw! (PhilRunninger) [#1019](https://github.com/scrooloose/nerdtree/pull/1019)
|
||||||
- **.6**: In CHANGELOG.md and PR template, make reference to PR a true HTML link. [#1017](https://github.com/scrooloose/nerdtree/pull/1017)
|
- **.6**: In CHANGELOG.md and PR template, make reference to PR a true HTML link. (PhilRunninger) [#1017](https://github.com/scrooloose/nerdtree/pull/1017)
|
||||||
- **.5**: Use `:mode` instead of `:redraw!` when updating menu. (PhilRunninger) [#1016](https://github.com/scrooloose/nerdtree/pull/1016)
|
- **.5**: Use `:mode` instead of `:redraw!` when updating menu. (PhilRunninger) [#1016](https://github.com/scrooloose/nerdtree/pull/1016)
|
||||||
- **.4**: When searching for root line num, stop at end of file. (PhilRunninger) [#1015](https://github.com/scrooloose/nerdtree/pull/1015)
|
- **.4**: When searching for root line num, stop at end of file. (PhilRunninger) [#1015](https://github.com/scrooloose/nerdtree/pull/1015)
|
||||||
- **.3**: Fix `<CR>` key map on the bookmark (lkebin) [#1014](https://github.com/scrooloose/nerdtree/pull/1014)
|
- **.3**: Fix `<CR>` key map on the bookmark (lkebin) [#1014](https://github.com/scrooloose/nerdtree/pull/1014)
|
||||||
|
|||||||
@@ -4,6 +4,11 @@ endif
|
|||||||
let g:loaded_nerdtree_autoload = 1
|
let g:loaded_nerdtree_autoload = 1
|
||||||
|
|
||||||
let s:rootNERDTreePath = resolve(expand("<sfile>:p:h:h"))
|
let s:rootNERDTreePath = resolve(expand("<sfile>:p:h:h"))
|
||||||
|
|
||||||
|
"FUNCTION: nerdtree#version(...) {{{1
|
||||||
|
" If any value is given as an argument, the entire line of text from the
|
||||||
|
" change log is shown for the current version; otherwise, only the version
|
||||||
|
" number is shown.
|
||||||
function! nerdtree#version(...)
|
function! nerdtree#version(...)
|
||||||
let l:changelog = readfile(join([s:rootNERDTreePath, "CHANGELOG.md"], nerdtree#slash()))
|
let l:changelog = readfile(join([s:rootNERDTreePath, "CHANGELOG.md"], nerdtree#slash()))
|
||||||
let l:text = 'Unknown'
|
let l:text = 'Unknown'
|
||||||
@@ -22,6 +27,7 @@ endfunction
|
|||||||
" SECTION: General Functions {{{1
|
" SECTION: General Functions {{{1
|
||||||
"============================================================
|
"============================================================
|
||||||
|
|
||||||
|
"FUNCTION: nerdtree#slash() {{{2
|
||||||
function! nerdtree#slash()
|
function! nerdtree#slash()
|
||||||
|
|
||||||
if nerdtree#runningWindows()
|
if nerdtree#runningWindows()
|
||||||
@@ -49,7 +55,6 @@ function! nerdtree#and(x,y)
|
|||||||
if (l:x % 2) && (l:y % 2)
|
if (l:x % 2) && (l:y % 2)
|
||||||
let l:result += float2nr(pow(2, l:n))
|
let l:result += float2nr(pow(2, l:n))
|
||||||
endif
|
endif
|
||||||
echomsg l:x . ", " . l:y . " => " l:result
|
|
||||||
let l:x = float2nr(l:x / 2)
|
let l:x = float2nr(l:x / 2)
|
||||||
let l:y = float2nr(l:y / 2)
|
let l:y = float2nr(l:y / 2)
|
||||||
let l:n += 1
|
let l:n += 1
|
||||||
|
|||||||
@@ -72,6 +72,7 @@ function! nerdtree#ui_glue#createDefaultBindings()
|
|||||||
call NERDTreeAddKeyMap({ 'key': g:NERDTreeMapOpenInTabSilent, 'scope': 'Bookmark', 'callback': s . 'openInNewTabSilent' })
|
call NERDTreeAddKeyMap({ 'key': g:NERDTreeMapOpenInTabSilent, 'scope': 'Bookmark', 'callback': s . 'openInNewTabSilent' })
|
||||||
|
|
||||||
call NERDTreeAddKeyMap({ 'key': g:NERDTreeMapOpenExpl, 'scope': "DirNode", 'callback': s."openExplorer" })
|
call NERDTreeAddKeyMap({ 'key': g:NERDTreeMapOpenExpl, 'scope': "DirNode", 'callback': s."openExplorer" })
|
||||||
|
call NERDTreeAddKeyMap({ 'key': g:NERDTreeMapOpenExpl, 'scope': "FileNode", 'callback': s."openExplorer" })
|
||||||
|
|
||||||
call NERDTreeAddKeyMap({ 'key': g:NERDTreeMapDeleteBookmark, 'scope': "Bookmark", 'callback': s."deleteBookmark" })
|
call NERDTreeAddKeyMap({ 'key': g:NERDTreeMapDeleteBookmark, 'scope': "Bookmark", 'callback': s."deleteBookmark" })
|
||||||
endfunction
|
endfunction
|
||||||
|
|||||||
@@ -62,9 +62,10 @@ function! s:MenuController._echoPrompt()
|
|||||||
|
|
||||||
if self.isMinimal()
|
if self.isMinimal()
|
||||||
let selection = self.menuItems[self.selection].text
|
let selection = self.menuItems[self.selection].text
|
||||||
|
let keyword = matchstr(selection, "\([^ ]*")
|
||||||
|
|
||||||
let shortcuts = map(copy(self.menuItems), "v:val['shortcut']")
|
let shortcuts = map(copy(self.menuItems), "v:val['shortcut']")
|
||||||
let shortcuts[self.selection] = " " . split(selection)[0] . " "
|
let shortcuts[self.selection] = " " . keyword . " "
|
||||||
|
|
||||||
echo "Menu: [" . join(shortcuts, ",") . "] (" . navHelp . " or shortcut): "
|
echo "Menu: [" . join(shortcuts, ",") . "] (" . navHelp . " or shortcut): "
|
||||||
else
|
else
|
||||||
|
|||||||
@@ -52,7 +52,7 @@ function! s:NERDTree.Close()
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
call nerdtree#exec(s:NERDTree.GetWinNum() . " wincmd w", 1)
|
call nerdtree#exec(s:NERDTree.GetWinNum() . " wincmd w", 1)
|
||||||
call nerdtree#exec("close", 1)
|
call nerdtree#exec("close", 0)
|
||||||
if l:useWinId
|
if l:useWinId
|
||||||
call nerdtree#exec("call win_gotoid(" . l:activeBufOrWin . ")", 0)
|
call nerdtree#exec("call win_gotoid(" . l:activeBufOrWin . ")", 0)
|
||||||
else
|
else
|
||||||
@@ -148,12 +148,19 @@ function! s:NERDTree.GetWinNum()
|
|||||||
return bufwinnr(t:NERDTreeBufName)
|
return bufwinnr(t:NERDTreeBufName)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
" If WindowTree, there is no t:NERDTreeBufName variable. Search all windows.
|
||||||
|
for w in range(1,winnr('$'))
|
||||||
|
if bufname(winbufnr(w)) =~# '^' . g:NERDTreeCreator.BufNamePrefix() . '\d\+$'
|
||||||
|
return w
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
|
||||||
return -1
|
return -1
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
"FUNCTION: s:NERDTree.IsOpen() {{{1
|
"FUNCTION: s:NERDTree.IsOpen() {{{1
|
||||||
function! s:NERDTree.IsOpen()
|
function! s:NERDTree.IsOpen()
|
||||||
return s:NERDTree.GetWinNum() != -1 || bufname('%') =~# '^' . g:NERDTreeCreator.BufNamePrefix() . '\d\+$'
|
return s:NERDTree.GetWinNum() != -1
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
"FUNCTION: s:NERDTree.isTabTree() {{{1
|
"FUNCTION: s:NERDTree.isTabTree() {{{1
|
||||||
|
|||||||
@@ -71,9 +71,9 @@ endfunction
|
|||||||
function! s:Opener._gotoTargetWin()
|
function! s:Opener._gotoTargetWin()
|
||||||
if b:NERDTree.isWinTree()
|
if b:NERDTree.isWinTree()
|
||||||
if self._where == 'v'
|
if self._where == 'v'
|
||||||
vsplit
|
call self._newVSplit()
|
||||||
elseif self._where == 'h'
|
elseif self._where == 'h'
|
||||||
split
|
call self._newSplit()
|
||||||
elseif self._where == 't'
|
elseif self._where == 't'
|
||||||
tabnew
|
tabnew
|
||||||
endif
|
endif
|
||||||
@@ -153,44 +153,18 @@ endfunction
|
|||||||
|
|
||||||
" FUNCTION: Opener._newSplit() {{{1
|
" FUNCTION: Opener._newSplit() {{{1
|
||||||
function! s:Opener._newSplit()
|
function! s:Opener._newSplit()
|
||||||
" Save the user's settings for splitbelow and splitright
|
|
||||||
let savesplitbelow=&splitbelow
|
|
||||||
let savesplitright=&splitright
|
|
||||||
|
|
||||||
" 'there' will be set to a command to move from the split window
|
|
||||||
" back to the explorer window
|
|
||||||
"
|
|
||||||
" 'back' will be set to a command to move from the explorer window
|
|
||||||
" back to the newly split window
|
|
||||||
"
|
|
||||||
" 'right' and 'below' will be set to the settings needed for
|
|
||||||
" splitbelow and splitright IF the explorer is the only window.
|
|
||||||
"
|
|
||||||
let there= g:NERDTreeWinPos ==# "left" ? "wincmd h" : "wincmd l"
|
|
||||||
let back = g:NERDTreeWinPos ==# "left" ? "wincmd l" : "wincmd h"
|
|
||||||
let right= g:NERDTreeWinPos ==# "left"
|
|
||||||
let below=0
|
|
||||||
|
|
||||||
" Attempt to go to adjacent window
|
|
||||||
call nerdtree#exec(back, 1)
|
|
||||||
|
|
||||||
let onlyOneWin = (winnr("$") ==# 1)
|
let onlyOneWin = (winnr("$") ==# 1)
|
||||||
|
let savesplitright = &splitright
|
||||||
" If no adjacent window, set splitright and splitbelow appropriately
|
|
||||||
if onlyOneWin
|
if onlyOneWin
|
||||||
let &splitright=right
|
let &splitright = (g:NERDTreeWinPos ==# "left")
|
||||||
let &splitbelow=below
|
|
||||||
else
|
|
||||||
" found adjacent window - invert split direction
|
|
||||||
let &splitright=!right
|
|
||||||
let &splitbelow=!below
|
|
||||||
endif
|
endif
|
||||||
|
" If only one window (ie. NERDTree), split vertically instead.
|
||||||
let splitMode = onlyOneWin ? "vertical" : ""
|
let splitMode = onlyOneWin ? "vertical" : ""
|
||||||
|
|
||||||
" Open the new window
|
" Open the new window
|
||||||
try
|
try
|
||||||
exec(splitMode." sp ")
|
call nerdtree#exec('wincmd p', 1)
|
||||||
|
call nerdtree#exec(splitMode . " split",1)
|
||||||
catch /^Vim\%((\a\+)\)\=:E37/
|
catch /^Vim\%((\a\+)\)\=:E37/
|
||||||
call g:NERDTree.CursorToTreeWin()
|
call g:NERDTree.CursorToTreeWin()
|
||||||
throw "NERDTree.FileAlreadyOpenAndModifiedError: ". self._path.str() ." is already open and modified."
|
throw "NERDTree.FileAlreadyOpenAndModifiedError: ". self._path.str() ." is already open and modified."
|
||||||
@@ -200,14 +174,12 @@ function! s:Opener._newSplit()
|
|||||||
|
|
||||||
"resize the tree window if no other window was open before
|
"resize the tree window if no other window was open before
|
||||||
if onlyOneWin
|
if onlyOneWin
|
||||||
let size = exists("b:NERDTreeOldWindowSize") ? b:NERDTreeOldWindowSize : g:NERDTreeWinSize
|
let size = exists('b:NERDTreeOldWindowSize') ? b:NERDTreeOldWindowSize : g:NERDTreeWinSize
|
||||||
call nerdtree#exec(there, 1)
|
call nerdtree#exec('wincmd p', 1)
|
||||||
exec("silent ". splitMode ." resize ". size)
|
call nerdtree#exec('silent '. splitMode .' resize '. size, 1)
|
||||||
call nerdtree#exec('wincmd p', 0)
|
call nerdtree#exec('wincmd p', 0)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
" Restore splitmode settings
|
|
||||||
let &splitbelow=savesplitbelow
|
|
||||||
let &splitright=savesplitright
|
let &splitright=savesplitright
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
@@ -215,7 +187,10 @@ endfunction
|
|||||||
function! s:Opener._newVSplit()
|
function! s:Opener._newVSplit()
|
||||||
let l:winwidth = winwidth('.')
|
let l:winwidth = winwidth('.')
|
||||||
|
|
||||||
if winnr('$') == 1
|
let onlyOneWin = (winnr("$") ==# 1)
|
||||||
|
let savesplitright = &splitright
|
||||||
|
if onlyOneWin
|
||||||
|
let &splitright = (g:NERDTreeWinPos ==# "left")
|
||||||
let l:winwidth = g:NERDTreeWinSize
|
let l:winwidth = g:NERDTreeWinSize
|
||||||
endif
|
endif
|
||||||
|
|
||||||
@@ -229,6 +204,7 @@ function! s:Opener._newVSplit()
|
|||||||
execute 'silent vertical resize ' . l:winwidth
|
execute 'silent vertical resize ' . l:winwidth
|
||||||
|
|
||||||
call nerdtree#exec(l:currentWindowNumber . 'wincmd w', 0)
|
call nerdtree#exec(l:currentWindowNumber . 'wincmd w', 0)
|
||||||
|
let &splitright=savesplitright
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
" FUNCTION: Opener.open(target) {{{1
|
" FUNCTION: Opener.open(target) {{{1
|
||||||
|
|||||||
@@ -413,24 +413,12 @@ function! s:Path.getSortKey()
|
|||||||
let metadata = []
|
let metadata = []
|
||||||
for tag in g:NERDTreeSortOrder
|
for tag in g:NERDTreeSortOrder
|
||||||
if tag =~? '\[\[-\?timestamp\]\]'
|
if tag =~? '\[\[-\?timestamp\]\]'
|
||||||
if self.isDirectory
|
let metadata += [self.isDirectory ? 0 : getftime(self.str()) * (tag =~ '-' ? -1 : 1)]
|
||||||
call add(metadata, 0)
|
|
||||||
else
|
|
||||||
call add(metadata, (tag =~ '-' ? -1 : 1) * getftime(self.str()))
|
|
||||||
endif
|
|
||||||
elseif tag =~? '\[\[-\?size\]\]'
|
elseif tag =~? '\[\[-\?size\]\]'
|
||||||
if self.isDirectory
|
let metadata += [self.isDirectory ? 0 : getfsize(self.str()) * (tag =~ '-' ? -1 : 1)]
|
||||||
call add(metadata, 0)
|
|
||||||
else
|
|
||||||
call add(metadata, (tag =~ '-' ? -1 : 1) * getfsize(self.str()))
|
|
||||||
endif
|
|
||||||
elseif tag =~? '\[\[extension\]\]'
|
elseif tag =~? '\[\[extension\]\]'
|
||||||
if self.isDirectory
|
|
||||||
call add(metadata, '')
|
|
||||||
else
|
|
||||||
let extension = matchstr(self.getLastPathComponent(0), '[^.]\+\.\zs[^.]\+$')
|
let extension = matchstr(self.getLastPathComponent(0), '[^.]\+\.\zs[^.]\+$')
|
||||||
call add(metadata, extension == '' ? nr2char(str2nr('0x10ffff',16)) : extension)
|
let metadata += [self.isDirectory ? '' : (extension == '' ? nr2char(str2nr('0x10ffff',16)) : extension)]
|
||||||
endif
|
|
||||||
endif
|
endif
|
||||||
endfor
|
endfor
|
||||||
|
|
||||||
|
|||||||
@@ -523,7 +523,8 @@ endfunction
|
|||||||
" Open an explorer window for this node in the previous window. The explorer
|
" Open an explorer window for this node in the previous window. The explorer
|
||||||
" can be a NERDTree window or a netrw window.
|
" can be a NERDTree window or a netrw window.
|
||||||
function! s:TreeDirNode.openExplorer()
|
function! s:TreeDirNode.openExplorer()
|
||||||
call self.open({'where': 'p'})
|
execute "wincmd p"
|
||||||
|
execute "edit ".self.path.str({'format':'Edit'})
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
" FUNCTION: TreeDirNode.openInNewTab(options) {{{1
|
" FUNCTION: TreeDirNode.openInNewTab(options) {{{1
|
||||||
|
|||||||
@@ -246,6 +246,12 @@ function! s:TreeFileNode.openInNewTab(options)
|
|||||||
call self.open(extend({'where': 't'}, a:options))
|
call self.open(extend({'where': 't'}, a:options))
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
|
" FUNCTION: TreeFileNode.openExplorer()
|
||||||
|
function! s:TreeFileNode.openExplorer()
|
||||||
|
execute "wincmd p"
|
||||||
|
execute "edit ".self.path.getParent().str({'format':'Edit'})
|
||||||
|
endfunction
|
||||||
|
|
||||||
" FUNCTION: TreeFileNode.putCursorHere(isJump, recurseUpward){{{1
|
" FUNCTION: TreeFileNode.putCursorHere(isJump, recurseUpward){{{1
|
||||||
" Places the cursor on the line number this node is rendered on
|
" Places the cursor on the line number this node is rendered on
|
||||||
"
|
"
|
||||||
|
|||||||
Reference in New Issue
Block a user