various changes
This commit is contained in:
parent
7dbf68e96b
commit
ff56395a8f
@ -1,6 +1,6 @@
|
|||||||
" =============================================================================
|
" =============================================================================
|
||||||
" File: autoload/ctrlp.vim
|
" File: autoload/ctrlp.vim
|
||||||
" Description: Full path fuzzy file and buffer finder for Vim.
|
" Description: Full path fuzzy file, buffer and MRU file finder for Vim.
|
||||||
" Author: Kien Nguyen <github.com/kien>
|
" Author: Kien Nguyen <github.com/kien>
|
||||||
" License: MIT
|
" License: MIT
|
||||||
" =============================================================================
|
" =============================================================================
|
||||||
@ -55,6 +55,13 @@ else
|
|||||||
unl g:ctrlp_working_path_mode
|
unl g:ctrlp_working_path_mode
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
if !exists('g:ctrlp_root_markers')
|
||||||
|
let s:rmarkers = []
|
||||||
|
else
|
||||||
|
let s:rmarkers = g:ctrlp_root_markers
|
||||||
|
unl g:ctrlp_root_markers
|
||||||
|
endif
|
||||||
|
|
||||||
if !exists('g:ctrlp_max_height')
|
if !exists('g:ctrlp_max_height')
|
||||||
let s:mxheight = 10
|
let s:mxheight = 10
|
||||||
else
|
else
|
||||||
@ -114,13 +121,24 @@ else
|
|||||||
unl g:ctrlp_dotfiles
|
unl g:ctrlp_dotfiles
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
if !exists('g:ctrlp_highlight_match')
|
||||||
|
let s:mathi = [1, 'Function']
|
||||||
|
else
|
||||||
|
let s:mathi = g:ctrlp_highlight_match
|
||||||
|
unl g:ctrlp_highlight_match
|
||||||
|
endif
|
||||||
|
|
||||||
|
if !exists('g:ctrlp_user_command')
|
||||||
|
let g:ctrlp_user_command = ''
|
||||||
|
endif
|
||||||
|
|
||||||
" Limiters
|
" Limiters
|
||||||
let s:compare_lim = 3000
|
let s:compare_lim = 3000
|
||||||
let s:nocache_lim = 4000
|
let s:nocache_lim = 4000
|
||||||
let s:mltipats_lim = 2000
|
let s:mltipats_lim = 2000
|
||||||
"}}}
|
"}}}
|
||||||
|
|
||||||
" Clear caches {{{
|
" * Clear caches {{{
|
||||||
func! ctrlp#clearcache()
|
func! ctrlp#clearcache()
|
||||||
let g:ctrlp_newcache = 1
|
let g:ctrlp_newcache = 1
|
||||||
endfunc
|
endfunc
|
||||||
@ -142,7 +160,7 @@ func! ctrlp#clearallcaches()
|
|||||||
endfunc
|
endfunc
|
||||||
"}}}
|
"}}}
|
||||||
|
|
||||||
" ListAllFiles {{{
|
" * ListAllFiles {{{
|
||||||
func! s:List(dirs, allfiles)
|
func! s:List(dirs, allfiles)
|
||||||
" note: wildignore is ignored when using **
|
" note: wildignore is ignored when using **
|
||||||
let glob = s:dotfiles ? '.*\|*' : '*'
|
let glob = s:dotfiles ? '.*\|*' : '*'
|
||||||
@ -164,11 +182,20 @@ func! s:ListAllFiles(path)
|
|||||||
let cache_file = ctrlp#utils#cachefile()
|
let cache_file = ctrlp#utils#cachefile()
|
||||||
if g:ctrlp_newcache || !filereadable(cache_file) || !s:caching
|
if g:ctrlp_newcache || !filereadable(cache_file) || !s:caching
|
||||||
" get the files
|
" get the files
|
||||||
|
if empty(g:ctrlp_user_command)
|
||||||
cal s:List(a:path, [])
|
cal s:List(a:path, [])
|
||||||
let allfiles = s:allfiles
|
let allfiles = s:allfiles
|
||||||
unl s:allfiles
|
unl s:allfiles
|
||||||
|
else
|
||||||
|
cal s:progress(escape('Indexing files...', ' '))
|
||||||
|
try
|
||||||
|
let allfiles = split(system(printf(g:ctrlp_user_command, shellescape(a:path))), '\n')
|
||||||
|
catch
|
||||||
|
retu []
|
||||||
|
endtry
|
||||||
|
endif
|
||||||
" remove base directory
|
" remove base directory
|
||||||
let path = &ssl || !exists('+ssl') ? getcwd().'/' : substitute(getcwd(), '\', '\\\\', 'g').'\\'
|
let path = &ssl || !exists('+ssl') ? getcwd().'/' : substitute(getcwd(), '\\', '\\\\', 'g').'\\'
|
||||||
cal map(allfiles, 'substitute(v:val, path, "", "g")')
|
cal map(allfiles, 'substitute(v:val, path, "", "g")')
|
||||||
let read_cache = 0
|
let read_cache = 0
|
||||||
else
|
else
|
||||||
@ -207,27 +234,22 @@ func! s:SplitPattern(str,...) "{{{
|
|||||||
endif
|
endif
|
||||||
" clear the jumptoline var
|
" clear the jumptoline var
|
||||||
if exists('s:jmpln') | unl s:jmpln | endif
|
if exists('s:jmpln') | unl s:jmpln | endif
|
||||||
if s:regexp || match(str, '[*^$+|]') >= 0
|
|
||||||
\ || match(str, '\\\(zs\|ze\|<\|>\)') >= 0
|
|
||||||
let str = substitute(str, '\\\\', '\', 'g')
|
|
||||||
" If pattern contains :\d (e.g. abc:25)
|
" If pattern contains :\d (e.g. abc:25)
|
||||||
if match(str, ':\d*$') >= 0
|
if match(str, ':\d*$') >= 0
|
||||||
" get the line to jump to
|
" get the line to jump to
|
||||||
let s:jmpln = matchstr(str, ':\zs\d*$')
|
let s:jmpln = matchstr(str, ':\zs\d*$')
|
||||||
" remove the line number
|
" remove the line number
|
||||||
let str = substitute(str, '\zs:\d*$', '', 'g')
|
let str = substitute(str, ':\d*$', '', 'g')
|
||||||
endif
|
endif
|
||||||
" don't split
|
if s:regexp || match(str, '[*^$+|]') >= 0
|
||||||
|
\ || match(str, '\\\(zs\|ze\|<\|>\)') >= 0
|
||||||
|
let str = substitute(str, '\\\\', '\', 'g')
|
||||||
let array = [str]
|
let array = [str]
|
||||||
elseif match(str, ':\d*$') >= 0 " If string contains :\d
|
|
||||||
" get the line to jump to
|
|
||||||
let s:jmpln = matchstr(str, ':\zs\d*$')
|
|
||||||
" remove the line number
|
|
||||||
let str = substitute(str, '\zs:\d*$', '', 'g')
|
|
||||||
" split into chars
|
|
||||||
let array = split(str, '\zs')
|
|
||||||
else
|
else
|
||||||
let array = split(str, '\zs')
|
let array = split(str, '\zs')
|
||||||
|
if exists('+ssl') && !&ssl
|
||||||
|
cal map(array, 'substitute(v:val, "\\", "\\\\\\\\", "g")')
|
||||||
|
endif
|
||||||
endif
|
endif
|
||||||
" Build the new pattern
|
" Build the new pattern
|
||||||
let nitem = !empty(array) ? array[0] : ''
|
let nitem = !empty(array) ? array[0] : ''
|
||||||
@ -235,7 +257,7 @@ func! s:SplitPattern(str,...) "{{{
|
|||||||
if len(array) > 1
|
if len(array) > 1
|
||||||
for i in range(1, len(array) - 1)
|
for i in range(1, len(array) - 1)
|
||||||
" Separator
|
" Separator
|
||||||
let sp = exists('a:1') ? a:1 : '.\{-}'
|
let sp = exists('a:1') ? a:1 : '[^'.array[i-1].']\{-}'
|
||||||
let nitem .= sp.array[i]
|
let nitem .= sp.array[i]
|
||||||
cal add(newpats, nitem)
|
cal add(newpats, nitem)
|
||||||
endfor
|
endfor
|
||||||
@ -251,7 +273,6 @@ func! s:GetMatchedItems(items, pats, limit) "{{{
|
|||||||
if len(items) >= s:mltipats_lim
|
if len(items) >= s:mltipats_lim
|
||||||
let pats = [pats[-1]]
|
let pats = [pats[-1]]
|
||||||
endif
|
endif
|
||||||
" pesky little tilde
|
|
||||||
cal map(pats, 'substitute(v:val, "\\\~", "\\\\\\~", "g")')
|
cal map(pats, 'substitute(v:val, "\\\~", "\\\\\\~", "g")')
|
||||||
" loop through the patterns
|
" loop through the patterns
|
||||||
for each in pats
|
for each in pats
|
||||||
@ -329,6 +350,10 @@ func! s:BufOpen(...) "{{{
|
|||||||
exe 'let &ea=' . s:CtrlP_ea
|
exe 'let &ea=' . s:CtrlP_ea
|
||||||
exe 'let &ut=' . s:CtrlP_ut
|
exe 'let &ut=' . s:CtrlP_ut
|
||||||
exe 'se gcr=' . s:CtrlP_gcr
|
exe 'se gcr=' . s:CtrlP_gcr
|
||||||
|
if exists('s:cwd')
|
||||||
|
exe 'chdir' s:cwd
|
||||||
|
unl s:cwd
|
||||||
|
endif
|
||||||
exe s:currwin.'winc w'
|
exe s:currwin.'winc w'
|
||||||
ec
|
ec
|
||||||
else
|
else
|
||||||
@ -368,7 +393,7 @@ func! s:BufOpen(...) "{{{
|
|||||||
endif
|
endif
|
||||||
endfunc "}}}
|
endfunc "}}}
|
||||||
|
|
||||||
func! s:Renderer(lines) "{{{
|
func! s:Renderer(lines, pat) "{{{
|
||||||
let nls = []
|
let nls = []
|
||||||
for i in range(0, len(a:lines) - 1)
|
for i in range(0, len(a:lines) - 1)
|
||||||
let nls = add(nls, '> '.a:lines[i])
|
let nls = add(nls, '> '.a:lines[i])
|
||||||
@ -378,11 +403,13 @@ func! s:Renderer(lines) "{{{
|
|||||||
let max = len(nls) < height ? len(nls) : height
|
let max = len(nls) < height ? len(nls) : height
|
||||||
exe 'res' max
|
exe 'res' max
|
||||||
" Output to buffer
|
" Output to buffer
|
||||||
if len(nls) >= 1
|
if !empty(nls)
|
||||||
setl cul
|
setl cul
|
||||||
" don't sort
|
" don't sort
|
||||||
if index([2], s:itemtype) < 0
|
if index([2], s:itemtype) < 0
|
||||||
cal sort(nls, 's:compare')
|
let s:compat = a:pat
|
||||||
|
cal sort(nls, 's:comatlen')
|
||||||
|
unl s:compat
|
||||||
endif
|
endif
|
||||||
if s:mwreverse
|
if s:mwreverse
|
||||||
cal reverse(nls)
|
cal reverse(nls)
|
||||||
@ -396,7 +423,6 @@ func! s:Renderer(lines) "{{{
|
|||||||
keepj norm! 1|
|
keepj norm! 1|
|
||||||
let b:matched = nls
|
let b:matched = nls
|
||||||
else
|
else
|
||||||
" If empty
|
|
||||||
setl nocul
|
setl nocul
|
||||||
cal setline('1', ' == NO MATCHES ==')
|
cal setline('1', ' == NO MATCHES ==')
|
||||||
endif
|
endif
|
||||||
@ -410,8 +436,14 @@ func! s:UpdateMatches(pat) "{{{
|
|||||||
" Delete the buffer's content
|
" Delete the buffer's content
|
||||||
sil! %d _
|
sil! %d _
|
||||||
let pats = s:SplitPattern(a:pat)
|
let pats = s:SplitPattern(a:pat)
|
||||||
|
let pat = pats[-1]
|
||||||
let lines = s:GetMatchedItems(s:lines, pats, s:mxheight)
|
let lines = s:GetMatchedItems(s:lines, pats, s:mxheight)
|
||||||
cal s:Renderer(lines)
|
cal s:Renderer(lines, pat)
|
||||||
|
" highlighting
|
||||||
|
if type(s:mathi) == 3 && len(s:mathi) == 2 && s:mathi[0] && exists('*clearmatches')
|
||||||
|
let grp = empty(s:mathi[1]) ? 'Function' : s:mathi[1]
|
||||||
|
cal s:highlight(pat, grp)
|
||||||
|
endif
|
||||||
endfunc "}}}
|
endfunc "}}}
|
||||||
|
|
||||||
func! s:BuildPrompt(...) "{{{
|
func! s:BuildPrompt(...) "{{{
|
||||||
@ -420,13 +452,13 @@ func! s:BuildPrompt(...) "{{{
|
|||||||
let base = base1.base2.'> '
|
let base = base1.base2.'> '
|
||||||
let cur = '_'
|
let cur = '_'
|
||||||
let estr = '"\'
|
let estr = '"\'
|
||||||
let start = escape(g:CtrlP_prompt[0], estr)
|
let prt = deepcopy(g:CtrlP_prompt)
|
||||||
let mid = escape(g:CtrlP_prompt[1], estr)
|
cal map(prt, 'escape(v:val, estr)')
|
||||||
let end = escape(g:CtrlP_prompt[2], estr)
|
let str = prt[0] . prt[1] . prt[2]
|
||||||
let str = l:start.l:mid.l:end
|
if s:nomatches
|
||||||
if strpart(str, 0, 2) != '..' && s:nomatches
|
|
||||||
cal s:UpdateMatches(str)
|
cal s:UpdateMatches(str)
|
||||||
endif
|
endif
|
||||||
|
cal s:statusline()
|
||||||
" Toggling
|
" Toggling
|
||||||
if !exists('a:1') || ( exists('a:1') && a:1 )
|
if !exists('a:1') || ( exists('a:1') && a:1 )
|
||||||
let hiactive = 'Normal'
|
let hiactive = 'Normal'
|
||||||
@ -438,18 +470,17 @@ func! s:BuildPrompt(...) "{{{
|
|||||||
" Build it
|
" Build it
|
||||||
redr
|
redr
|
||||||
exe 'echohl' hibase '| echon "'.base.'"
|
exe 'echohl' hibase '| echon "'.base.'"
|
||||||
\ | echohl' hiactive '| echon "'.start.'"
|
\ | echohl' hiactive '| echon "'.prt[0].'"
|
||||||
\ | echohl' hibase '| echon "'.mid.'"
|
\ | echohl' hibase '| echon "'.prt[1].'"
|
||||||
\ | echohl' hiactive '| echon "'.end.'"
|
\ | echohl' hiactive '| echon "'.prt[2].'"
|
||||||
\ | echohl None'
|
\ | echohl None'
|
||||||
" Append the cursor _ at the end
|
" Append the cursor _ at the end
|
||||||
if empty(mid) && ( !exists('a:1') || ( exists('a:1') && a:1 ) )
|
if empty(prt[1]) && ( !exists('a:1') || ( exists('a:1') && a:1 ) )
|
||||||
exe 'echohl' hibase '| echon "'.cur.'" | echohl None'
|
exe 'echohl' hibase '| echon "'.cur.'" | echohl None'
|
||||||
endif
|
endif
|
||||||
endfunc "}}}
|
endfunc "}}}
|
||||||
|
|
||||||
"Mightdo: PrtSelectJump() cycles through matches. /medium
|
" * Prt Actions {{{
|
||||||
" Prt Actions {{{
|
|
||||||
func! s:PrtClear()
|
func! s:PrtClear()
|
||||||
let s:nomatches = 1
|
let s:nomatches = 1
|
||||||
let g:CtrlP_prompt = ['','','']
|
let g:CtrlP_prompt = ['','','']
|
||||||
@ -538,8 +569,24 @@ func! s:PrtSelectJump(char,...)
|
|||||||
if exists('a:1')
|
if exists('a:1')
|
||||||
let lines = map(lines, 'split(v:val, ''[\/]\ze[^\/]\+$'')[-1]')
|
let lines = map(lines, 'split(v:val, ''[\/]\ze[^\/]\+$'')[-1]')
|
||||||
endif
|
endif
|
||||||
if match(lines, '\c^'.a:char) >= 0
|
" cycle through matches, use s:jmpchr to store last jump
|
||||||
exe match(lines, '\c^'.a:char) + 1
|
let chr = escape(a:char, '.~')
|
||||||
|
if match(lines, '\c^'.chr) >= 0
|
||||||
|
" if not exists or does but not for the same char
|
||||||
|
let pos = match(lines, '\c^'.chr)
|
||||||
|
if !exists('s:jmpchr') || ( exists('s:jmpchr') && s:jmpchr[0] != chr )
|
||||||
|
let jmpln = pos
|
||||||
|
let s:jmpchr = [chr, pos]
|
||||||
|
elseif exists('s:jmpchr') && s:jmpchr[0] == chr
|
||||||
|
" start of lines
|
||||||
|
if s:jmpchr[1] == -1
|
||||||
|
let s:jmpchr[1] = pos
|
||||||
|
endif
|
||||||
|
let npos = match(lines, '\c^'.chr, s:jmpchr[1] + 1)
|
||||||
|
let jmpln = npos == -1 ? pos : npos
|
||||||
|
let s:jmpchr = [chr, npos]
|
||||||
|
endif
|
||||||
|
keepj exe jmpln + 1
|
||||||
let g:CtrlP_cline = line('.')
|
let g:CtrlP_cline = line('.')
|
||||||
endif
|
endif
|
||||||
endfunc
|
endfunc
|
||||||
@ -547,12 +594,11 @@ endfunc
|
|||||||
func! s:PrtClearCache()
|
func! s:PrtClearCache()
|
||||||
cal ctrlp#clearcache()
|
cal ctrlp#clearcache()
|
||||||
cal s:SetLines(s:itemtype)
|
cal s:SetLines(s:itemtype)
|
||||||
cal s:statusline()
|
|
||||||
cal s:BuildPrompt()
|
cal s:BuildPrompt()
|
||||||
endfunc
|
endfunc
|
||||||
"}}}
|
"}}}
|
||||||
|
|
||||||
" MapKeys {{{
|
" * MapKeys {{{
|
||||||
func! s:MapKeys(...)
|
func! s:MapKeys(...)
|
||||||
" Normal keystrokes
|
" Normal keystrokes
|
||||||
let func = !exists('a:1') || ( exists('a:1') && a:1 ) ? 'PrtAdd' : 'PrtSelectJump'
|
let func = !exists('a:1') || ( exists('a:1') && a:1 ) ? 'PrtAdd' : 'PrtSelectJump'
|
||||||
@ -632,7 +678,7 @@ func! s:MapSpecs(...)
|
|||||||
endfunc
|
endfunc
|
||||||
"}}}
|
"}}}
|
||||||
|
|
||||||
" ToggleFocus {{{
|
" * Toggling functions {{{
|
||||||
func! s:Focus()
|
func! s:Focus()
|
||||||
retu !exists('b:focus') ? 1 : b:focus
|
retu !exists('b:focus') ? 1 : b:focus
|
||||||
endfunc
|
endfunc
|
||||||
@ -640,66 +686,62 @@ endfunc
|
|||||||
func! s:ToggleFocus()
|
func! s:ToggleFocus()
|
||||||
let b:focus = !exists('b:focus') || b:focus ? 0 : 1
|
let b:focus = !exists('b:focus') || b:focus ? 0 : 1
|
||||||
cal s:MapKeys(b:focus)
|
cal s:MapKeys(b:focus)
|
||||||
cal s:statusline(b:focus)
|
|
||||||
cal s:BuildPrompt(b:focus)
|
cal s:BuildPrompt(b:focus)
|
||||||
endfunc
|
endfunc
|
||||||
"}}}
|
|
||||||
|
|
||||||
func! s:ToggleRegex() "{{{
|
func! s:ToggleRegex()
|
||||||
let s:regexp = s:regexp ? 0 : 1
|
let s:regexp = s:regexp ? 0 : 1
|
||||||
cal s:statusline()
|
|
||||||
let s:nomatches = 1
|
let s:nomatches = 1
|
||||||
cal s:BuildPrompt(s:Focus())
|
cal s:BuildPrompt(s:Focus())
|
||||||
endfunc "}}}
|
endfunc
|
||||||
|
|
||||||
func! s:ToggleByFname() "{{{
|
func! s:ToggleByFname()
|
||||||
let s:byfname = s:byfname ? 0 : 1
|
let s:byfname = s:byfname ? 0 : 1
|
||||||
cal s:MapKeys(s:Focus(), 1)
|
cal s:MapKeys(s:Focus(), 1)
|
||||||
cal s:statusline()
|
|
||||||
let s:nomatches = 1
|
let s:nomatches = 1
|
||||||
cal s:BuildPrompt(s:Focus())
|
cal s:BuildPrompt(s:Focus())
|
||||||
endfunc "}}}
|
endfunc
|
||||||
|
|
||||||
func! s:ToggleType(dir) "{{{
|
func! s:ToggleType(dir)
|
||||||
let len = 1 + g:ctrlp_mru_files
|
let len = 1 + g:ctrlp_mru_files
|
||||||
let s:itemtype = s:walker(len, s:itemtype, a:dir)
|
let s:itemtype = s:walker(len, s:itemtype, a:dir)
|
||||||
cal s:Type(s:itemtype)
|
cal s:Type(s:itemtype)
|
||||||
endfunc "}}}
|
endfunc
|
||||||
|
|
||||||
func! s:Type(type) "{{{
|
func! s:Type(type)
|
||||||
let s:itemtype = a:type
|
let s:itemtype = a:type
|
||||||
cal s:syntax()
|
cal s:syntax()
|
||||||
cal s:SetLines(s:itemtype)
|
cal s:SetLines(s:itemtype)
|
||||||
cal s:statusline()
|
|
||||||
let s:nomatches = 1
|
let s:nomatches = 1
|
||||||
cal s:BuildPrompt(s:Focus())
|
cal s:BuildPrompt(s:Focus())
|
||||||
endfunc "}}}
|
endfunc
|
||||||
|
"}}}
|
||||||
|
|
||||||
" ctrlp#SetWorkingPath(...) {{{
|
" * SetWorkingPath {{{
|
||||||
func! s:FindRoot(curr, mark)
|
func! s:FindRoot(curr, mark)
|
||||||
if !empty(globpath(a:curr, a:mark))
|
if !empty(globpath(a:curr, a:mark))
|
||||||
exe 'chdir' a:curr
|
exe 'chdir' a:curr
|
||||||
else
|
else
|
||||||
let parent = substitute(a:curr, '[\/]\zs[^\/]\+[\/]\?$', '', '')
|
let parent = substitute(a:curr, '[\/]\zs[^\/]\+[\/]\?$', '', '')
|
||||||
if parent != a:curr
|
if parent != a:curr | cal s:FindRoot(parent, a:mark) | endif
|
||||||
cal s:FindRoot(parent, a:mark)
|
|
||||||
endif
|
|
||||||
endif
|
endif
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
func! ctrlp#SetWorkingPath(...)
|
func! ctrlp#SetWorkingPath(...)
|
||||||
let l:pathmode = 2
|
let l:pathmode = 2
|
||||||
if exists('a:1')
|
let s:cwd = getcwd()
|
||||||
|
if exists('a:1') && len(a:1) == 1 && !type('a:1')
|
||||||
let l:pathmode = a:1
|
let l:pathmode = a:1
|
||||||
|
elseif exists('a:1') && len(a:1) > 1 && type('a:1')
|
||||||
|
exe 'chdir' a:1
|
||||||
|
retu
|
||||||
endif
|
endif
|
||||||
if match(expand('%:p'), '^\<.\+\>://.*') >= 0
|
if match(expand('%:p'), '^\<.\+\>://.*') >= 0
|
||||||
\ || !s:pathmode || !l:pathmode
|
\ || !s:pathmode || !l:pathmode
|
||||||
retu
|
retu
|
||||||
endif
|
endif
|
||||||
if exists('+acd')
|
if exists('+acd') | se noacd | endif
|
||||||
se noacd
|
exe 'chdir' exists('*fnameescape') ? fnameescape(expand('%:p:h')) : expand('%:p:h')
|
||||||
endif
|
|
||||||
exe 'chdir' fnameescape(expand('%:p:h'))
|
|
||||||
if s:pathmode == 1 || l:pathmode == 1 | retu | endif
|
if s:pathmode == 1 || l:pathmode == 1 | retu | endif
|
||||||
let markers = [
|
let markers = [
|
||||||
\ 'root.dir',
|
\ 'root.dir',
|
||||||
@ -709,10 +751,8 @@ func! ctrlp#SetWorkingPath(...)
|
|||||||
\ '.hg/',
|
\ '.hg/',
|
||||||
\ '.bzr/',
|
\ '.bzr/',
|
||||||
\ ]
|
\ ]
|
||||||
if exists('g:ctrlp_root_markers')
|
if exists('s:rmarkers') && type(s:rmarkers) == 3 && !empty(s:rmarkers)
|
||||||
\ && type(g:ctrlp_root_markers) == 3
|
cal extend(markers, s:rmarkers, 0)
|
||||||
\ && !empty(g:ctrlp_root_markers)
|
|
||||||
cal extend(markers, g:ctrlp_root_markers, 0)
|
|
||||||
endif
|
endif
|
||||||
for marker in markers
|
for marker in markers
|
||||||
cal s:FindRoot(getcwd(), marker)
|
cal s:FindRoot(getcwd(), marker)
|
||||||
@ -724,7 +764,7 @@ endfunc
|
|||||||
func! s:AcceptSelection(mode,...) "{{{
|
func! s:AcceptSelection(mode,...) "{{{
|
||||||
let md = a:mode
|
let md = a:mode
|
||||||
" use .. to go back in the dir tree
|
" use .. to go back in the dir tree
|
||||||
if md == 'e'
|
if md == 'e' && !s:itemtype
|
||||||
let prt = g:CtrlP_prompt
|
let prt = g:CtrlP_prompt
|
||||||
let str = prt[0] . prt[1] . prt[2]
|
let str = prt[0] . prt[1] . prt[2]
|
||||||
if str == '..'
|
if str == '..'
|
||||||
@ -769,7 +809,7 @@ func! s:AcceptSelection(mode,...) "{{{
|
|||||||
ec
|
ec
|
||||||
endfunc "}}}
|
endfunc "}}}
|
||||||
|
|
||||||
" Helper functions {{{
|
" * Helper functions {{{
|
||||||
func! s:compare(s1, s2)
|
func! s:compare(s1, s2)
|
||||||
" by length
|
" by length
|
||||||
let str1 = strlen(a:s1)
|
let str1 = strlen(a:s1)
|
||||||
@ -777,6 +817,31 @@ func! s:compare(s1, s2)
|
|||||||
retu str1 == str2 ? 0 : str1 > str2 ? 1 : -1
|
retu str1 == str2 ? 0 : str1 > str2 ? 1 : -1
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func! s:comatlen(s1, s2)
|
||||||
|
" by match length
|
||||||
|
let str1 = min(s:smatstr(a:s1, s:compat))
|
||||||
|
let str2 = min(s:smatstr(a:s2, s:compat))
|
||||||
|
retu str1 == str2 ? 0 : str1 > str2 ? 1 : -1
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
" find shortest match in a string
|
||||||
|
" return a list with lengths of the matches
|
||||||
|
func! s:smatstr(str, pat, ...)
|
||||||
|
if empty(a:pat) || a:pat == '$' || a:pat == '^'
|
||||||
|
retu []
|
||||||
|
endif
|
||||||
|
let st = exists('a:1') ? a:1 : 0
|
||||||
|
let lens = exists('a:2') ? a:2 : []
|
||||||
|
if match(a:str, a:pat, st) != -1
|
||||||
|
let start = match(a:str, a:pat, st)
|
||||||
|
let len = len(matchstr(a:str, a:pat, st))
|
||||||
|
let end = matchend(a:str, a:pat, st)
|
||||||
|
let lens = add(lens, len)
|
||||||
|
let lens = s:smatstr(a:str, a:pat, end, lens)
|
||||||
|
endif
|
||||||
|
retu lens
|
||||||
|
endfunc
|
||||||
|
|
||||||
func! s:walker(max, pos, dir, ...)
|
func! s:walker(max, pos, dir, ...)
|
||||||
if a:dir == 1
|
if a:dir == 1
|
||||||
let pos = a:pos < a:max ? a:pos + 1 : 0
|
let pos = a:pos < a:max ? a:pos + 1 : 0
|
||||||
@ -844,9 +909,22 @@ func! s:syntax()
|
|||||||
hi link CtrlPNoEntries Error
|
hi link CtrlPNoEntries Error
|
||||||
hi CtrlPLineMarker guifg=bg
|
hi CtrlPLineMarker guifg=bg
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func! s:highlight(pat, grp)
|
||||||
|
cal clearmatches()
|
||||||
|
if !empty(a:pat) && a:pat != '..'
|
||||||
|
let pat = substitute(a:pat, '\~', '\\~', 'g')
|
||||||
|
if !s:regexp
|
||||||
|
let pat = escape(pat, '.')
|
||||||
|
endif
|
||||||
|
cal matchadd(a:grp, '\c'.pat)
|
||||||
|
cal matchadd('CtrlPLineMarker', '^>')
|
||||||
|
endif
|
||||||
|
endfunc
|
||||||
"}}}
|
"}}}
|
||||||
|
|
||||||
func! s:SetLines(type) "{{{
|
" * Initialization {{{
|
||||||
|
func! s:SetLines(type)
|
||||||
let s:itemtype = a:type
|
let s:itemtype = a:type
|
||||||
if !s:itemtype
|
if !s:itemtype
|
||||||
let s:lines = s:ListAllFiles(getcwd())
|
let s:lines = s:ListAllFiles(getcwd())
|
||||||
@ -855,16 +933,16 @@ func! s:SetLines(type) "{{{
|
|||||||
elseif s:itemtype >= 2
|
elseif s:itemtype >= 2
|
||||||
let s:lines = s:hooks(s:itemtype)
|
let s:lines = s:hooks(s:itemtype)
|
||||||
endif
|
endif
|
||||||
endfunc "}}}
|
endfunc
|
||||||
|
|
||||||
func! s:hooks(type) "{{{
|
func! s:hooks(type)
|
||||||
let types = {
|
let types = {
|
||||||
\ '2': 'ctrlp#mrufiles#list(-1)'
|
\ '2': 'ctrlp#mrufiles#list(-1)'
|
||||||
\ }
|
\ }
|
||||||
retu eval(types[a:type])
|
retu eval(types[a:type])
|
||||||
endfunc "}}}
|
endfunc
|
||||||
|
|
||||||
func! ctrlp#init(type, ...) "{{{
|
func! ctrlp#init(type, ...)
|
||||||
let s:nomatches = 1
|
let s:nomatches = 1
|
||||||
if exists('a:1')
|
if exists('a:1')
|
||||||
cal ctrlp#SetWorkingPath(a:1)
|
cal ctrlp#SetWorkingPath(a:1)
|
||||||
@ -876,19 +954,17 @@ func! ctrlp#init(type, ...) "{{{
|
|||||||
cal s:MapKeys()
|
cal s:MapKeys()
|
||||||
cal s:SetLines(a:type)
|
cal s:SetLines(a:type)
|
||||||
cal s:BuildPrompt()
|
cal s:BuildPrompt()
|
||||||
cal s:statusline()
|
|
||||||
cal s:syntax()
|
cal s:syntax()
|
||||||
endfunc "}}}
|
endfunc
|
||||||
|
"}}}
|
||||||
|
|
||||||
" Autocmds {{{
|
aug CtrlPAug "{{{
|
||||||
aug CtrlPAug
|
|
||||||
au!
|
au!
|
||||||
au BufLeave,WinLeave ControlP cal s:BufOpen('ControlP', 'del')
|
au BufLeave,WinLeave ControlP cal s:BufOpen('ControlP', 'del')
|
||||||
au VimLeavePre *
|
au VimLeavePre *
|
||||||
\ if s:cconex
|
\ if s:cconex
|
||||||
\ | cal ctrlp#clearallcaches() |
|
\ | cal ctrlp#clearallcaches() |
|
||||||
\ endif
|
\ endif
|
||||||
aug END
|
aug END "}}}
|
||||||
"}}}
|
|
||||||
|
|
||||||
" vim:fen:fdl=0:ts=2:sw=2:sts=2
|
" vim:fen:fdl=0:ts=2:sw=2:sts=2
|
||||||
|
@ -44,6 +44,16 @@ Use this option to disable the plugin completely: >
|
|||||||
let g:loaded_ctrlp = 1
|
let g:loaded_ctrlp = 1
|
||||||
<
|
<
|
||||||
|
|
||||||
|
*'g:ctrlp_by_filename'*
|
||||||
|
Set this to 1 to set search by filename (not full path) as the default: >
|
||||||
|
let g:ctrlp_by_filename = 0
|
||||||
|
<
|
||||||
|
|
||||||
|
*'g:ctrlp_regexp_search'*
|
||||||
|
Set this to 1 to set full |regexp| search as the default mode: >
|
||||||
|
let g:ctrlp_regexp_search = 0
|
||||||
|
<
|
||||||
|
|
||||||
*'g:ctrlp_match_window_reversed'*
|
*'g:ctrlp_match_window_reversed'*
|
||||||
Reverse the sort order of the matched files in the match window. The default
|
Reverse the sort order of the matched files in the match window. The default
|
||||||
setting is from bottom to top: >
|
setting is from bottom to top: >
|
||||||
@ -104,11 +114,6 @@ Set the maximum height of the match window: >
|
|||||||
let g:ctrlp_max_height = 10
|
let g:ctrlp_max_height = 10
|
||||||
<
|
<
|
||||||
|
|
||||||
*'g:ctrlp_regexp_search'*
|
|
||||||
Set this to 1 to set full |regexp| search as the default mode: >
|
|
||||||
let g:ctrlp_regexp_search = 0
|
|
||||||
<
|
|
||||||
|
|
||||||
*'g:ctrlp_use_caching'*
|
*'g:ctrlp_use_caching'*
|
||||||
Set this to 0 to disable per-session caching. When disabled, caching will still
|
Set this to 0 to disable per-session caching. When disabled, caching will still
|
||||||
be enabled for directories that have more than 4000 files: >
|
be enabled for directories that have more than 4000 files: >
|
||||||
@ -117,7 +122,7 @@ be enabled for directories that have more than 4000 files: >
|
|||||||
Note: you can quickly purge the cache by pressing <F5>.
|
Note: you can quickly purge the cache by pressing <F5>.
|
||||||
|
|
||||||
*'g:ctrlp_clear_cache_on_exit'*
|
*'g:ctrlp_clear_cache_on_exit'*
|
||||||
Set this to 0 to enable cross-sessions caching by not clearing caches upon
|
Set this to 0 to enable cross-sessions caching by not deleting the caches upon
|
||||||
exit: >
|
exit: >
|
||||||
let g:ctrlp_clear_cache_on_exit = 1
|
let g:ctrlp_clear_cache_on_exit = 1
|
||||||
<
|
<
|
||||||
@ -127,11 +132,6 @@ Set the parent directory for the '.ctrlp_cache' directory: >
|
|||||||
let g:ctrlp_cache_dir = $HOME
|
let g:ctrlp_cache_dir = $HOME
|
||||||
<
|
<
|
||||||
|
|
||||||
*'g:ctrlp_by_filename'*
|
|
||||||
Set this to 1 to set search by filename (not full path) as the default: >
|
|
||||||
let g:ctrlp_by_filename = 0
|
|
||||||
<
|
|
||||||
|
|
||||||
*'g:ctrlp_prompt_mappings'*
|
*'g:ctrlp_prompt_mappings'*
|
||||||
Use this to customize the mappings inside |CtrlP|’s prompt to your liking. You
|
Use this to customize the mappings inside |CtrlP|’s prompt to your liking. You
|
||||||
only need to keep the lines that you’ve changed the values (inside []): >
|
only need to keep the lines that you’ve changed the values (inside []): >
|
||||||
@ -189,16 +189,37 @@ Example: >
|
|||||||
<
|
<
|
||||||
|
|
||||||
*'g:ctrlp_dotfiles'*
|
*'g:ctrlp_dotfiles'*
|
||||||
Set this to 0 if you don’t want |CtrlP| to search for dotfiles: >
|
Set this to 0 if you don’t want |CtrlP| to search for dotfiles and dotdirs: >
|
||||||
let g:ctrlp_dotfiles = 1
|
let g:ctrlp_dotfiles = 1
|
||||||
<
|
<
|
||||||
|
|
||||||
|
*'g:ctrlp_highlight_match'*
|
||||||
|
Use this to enable/disable highlighting of the matched patterns and to specify
|
||||||
|
the highlight group that’ll be used: >
|
||||||
|
let g:ctrlp_highlight_match = [1, 'Function']
|
||||||
|
<
|
||||||
|
|
||||||
|
*'g:ctrlp_user_command'*
|
||||||
|
Specify an external tool to use for indexing files instead of Vim’s globpath().
|
||||||
|
Use %s in place of the target directory: >
|
||||||
|
let g:ctrlp_user_command = ''
|
||||||
|
<
|
||||||
|
Examples: >
|
||||||
|
" Linux/MacOSX:
|
||||||
|
let g:ctrlp_user_command = 'find %s -type f'
|
||||||
|
|
||||||
|
" Windows:
|
||||||
|
let g:ctrlp_user_command = 'dir %s /-n /b /s /a-d'
|
||||||
|
<
|
||||||
|
|
||||||
===============================================================================
|
===============================================================================
|
||||||
3. Commands *ctrlp-commands*
|
3. Commands *ctrlp-commands*
|
||||||
|
|
||||||
*:CtrlP*
|
*:CtrlP*
|
||||||
:CtrlP
|
:CtrlP [<start-directory>]
|
||||||
Open the |CtrlP| prompt in find files mode.
|
Open the |CtrlP| prompt in find files mode.
|
||||||
|
If no argument is given, the value of |g:ctrlp_working_path_mode| will be
|
||||||
|
used to determined the |current-directory|.
|
||||||
|
|
||||||
*:CtrlPBuffer*
|
*:CtrlPBuffer*
|
||||||
:CtrlPBuffer
|
:CtrlPBuffer
|
||||||
@ -216,19 +237,21 @@ Set this to 0 if you don’t want |CtrlP| to search for dotfiles: >
|
|||||||
:ClearAllCtrlPCaches
|
:ClearAllCtrlPCaches
|
||||||
Delete all the saved cache files in |ctrlp_cache_dir|.
|
Delete all the saved cache files in |ctrlp_cache_dir|.
|
||||||
|
|
||||||
|
The following commands ignore the value of |g:ctrlp_working_path_mode|:
|
||||||
|
|
||||||
*:CtrlPCurWD*
|
*:CtrlPCurWD*
|
||||||
:CtrlPCurWD
|
:CtrlPCurWD
|
||||||
Find files in the current working directory.
|
Find files in the |current-directory|.
|
||||||
Ignores |g:ctrlp_working_path_mode|.
|
|
||||||
|
|
||||||
*:CtrlPCurFile*
|
*:CtrlPCurFile*
|
||||||
:CtrlPCurFile
|
:CtrlPCurFile
|
||||||
Find files in the same directory as the current file, recursively.
|
Find files in the same directory as the current file, regardless of what the
|
||||||
|
|current-directory| is.
|
||||||
|
|
||||||
*:CtrlPRoot*
|
*:CtrlPRoot*
|
||||||
:CtrlPRoot
|
:CtrlPRoot
|
||||||
Same as |:CtrlPCurFile| but start from the project’s root.
|
Same as |:CtrlPCurFile| but start from the project’s root.
|
||||||
See also |g:ctrlp_working_path_mode|.
|
Check |g:ctrlp_working_path_mode| to see how |CtrlP| finds a root.
|
||||||
|
|
||||||
===============================================================================
|
===============================================================================
|
||||||
4. Mappings *ctrlp-mappings*
|
4. Mappings *ctrlp-mappings*
|
||||||
@ -244,7 +267,7 @@ Once inside the prompt:
|
|||||||
|regexp| mode.
|
|regexp| mode.
|
||||||
(note: in full |regexp| mode, the prompt’s base is 'r>>' instead of '>>>')
|
(note: in full |regexp| mode, the prompt’s base is 'r>>' instead of '>>>')
|
||||||
|
|
||||||
See also |input-formats|.
|
See also |input-formats| and |g:ctrlp_regexp_search|.
|
||||||
|
|
||||||
<c-d>
|
<c-d>
|
||||||
Toggle between full path search and filename only search.
|
Toggle between full path search and filename only search.
|
||||||
@ -289,7 +312,7 @@ Once inside the prompt:
|
|||||||
Move the cursor one character to the 'right'
|
Move the cursor one character to the 'right'
|
||||||
|
|
||||||
<c-w>
|
<c-w>
|
||||||
Delete a preceding (inner) word
|
Delete a preceding inner word
|
||||||
|
|
||||||
<c-u>
|
<c-u>
|
||||||
Clear the input field
|
Clear the input field
|
||||||
@ -317,6 +340,14 @@ Once inside the prompt:
|
|||||||
|
|
||||||
Chose your own mappings with |g:ctrlp_prompt_mappings|.
|
Chose your own mappings with |g:ctrlp_prompt_mappings|.
|
||||||
|
|
||||||
|
When inside the match window (press <tab> to switch to):
|
||||||
|
|
||||||
|
a-z
|
||||||
|
0-9
|
||||||
|
~^-=;`',.+!@#$%&_(){}[]
|
||||||
|
Cycle through the lines with the first letter (paths or filenames) that
|
||||||
|
match that character.
|
||||||
|
|
||||||
===============================================================================
|
===============================================================================
|
||||||
5. Input Formats *ctrlp-input-formats*
|
5. Input Formats *ctrlp-input-formats*
|
||||||
|
|
||||||
@ -329,7 +360,7 @@ b) Vim |regexp|. If the input string contains '*', '^', '$', '+' or '$', it’l
|
|||||||
be treated as a Vim’s |regexp| |pattern| without any modification.
|
be treated as a Vim’s |regexp| |pattern| without any modification.
|
||||||
e.g. 'abc\d*efg' will be read as 'abc\d*efg'.
|
e.g. 'abc\d*efg' will be read as 'abc\d*efg'.
|
||||||
|
|
||||||
See also |ctrlp-fullregexp|.
|
See also |ctrlp-fullregexp| and |g:ctrlp_regexp_search|.
|
||||||
|
|
||||||
c) Strings end with a colon ':' followed by an arbitrary number will be read
|
c) Strings end with a colon ':' followed by an arbitrary number will be read
|
||||||
as a line number to jump to after opening the file.
|
as a line number to jump to after opening the file.
|
||||||
@ -360,9 +391,12 @@ CHANGELOG
|
|||||||
|
|
||||||
*ctrlp-update-2*
|
*ctrlp-update-2*
|
||||||
Update #2~
|
Update #2~
|
||||||
|
+ Ability to cycle through matched lines in the match window.
|
||||||
+ Extended the behavior of |g:ctrlp_persistent_input|
|
+ Extended the behavior of |g:ctrlp_persistent_input|
|
||||||
+ New option: |g:ctrlp_dotfiles|,
|
+ New option: |g:ctrlp_dotfiles|,
|
||||||
|g:ctrlp_clear_cache_on_exit|
|
|g:ctrlp_clear_cache_on_exit|,
|
||||||
|
|g:ctrlp_highlight_match|,
|
||||||
|
|g:ctrlp_user_command|
|
||||||
+ New input format: '..' (section 5.d)
|
+ New input format: '..' (section 5.d)
|
||||||
+ New mapping: <F5>.
|
+ New mapping: <F5>.
|
||||||
+ New commands: |:CtrlPCurWD|,
|
+ New commands: |:CtrlPCurWD|,
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
" =============================================================================
|
" =============================================================================
|
||||||
" File: plugin/ctrlp.vim
|
" File: plugin/ctrlp.vim
|
||||||
" Description: Full path fuzzy file and buffer finder for Vim.
|
" Description: Full path fuzzy file, buffer and MRU file finder for Vim.
|
||||||
" Author: Kien Nguyen <github.com/kien>
|
" Author: Kien Nguyen <github.com/kien>
|
||||||
" License: MIT
|
" License: MIT
|
||||||
" =============================================================================
|
" =============================================================================
|
||||||
@ -13,7 +13,7 @@ let g:loaded_ctrlp = 1
|
|||||||
if !exists('g:ctrlp_map') | let g:ctrlp_map = '<c-p>' | endif
|
if !exists('g:ctrlp_map') | let g:ctrlp_map = '<c-p>' | endif
|
||||||
if !exists('g:ctrlp_mru_files') | let g:ctrlp_mru_files = 1 | endif
|
if !exists('g:ctrlp_mru_files') | let g:ctrlp_mru_files = 1 | endif
|
||||||
|
|
||||||
com! CtrlP cal ctrlp#init(0)
|
com! -nargs=? CtrlP cal ctrlp#init(0, <q-args>)
|
||||||
com! CtrlPBuffer cal ctrlp#init(1)
|
com! CtrlPBuffer cal ctrlp#init(1)
|
||||||
com! CtrlPMRUFiles cal ctrlp#init(2)
|
com! CtrlPMRUFiles cal ctrlp#init(2)
|
||||||
com! ClearCtrlPCache cal ctrlp#clearcache()
|
com! ClearCtrlPCache cal ctrlp#clearcache()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user