Tag and Quickfix extensions
* New extensions for searching tag and quickfix. * Option to update the results lazily. Close #37.
This commit is contained in:
parent
dee2f5a998
commit
ef9e072c5f
@ -2,11 +2,12 @@
|
|||||||
" File: autoload/ctrlp.vim
|
" File: autoload/ctrlp.vim
|
||||||
" Description: Fuzzy file, buffer and MRU file finder.
|
" Description: Fuzzy file, buffer and MRU file finder.
|
||||||
" Author: Kien Nguyen <github.com/kien>
|
" Author: Kien Nguyen <github.com/kien>
|
||||||
" Version: 1.6.1
|
" Version: 1.6.2
|
||||||
" =============================================================================
|
" =============================================================================
|
||||||
|
|
||||||
" Static variables {{{
|
" Static variables {{{
|
||||||
fu! s:opts()
|
fu! s:opts()
|
||||||
|
let hst = exists('+hi') ? &hi : 20
|
||||||
let opts = {
|
let opts = {
|
||||||
\ 'g:ctrlp_by_filename': ['s:byfname', 0],
|
\ 'g:ctrlp_by_filename': ['s:byfname', 0],
|
||||||
\ 'g:ctrlp_clear_cache_on_exit': ['s:clrex', 1],
|
\ 'g:ctrlp_clear_cache_on_exit': ['s:clrex', 1],
|
||||||
@ -15,12 +16,14 @@ fu! s:opts()
|
|||||||
\ 'g:ctrlp_extensions': ['s:extensions', []],
|
\ 'g:ctrlp_extensions': ['s:extensions', []],
|
||||||
\ 'g:ctrlp_follow_symlinks': ['s:folsym', 0],
|
\ 'g:ctrlp_follow_symlinks': ['s:folsym', 0],
|
||||||
\ 'g:ctrlp_highlight_match': ['s:mathi', [1, 'Identifier']],
|
\ 'g:ctrlp_highlight_match': ['s:mathi', [1, 'Identifier']],
|
||||||
|
\ 'g:ctrlp_lazy_update': ['s:lazy', 0],
|
||||||
\ 'g:ctrlp_jump_to_buffer': ['s:jmptobuf', 1],
|
\ 'g:ctrlp_jump_to_buffer': ['s:jmptobuf', 1],
|
||||||
\ 'g:ctrlp_match_window_bottom': ['s:mwbottom', 1],
|
\ 'g:ctrlp_match_window_bottom': ['s:mwbottom', 1],
|
||||||
\ 'g:ctrlp_match_window_reversed': ['s:mwreverse', 1],
|
\ 'g:ctrlp_match_window_reversed': ['s:mwreverse', 1],
|
||||||
\ 'g:ctrlp_max_depth': ['s:maxdepth', 40],
|
\ 'g:ctrlp_max_depth': ['s:maxdepth', 40],
|
||||||
\ 'g:ctrlp_max_files': ['s:maxfiles', 20000],
|
\ 'g:ctrlp_max_files': ['s:maxfiles', 20000],
|
||||||
\ 'g:ctrlp_max_height': ['s:mxheight', 10],
|
\ 'g:ctrlp_max_height': ['s:mxheight', 10],
|
||||||
|
\ 'g:ctrlp_max_history': ['s:maxhst', hst],
|
||||||
\ 'g:ctrlp_open_multi': ['s:opmul', '1v'],
|
\ 'g:ctrlp_open_multi': ['s:opmul', '1v'],
|
||||||
\ 'g:ctrlp_open_new_file': ['s:newfop', 3],
|
\ 'g:ctrlp_open_new_file': ['s:newfop', 3],
|
||||||
\ 'g:ctrlp_prompt_mappings': ['s:urprtmaps', 0],
|
\ 'g:ctrlp_prompt_mappings': ['s:urprtmaps', 0],
|
||||||
@ -28,16 +31,13 @@ fu! s:opts()
|
|||||||
\ 'g:ctrlp_root_markers': ['s:rmarkers', []],
|
\ 'g:ctrlp_root_markers': ['s:rmarkers', []],
|
||||||
\ 'g:ctrlp_split_window': ['s:splitwin', 0],
|
\ 'g:ctrlp_split_window': ['s:splitwin', 0],
|
||||||
\ 'g:ctrlp_use_caching': ['s:caching', 1],
|
\ 'g:ctrlp_use_caching': ['s:caching', 1],
|
||||||
|
\ 'g:ctrlp_user_command': ['s:usrcmd', ''],
|
||||||
\ 'g:ctrlp_working_path_mode': ['s:pathmode', 2],
|
\ 'g:ctrlp_working_path_mode': ['s:pathmode', 2],
|
||||||
\ }
|
\ }
|
||||||
for [ke, va] in items(opts)
|
for [ke, va] in items(opts)
|
||||||
exe 'let' va[0] '=' string(exists(ke) ? eval(ke) : va[1]) '| unl!' ke
|
exe 'let' va[0] '=' string(exists(ke) ? eval(ke) : va[1])
|
||||||
endfo
|
endfo
|
||||||
if !exists('g:ctrlp_newcache') | let g:ctrlp_newcache = 0 | en
|
if !exists('g:ctrlp_newcache') | let g:ctrlp_newcache = 0 | en
|
||||||
if !exists('g:ctrlp_user_command') | let g:ctrlp_user_command = '' | en
|
|
||||||
let s:maxhst = exists('g:ctrlp_max_history') ? g:ctrlp_max_history
|
|
||||||
\ : exists('+hi') ? &hi : 20
|
|
||||||
unl! g:ctrlp_max_history
|
|
||||||
" Note: wildignore is ignored when using **
|
" Note: wildignore is ignored when using **
|
||||||
let s:glob = s:dotfiles ? '.*\|*' : '*'
|
let s:glob = s:dotfiles ? '.*\|*' : '*'
|
||||||
let s:maxdepth = min([s:maxdepth, 100])
|
let s:maxdepth = min([s:maxdepth, 100])
|
||||||
@ -53,7 +53,7 @@ let s:lash = ctrlp#utils#lash()
|
|||||||
" Global options
|
" Global options
|
||||||
let s:glbs = { 'magic': 1, 'to': 1, 'tm': 0, 'sb': 1, 'hls': 0, 'im': 0,
|
let s:glbs = { 'magic': 1, 'to': 1, 'tm': 0, 'sb': 1, 'hls': 0, 'im': 0,
|
||||||
\ 'report': 9999, 'sc': 0, 'ss': 0, 'siso': 0, 'mfd': 200, 'mouse': 'n',
|
\ 'report': 9999, 'sc': 0, 'ss': 0, 'siso': 0, 'mfd': 200, 'mouse': 'n',
|
||||||
\ 'gcr': 'a:block-PmenuSel-blinkon0' }
|
\ 'gcr': 'a:block-PmenuSel-blinkon0', 'ut': ( s:lazy > 1 ? s:lazy : 250 ) }
|
||||||
|
|
||||||
" Limiters
|
" Limiters
|
||||||
let [s:compare_lim, s:nocache_lim, s:mltipats_lim] = [3000, 4000, 2000]
|
let [s:compare_lim, s:nocache_lim, s:mltipats_lim] = [3000, 4000, 2000]
|
||||||
@ -62,6 +62,7 @@ let [s:compare_lim, s:nocache_lim, s:mltipats_lim] = [3000, 4000, 2000]
|
|||||||
fu! s:Open()
|
fu! s:Open()
|
||||||
let [s:cwd, s:winres] = [getcwd(), winrestcmd()]
|
let [s:cwd, s:winres] = [getcwd(), winrestcmd()]
|
||||||
let [s:crfile, s:crfpath] = [expand('%:p', 1), expand('%:p:h', 1)]
|
let [s:crfile, s:crfpath] = [expand('%:p', 1), expand('%:p:h', 1)]
|
||||||
|
let [s:crword, s:crvisual] = [expand('<cword>'), s:lastvisual()]
|
||||||
sil! exe s:mwbottom ? 'bo' : 'to' '1new ControlP'
|
sil! exe s:mwbottom ? 'bo' : 'to' '1new ControlP'
|
||||||
let s:currwin = s:mwbottom ? winnr('#') : winnr('#') + 1
|
let s:currwin = s:mwbottom ? winnr('#') : winnr('#') + 1
|
||||||
let [s:bufnr, s:prompt] = [bufnr('%'), ['', '', '']]
|
let [s:bufnr, s:prompt] = [bufnr('%'), ['', '', '']]
|
||||||
@ -89,14 +90,14 @@ fu! s:Close()
|
|||||||
let [g:ctrlp_lines, g:ctrlp_allfiles] = [[], []]
|
let [g:ctrlp_lines, g:ctrlp_allfiles] = [[], []]
|
||||||
exe s:winres
|
exe s:winres
|
||||||
unl! s:focus s:hisidx s:hstgot s:marked s:statypes s:cline s:init s:savestr
|
unl! s:focus s:hisidx s:hstgot s:marked s:statypes s:cline s:init s:savestr
|
||||||
\ s:crfile s:crfpath
|
\ s:crfile s:crfpath s:crword s:crvisual g:ctrlp_nolimit
|
||||||
cal s:recordhist(join(s:prompt, ''))
|
cal s:recordhist(join(s:prompt, ''))
|
||||||
ec
|
ec
|
||||||
endf
|
endf
|
||||||
"}}}
|
"}}}
|
||||||
" * Clear caches {{{
|
" * Clear caches {{{
|
||||||
fu! ctrlp#clr()
|
fu! ctrlp#clr(...)
|
||||||
let g:ctrlp_newcache = 1
|
exe 'let g:ctrlp_new'.( exists('a:1') ? a:1 : 'cache' ).' = 1'
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! ctrlp#clra(...)
|
fu! ctrlp#clra(...)
|
||||||
@ -117,7 +118,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()
|
||||||
let s:prompt = ['', '', '']
|
|
||||||
unl! s:cline
|
unl! s:cline
|
||||||
endf
|
endf
|
||||||
"}}}
|
"}}}
|
||||||
@ -196,7 +196,8 @@ endf "}}}
|
|||||||
" * MatchedItems() {{{
|
" * MatchedItems() {{{
|
||||||
fu! s:MatchIt(items, pat, limit)
|
fu! s:MatchIt(items, pat, limit)
|
||||||
let [items, pat, limit, newitems] = [a:items, a:pat, a:limit, []]
|
let [items, pat, limit, newitems] = [a:items, a:pat, a:limit, []]
|
||||||
let mfunc = s:byfname ? 's:matchsubstr' : 'match'
|
let mfunc = s:byfname ? 's:matchfname'
|
||||||
|
\ : s:itemtype > 2 ? 's:matchtab' : 'match'
|
||||||
for item in items
|
for item in items
|
||||||
if call(mfunc, [item, pat]) >= 0 | cal add(newitems, item) | en
|
if call(mfunc, [item, pat]) >= 0 | cal add(newitems, item) | en
|
||||||
if limit > 0 && len(newitems) >= limit | brea | en
|
if limit > 0 && len(newitems) >= limit | brea | en
|
||||||
@ -209,13 +210,13 @@ fu! s:MatchedItems(items, pats, limit)
|
|||||||
" If items is longer than s:mltipats_lim, use only the last pattern
|
" If items is longer than s:mltipats_lim, use only the last pattern
|
||||||
if len(items) >= s:mltipats_lim | let pats = [pats[-1]] | en
|
if len(items) >= s:mltipats_lim | let pats = [pats[-1]] | en
|
||||||
cal map(pats, 'substitute(v:val, "\\\~", "\\\\\\~", "g")')
|
cal map(pats, 'substitute(v:val, "\\\~", "\\\\\\~", "g")')
|
||||||
|
if !s:regexp | cal map(pats, 'escape(v:val, ".")') | en
|
||||||
" Loop through the patterns
|
" Loop through the patterns
|
||||||
for each in pats
|
for each in pats
|
||||||
" If newitems is small, set it as items to search in
|
" If newitems is small, set it as items to search in
|
||||||
if exists('newitems') && len(newitems) < limit
|
if exists('newitems') && len(newitems) < limit
|
||||||
let items = copy(newitems)
|
let items = copy(newitems)
|
||||||
en
|
en
|
||||||
if !s:regexp | let each = escape(each, '.') | en
|
|
||||||
if empty(items) " End here
|
if empty(items) " End here
|
||||||
retu exists('newitems') ? newitems : []
|
retu exists('newitems') ? newitems : []
|
||||||
el " Start here, go back up if have 2 or more in pats
|
el " Start here, go back up if have 2 or more in pats
|
||||||
@ -246,10 +247,10 @@ fu! s:SplitPattern(str, ...) "{{{
|
|||||||
let nitem = !empty(array) ? array[0] : ''
|
let nitem = !empty(array) ? array[0] : ''
|
||||||
let newpats = [nitem]
|
let newpats = [nitem]
|
||||||
if len(array) > 1
|
if len(array) > 1
|
||||||
for i in range(1, len(array) - 1)
|
for item in range(1, len(array) - 1)
|
||||||
" Separator
|
" Separator
|
||||||
let sep = exists('a:1') ? a:1 : '[^'.array[i-1].']\{-}'
|
let sep = exists('a:1') ? a:1 : '[^'.array[item-1].']\{-}'
|
||||||
let nitem .= sep.array[i]
|
let nitem .= sep.array[item]
|
||||||
cal add(newpats, nitem)
|
cal add(newpats, nitem)
|
||||||
endfo
|
endfo
|
||||||
en
|
en
|
||||||
@ -266,11 +267,13 @@ fu! s:Render(lines, pat)
|
|||||||
setl nocul
|
setl nocul
|
||||||
cal setline(1, ' == NO MATCHES ==')
|
cal setline(1, ' == NO MATCHES ==')
|
||||||
cal s:unmarksigns()
|
cal s:unmarksigns()
|
||||||
|
if s:dohighlight() | cal clearmatches() | en
|
||||||
retu
|
retu
|
||||||
en
|
en
|
||||||
setl cul
|
setl cul
|
||||||
" Sort if not MRU
|
" Sort if not MRU
|
||||||
if s:itemtype != 2 || !empty(join(s:prompt, ''))
|
if ( s:itemtype != 2 && !exists('g:ctrlp_nolimit') )
|
||||||
|
\ || !empty(join(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
|
||||||
@ -285,34 +288,40 @@ fu! s:Render(lines, pat)
|
|||||||
cal s:remarksigns()
|
cal s:remarksigns()
|
||||||
if exists('s:cline') | cal cursor(s:cline, 1) | en
|
if exists('s:cline') | cal cursor(s:cline, 1) | en
|
||||||
" Highlighting
|
" Highlighting
|
||||||
if type(s:mathi) == 3 && len(s:mathi) == 2 && s:mathi[0]
|
if s:dohighlight()
|
||||||
\ && exists('*clearmatches')
|
|
||||||
cal s:highlight(a:pat, empty(s:mathi[1]) ? 'Identifier' : s:mathi[1])
|
cal s:highlight(a:pat, empty(s:mathi[1]) ? 'Identifier' : s:mathi[1])
|
||||||
en
|
en
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:Update(pat, ...)
|
fu! s:Update(str)
|
||||||
let pat = a:pat
|
|
||||||
" Get the previous string if existed
|
" Get the previous string if existed
|
||||||
let oldstr = exists('s:savestr') ? s:savestr : ''
|
let oldstr = exists('s:savestr') ? s:savestr : ''
|
||||||
let pats = s:SplitPattern(pat)
|
let pats = s:SplitPattern(a:str)
|
||||||
" Get the new string sans tail
|
" Get the new string sans tail
|
||||||
let notail = substitute(pat, ':\([^:]\|\\:\)*$', '', 'g')
|
let notail = substitute(a:str, ':\([^:]\|\\:\)*$', '', 'g')
|
||||||
" Stop if the string's unchanged
|
" Stop if the string's unchanged
|
||||||
if notail == oldstr && !empty(notail) && !exists('a:1') && !exists('s:force')
|
if notail == oldstr && !empty(notail) && !exists('s:force')
|
||||||
retu
|
retu
|
||||||
en
|
en
|
||||||
let lines = s:MatchedItems(g:ctrlp_lines, pats, s:mxheight)
|
let lines = exists('g:ctrlp_nolimit') && empty(notail) ? copy(g:ctrlp_lines)
|
||||||
|
\ : s:MatchedItems(g:ctrlp_lines, pats, s:mxheight)
|
||||||
cal s:Render(lines, pats[-1])
|
cal s:Render(lines, pats[-1])
|
||||||
endf
|
endf
|
||||||
|
|
||||||
|
fu! s:ForceUpdate()
|
||||||
|
let [estr, prt] = ['"\', copy(s:prompt)]
|
||||||
|
cal map(prt, 'escape(v:val, estr)')
|
||||||
|
cal s:Update(join(prt, ''))
|
||||||
|
endf
|
||||||
|
|
||||||
fu! s:BuildPrompt(upd, ...)
|
fu! s:BuildPrompt(upd, ...)
|
||||||
let base = ( s:regexp ? 'r' : '>' ).( s:byfname ? 'd' : '>' ).'> '
|
let base = ( s:regexp ? 'r' : '>' ).( s:byfname ? 'd' : '>' ).'> '
|
||||||
let [estr, prt] = ['"\', copy(s:prompt)]
|
let [estr, prt] = ['"\', copy(s:prompt)]
|
||||||
cal map(prt, 'escape(v:val, estr)')
|
cal map(prt, 'escape(v:val, estr)')
|
||||||
let str = join(prt, '')
|
let str = join(prt, '')
|
||||||
if a:upd && ( s:matches || s:regexp || match(str, '[*|]') >= 0 )
|
let lazy = empty(str) || exists('s:force') || !has('autocmd') ? 0 : s:lazy
|
||||||
sil! cal call('s:Update', exists('a:2') ? [str, a:2] : [str])
|
if a:upd && ( s:matches || s:regexp || match(str, '[*|]') >= 0 ) && !lazy
|
||||||
|
sil! cal s:Update(str)
|
||||||
en
|
en
|
||||||
sil! cal s:statusline()
|
sil! cal s:statusline()
|
||||||
" Toggling
|
" Toggling
|
||||||
@ -364,18 +373,23 @@ endf
|
|||||||
fu! s:PrtDeleteWord()
|
fu! s:PrtDeleteWord()
|
||||||
unl! s:hstgot
|
unl! s:hstgot
|
||||||
let [str, s:matches] = [s:prompt[0], 1]
|
let [str, s:matches] = [s:prompt[0], 1]
|
||||||
if match(str, '\W\w\+$') >= 0
|
let str = match(str, '\W\w\+$') >= 0 ? matchstr(str, '^.\+\W\ze\w\+$')
|
||||||
let str = matchstr(str, '^.\+\W\ze\w\+$')
|
\ : match(str, '\w\W\+$') >= 0 ? matchstr(str, '^.\+\w\ze\W\+$')
|
||||||
elsei match(str, '\w\W\+$') >= 0
|
\ : match(str, '\s\+$') >= 0 ? matchstr(str, '^.*[^ \t]\+\ze\s\+$')
|
||||||
let str = matchstr(str, '^.\+\w\ze\W\+$')
|
\ : match(str, ' ') <= 0 ? '' : str
|
||||||
elsei match(str, '\s\+$') >= 0
|
|
||||||
let str = matchstr(str, '^.*[^ \t]\+\ze\s\+$')
|
|
||||||
elsei match(str, ' ') <= 0
|
|
||||||
let str = ''
|
|
||||||
en
|
|
||||||
let s:prompt[0] = str
|
let s:prompt[0] = str
|
||||||
cal s:BuildPrompt(1)
|
cal s:BuildPrompt(1)
|
||||||
endf
|
endf
|
||||||
|
|
||||||
|
fu! s:PrtInsert(type)
|
||||||
|
unl! s:hstgot
|
||||||
|
" Insert current word, search register, last visual and clipboard
|
||||||
|
let s:prompt[0] .= a:type == 'w' ? s:crword
|
||||||
|
\ : a:type == 's' ? getreg('/')
|
||||||
|
\ : a:type == 'v' ? s:crvisual
|
||||||
|
\ : a:type == '+' ? substitute(getreg('+'), '\n', '\\n', 'g') : s:prompt[0]
|
||||||
|
cal s:BuildPrompt(1)
|
||||||
|
endf
|
||||||
"}}}
|
"}}}
|
||||||
" Movement {{{
|
" Movement {{{
|
||||||
fu! s:PrtCurLeft()
|
fu! s:PrtCurLeft()
|
||||||
@ -405,14 +419,14 @@ endf
|
|||||||
|
|
||||||
fu! s:PrtCurEnd()
|
fu! s:PrtCurEnd()
|
||||||
let prt = s:prompt
|
let prt = s:prompt
|
||||||
let str = join(prt, '')
|
let [prt[0], prt[1], prt[2]] = [join(prt, ''), '', '']
|
||||||
let [prt[0], prt[1], prt[2]] = [str, '', '']
|
|
||||||
cal s:BuildPrompt(0)
|
cal s:BuildPrompt(0)
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:PrtSelectMove(dir)
|
fu! s:PrtSelectMove(dir)
|
||||||
exe 'norm!' a:dir
|
exe 'norm!' a:dir
|
||||||
let s:cline = line('.')
|
let s:cline = line('.')
|
||||||
|
if line('$') > winheight(0) | cal s:BuildPrompt(0, s:Focus()) | en
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:PrtSelectJump(char, ...)
|
fu! s:PrtSelectJump(char, ...)
|
||||||
@ -435,20 +449,25 @@ fu! s:PrtSelectJump(char, ...)
|
|||||||
en
|
en
|
||||||
keepj exe jmpln + 1
|
keepj exe jmpln + 1
|
||||||
let s:cline = line('.')
|
let s:cline = line('.')
|
||||||
|
if line('$') > winheight(0) | cal s:BuildPrompt(0, s:Focus()) | en
|
||||||
en
|
en
|
||||||
endf
|
endf
|
||||||
"}}}
|
"}}}
|
||||||
" Hooks {{{
|
" Misc {{{
|
||||||
fu! s:PrtClearCache()
|
fu! s:PrtClearCache()
|
||||||
let s:force = 1
|
if s:itemtype == 1 | retu | en
|
||||||
if !s:itemtype
|
if s:itemtype == 0
|
||||||
cal ctrlp#clr()
|
cal ctrlp#clr()
|
||||||
cal s:SetLines(s:itemtype)
|
elsei s:itemtype > 2
|
||||||
cal s:BuildPrompt(1)
|
cal ctrlp#clr(s:statypes[s:itemtype][1])
|
||||||
elsei s:itemtype == 2
|
|
||||||
let g:ctrlp_lines = ctrlp#mrufiles#list(-1, 1)
|
|
||||||
cal s:BuildPrompt(1)
|
|
||||||
en
|
en
|
||||||
|
if s:itemtype == 2
|
||||||
|
let g:ctrlp_lines = ctrlp#mrufiles#list(-1, 1)
|
||||||
|
el
|
||||||
|
cal s:SetLines(s:itemtype)
|
||||||
|
en
|
||||||
|
let s:force = 1
|
||||||
|
cal s:BuildPrompt(1)
|
||||||
unl s:force
|
unl s:force
|
||||||
endf
|
endf
|
||||||
|
|
||||||
@ -475,8 +494,9 @@ fu! s:PrtHistory(...)
|
|||||||
" Limit idx within 0 and hslen
|
" Limit idx within 0 and hslen
|
||||||
let idx = idx < 0 ? 0 : idx >= hslen ? hslen > 1 ? hslen - 1 : 0 : idx
|
let idx = idx < 0 ? 0 : idx >= hslen ? hslen > 1 ? hslen - 1 : 0 : idx
|
||||||
let s:prompt = [hst[idx], '', '']
|
let s:prompt = [hst[idx], '', '']
|
||||||
let [s:hisidx, s:hstgot] = [idx, 1]
|
let [s:hisidx, s:hstgot, s:force] = [idx, 1, 1]
|
||||||
cal s:BuildPrompt(1)
|
cal s:BuildPrompt(1)
|
||||||
|
unl s:force
|
||||||
endf
|
endf
|
||||||
"}}}
|
"}}}
|
||||||
"}}}
|
"}}}
|
||||||
@ -513,12 +533,16 @@ fu! s:MapSpecs(...)
|
|||||||
\ 'ToggleByFname()': ['<c-d>'],
|
\ 'ToggleByFname()': ['<c-d>'],
|
||||||
\ 'ToggleType(1)': ['<c-f>', '<c-up'],
|
\ 'ToggleType(1)': ['<c-f>', '<c-up'],
|
||||||
\ 'ToggleType(-1)': ['<c-b>', '<c-down>'],
|
\ 'ToggleType(-1)': ['<c-b>', '<c-down>'],
|
||||||
|
\ 'PrtInsert("w")': ['<F2>'],
|
||||||
|
\ 'PrtInsert("s")': ['<F3>'],
|
||||||
|
\ 'PrtInsert("v")': ['<F4>'],
|
||||||
|
\ 'PrtInsert("+")': ['<F6>'],
|
||||||
\ 'PrtCurStart()': ['<c-a>'],
|
\ 'PrtCurStart()': ['<c-a>'],
|
||||||
\ 'PrtCurEnd()': ['<c-e>'],
|
\ 'PrtCurEnd()': ['<c-e>'],
|
||||||
\ 'PrtCurLeft()': ['<c-h>', '<left>'],
|
\ 'PrtCurLeft()': ['<c-h>', '<left>'],
|
||||||
\ 'PrtCurRight()': ['<c-l>', '<right>'],
|
\ 'PrtCurRight()': ['<c-l>', '<right>'],
|
||||||
\ 'PrtClearCache()': ['<F5>'],
|
\ 'PrtClearCache()': ['<F5>'],
|
||||||
\ 'PrtDeleteMRU()': ['<F8>'],
|
\ 'PrtDeleteMRU()': ['<F7>'],
|
||||||
\ 'CreateNewFile()': ['<c-y>'],
|
\ 'CreateNewFile()': ['<c-y>'],
|
||||||
\ 'MarkToOpen()': ['<c-z>'],
|
\ 'MarkToOpen()': ['<c-z>'],
|
||||||
\ 'OpenMulti()': ['<c-o>'],
|
\ 'OpenMulti()': ['<c-o>'],
|
||||||
@ -546,6 +570,10 @@ fu! s:MapSpecs(...)
|
|||||||
\ 'PrtCurRight()',
|
\ 'PrtCurRight()',
|
||||||
\ 'PrtHistory(-1)',
|
\ 'PrtHistory(-1)',
|
||||||
\ 'PrtHistory(1)',
|
\ 'PrtHistory(1)',
|
||||||
|
\ 'PrtInsert("w")',
|
||||||
|
\ 'PrtInsert("s")',
|
||||||
|
\ 'PrtInsert("v")',
|
||||||
|
\ 'PrtInsert("+")',
|
||||||
\ ]
|
\ ]
|
||||||
for ke in prtunmaps | for kp in prtmaps[ke]
|
for ke in prtunmaps | for kp in prtmaps[ke]
|
||||||
exe lcmap kp '<Nop>'
|
exe lcmap kp '<Nop>'
|
||||||
@ -582,19 +610,23 @@ endf
|
|||||||
fu! s:ToggleType(dir)
|
fu! s:ToggleType(dir)
|
||||||
let ext = exists('g:ctrlp_ext_vars') ? len(g:ctrlp_ext_vars) : 0
|
let ext = exists('g:ctrlp_ext_vars') ? len(g:ctrlp_ext_vars) : 0
|
||||||
let s:itemtype = s:walker(g:ctrlp_builtins + ext, s:itemtype, a:dir)
|
let s:itemtype = s:walker(g:ctrlp_builtins + ext, s:itemtype, a:dir)
|
||||||
cal s:Type(s:itemtype)
|
let s:extid = s:itemtype - ( g:ctrlp_builtins + 1 )
|
||||||
endf
|
unl! g:ctrlp_nolimit
|
||||||
|
|
||||||
fu! s:Type(type)
|
|
||||||
let s:itemtype = a:type
|
|
||||||
cal s:SetLines(s:itemtype)
|
cal s:SetLines(s:itemtype)
|
||||||
cal s:PrtSwitcher()
|
cal s:PrtSwitcher()
|
||||||
cal s:syntax()
|
if s:itemtype > 2
|
||||||
|
if exists('g:ctrlp_ext_vars['.s:extid.'][4][0]')
|
||||||
|
let g:ctrlp_nolimit = g:ctrlp_ext_vars[s:extid][4][0]
|
||||||
|
en
|
||||||
|
el
|
||||||
|
cal s:syntax()
|
||||||
|
en
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:PrtSwitcher()
|
fu! s:PrtSwitcher()
|
||||||
let s:matches = 1
|
let [s:force, s:matches] = [1, 1]
|
||||||
cal s:BuildPrompt(1, s:Focus(), 1)
|
cal s:BuildPrompt(1, s:Focus())
|
||||||
|
unl s:force
|
||||||
endf
|
endf
|
||||||
"}}}
|
"}}}
|
||||||
fu! s:SetWD(...) "{{{
|
fu! s:SetWD(...) "{{{
|
||||||
@ -602,12 +634,12 @@ fu! s:SetWD(...) "{{{
|
|||||||
if exists('a:1') && len(a:1) == 1 && !type(a:1)
|
if exists('a:1') && len(a:1) == 1 && !type(a:1)
|
||||||
let pathmode = a:1
|
let pathmode = a:1
|
||||||
elsei exists('a:1') && len(a:1) > 1 && type(a:1)
|
elsei exists('a:1') && len(a:1) > 1 && type(a:1)
|
||||||
cal s:setdir(a:1) | retu
|
cal ctrlp#setdir(a:1) | retu
|
||||||
en
|
en
|
||||||
if !exists('a:2')
|
if !exists('a:2')
|
||||||
if match(s:crfile, '^\<.\+\>://.*') >= 0 || !pathmode | retu | en
|
if match(s:crfile, '^\<.\+\>://.*') >= 0 || !pathmode | retu | en
|
||||||
if exists('+acd') | let [s:glb_acd, &acd] = [&acd, 0] | en
|
if exists('+acd') | let [s:glb_acd, &acd] = [&acd, 0] | en
|
||||||
cal s:setdir(s:crfpath)
|
cal ctrlp#setdir(s:crfpath)
|
||||||
en
|
en
|
||||||
if pathmode == 1 | retu | en
|
if pathmode == 1 | retu | en
|
||||||
let markers = ['root.dir','.git/','.hg/','.vimprojects','_darcs/','.bzr/']
|
let markers = ['root.dir','.git/','.hg/','.vimprojects','_darcs/','.bzr/']
|
||||||
@ -639,15 +671,9 @@ fu! ctrlp#acceptfile(mode, matchstr)
|
|||||||
exe bufwinnr.'winc w'
|
exe bufwinnr.'winc w'
|
||||||
el
|
el
|
||||||
" Determine the command to use
|
" Determine the command to use
|
||||||
if md == 't' || s:splitwin == 1
|
let cmd = md == 't' || s:splitwin == 1 ? 'tabe'
|
||||||
let cmd = 'tabe'
|
\ : md == 'h' || s:splitwin == 2 ? 'new'
|
||||||
elsei md == 'h' || s:splitwin == 2
|
\ : md == 'v' || s:splitwin == 3 ? 'vne' : ctrlp#normcmd('e')
|
||||||
let cmd = 'new'
|
|
||||||
elsei md == 'v' || s:splitwin == 3
|
|
||||||
let cmd = 'vne'
|
|
||||||
el
|
|
||||||
let cmd = s:normcmd('e')
|
|
||||||
en
|
|
||||||
" Open new window/buffer
|
" Open new window/buffer
|
||||||
cal s:openfile(cmd, filpath)
|
cal s:openfile(cmd, filpath)
|
||||||
en
|
en
|
||||||
@ -679,15 +705,9 @@ fu! s:CreateNewFile() "{{{
|
|||||||
let filpath = getcwd().s:lash.optyp
|
let filpath = getcwd().s:lash.optyp
|
||||||
cal s:insertcache(str)
|
cal s:insertcache(str)
|
||||||
cal s:PrtExit()
|
cal s:PrtExit()
|
||||||
if s:newfop == 1
|
let cmd = s:newfop == 1 ? 'tabe'
|
||||||
let cmd = 'tabe'
|
\ : s:newfop == 2 ? 'new'
|
||||||
elsei s:newfop == 2
|
\ : s:newfop == 3 ? 'vne' : ctrlp#normcmd('e')
|
||||||
let cmd = 'new'
|
|
||||||
elsei s:newfop == 3
|
|
||||||
let cmd = 'vne'
|
|
||||||
el
|
|
||||||
let cmd = s:normcmd('e')
|
|
||||||
en
|
|
||||||
cal s:openfile(cmd, filpath)
|
cal s:openfile(cmd, filpath)
|
||||||
en
|
en
|
||||||
endf "}}}
|
endf "}}}
|
||||||
@ -808,7 +828,7 @@ fu! s:mixedsort(s1, 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 = s:comparent(a:s1, a:s2)
|
||||||
if s:height < 21
|
if s:height < 21
|
||||||
retu 6 * cml + 3 * par + 2 * s:comptime(a:s1, a:s2) + 1 * cln
|
retu 6 * cml + 3 * par + 2 * s:comptime(a:s1, a:s2) + cln
|
||||||
en
|
en
|
||||||
retu 3 * cml + 2 * par + cln
|
retu 3 * cml + 2 * par + cln
|
||||||
en
|
en
|
||||||
@ -862,7 +882,7 @@ endf
|
|||||||
|
|
||||||
fu! s:parentdir(curr)
|
fu! s:parentdir(curr)
|
||||||
let parent = s:getparent(a:curr)
|
let parent = s:getparent(a:curr)
|
||||||
if parent != a:curr | cal s:setdir(parent) | en
|
if parent != a:curr | cal ctrlp#setdir(parent) | en
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:getparent(item)
|
fu! s:getparent(item)
|
||||||
@ -899,11 +919,11 @@ endf
|
|||||||
fu! s:findroot(curr, mark, depth, type)
|
fu! s:findroot(curr, mark, depth, type)
|
||||||
let [depth, notfound] = [a:depth + 1, empty(s:glbpath(a:curr, a:mark, 1))]
|
let [depth, notfound] = [a:depth + 1, empty(s:glbpath(a:curr, a:mark, 1))]
|
||||||
if !notfound || depth > s:maxdepth
|
if !notfound || depth > s:maxdepth
|
||||||
if notfound | cal s:setdir(s:cwd) | en
|
if notfound | cal ctrlp#setdir(s:cwd) | en
|
||||||
if a:type
|
if a:type
|
||||||
let s:vcsroot = depth <= s:maxdepth ? a:curr : ''
|
let s:vcsroot = depth <= s:maxdepth ? a:curr : ''
|
||||||
el
|
el
|
||||||
cal s:setdir(a:curr)
|
cal ctrlp#setdir(a:curr)
|
||||||
let s:foundroot = 1
|
let s:foundroot = 1
|
||||||
en
|
en
|
||||||
el
|
el
|
||||||
@ -916,15 +936,15 @@ fu! s:glbpath(...)
|
|||||||
retu call('globpath', v:version > 701 ? [a:1, a:2, a:3] : [a:1, a:2])
|
retu call('globpath', v:version > 701 ? [a:1, a:2, a:3] : [a:1, a:2])
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:fnesc(path)
|
fu! ctrlp#fnesc(path)
|
||||||
retu exists('*fnameescape') ? fnameescape(a:path) : escape(a:path, " %#*?|<\"\n")
|
retu exists('*fnameescape') ? fnameescape(a:path) : escape(a:path, " %#*?|<\"\n")
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:setdir(path)
|
fu! ctrlp#setdir(path)
|
||||||
try
|
try
|
||||||
exe 'lc!' s:fnesc(a:path)
|
exe 'lc!' ctrlp#fnesc(a:path)
|
||||||
cat
|
cat
|
||||||
cal s:msg("Can't change working dir. Directory not exists.")
|
cal ctrlp#msg("Can't change working dir. Directory not exists.")
|
||||||
endt
|
endt
|
||||||
endf
|
endf
|
||||||
"}}}
|
"}}}
|
||||||
@ -938,7 +958,7 @@ endf
|
|||||||
|
|
||||||
fu! s:highlight(pat, grp)
|
fu! s:highlight(pat, grp)
|
||||||
cal clearmatches()
|
cal clearmatches()
|
||||||
if !empty(a:pat) && a:pat != '..'
|
if !empty(a:pat) && a:pat != '..' && s:itemtype < 3
|
||||||
let pat = substitute(a:pat, '\~', '\\~', 'g')
|
let pat = substitute(a:pat, '\~', '\\~', 'g')
|
||||||
if !s:regexp | let pat = escape(pat, '.') | en
|
if !s:regexp | let pat = escape(pat, '.') | en
|
||||||
" Match only filename
|
" Match only filename
|
||||||
@ -950,6 +970,11 @@ fu! s:highlight(pat, grp)
|
|||||||
cal matchadd('CtrlPLineMarker', '^>')
|
cal matchadd('CtrlPLineMarker', '^>')
|
||||||
en
|
en
|
||||||
endf
|
endf
|
||||||
|
|
||||||
|
fu! s:dohighlight()
|
||||||
|
retu type(s:mathi) == 3 && len(s:mathi) == 2 && s:mathi[0]
|
||||||
|
\ && exists('*clearmatches')
|
||||||
|
endf
|
||||||
"}}}
|
"}}}
|
||||||
" Prompt history {{{
|
" Prompt history {{{
|
||||||
fu! s:gethistloc()
|
fu! s:gethistloc()
|
||||||
@ -1033,7 +1058,7 @@ fu! s:normbuf()
|
|||||||
retu winnrs
|
retu winnrs
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:normcmd(cmd)
|
fu! ctrlp#normcmd(cmd)
|
||||||
if !empty(s:nosplit) && match([bufname('%'), &l:ft], s:nosplit) >= 0
|
if !empty(s:nosplit) && match([bufname('%'), &l:ft], s:nosplit) >= 0
|
||||||
retu a:cmd
|
retu a:cmd
|
||||||
en
|
en
|
||||||
@ -1111,20 +1136,30 @@ fu! s:specinputs()
|
|||||||
retu 0
|
retu 0
|
||||||
endf
|
endf
|
||||||
|
|
||||||
|
fu! s:lastvisual()
|
||||||
|
let [cview, oreg, oreg_type] = [winsaveview(), getreg('v'), getregtype('v')]
|
||||||
|
norm! gv"vy
|
||||||
|
let selected = substitute(getreg('v'), '\n', '\\n', 'g')
|
||||||
|
cal setreg('v', oreg, oreg_type)
|
||||||
|
cal winrestview(cview)
|
||||||
|
retu selected
|
||||||
|
endf
|
||||||
|
|
||||||
fu! s:openfile(cmd, filpath)
|
fu! s:openfile(cmd, filpath)
|
||||||
let cmd = a:cmd == 'e' && &modified ? 'hid e' : a:cmd
|
let cmd = a:cmd == 'e' && &modified ? 'hid e' : a:cmd
|
||||||
|
let tail = s:tail()
|
||||||
try
|
try
|
||||||
exe cmd.s:tail().' '.s:fnesc(a:filpath)
|
exe cmd.tail.' '.ctrlp#fnesc(a:filpath)
|
||||||
cat
|
cat
|
||||||
cal s:msg("Operation can't be completed. Make sure filename is valid.")
|
cal ctrlp#msg("Operation can't be completed. Make sure filename is valid.")
|
||||||
fina
|
fina
|
||||||
if !empty(s:tail())
|
if !empty(tail)
|
||||||
sil! norm! zOzz
|
sil! norm! zOzz
|
||||||
en
|
en
|
||||||
endt
|
endt
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:msg(msg)
|
fu! ctrlp#msg(msg)
|
||||||
echoh Identifier | echon "CtrlP: ".a:msg | echoh None
|
echoh Identifier | echon "CtrlP: ".a:msg | echoh None
|
||||||
endf
|
endf
|
||||||
|
|
||||||
@ -1158,10 +1193,14 @@ fu! s:walker(max, pos, dir)
|
|||||||
retu a:dir > 0 ? a:pos < a:max ? a:pos + 1 : 0 : a:pos > 0 ? a:pos - 1 : a:max
|
retu a:dir > 0 ? a:pos < a:max ? a:pos + 1 : 0 : a:pos > 0 ? a:pos - 1 : a:max
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:matchsubstr(item, pat)
|
fu! s:matchfname(item, pat)
|
||||||
retu match(split(a:item, '[\/]\ze[^\/]\+$')[-1], a:pat)
|
retu match(split(a:item, '[\/]\ze[^\/]\+$')[-1], a:pat)
|
||||||
endf
|
endf
|
||||||
|
|
||||||
|
fu! s:matchtab(item, pat)
|
||||||
|
retu match(split(a:item, '\t[^\t]\+$')[0], a:pat)
|
||||||
|
endf
|
||||||
|
|
||||||
fu! s:maxfiles(len)
|
fu! s:maxfiles(len)
|
||||||
retu s:maxfiles && a:len > s:maxfiles ? 1 : 0
|
retu s:maxfiles && a:len > s:maxfiles ? 1 : 0
|
||||||
endf
|
endf
|
||||||
@ -1184,7 +1223,7 @@ fu! s:insertcache(str)
|
|||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:lscommand()
|
fu! s:lscommand()
|
||||||
let cmd = g:ctrlp_user_command
|
let cmd = s:usrcmd
|
||||||
if type(cmd) == 1
|
if type(cmd) == 1
|
||||||
retu cmd
|
retu cmd
|
||||||
elsei type(cmd) == 3 && len(cmd) >= 2 && !empty(cmd[0]) && !empty(cmd[1])
|
elsei type(cmd) == 3 && len(cmd) >= 2 && !empty(cmd[0]) && !empty(cmd[1])
|
||||||
@ -1232,6 +1271,9 @@ if has('autocmd') "{{{
|
|||||||
au BufEnter ControlP cal s:checkbuf()
|
au BufEnter ControlP cal s:checkbuf()
|
||||||
au BufLeave ControlP cal s:Close()
|
au BufLeave ControlP cal s:Close()
|
||||||
au VimLeavePre * cal s:leavepre()
|
au VimLeavePre * cal s:leavepre()
|
||||||
|
if s:lazy
|
||||||
|
au CursorHold ControlP cal s:ForceUpdate()
|
||||||
|
en
|
||||||
aug END
|
aug END
|
||||||
en "}}}
|
en "}}}
|
||||||
|
|
||||||
|
@ -7,13 +7,13 @@
|
|||||||
" Static variables {{{
|
" Static variables {{{
|
||||||
fu! ctrlp#mrufiles#opts()
|
fu! ctrlp#mrufiles#opts()
|
||||||
let opts = {
|
let opts = {
|
||||||
\ 'g:ctrlp_mruf_max': ['s:max', 150],
|
\ 'g:ctrlp_mruf_max': ['s:max', 250],
|
||||||
\ 'g:ctrlp_mruf_include': ['s:include', ''],
|
\ 'g:ctrlp_mruf_include': ['s:include', ''],
|
||||||
\ 'g:ctrlp_mruf_exclude': ['s:exclude', ''],
|
\ 'g:ctrlp_mruf_exclude': ['s:exclude', ''],
|
||||||
\ 'g:ctrlp_mruf_case_sensitive': ['s:csen', 1],
|
\ 'g:ctrlp_mruf_case_sensitive': ['s:csen', 1],
|
||||||
\ }
|
\ }
|
||||||
for [ke, va] in items(opts)
|
for [ke, va] in items(opts)
|
||||||
exe 'let' va[0] '=' string(exists(ke) ? eval(ke) : va[1]) '| unl!' ke
|
exe 'let' va[0] '=' string(exists(ke) ? eval(ke) : va[1])
|
||||||
endfo
|
endfo
|
||||||
endf
|
endf
|
||||||
cal ctrlp#mrufiles#opts()
|
cal ctrlp#mrufiles#opts()
|
||||||
|
56
autoload/ctrlp/quickfix.vim
Normal file
56
autoload/ctrlp/quickfix.vim
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
" =============================================================================
|
||||||
|
" File: autoload/ctrlp/quickfix.vim
|
||||||
|
" Description: Quickfix extension
|
||||||
|
" Author: Kien Nguyen <github.com/kien>
|
||||||
|
" =============================================================================
|
||||||
|
|
||||||
|
" Init {{{
|
||||||
|
if exists('g:loaded_ctrlp_quickfix') && g:loaded_ctrlp_quickfix
|
||||||
|
fini
|
||||||
|
en
|
||||||
|
let g:loaded_ctrlp_quickfix = 1
|
||||||
|
|
||||||
|
let s:var_qf = ['ctrlp#quickfix#init()', 'ctrlp#quickfix#accept', 'quickfix',
|
||||||
|
\ 'qfx', [1]]
|
||||||
|
|
||||||
|
let g:ctrlp_ext_vars = exists('g:ctrlp_ext_vars') && !empty(g:ctrlp_ext_vars)
|
||||||
|
\ ? add(g:ctrlp_ext_vars, s:var_qf) : [s:var_qf]
|
||||||
|
|
||||||
|
let s:id = g:ctrlp_builtins + len(g:ctrlp_ext_vars)
|
||||||
|
|
||||||
|
fu! s:lineout(dict)
|
||||||
|
retu printf('%s|%d:%d| %s', bufname(a:dict['bufnr']), a:dict['lnum'],
|
||||||
|
\ a:dict['col'], matchstr(a:dict['text'], '\s*\zs.*\S'))
|
||||||
|
endf
|
||||||
|
"}}}
|
||||||
|
" Public {{{
|
||||||
|
fu! ctrlp#quickfix#init()
|
||||||
|
let g:ctrlp_nolimit = 1
|
||||||
|
sy match CtrlPqfLineCol '|\zs\d\+:\d\+\ze|'
|
||||||
|
hi def link CtrlPqfLineCol Search
|
||||||
|
retu map(getqflist(), 's:lineout(v:val)')
|
||||||
|
endf
|
||||||
|
|
||||||
|
fu! ctrlp#quickfix#accept(mode, str)
|
||||||
|
let items = matchlist(a:str, '^\([^|]\+\ze\)|\(\d\+\):\(\d\+\)|')
|
||||||
|
let [md, filpath] = [a:mode, fnamemodify(items[1], ':p')]
|
||||||
|
if empty(filpath) | retu | en
|
||||||
|
cal ctrlp#exit()
|
||||||
|
let cmd = md == 't' ? 'tabe' : md == 'h' ? 'new' : md == 'v' ? 'vne'
|
||||||
|
\ : ctrlp#normcmd('e')
|
||||||
|
let cmd = cmd == 'e' && &modified ? 'hid e' : cmd
|
||||||
|
try
|
||||||
|
exe cmd.' '.ctrlp#fnesc(filpath)
|
||||||
|
cat
|
||||||
|
cal ctrlp#msg("Invalid command or argument.")
|
||||||
|
fina
|
||||||
|
cal cursor(items[2], items[3]) | sil! norm! zOzz
|
||||||
|
endt
|
||||||
|
endf
|
||||||
|
|
||||||
|
fu! ctrlp#quickfix#id()
|
||||||
|
retu s:id
|
||||||
|
endf
|
||||||
|
"}}}
|
||||||
|
|
||||||
|
" vim:fen:fdl=0:ts=2:sw=2:sts=2
|
58
autoload/ctrlp/tag.vim
Normal file
58
autoload/ctrlp/tag.vim
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
" =============================================================================
|
||||||
|
" File: autoload/ctrlp/tag.vim
|
||||||
|
" Description: Tag file extension
|
||||||
|
" Author: Kien Nguyen <github.com/kien>
|
||||||
|
" =============================================================================
|
||||||
|
|
||||||
|
" Init {{{
|
||||||
|
if exists('g:loaded_ctrlp_tag') && g:loaded_ctrlp_tag
|
||||||
|
fini
|
||||||
|
en
|
||||||
|
let [g:loaded_ctrlp_tag, g:ctrlp_newtag] = [1, 0]
|
||||||
|
|
||||||
|
let s:tag_var = ['ctrlp#tag#init()', 'ctrlp#tag#accept', 'tags', 'tag']
|
||||||
|
|
||||||
|
let g:ctrlp_ext_vars = exists('g:ctrlp_ext_vars') && !empty(g:ctrlp_ext_vars)
|
||||||
|
\ ? add(g:ctrlp_ext_vars, s:tag_var) : [s:tag_var]
|
||||||
|
|
||||||
|
let s:id = g:ctrlp_builtins + len(g:ctrlp_ext_vars)
|
||||||
|
"}}}
|
||||||
|
" Public {{{
|
||||||
|
fu! ctrlp#tag#init()
|
||||||
|
if exists('s:cwd') && s:cwd == getcwd()
|
||||||
|
let newtags = 0
|
||||||
|
el
|
||||||
|
let s:cwd = getcwd()
|
||||||
|
let newtags = 1
|
||||||
|
en
|
||||||
|
if ( newtags && !exists('g:ctrlp_alltags['''.s:cwd.''']') ) || g:ctrlp_newtag
|
||||||
|
let alltags = map(taglist('.*'), 'v:val["name"]." ".v:val["filename"]')
|
||||||
|
cal extend(g:ctrlp_alltags, { s:cwd : alltags })
|
||||||
|
let g:ctrlp_newtag = 0
|
||||||
|
en
|
||||||
|
sy match CtrlPTagFilename '\zs\t.*\ze$'
|
||||||
|
hi link CtrlPTagFilename Comment
|
||||||
|
retu g:ctrlp_alltags[s:cwd]
|
||||||
|
endf
|
||||||
|
|
||||||
|
fu! ctrlp#tag#accept(mode, str)
|
||||||
|
cal ctrlp#exit()
|
||||||
|
let md = a:mode
|
||||||
|
let cmd = md == 't' ? 'tabnew' : md == 'h' ? 'new' : md == 'v' ? 'vne'
|
||||||
|
\ : ctrlp#normcmd('ene')
|
||||||
|
let cmd = cmd == 'ene' && &modified ? 'hid ene' : cmd
|
||||||
|
try
|
||||||
|
exe cmd
|
||||||
|
cal ctrlp#setdir(s:cwd)
|
||||||
|
exe 'ta' split(a:str, '\t[^\t]\+$')[0]
|
||||||
|
cat
|
||||||
|
cal ctrlp#msg("Tag not found.")
|
||||||
|
endt
|
||||||
|
endf
|
||||||
|
|
||||||
|
fu! ctrlp#tag#id()
|
||||||
|
retu s:id
|
||||||
|
endf
|
||||||
|
"}}}
|
||||||
|
|
||||||
|
" vim:fen:fdl=0:ts=2:sw=2:sts=2
|
@ -26,9 +26,10 @@ fu! ctrlp#utils#cachedir()
|
|||||||
retu s:cache_dir
|
retu s:cache_dir
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! ctrlp#utils#cachefile()
|
fu! ctrlp#utils#cachefile(...)
|
||||||
let cache_file = substitute(getcwd(), '\([\/]\|^\a\zs:\)', '%', 'g').'.txt'
|
let tail = exists('a:1') ? '.'.a:1 : ''
|
||||||
retu s:cache_dir.s:lash.cache_file
|
let cache_file = substitute(getcwd(), '\([\/]\|^\a\zs:\)', '%', 'g').tail.'.txt'
|
||||||
|
retu exists('a:1') ? cache_file : s:cache_dir.s:lash.cache_file
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! ctrlp#utils#readfile(file)
|
fu! ctrlp#utils#readfile(file)
|
||||||
|
100
doc/ctrlp.txt
100
doc/ctrlp.txt
@ -1,4 +1,4 @@
|
|||||||
*ctrlp.txt* Fuzzy file, buffer and MRU file finder. v1.6.1
|
*ctrlp.txt* Fuzzy file, buffer and MRU file finder. v1.6.2
|
||||||
*CtrlP* *ControlP* *'ctrlp'* *'ctrl-p'*
|
*CtrlP* *ControlP* *'ctrlp'* *'ctrl-p'*
|
||||||
===============================================================================
|
===============================================================================
|
||||||
# #
|
# #
|
||||||
@ -18,6 +18,7 @@ CONTENTS *ctrlp-contents*
|
|||||||
3. Commands.....................................|ctrlp-commands|
|
3. Commands.....................................|ctrlp-commands|
|
||||||
4. Mappings.....................................|ctrlp-mappings|
|
4. Mappings.....................................|ctrlp-mappings|
|
||||||
5. Input Formats................................|ctrlp-input-formats|
|
5. Input Formats................................|ctrlp-input-formats|
|
||||||
|
6. Extensions...................................|ctrlp-extensions|
|
||||||
|
|
||||||
===============================================================================
|
===============================================================================
|
||||||
1. Intro *ctrlp-intro*
|
1. Intro *ctrlp-intro*
|
||||||
@ -27,6 +28,8 @@ Written in pure Vimscript for MacVim and Vim version 7.0+. Has full support for
|
|||||||
Vim’s |regexp| as search pattern, built-in MRU monitoring, project’s root
|
Vim’s |regexp| as search pattern, built-in MRU monitoring, project’s root
|
||||||
finder, and more.
|
finder, and more.
|
||||||
|
|
||||||
|
To enable optional extensions (tag, quickfix ...), see |ctrlp-extensions|.
|
||||||
|
|
||||||
===============================================================================
|
===============================================================================
|
||||||
2. Options *ctrlp-options*
|
2. Options *ctrlp-options*
|
||||||
|
|
||||||
@ -141,7 +144,7 @@ only need to keep the lines that you’ve changed the values (inside []): >
|
|||||||
\ 'PrtCurLeft()': ['<c-h>', '<left>'],
|
\ 'PrtCurLeft()': ['<c-h>', '<left>'],
|
||||||
\ 'PrtCurRight()': ['<c-l>', '<right>'],
|
\ 'PrtCurRight()': ['<c-l>', '<right>'],
|
||||||
\ 'PrtClearCache()': ['<F5>'],
|
\ 'PrtClearCache()': ['<F5>'],
|
||||||
\ 'PrtDeleteMRU()': ['<F8>'],
|
\ 'PrtDeleteMRU()': ['<F7>'],
|
||||||
\ 'CreateNewFile()': ['<c-y>'],
|
\ 'CreateNewFile()': ['<c-y>'],
|
||||||
\ 'MarkToOpen()': ['<c-z>'],
|
\ 'MarkToOpen()': ['<c-z>'],
|
||||||
\ 'OpenMulti()': ['<c-o>'],
|
\ 'OpenMulti()': ['<c-o>'],
|
||||||
@ -151,7 +154,7 @@ only need to keep the lines that you’ve changed the values (inside []): >
|
|||||||
|
|
||||||
*'g:ctrlp_mruf_max'*
|
*'g:ctrlp_mruf_max'*
|
||||||
Specify the number of recently opened files you want |CtrlP| to remember: >
|
Specify the number of recently opened files you want |CtrlP| to remember: >
|
||||||
let g:ctrlp_mruf_max = 150
|
let g:ctrlp_mruf_max = 250
|
||||||
<
|
<
|
||||||
|
|
||||||
*'g:ctrlp_mruf_exclude'*
|
*'g:ctrlp_mruf_exclude'*
|
||||||
@ -194,7 +197,7 @@ this.
|
|||||||
|
|
||||||
Other note: |wildignore| influences the result of |expand()|, |globpath()| and
|
Other note: |wildignore| influences the result of |expand()|, |globpath()| and
|
||||||
|glob()| which many plugins use to find stuff on the system (e.g. fugitive.vim
|
|glob()| which many plugins use to find stuff on the system (e.g. fugitive.vim
|
||||||
looks for .git/, some other plugins look for external .exe tools on Windows).
|
looks for .git/, some other plugins look for external exe tools on Windows).
|
||||||
So be a little mindful of what you put in your |wildignore|.
|
So be a little mindful of what you put in your |wildignore|.
|
||||||
|
|
||||||
*'g:ctrlp_highlight_match'*
|
*'g:ctrlp_highlight_match'*
|
||||||
@ -215,8 +218,8 @@ The maximum depth of a directory tree to recurse into: >
|
|||||||
Note: the larger these values, the more memory Vim uses.
|
Note: the larger these values, the more memory Vim uses.
|
||||||
|
|
||||||
*'g:ctrlp_user_command'*
|
*'g:ctrlp_user_command'*
|
||||||
Specify an external tool to use for listing files instead of using Vim’s
|
Specify an external tool to use for listing files instead of Vim’s globpath().
|
||||||
globpath(). Use %s in place of the target directory: >
|
Use %s in place of the target directory: >
|
||||||
let g:ctrlp_user_command = ''
|
let g:ctrlp_user_command = ''
|
||||||
<
|
<
|
||||||
Examples: >
|
Examples: >
|
||||||
@ -233,7 +236,7 @@ faster when working with large projects: >
|
|||||||
let g:ctrlp_user_command = [repo_marker, vcs_ls_command, fallback_command]
|
let g:ctrlp_user_command = [repo_marker, vcs_ls_command, fallback_command]
|
||||||
<
|
<
|
||||||
If the fallback_command is empty or not defined, globpath() will then be used
|
If the fallback_command is empty or not defined, globpath() will then be used
|
||||||
when outside a repo.
|
when searching outside a repo.
|
||||||
Examples: >
|
Examples: >
|
||||||
let g:ctrlp_user_command = ['.git/', 'cd %s && git ls-files']
|
let g:ctrlp_user_command = ['.git/', 'cd %s && git ls-files']
|
||||||
let g:ctrlp_user_command = ['.hg/', 'hg --cwd %s locate --fullpath -I .']
|
let g:ctrlp_user_command = ['.hg/', 'hg --cwd %s locate --fullpath -I .']
|
||||||
@ -252,7 +255,7 @@ pressing <c-y>:
|
|||||||
|
|
||||||
*'g:ctrlp_max_history'*
|
*'g:ctrlp_max_history'*
|
||||||
The maximum number of input strings you want |CtrlP| to remember. The default
|
The maximum number of input strings you want |CtrlP| to remember. The default
|
||||||
value mirrors Vim’s global |'history'| option. E.g. `set history=50`: >
|
value mirrors Vim’s global |'history'| option: >
|
||||||
let g:ctrlp_max_history = &history
|
let g:ctrlp_max_history = &history
|
||||||
<
|
<
|
||||||
Set to 0 to disable prompt’s history.
|
Set to 0 to disable prompt’s history.
|
||||||
@ -285,23 +288,32 @@ Set this to 1 to follow symbolic links when listing files: >
|
|||||||
let g:ctrlp_follow_symlinks = 0
|
let g:ctrlp_follow_symlinks = 0
|
||||||
<
|
<
|
||||||
|
|
||||||
|
*'g:ctrlp_lazy_update'*
|
||||||
|
Set this to 1 to enable the lazy-update feature: only update the match window
|
||||||
|
after typing’s been stopped for a certain amount of time: >
|
||||||
|
let g:ctrlp_lazy_update = 0
|
||||||
|
<
|
||||||
|
If is 1, update after 250ms. If bigger than 1, the number will be used as the
|
||||||
|
delay time in milliseconds.
|
||||||
|
|
||||||
===============================================================================
|
===============================================================================
|
||||||
3. Commands *ctrlp-commands*
|
3. Commands *ctrlp-commands*
|
||||||
|
|
||||||
*:CtrlP*
|
*:CtrlP*
|
||||||
:CtrlP [starting-directory]
|
:CtrlP [starting-directory]
|
||||||
Open the |CtrlP| prompt in find file mode.
|
Open |CtrlP| in find file mode.
|
||||||
|
|
||||||
If no argument is given, the value of |g:ctrlp_working_path_mode| will be
|
If no argument is given, the value of |g:ctrlp_working_path_mode| will be
|
||||||
used to determine the starting directory.
|
used to determine the starting directory.
|
||||||
You can use <tab> to auto-complete the [starting-directory] when typing it.
|
You can use <tab> to auto-complete the [starting-directory] when typing it.
|
||||||
|
|
||||||
*:CtrlPBuffer*
|
*:CtrlPBuffer*
|
||||||
:CtrlPBuffer
|
:CtrlPBuffer
|
||||||
Open the |CtrlP| prompt in find buffer mode.
|
Open |CtrlP| in find buffer mode.
|
||||||
|
|
||||||
*:CtrlPMRU*
|
*:CtrlPMRU*
|
||||||
:CtrlPMRU
|
:CtrlPMRU
|
||||||
Open the |CtrlP| prompt in find Most-Recently-Used file mode.
|
Open |CtrlP| in find Most-Recently-Used file mode.
|
||||||
|
|
||||||
*:ClearCtrlPCache*
|
*:ClearCtrlPCache*
|
||||||
:ClearCtrlPCache
|
:ClearCtrlPCache
|
||||||
@ -333,7 +345,7 @@ The following commands ignore the current value of |g:ctrlp_working_path_mode|:
|
|||||||
|
|
||||||
*'ctrlp-<c-p>'*
|
*'ctrlp-<c-p>'*
|
||||||
<c-p>
|
<c-p>
|
||||||
Default |Normal| mode mapping to open the |CtrlP| prompt.
|
Default |Normal| mode mapping to open the |CtrlP| prompt in find file mode.
|
||||||
|
|
||||||
Once inside the prompt:~
|
Once inside the prompt:~
|
||||||
|
|
||||||
@ -349,12 +361,11 @@ Once inside the prompt:~
|
|||||||
|
|
||||||
<c-f>, 'forward'
|
<c-f>, 'forward'
|
||||||
<c-up>
|
<c-up>
|
||||||
Scroll to the 'next' search type in the sequence. Currently file, buffer
|
Scroll to the 'next' search mode in the sequence.
|
||||||
and most recently used file (MRU) are available.
|
|
||||||
|
|
||||||
<c-b>, 'backward'
|
<c-b>, 'backward'
|
||||||
<c-down>
|
<c-down>
|
||||||
Scroll to the 'previous' search type in the sequence.
|
Scroll to the 'previous' search mode in the sequence.
|
||||||
|
|
||||||
<tab>
|
<tab>
|
||||||
Toggle the focus between the match window and the prompt.
|
Toggle the focus between the match window and the prompt.
|
||||||
@ -388,7 +399,7 @@ Once inside the prompt:~
|
|||||||
Clear the input field
|
Clear the input field
|
||||||
|
|
||||||
<cr>
|
<cr>
|
||||||
Open selected file with the method specified with |g:ctrlp_split_window|
|
Open selected file in the active window if possible.
|
||||||
|
|
||||||
<c-t>
|
<c-t>
|
||||||
Open selected file in a new 'tab'
|
Open selected file in a new 'tab'
|
||||||
@ -405,10 +416,10 @@ Once inside the prompt:~
|
|||||||
Create a new file and its parent directories.
|
Create a new file and its parent directories.
|
||||||
|
|
||||||
<c-n>
|
<c-n>
|
||||||
'Next' string in the prompt’s history
|
Next string in the prompt’s history
|
||||||
|
|
||||||
<c-p>
|
<c-p>
|
||||||
'Previous' string in the prompt’s history
|
Previous string in the prompt’s history
|
||||||
|
|
||||||
<c-z>
|
<c-z>
|
||||||
Mark/unmark a file to be opened with <c-o>.
|
Mark/unmark a file to be opened with <c-o>.
|
||||||
@ -417,11 +428,11 @@ Once inside the prompt:~
|
|||||||
Open files marked by <c-z>.
|
Open files marked by <c-z>.
|
||||||
|
|
||||||
<F5>
|
<F5>
|
||||||
Refresh the match window and purge the cache for the current directory.
|
- Refresh the match window and purge the cache for the current directory.
|
||||||
Or remove deleted files from MRU list.
|
- Remove deleted files from MRU list.
|
||||||
|
|
||||||
<F8>
|
<F7>
|
||||||
Clear the MRU list.
|
Clear MRU list.
|
||||||
|
|
||||||
<esc>,
|
<esc>,
|
||||||
<c-c>,
|
<c-c>,
|
||||||
@ -478,30 +489,52 @@ f) Type the name of a non-existent file and press <c-y> to create it.
|
|||||||
|
|
||||||
g) Submit ? to open this help file.
|
g) Submit ? to open this help file.
|
||||||
|
|
||||||
|
===============================================================================
|
||||||
|
6. Extensions *ctrlp-extensions*
|
||||||
|
|
||||||
|
Extensions are optional. To enable an extension, add its name to the variable
|
||||||
|
g:ctrlp_extensions: >
|
||||||
|
let g:ctrlp_extensions = ['tag', 'qfx']
|
||||||
|
<
|
||||||
|
|
||||||
|
Available extensions:~
|
||||||
|
|
||||||
|
* Tag mode:~
|
||||||
|
- Shortname: 'tag'
|
||||||
|
- Command: ':CtrlPTag'
|
||||||
|
- Search for a tag within a generated central tags file, and jump to the
|
||||||
|
definition. Use the Vim’s option |'tags'| to specify the names and the
|
||||||
|
locations of the tags file(s). Example: `set tags+=tags/help,doc/tags`
|
||||||
|
|
||||||
|
* Quickfix mode:~
|
||||||
|
- Shortname: 'qfx'
|
||||||
|
- Command: ':CtrlPQuickfix'
|
||||||
|
- Search for an entry in the current quickfix errors and jump to it. If the
|
||||||
|
|
||||||
===============================================================================
|
===============================================================================
|
||||||
EXTENDING *ctrlp-extending*
|
EXTENDING *ctrlp-extending*
|
||||||
|
|
||||||
Extending |CtrlP| is very simple. Simply create a .vim file following a short
|
Extending |CtrlP| is very simple. Simply create a vim file following a short
|
||||||
guidelines, place it in autoload/ctrlp/ and add its name to your .vimrc.
|
guidelines, place it in autoload/ctrlp/ and add its name to your .vimrc.
|
||||||
|
|
||||||
To see how it all works, get the sample.vim from the 'extensions' branch on the
|
To see how it works, get the sample.vim from the extensions branch on the main
|
||||||
main git repository (https://github.com/kien/ctrlp.vim/tree/extensions), and
|
git repository (https://github.com/kien/ctrlp.vim/tree/extensions), and place
|
||||||
place it (along with the parent directories) somewhere in your runtimepath.
|
it along with the parent directories somewhere in your runtimepath. Then put
|
||||||
Then put this into your .vimrc: >
|
this into your .vimrc: >
|
||||||
let g:ctrlp_extensions = ['sample']
|
let g:ctrlp_extensions = ['sample']
|
||||||
<
|
<
|
||||||
A 4th search type will show up the next time you open |CtrlP|.
|
A new search type will show up the next time you open |CtrlP|.
|
||||||
|
|
||||||
For more details, check out the comments inside sample.vim.~
|
For more details, check out the comments inside sample.vim.~
|
||||||
|
|
||||||
===============================================================================
|
===============================================================================
|
||||||
CREDITS *ctrlp-credits*
|
CREDITS *ctrlp-credits*
|
||||||
|
|
||||||
Developed by Kien Nguyen (github.com/kien), initially based on the Command-T
|
Developed by Kien Nguyen <github.com/kien>, initially based on the Command-T
|
||||||
and the LustyExplorer plugins. No code was taken from these plugins, but I did
|
and the LustyExplorer plugins. No code was taken from these plugins, but I did
|
||||||
clone the majority of their (awesome) interfaces and the way they work.
|
clone the majority of their (awesome) interfaces and the way they work.
|
||||||
|
|
||||||
The was originally written as a module for a would-be larger plugin called
|
This was originally written as a module for a would-be larger plugin called
|
||||||
AutoDoc.vim which I’ve stopped developing because of lost of interest. I really
|
AutoDoc.vim which I’ve stopped developing because of lost of interest. I really
|
||||||
liked the way Command-T and LustyExplorer deal with user’s input, so I wrote a
|
liked the way Command-T and LustyExplorer deal with user’s input, so I wrote a
|
||||||
pure Vimscript version of their prompt window, intended to use it for the
|
pure Vimscript version of their prompt window, intended to use it for the
|
||||||
@ -525,12 +558,13 @@ Special thanks:~
|
|||||||
===============================================================================
|
===============================================================================
|
||||||
CHANGELOG *ctrlp-changelog*
|
CHANGELOG *ctrlp-changelog*
|
||||||
|
|
||||||
+ New option: |g:ctrlp_follow_symlinks|
|
+ New features: Tag and Quickfix extensions.
|
||||||
|
+ New options: |g:ctrlp_lazy_update|,
|
||||||
|
|g:ctrlp_follow_symlinks|
|
||||||
|
|
||||||
Before 2011/11/13~
|
Before 2011/11/13~
|
||||||
|
|
||||||
+ New special input: '/' and '\' find root (section 5.e)
|
+ New special input: '/' and '\' find root (section 5.e)
|
||||||
+ New mapping: <F8> clear MRU.
|
|
||||||
+ Remove ctrlp#SetWorkingPath().
|
+ Remove ctrlp#SetWorkingPath().
|
||||||
+ Remove |g:ctrlp_mru_files|, make MRU permanent.
|
+ Remove |g:ctrlp_mru_files|, make MRU permanent.
|
||||||
+ Extend |g:ctrlp_open_multi|, add new ways to open files.
|
+ Extend |g:ctrlp_open_multi|, add new ways to open files.
|
||||||
@ -597,4 +631,4 @@ Before 2011/09/12~
|
|||||||
First public release: 2011/09/06~
|
First public release: 2011/09/06~
|
||||||
|
|
||||||
===============================================================================
|
===============================================================================
|
||||||
vim:et:ts=2:sw=2:sts=2
|
vim:ft=help:et:ts=2:sw=2:sts=2:norl
|
||||||
|
@ -8,7 +8,7 @@
|
|||||||
if ( exists('g:loaded_ctrlp') && g:loaded_ctrlp ) || v:version < 700 || &cp
|
if ( exists('g:loaded_ctrlp') && g:loaded_ctrlp ) || v:version < 700 || &cp
|
||||||
fini
|
fini
|
||||||
en
|
en
|
||||||
let g:loaded_ctrlp = 1
|
let [g:loaded_ctrlp, g:ctrlp_lines, g:ctrlp_allfiles] = [1, [], []]
|
||||||
|
|
||||||
if !exists('g:ctrlp_map') | let g:ctrlp_map = '<c-p>' | en
|
if !exists('g:ctrlp_map') | let g:ctrlp_map = '<c-p>' | en
|
||||||
|
|
||||||
@ -29,4 +29,12 @@ exe 'nn <silent>' g:ctrlp_map ':<c-u>CtrlP<cr>'
|
|||||||
|
|
||||||
cal ctrlp#mrufiles#init()
|
cal ctrlp#mrufiles#init()
|
||||||
|
|
||||||
let [g:ctrlp_lines, g:ctrlp_allfiles] = [[], []]
|
if !exists('g:ctrlp_extensions') | fini | en
|
||||||
|
|
||||||
|
if index(g:ctrlp_extensions, 'tag') >= 0
|
||||||
|
let g:ctrlp_alltags = {} | com! CtrlPTag cal ctrlp#init(ctrlp#tag#id())
|
||||||
|
en
|
||||||
|
|
||||||
|
if index(g:ctrlp_extensions, 'quickfix') >= 0
|
||||||
|
com! CtrlPQuickfix cal ctrlp#init(ctrlp#quickfix#id())
|
||||||
|
en
|
||||||
|
@ -12,7 +12,7 @@ Full path fuzzy __file__, __buffer__ and __MRU__ file finder for Vim.
|
|||||||
|
|
||||||
## Basic Usage
|
## Basic Usage
|
||||||
* Press `<c-p>` or run `:CtrlP` to invoke CtrlP in find file mode.
|
* Press `<c-p>` or run `:CtrlP` to invoke CtrlP in find file mode.
|
||||||
* Or use `:CtrlPBuffer` and `:CtrlPMRU` for buffer and MRU mode.
|
* Or run `:CtrlPBuffer` or `:CtrlPMRU` to invoke CtrlP in buffer or MRU mode.
|
||||||
|
|
||||||
Once CtrlP is open:
|
Once CtrlP is open:
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user