Refactor code to use getSortKey() and replace regular expression with
simple string comparison in tree_dir_node.vim
This commit is contained in:
parent
3fb3fe3477
commit
80e184df56
@ -34,11 +34,11 @@ function! nerdtree#compareNodes(n1, n2)
|
|||||||
return a:n1.path.compareTo(a:n2.path)
|
return a:n1.path.compareTo(a:n2.path)
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
"FUNCTION: nerdtree#compareNodesBySortingToken(n1, n2) {{{2
|
"FUNCTION: nerdtree#compareNodesBySortKey(n1, n2) {{{2
|
||||||
function! nerdtree#compareNodesBySortingToken(n1, n2)
|
function! nerdtree#compareNodesBySortKey(n1, n2)
|
||||||
if a:n1.sorting_token < a:n2.sorting_token
|
if a:n1.path.getSortKey() < a:n2.path.getSortKey()
|
||||||
return -1
|
return -1
|
||||||
elseif a:n1.sorting_token > a:n2.sorting_token
|
elseif a:n1.path.getSortKey() > a:n2.path.getSortKey()
|
||||||
return 1
|
return 1
|
||||||
else
|
else
|
||||||
return 0
|
return 0
|
||||||
|
@ -1,6 +1,9 @@
|
|||||||
"we need to use this number many times for sorting... so we calculate it only
|
"we need to use this number many times for sorting... so we calculate it only
|
||||||
"once here
|
"once here
|
||||||
let s:NERDTreeSortStarIndex = index(g:NERDTreeSortOrder, '*')
|
let s:NERDTreeSortStarIndex = index(g:NERDTreeSortOrder, '*')
|
||||||
|
" used in formating sortKey, e.g. '%04d'
|
||||||
|
let s:format = "%0" . float2nr(ceil(log10(len(g:NERDTreeSortOrder)))) . "d"
|
||||||
|
|
||||||
|
|
||||||
"CLASS: Path
|
"CLASS: Path
|
||||||
"============================================================
|
"============================================================
|
||||||
@ -361,6 +364,24 @@ function! s:Path.getSortOrderIndex()
|
|||||||
return s:NERDTreeSortStarIndex
|
return s:NERDTreeSortStarIndex
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
|
"FUNCTION: Path.getSortKey() {{{1
|
||||||
|
"returns a string used in compare function for sorting
|
||||||
|
function! s:Path.getSortKey()
|
||||||
|
if !exists("self.sortKey")
|
||||||
|
let path = self.getLastPathComponent(1)
|
||||||
|
if !g:NERDTreeSortHiddenFirst
|
||||||
|
let path = substitute(path, '^[._]', '', '')
|
||||||
|
endif
|
||||||
|
if !g:NERDTreeCaseSensitiveSort
|
||||||
|
let path = tolower(path)
|
||||||
|
endif
|
||||||
|
let self.sortKey = printf(s:format, self.getSortOrderIndex()) . path
|
||||||
|
endif
|
||||||
|
|
||||||
|
return self.sortKey
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
|
||||||
"FUNCTION: Path.isUnixHiddenFile() {{{1
|
"FUNCTION: Path.isUnixHiddenFile() {{{1
|
||||||
"check for unix hidden files
|
"check for unix hidden files
|
||||||
function! s:Path.isUnixHiddenFile()
|
function! s:Path.isUnixHiddenFile()
|
||||||
|
@ -246,8 +246,13 @@ function! s:TreeDirNode._initChildren(silent)
|
|||||||
"filter out the .. and . directories
|
"filter out the .. and . directories
|
||||||
"Note: we must match .. AND ../ cos sometimes the globpath returns
|
"Note: we must match .. AND ../ cos sometimes the globpath returns
|
||||||
"../ for path with strange chars (eg $)
|
"../ for path with strange chars (eg $)
|
||||||
if i !~# '\/\.\.\/\?$' && i !~# '\/\.\/\?$'
|
" if i !~# '\/\.\.\/\?$' && i !~# '\/\.\/\?$'
|
||||||
|
"
|
||||||
|
" 20150511
|
||||||
|
" Regular expression is too expensive. Use simply string comparison
|
||||||
|
" instead
|
||||||
|
if i[len(i)-3:2] != ".." && i[len(i)-2:2] != ".." &&
|
||||||
|
\ i[len(i)-2:1] != "." && i[len(i)-1] != "."
|
||||||
"put the next file in a new node and attach it
|
"put the next file in a new node and attach it
|
||||||
try
|
try
|
||||||
let path = g:NERDTreePath.New(i)
|
let path = g:NERDTreePath.New(i)
|
||||||
@ -405,8 +410,13 @@ function! s:TreeDirNode.refresh()
|
|||||||
"filter out the .. and . directories
|
"filter out the .. and . directories
|
||||||
"Note: we must match .. AND ../ cos sometimes the globpath returns
|
"Note: we must match .. AND ../ cos sometimes the globpath returns
|
||||||
"../ for path with strange chars (eg $)
|
"../ for path with strange chars (eg $)
|
||||||
if i !~# '\/\.\.\/\?$' && i !~# '\/\.\/\?$'
|
"if i !~# '\/\.\.\/\?$' && i !~# '\/\.\/\?$'
|
||||||
|
|
||||||
|
" 20150511
|
||||||
|
" Regular expression is too expensive. Use simply string comparison
|
||||||
|
" instead
|
||||||
|
if i[len(i)-3:2] != ".." && i[len(i)-2:2] != ".." &&
|
||||||
|
\ i[len(i)-2:1] != "." && i[len(i)-1] != "."
|
||||||
try
|
try
|
||||||
"create a new path and see if it exists in this nodes children
|
"create a new path and see if it exists in this nodes children
|
||||||
let path = g:NERDTreePath.New(i)
|
let path = g:NERDTreePath.New(i)
|
||||||
@ -504,24 +514,7 @@ endfunction
|
|||||||
"directory priority.
|
"directory priority.
|
||||||
"
|
"
|
||||||
function! s:TreeDirNode.sortChildren()
|
function! s:TreeDirNode.sortChildren()
|
||||||
let CompareFunc = function("nerdtree#compareNodesBySortingToken")
|
let CompareFunc = function("nerdtree#compareNodesBySortKey")
|
||||||
" To optimize sorting, let's generate the sorting token for comparison
|
|
||||||
|
|
||||||
" calculate how large number is needed to represent " order index
|
|
||||||
let digit = ceil(log10(len(g:NERDTreeSortOrder)))
|
|
||||||
let format = "%0" . float2nr(digit) . "d" " e.g. '%04d'
|
|
||||||
|
|
||||||
for child in self.children
|
|
||||||
let path = child.path.getLastPathComponent(1)
|
|
||||||
if !g:NERDTreeSortHiddenFirst
|
|
||||||
let path = substitute(path, '^[._]', '', '')
|
|
||||||
endif
|
|
||||||
if !g:NERDTreeCaseSensitiveSort
|
|
||||||
let path = tolower(path)
|
|
||||||
endif
|
|
||||||
let child.sorting_token = printf(format, child.path.getSortOrderIndex()) . path
|
|
||||||
endfor
|
|
||||||
|
|
||||||
call sort(self.children, CompareFunc)
|
call sort(self.children, CompareFunc)
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user