123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249 |
- if exists('g:loaded_nerdtree_autoload')
- finish
- endif
- let g:loaded_nerdtree_autoload = 1
- 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(...) abort
- let l:text = 'Unknown'
- try
- let l:changelog = readfile(join([s:rootNERDTreePath, 'CHANGELOG.md'], nerdtree#slash()))
- let l:line = 0
- while l:line <= len(l:changelog)
- if l:changelog[l:line] =~# '\d\+\.\d\+'
- let l:text = substitute(l:changelog[l:line], '.*\(\d\+.\d\+\).*', '\1', '')
- let l:text .= substitute(l:changelog[l:line+1], '^.\{-}\(\.\d\+\).\{-}:\(.*\)', a:0>0 ? '\1:\2' : '\1', '')
- break
- endif
- let l:line += 1
- endwhile
- catch
- endtry
- return l:text
- endfunction
- " SECTION: General Functions {{{1
- "============================================================
- " FUNCTION: nerdtree#closeTreeOnOpen() {{{2
- function! nerdtree#closeTreeOnOpen() abort
- return g:NERDTreeQuitOnOpen == 1 || g:NERDTreeQuitOnOpen == 3
- endfunction
- " FUNCTION: nerdtree#closeBookmarksOnOpen() {{{2
- function! nerdtree#closeBookmarksOnOpen() abort
- return g:NERDTreeQuitOnOpen == 2 || g:NERDTreeQuitOnOpen == 3
- endfunction
- " FUNCTION: nerdtree#slash() {{{2
- " Return the path separator used by the underlying file system. Special
- " consideration is taken for the use of the 'shellslash' option on Windows
- " systems.
- function! nerdtree#slash() abort
- if nerdtree#runningWindows()
- if exists('+shellslash') && &shellslash
- return '/'
- endif
- return '\'
- endif
- return '/'
- endfunction
- "FUNCTION: nerdtree#checkForBrowse(dir) {{{2
- "inits a window tree in the current buffer if appropriate
- function! nerdtree#checkForBrowse(dir) abort
- if !isdirectory(a:dir)
- return
- endif
- if s:reuseWin(a:dir)
- return
- endif
- call g:NERDTreeCreator.CreateWindowTree(a:dir)
- endfunction
- "FUNCTION: s:reuseWin(dir) {{{2
- "finds a NERDTree buffer with root of dir, and opens it.
- function! s:reuseWin(dir) abort
- let path = g:NERDTreePath.New(fnamemodify(a:dir, ':p'))
- for i in range(1, bufnr('$'))
- unlet! nt
- let nt = getbufvar(i, 'NERDTree')
- if empty(nt)
- continue
- endif
- if nt.isWinTree() && nt.root.path.equals(path)
- call nt.setPreviousBuf(bufnr('#'))
- exec 'buffer ' . i
- return 1
- endif
- endfor
- return 0
- endfunction
- " FUNCTION: nerdtree#completeBookmarks(A,L,P) {{{2
- " completion function for the bookmark commands
- function! nerdtree#completeBookmarks(A,L,P) abort
- return filter(g:NERDTreeBookmark.BookmarkNames(), 'v:val =~# "^' . a:A . '"')
- endfunction
- "FUNCTION: nerdtree#compareNodes(n1, n2) {{{2
- function! nerdtree#compareNodes(n1, n2) abort
- return nerdtree#compareNodePaths(a:n1.path, a:n2.path)
- endfunction
- "FUNCTION: nerdtree#compareNodePaths(p1, p2) {{{2
- function! nerdtree#compareNodePaths(p1, p2) abort
- let sortKey1 = a:p1.getSortKey()
- let sortKey2 = a:p2.getSortKey()
- let i = 0
- while i < min([len(sortKey1), len(sortKey2)])
- " Compare chunks upto common length.
- " If chunks have different type, the one which has
- " integer type is the lesser.
- if type(sortKey1[i]) == type(sortKey2[i])
- if sortKey1[i] <# sortKey2[i]
- return - 1
- elseif sortKey1[i] ># sortKey2[i]
- return 1
- endif
- elseif type(sortKey1[i]) == type(0)
- return -1
- elseif type(sortKey2[i]) == type(0)
- return 1
- endif
- let i += 1
- endwhile
- " Keys are identical upto common length.
- " The key which has smaller chunks is the lesser one.
- if len(sortKey1) < len(sortKey2)
- return -1
- elseif len(sortKey1) > len(sortKey2)
- return 1
- else
- return 0
- endif
- endfunction
- " FUNCTION: nerdtree#deprecated(func, [msg]) {{{2
- " Issue a deprecation warning for a:func. If a second arg is given, use this
- " as the deprecation message
- function! nerdtree#deprecated(func, ...) abort
- let msg = a:0 ? a:func . ' ' . a:1 : a:func . ' is deprecated'
- if !exists('s:deprecationWarnings')
- let s:deprecationWarnings = {}
- endif
- if !has_key(s:deprecationWarnings, a:func)
- let s:deprecationWarnings[a:func] = 1
- echomsg msg
- endif
- endfunction
- " FUNCTION: nerdtree#exec(cmd, ignoreAll) {{{2
- " Same as :exec cmd but, if ignoreAll is TRUE, set eventignore=all for the duration
- function! nerdtree#exec(cmd, ignoreAll) abort
- let old_ei = &eventignore
- if a:ignoreAll
- set eventignore=all
- endif
- try
- exec a:cmd
- finally
- let &eventignore = old_ei
- endtry
- endfunction
- " FUNCTION: nerdtree#has_opt(options, name) {{{2
- function! nerdtree#has_opt(options, name) abort
- return has_key(a:options, a:name) && a:options[a:name] ==# 1
- endfunction
- " FUNCTION: nerdtree#loadClassFiles() {{{2
- function! nerdtree#loadClassFiles() abort
- runtime lib/nerdtree/path.vim
- runtime lib/nerdtree/menu_controller.vim
- runtime lib/nerdtree/menu_item.vim
- runtime lib/nerdtree/key_map.vim
- runtime lib/nerdtree/bookmark.vim
- runtime lib/nerdtree/tree_file_node.vim
- runtime lib/nerdtree/tree_dir_node.vim
- runtime lib/nerdtree/opener.vim
- runtime lib/nerdtree/creator.vim
- runtime lib/nerdtree/flag_set.vim
- runtime lib/nerdtree/nerdtree.vim
- runtime lib/nerdtree/ui.vim
- runtime lib/nerdtree/event.vim
- runtime lib/nerdtree/notifier.vim
- endfunction
- " FUNCTION: nerdtree#postSourceActions() {{{2
- function! nerdtree#postSourceActions() abort
- call g:NERDTreeBookmark.CacheBookmarks(1)
- call nerdtree#ui_glue#createDefaultBindings()
- "load all nerdtree plugins
- runtime! nerdtree_plugin/**/*.vim
- endfunction
- "FUNCTION: nerdtree#runningWindows(dir) {{{2
- function! nerdtree#runningWindows() abort
- return has('win16') || has('win32') || has('win64')
- endfunction
- "FUNCTION: nerdtree#runningCygwin(dir) {{{2
- function! nerdtree#runningCygwin() abort
- return has('win32unix')
- endfunction
- " SECTION: View Functions {{{1
- "============================================================
- "FUNCTION: nerdtree#echo {{{2
- "A wrapper for :echo. Appends 'NERDTree:' on the front of all messages
- "
- "Args:
- "msg: the message to echo
- function! nerdtree#echo(msg) abort
- redraw
- echomsg empty(a:msg) ? '' : ('NERDTree: ' . a:msg)
- endfunction
- "FUNCTION: nerdtree#echoError {{{2
- "Wrapper for nerdtree#echo, sets the message type to errormsg for this message
- "Args:
- "msg: the message to echo
- function! nerdtree#echoError(msg) abort
- echohl errormsg
- call nerdtree#echo(a:msg)
- echohl normal
- endfunction
- "FUNCTION: nerdtree#echoWarning {{{2
- "Wrapper for nerdtree#echo, sets the message type to warningmsg for this message
- "Args:
- "msg: the message to echo
- function! nerdtree#echoWarning(msg) abort
- echohl warningmsg
- call nerdtree#echo(a:msg)
- echohl normal
- endfunction
- "FUNCTION: nerdtree#renderView {{{2
- function! nerdtree#renderView() abort
- call b:NERDTree.render()
- endfunction
- " vim: set sw=4 sts=4 et fdm=marker:
|