A few tweaks
* Fix `:CtrlP .` (thanks to @mattn) * Enhance jump-to-open-buffer: jump to line number as well * Close #39
This commit is contained in:
parent
c90a61f36d
commit
9bff726dd6
@ -1,8 +1,8 @@
|
|||||||
" =============================================================================
|
" =============================================================================
|
||||||
" File: autoload/ctrlp.vim
|
" File: autoload/ctrlp.vim
|
||||||
" Description: Fuzzy file, buffer and MRU file finder.
|
" Description: Fuzzy file, buffer, mru and tag finder.
|
||||||
" Author: Kien Nguyen <github.com/kien>
|
" Author: Kien Nguyen <github.com/kien>
|
||||||
" Version: 1.6.3
|
" Version: 1.6.4
|
||||||
" =============================================================================
|
" =============================================================================
|
||||||
|
|
||||||
" Static variables {{{1
|
" Static variables {{{1
|
||||||
@ -39,7 +39,6 @@ fu! s:opts()
|
|||||||
exe 'let' va[0] '=' string(exists(ke) ? eval(ke) : va[1])
|
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
|
||||||
" 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])
|
||||||
let g:ctrlp_builtins = 2
|
let g:ctrlp_builtins = 2
|
||||||
@ -642,11 +641,11 @@ fu! s:PrtSwitcher()
|
|||||||
endf
|
endf
|
||||||
fu! s:SetWD(...) "{{{1
|
fu! s:SetWD(...) "{{{1
|
||||||
let pathmode = s:pathmode
|
let pathmode = s:pathmode
|
||||||
if exists('a:1') && len(a:1) == 1 && !type(a:1)
|
if exists('a:1') && len(a:1) | if type(a:1)
|
||||||
let pathmode = a:1
|
|
||||||
elsei exists('a:1') && len(a:1) >= 1 && type(a:1)
|
|
||||||
cal ctrlp#setdir(a:1) | retu
|
cal ctrlp#setdir(a:1) | retu
|
||||||
en
|
el
|
||||||
|
let pathmode = a:1
|
||||||
|
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
|
||||||
@ -664,7 +663,7 @@ fu! s:SetWD(...) "{{{1
|
|||||||
unl! s:foundroot
|
unl! s:foundroot
|
||||||
endf
|
endf
|
||||||
" * AcceptSelection() {{{1
|
" * AcceptSelection() {{{1
|
||||||
fu! ctrlp#acceptfile(mode, matchstr)
|
fu! ctrlp#acceptfile(mode, matchstr, ...)
|
||||||
let [md, matchstr] = [a:mode, a:matchstr]
|
let [md, matchstr] = [a:mode, a:matchstr]
|
||||||
" Get the full path
|
" Get the full path
|
||||||
let filpath = s:itemtype ? matchstr : getcwd().s:lash.matchstr
|
let filpath = s:itemtype ? matchstr : getcwd().s:lash.matchstr
|
||||||
@ -673,20 +672,23 @@ fu! ctrlp#acceptfile(mode, matchstr)
|
|||||||
if s:jmptobuf && bufnum > 0 && md == 'e'
|
if s:jmptobuf && bufnum > 0 && md == 'e'
|
||||||
let [jmpb, bufwinnr] = [1, bufwinnr(bufnum)]
|
let [jmpb, bufwinnr] = [1, bufwinnr(bufnum)]
|
||||||
let buftab = s:jmptobuf > 1 ? s:buftab(bufnum) : [0, 0]
|
let buftab = s:jmptobuf > 1 ? s:buftab(bufnum) : [0, 0]
|
||||||
|
let j2l = a:0 ? a:1 : str2nr(matchstr(s:tail(), '^ +\zs\d\+$'))
|
||||||
en
|
en
|
||||||
" Switch to existing buffer or open new one
|
" Switch to existing buffer or open new one
|
||||||
if exists('jmpb') && buftab[0]
|
if exists('jmpb') && buftab[0]
|
||||||
exe 'tabn' buftab[1]
|
exe 'tabn' buftab[1]
|
||||||
exe buftab[0].'winc w'
|
exe buftab[0].'winc w'
|
||||||
|
if j2l | cal s:j2l(j2l) | en
|
||||||
elsei exists('jmpb') && bufwinnr > 0
|
elsei exists('jmpb') && bufwinnr > 0
|
||||||
exe bufwinnr.'winc w'
|
exe bufwinnr.'winc w'
|
||||||
|
if j2l | cal s:j2l(j2l) | en
|
||||||
el
|
el
|
||||||
" Determine the command to use
|
" Determine the command to use
|
||||||
let cmd = md == 't' || s:splitwin == 1 ? 'tabe'
|
let cmd = md == 't' || s:splitwin == 1 ? 'tabe'
|
||||||
\ : md == 'h' || s:splitwin == 2 ? 'new'
|
\ : md == 'h' || s:splitwin == 2 ? 'new'
|
||||||
\ : md == 'v' || s:splitwin == 3 ? 'vne' : ctrlp#normcmd('e')
|
\ : md == 'v' || s:splitwin == 3 ? 'vne' : ctrlp#normcmd('e')
|
||||||
" Open new window/buffer
|
" Open new window/buffer
|
||||||
cal s:openfile(cmd, filpath)
|
cal call('s:openfile', a:0 ? [cmd, filpath, ' +'.a:1] : [cmd, filpath])
|
||||||
en
|
en
|
||||||
endf
|
endf
|
||||||
|
|
||||||
@ -1173,9 +1175,9 @@ fu! ctrlp#msg(msg)
|
|||||||
echoh Identifier | echon "CtrlP: ".a:msg | echoh None
|
echoh Identifier | echon "CtrlP: ".a:msg | echoh None
|
||||||
endf
|
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()
|
let tail = a:0 ? a:1 : s:tail()
|
||||||
try
|
try
|
||||||
exe cmd.tail.' '.ctrlp#fnesc(a:filpath)
|
exe cmd.tail.' '.ctrlp#fnesc(a:filpath)
|
||||||
cat
|
cat
|
||||||
@ -1195,6 +1197,11 @@ fu! s:writecache(read_cache, cache_file)
|
|||||||
en
|
en
|
||||||
endf
|
endf
|
||||||
|
|
||||||
|
fu! s:j2l(nr)
|
||||||
|
exe a:nr
|
||||||
|
sil! norm! zOzz
|
||||||
|
endf
|
||||||
|
|
||||||
fu! s:regexfilter(str)
|
fu! s:regexfilter(str)
|
||||||
let str = a:str
|
let str = a:str
|
||||||
let pats = {
|
let pats = {
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
" =============================================================================
|
" =============================================================================
|
||||||
" File: autoload/ctrlp/dir.vim
|
" File: autoload/ctrlp/dir.vim
|
||||||
" Description: Directory switcher extension
|
" Description: Directory extension
|
||||||
" Author: Kien Nguyen <github.com/kien>
|
" Author: Kien Nguyen <github.com/kien>
|
||||||
" =============================================================================
|
" =============================================================================
|
||||||
|
|
||||||
|
61
autoload/ctrlp/line.vim
Normal file
61
autoload/ctrlp/line.vim
Normal file
@ -0,0 +1,61 @@
|
|||||||
|
" =============================================================================
|
||||||
|
" File: autoload/ctrlp/line.vim
|
||||||
|
" Description: Line extension - find a line in any buffer.
|
||||||
|
" Author: Kien Nguyen <github.com/kien>
|
||||||
|
" =============================================================================
|
||||||
|
|
||||||
|
" Init {{{1
|
||||||
|
if exists('g:loaded_ctrlp_line') && g:loaded_ctrlp_line
|
||||||
|
fini
|
||||||
|
en
|
||||||
|
let g:loaded_ctrlp_line = 1
|
||||||
|
|
||||||
|
let s:line_var = ['ctrlp#line#init()', 'ctrlp#line#accept', 'lines', 'line']
|
||||||
|
|
||||||
|
let g:ctrlp_ext_vars = exists('g:ctrlp_ext_vars') && !empty(g:ctrlp_ext_vars)
|
||||||
|
\ ? add(g:ctrlp_ext_vars, s:line_var) : [s:line_var]
|
||||||
|
|
||||||
|
let s:id = g:ctrlp_builtins + len(g:ctrlp_ext_vars)
|
||||||
|
" Public {{{1
|
||||||
|
fu! ctrlp#line#init()
|
||||||
|
let [bufs, lines] = [[], []]
|
||||||
|
for each in range(1, bufnr('$'))
|
||||||
|
if getbufvar(each, '&bl')
|
||||||
|
let bufname = bufname(each)
|
||||||
|
if strlen(bufname) && bufname != 'ControlP'
|
||||||
|
cal add(bufs, fnamemodify(bufname, ':p'))
|
||||||
|
en
|
||||||
|
en
|
||||||
|
endfo
|
||||||
|
cal filter(bufs, 'filereadable(v:val)')
|
||||||
|
for each in bufs
|
||||||
|
let from_file = readfile(each)
|
||||||
|
cal map(from_file, 'tr(v:val, '' '', '' '')')
|
||||||
|
let [id, len_ff, bufnr] = [1, len(from_file), bufnr(each)]
|
||||||
|
wh id <= len_ff
|
||||||
|
let from_file[id-1] .= ' #:'.bufnr.':'.id
|
||||||
|
let id += 1
|
||||||
|
endw
|
||||||
|
cal filter(from_file, 'v:val !~ ''^\s*\t#:\d\+:\d\+$''')
|
||||||
|
cal extend(lines, from_file)
|
||||||
|
endfo
|
||||||
|
sy match CtrlPTabExtra '\zs\t.*\ze$'
|
||||||
|
hi link CtrlPTabExtra Comment
|
||||||
|
retu lines
|
||||||
|
endf
|
||||||
|
|
||||||
|
fu! ctrlp#line#accept(mode, str)
|
||||||
|
let info = get(split(a:str, '\t#:\ze\d\+:\d\+$'), 1, 0)
|
||||||
|
let bufnr = str2nr(get(split(info, ':'), 0, 0))
|
||||||
|
let linenr = get(split(info, ':'), 1, 0)
|
||||||
|
if bufnr
|
||||||
|
cal ctrlp#acceptfile(a:mode, fnamemodify(bufname(bufnr), ':p'), linenr)
|
||||||
|
en
|
||||||
|
endf
|
||||||
|
|
||||||
|
fu! ctrlp#line#id()
|
||||||
|
retu s:id
|
||||||
|
endf
|
||||||
|
"}}}
|
||||||
|
|
||||||
|
" vim:fen:fdm=marker:fmr={{{,}}}:fdl=0:fdc=1:ts=2:sw=2:sts=2
|
@ -54,8 +54,8 @@ fu! ctrlp#tag#init(tagfiles)
|
|||||||
let alltags = ctrlp#utils#readfile(each)
|
let alltags = ctrlp#utils#readfile(each)
|
||||||
cal extend(g:ctrlp_alltags, alltags)
|
cal extend(g:ctrlp_alltags, alltags)
|
||||||
endfo
|
endfo
|
||||||
sy match CtrlPTagFilename '\zs\t.*\ze$'
|
sy match CtrlPTabExtra '\zs\t.*\ze$'
|
||||||
hi link CtrlPTagFilename Comment
|
hi link CtrlPTabExtra Comment
|
||||||
retu g:ctrlp_alltags
|
retu g:ctrlp_alltags
|
||||||
endf
|
endf
|
||||||
|
|
||||||
@ -64,13 +64,13 @@ fu! ctrlp#tag#accept(mode, str)
|
|||||||
let str = matchstr(a:str, '^[^\t]\+\t\+[^\t]\+\ze\t')
|
let str = matchstr(a:str, '^[^\t]\+\t\+[^\t]\+\ze\t')
|
||||||
let [md, tg] = [a:mode, split(str, '^[^\t]\+\zs\t')[0]]
|
let [md, tg] = [a:mode, split(str, '^[^\t]\+\zs\t')[0]]
|
||||||
let fnd = s:findcount(str)
|
let fnd = s:findcount(str)
|
||||||
if fnd[0] == 1
|
let cmds = {
|
||||||
let cmd = md == 't' ? 'tabe' : md == 'h' ? 'new'
|
\ 't': ['tabe', 'tab stj'],
|
||||||
\ : md == 'v' ? 'vne' : 'ene'
|
\ 'h': ['new', 'stj'],
|
||||||
el
|
\ 'v': ['vne', 'vert stj'],
|
||||||
let cmd = md == 't' ? 'tab stj' : md == 'h' ? 'stj'
|
\ 'e': ['ene', 'tj'],
|
||||||
\ : md == 'v' ? 'vert stj' : 'tj'
|
\ }
|
||||||
en
|
let cmd = fnd[0] == 1 ? cmds[md][0] : cmds[md][1]
|
||||||
let cmd = cmd =~ 'tj\|ene' && &modified ? 'hid '.cmd : cmd
|
let cmd = cmd =~ 'tj\|ene' && &modified ? 'hid '.cmd : cmd
|
||||||
try
|
try
|
||||||
if fnd[0] == 1
|
if fnd[0] == 1
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
*ctrlp.txt* Fuzzy file, buffer and MRU file finder. v1.6.3
|
*ctrlp.txt* Fuzzy file, buffer, mru and tag finder. v1.6.4
|
||||||
*CtrlP* *ControlP* *'ctrlp'* *'ctrl-p'*
|
*CtrlP* *ControlP* *'ctrlp'* *'ctrl-p'*
|
||||||
===============================================================================
|
===============================================================================
|
||||||
# #
|
# #
|
||||||
@ -151,6 +151,13 @@ only need to keep the lines that you’ve changed the values (inside []): >
|
|||||||
\ 'PrtExit()': ['<esc>', '<c-c>', '<c-g>'],
|
\ 'PrtExit()': ['<esc>', '<c-c>', '<c-g>'],
|
||||||
\ }
|
\ }
|
||||||
<
|
<
|
||||||
|
If you have problem with <bs> moving left instead of deleting a char, add this
|
||||||
|
to your |vimrc|: >
|
||||||
|
let g:ctrlp_prompt_mappings = {
|
||||||
|
\ 'PrtBS()': ['<c-h>'],
|
||||||
|
\ 'PrtCurLeft()': ['<left>'],
|
||||||
|
\ }
|
||||||
|
<
|
||||||
|
|
||||||
*'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: >
|
||||||
@ -445,7 +452,7 @@ Once inside the prompt:~
|
|||||||
<c-g>
|
<c-g>
|
||||||
Exit |CtrlP|. <c-c> can also be used to stop the file scan.
|
Exit |CtrlP|. <c-c> can also be used to stop the file scan.
|
||||||
|
|
||||||
Chose your own mappings with |g:ctrlp_prompt_mappings|.
|
Choose your own mappings with |g:ctrlp_prompt_mappings|.
|
||||||
|
|
||||||
When inside the match window (press <tab> to switch):~
|
When inside the match window (press <tab> to switch):~
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
" =============================================================================
|
" =============================================================================
|
||||||
" File: plugin/ctrlp.vim
|
" File: plugin/ctrlp.vim
|
||||||
" Description: Fuzzy file, buffer and MRU file finder.
|
" Description: Fuzzy file, buffer, mru and tag finder.
|
||||||
" Author: Kien Nguyen <github.com/kien>
|
" Author: Kien Nguyen <github.com/kien>
|
||||||
" =============================================================================
|
" =============================================================================
|
||||||
" GetLatestVimScripts: 3736 1 :AutoInstall: ctrlp.zip
|
" GetLatestVimScripts: 3736 1 :AutoInstall: ctrlp.zip
|
||||||
|
Loading…
x
Reference in New Issue
Block a user