Add filename comparison into the mix
This commit is contained in:
parent
f0d2ce1be7
commit
ce17f507b5
@ -49,9 +49,9 @@ fu! s:opts()
|
|||||||
let s:igntype = empty(s:usrign) ? -1 : type(s:usrign)
|
let s:igntype = empty(s:usrign) ? -1 : type(s:usrign)
|
||||||
" Extensions
|
" Extensions
|
||||||
let g:ctrlp_builtins = 2
|
let g:ctrlp_builtins = 2
|
||||||
if !empty(s:extensions) | for each in s:extensions
|
for each in s:extensions
|
||||||
exe 'ru autoload/ctrlp/'.each.'.vim'
|
exe 'ru autoload/ctrlp/'.each.'.vim'
|
||||||
endfo | en
|
endfo
|
||||||
" Keymaps
|
" Keymaps
|
||||||
let [s:lcmap, s:prtmaps] = ['nn <buffer> <silent>', {
|
let [s:lcmap, s:prtmaps] = ['nn <buffer> <silent>', {
|
||||||
\ 'PrtBS()': ['<bs>', '<c-]>'],
|
\ 'PrtBS()': ['<bs>', '<c-]>'],
|
||||||
@ -219,7 +219,6 @@ fu! ctrlp#reset()
|
|||||||
cal s:opts()
|
cal s:opts()
|
||||||
cal ctrlp#utils#opts()
|
cal ctrlp#utils#opts()
|
||||||
cal ctrlp#mrufiles#opts()
|
cal ctrlp#mrufiles#opts()
|
||||||
unl! s:cline
|
|
||||||
endf
|
endf
|
||||||
" * Files() {{{1
|
" * Files() {{{1
|
||||||
fu! s:Files()
|
fu! s:Files()
|
||||||
@ -383,7 +382,7 @@ fu! s:Render(lines, pat, ipt)
|
|||||||
en
|
en
|
||||||
" Sort if not MRU
|
" Sort if not MRU
|
||||||
if ( s:itemtype != 2 && !exists('g:ctrlp_nolimit') )
|
if ( s:itemtype != 2 && !exists('g:ctrlp_nolimit') )
|
||||||
\ || !empty(join(s:prompt, ''))
|
\ || s:prompt != ['', '', '']
|
||||||
let s:compat = a:pat
|
let s:compat = a:pat
|
||||||
cal sort(lines, 's:mixedsort')
|
cal sort(lines, 's:mixedsort')
|
||||||
unl s:compat
|
unl s:compat
|
||||||
@ -401,7 +400,7 @@ fu! s:Render(lines, pat, ipt)
|
|||||||
en
|
en
|
||||||
" Highlighting
|
" Highlighting
|
||||||
if s:dohighlight()
|
if s:dohighlight()
|
||||||
cal s:highlight(a:pat, s:mathi[1] == '' ? 'Identifier' : s:mathi[1], a:ipt)
|
cal s:highlight(a:pat, s:mathi[1] == '' ? 'CtrlPMatch' : s:mathi[1], a:ipt)
|
||||||
en
|
en
|
||||||
endf
|
endf
|
||||||
|
|
||||||
@ -411,11 +410,8 @@ fu! s:Update(str)
|
|||||||
" Get the new string sans tail
|
" Get the new string sans tail
|
||||||
let str = s:sanstail(a:str)
|
let str = s:sanstail(a:str)
|
||||||
" Stop if the string's unchanged
|
" Stop if the string's unchanged
|
||||||
if str == oldstr && !empty(str) && !exists('s:force')
|
if str == oldstr && !empty(str) && !exists('s:force') | retu | en
|
||||||
retu
|
let [pat, ipt] = [s:SplitPattern(str), s:ispathitem()]
|
||||||
en
|
|
||||||
let pat = s:SplitPattern(str)
|
|
||||||
let ipt = s:ispathitem()
|
|
||||||
let lines = exists('g:ctrlp_nolimit') && empty(str) ? copy(g:ctrlp_lines)
|
let lines = exists('g:ctrlp_nolimit') && empty(str) ? copy(g:ctrlp_lines)
|
||||||
\ : s:MatchedItems(g:ctrlp_lines, pat, s:winh, ipt)
|
\ : s:MatchedItems(g:ctrlp_lines, pat, s:winh, ipt)
|
||||||
cal s:Render(lines, pat, ipt)
|
cal s:Render(lines, pat, ipt)
|
||||||
@ -627,17 +623,17 @@ endf
|
|||||||
fu! s:MapKeys(...)
|
fu! s:MapKeys(...)
|
||||||
" Normal keys
|
" Normal keys
|
||||||
let pfunc = a:0 && !a:1 ? 'PrtSelectJump' : 'PrtAdd'
|
let pfunc = a:0 && !a:1 ? 'PrtSelectJump' : 'PrtAdd'
|
||||||
let dojmp = s:byfname && pfunc == 'PrtSelectJump' ? ', 1' : ''
|
let dojmp = s:byfname && a:0 && !a:1 ? ', 1' : ''
|
||||||
let cmd = "nn \<buffer> \<silent> \<char-%d> :\<c-u>cal \<SID>%s(\"%s\"%s)\<cr>"
|
let pcmd = "nn \<buffer> \<silent> \<k%s> :\<c-u>cal \<SID>%s(\"%s\"%s)\<cr>"
|
||||||
|
let cmd = substitute(pcmd, 'k%s', 'char-%d', '')
|
||||||
for each in range(32, 126)
|
for each in range(32, 126)
|
||||||
exe printf(cmd, each, pfunc, escape(nr2char(each), '"|\'), dojmp)
|
exe printf(cmd, each, pfunc, escape(nr2char(each), '"|\'), dojmp)
|
||||||
endfo
|
endfo
|
||||||
let kpcmd = substitute(cmd, 'char-%d', 'k%s', '')
|
|
||||||
for each in range(0, 9)
|
for each in range(0, 9)
|
||||||
exe printf(kpcmd, each, pfunc, each, dojmp)
|
exe printf(pcmd, each, pfunc, each, dojmp)
|
||||||
endfo
|
endfo
|
||||||
for [ke, va] in items(s:kprange)
|
for [ke, va] in items(s:kprange)
|
||||||
exe printf(kpcmd, ke, pfunc, va, dojmp)
|
exe printf(pcmd, ke, pfunc, va, dojmp)
|
||||||
endfo
|
endfo
|
||||||
" Special keys
|
" Special keys
|
||||||
if a:0 < 2
|
if a:0 < 2
|
||||||
@ -791,8 +787,7 @@ fu! s:AcceptSelection(mode)
|
|||||||
let str = join(s:prompt, '')
|
let str = join(s:prompt, '')
|
||||||
if a:mode == 'e' | if s:SpecInputs(str) | retu | en | en
|
if a:mode == 'e' | if s:SpecInputs(str) | retu | en | en
|
||||||
" Get the selected line
|
" Get the selected line
|
||||||
let line = exists('s:matched') && !empty(s:matched)
|
let line = !empty(s:matched) ? s:matched[line('.') - 1] : ''
|
||||||
\ ? s:matched[line('.') - 1] : ''
|
|
||||||
if a:mode != 'e' && s:itemtype < 3 && line == ''
|
if a:mode != 'e' && s:itemtype < 3 && line == ''
|
||||||
\ && str !~ '\v^(\.\.|/|\\|\?)$'
|
\ && str !~ '\v^(\.\.|/|\\|\?)$'
|
||||||
cal s:CreateNewFile(a:mode) | retu
|
cal s:CreateNewFile(a:mode) | retu
|
||||||
@ -840,8 +835,7 @@ fu! s:MarkToOpen()
|
|||||||
\ || ( s:itemtype > g:ctrlp_builtins && s:type() !~ 'rts' )
|
\ || ( s:itemtype > g:ctrlp_builtins && s:type() !~ 'rts' )
|
||||||
retu
|
retu
|
||||||
en
|
en
|
||||||
let line = exists('s:matched') && !empty(s:matched)
|
let line = !empty(s:matched) ? s:matched[line('.') - 1] : ''
|
||||||
\ ? s:matched[line('.') - 1] : ''
|
|
||||||
if empty(line) | retu | en
|
if empty(line) | retu | en
|
||||||
let filpath = fnamemodify(line, ':p')
|
let filpath = fnamemodify(line, ':p')
|
||||||
if exists('s:marked') && s:dictindex(s:marked, filpath) > 0
|
if exists('s:marked') && s:dictindex(s:marked, filpath) > 0
|
||||||
@ -938,6 +932,13 @@ fu! s:comparent(s1, s2)
|
|||||||
retu 0
|
retu 0
|
||||||
endf
|
endf
|
||||||
|
|
||||||
|
fu! s:compfnlen(s1, s2)
|
||||||
|
" By filename length
|
||||||
|
let len1 = strlen(split(a:s1, s:lash)[-1])
|
||||||
|
let len2 = strlen(split(a:s2, s:lash)[-1])
|
||||||
|
retu len1 == len2 ? 0 : len1 > len2 ? 1 : -1
|
||||||
|
endf
|
||||||
|
|
||||||
fu! s:matchlens(str, pat, ...)
|
fu! s:matchlens(str, pat, ...)
|
||||||
if empty(a:pat) || index(['^', '$'], a:pat) >= 0 | retu {} | en
|
if empty(a:pat) || index(['^', '$'], a:pat) >= 0 | retu {} | en
|
||||||
let st = a:0 ? a:1 : 0
|
let st = a:0 ? a:1 : 0
|
||||||
@ -959,11 +960,12 @@ endf
|
|||||||
fu! s:mixedsort(s1, s2)
|
fu! s:mixedsort(s1, s2)
|
||||||
let [cml, cln] = [s:compmatlen(a:s1, a:s2), ctrlp#complen(a:s1, a:s2)]
|
let [cml, cln] = [s:compmatlen(a:s1, a:s2), ctrlp#complen(a:s1, a:s2)]
|
||||||
if s:itemtype < 3 && s:height < 51
|
if s:itemtype < 3 && s:height < 51
|
||||||
let par = s:comparent(a:s1, a:s2)
|
let [par, cfn] = [s:comparent(a:s1, a:s2), s:compfnlen(a:s1, a:s2)]
|
||||||
if s:height < 21
|
if s:height < 21
|
||||||
retu 6 * cml + 3 * par + 2 * s:comptime(a:s1, a:s2) + cln
|
let ctm = s:comptime(a:s1, a:s2)
|
||||||
|
retu 12 * cml + 6 * par + 3 * cfn + 2 * ctm + cln
|
||||||
en
|
en
|
||||||
retu 3 * cml + 2 * par + cln
|
retu 6 * cml + 3 * par + 2 * cfn + cln
|
||||||
en
|
en
|
||||||
retu 2 * cml + cln
|
retu 2 * cml + cln
|
||||||
endf
|
endf
|
||||||
@ -1344,7 +1346,7 @@ fu! s:argmaps(md, ...)
|
|||||||
endf
|
endf
|
||||||
" Misc {{{2
|
" Misc {{{2
|
||||||
fu! s:strwidth(str)
|
fu! s:strwidth(str)
|
||||||
retu v:version > 702 ? strdisplaywidth(a:str) : strlen(a:str)
|
retu exists('*strdisplaywidth') ? strdisplaywidth(a:str) : strlen(a:str)
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:getenv()
|
fu! s:getenv()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user