<c-n>, <c-p> next/prev string in prompt's history

This commit is contained in:
Kien N 2011-09-29 19:15:33 +07:00
parent 32854b4056
commit 0158e6406a
2 changed files with 102 additions and 23 deletions

View File

@ -22,7 +22,7 @@ func! s:opts()
endif endif
if !exists('g:ctrlp_persistent_input') if !exists('g:ctrlp_persistent_input')
let s:pinput = 1 let s:pinput = 0
else else
let s:pinput = g:ctrlp_persistent_input let s:pinput = g:ctrlp_persistent_input
unl g:ctrlp_persistent_input unl g:ctrlp_persistent_input
@ -157,6 +157,13 @@ func! s:opts()
let s:newfop = g:ctrlp_open_new_file let s:newfop = g:ctrlp_open_new_file
unl g:ctrlp_open_new_file unl g:ctrlp_open_new_file
endif endif
if !exists('g:ctrlp_max_history')
let s:maxhst = exists('+hi') ? &hi : 20
else
let s:maxhst = g:ctrlp_max_history
unl g:ctrlp_max_history
endif
endfunc endfunc
cal s:opts() cal s:opts()
@ -397,6 +404,8 @@ func! s:BufOpen(...) "{{{
endif endif
unl! s:focus unl! s:focus
unl! s:firstinit unl! s:firstinit
unl! s:hisidx
unl! s:hstgot
let g:ctrlp_lines = [] let g:ctrlp_lines = []
let g:ctrlp_allfiles = [] let g:ctrlp_allfiles = []
exe s:currwin.'winc w' exe s:currwin.'winc w'
@ -423,8 +432,8 @@ func! s:BufOpen(...) "{{{
if !exists('g:CtrlP_prompt') || !s:pinput if !exists('g:CtrlP_prompt') || !s:pinput
let g:CtrlP_prompt = ['', '', ''] let g:CtrlP_prompt = ['', '', '']
endif endif
if !exists('g:ctrlp_history') if !exists('s:ctrlp_history')
let g:ctrlp_history = [''] let s:ctrlp_history = filereadable(s:gethistloc()[1]) ? s:gethistdata() : ['']
endif endif
se magic se magic
se to se to
@ -542,7 +551,9 @@ func! s:CreateNewFile() "{{{
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]
let arr = split(str, '[\/]') let arr = split(str, '[\/]')
cal map(arr, 'escape(v:val, "%#")')
let fname = remove(arr, -1) let fname = remove(arr, -1)
cal s:recordhist(str)
winc c winc c
if s:newfop == 1 " In new tab if s:newfop == 1 " In new tab
tabnew tabnew
@ -561,16 +572,19 @@ func! s:CreateNewFile() "{{{
else else
exe 'bo '.cmd.' '.fname exe 'bo '.cmd.' '.fname
endif endif
cal s:insertcache(str)
endfunc "}}} endfunc "}}}
" * Prt Actions {{{ " * Prt Actions {{{
func! s:PrtClear() func! s:PrtClear()
let s:nomatches = 1 let s:nomatches = 1
unl! s:hstgot
let g:CtrlP_prompt = ['','',''] let g:CtrlP_prompt = ['','','']
cal s:BuildPrompt() cal s:BuildPrompt()
endfunc endfunc
func! s:PrtAdd(char) func! s:PrtAdd(char)
unl! s:hstgot
let prt = g:CtrlP_prompt let prt = g:CtrlP_prompt
let prt[0] = prt[0] . a:char let prt[0] = prt[0] . a:char
cal s:BuildPrompt() cal s:BuildPrompt()
@ -578,6 +592,7 @@ endfunc
func! s:PrtBS() func! s:PrtBS()
let s:nomatches = 1 let s:nomatches = 1
unl! s:hstgot
let prt = g:CtrlP_prompt let prt = g:CtrlP_prompt
let prt[0] = strpart(prt[0], -1, strlen(prt[0])) let prt[0] = strpart(prt[0], -1, strlen(prt[0]))
cal s:BuildPrompt() cal s:BuildPrompt()
@ -585,6 +600,7 @@ endfunc
func! s:PrtDelete() func! s:PrtDelete()
let s:nomatches = 1 let s:nomatches = 1
unl! s:hstgot
let prt = g:CtrlP_prompt let prt = g:CtrlP_prompt
let prt[1] = strpart(prt[2], 0, 1) let prt[1] = strpart(prt[2], 0, 1)
let prt[2] = strpart(prt[2], 1) let prt[2] = strpart(prt[2], 1)
@ -627,6 +643,7 @@ endfunc
func! s:PrtDeleteWord() func! s:PrtDeleteWord()
let s:nomatches = 1 let s:nomatches = 1
unl! s:hstgot
let prt = g:CtrlP_prompt let prt = g:CtrlP_prompt
let str = prt[0] let str = prt[0]
if match(str, '\W\w\+$') >= 0 if match(str, '\W\w\+$') >= 0
@ -683,13 +700,14 @@ endfunc
func! s:PrtHistory(...) func! s:PrtHistory(...)
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]
let g:ctrlp_history[0] = str let hst = s:ctrlp_history
let hislen = len(g:ctrlp_history) let hst[0] = exists('s:hstgot') ? hst[0] : str
let s:hisidx = exists('s:hisidx') ? s:hisidx + a:1 : a:1 let hslen = len(hst)
let s:hisidx = s:hisidx < 0 ? 0 : s:hisidx >= hislen ? hislen - 1 : s:hisidx let idx = exists('s:hisidx') ? s:hisidx + a:1 : a:1
let prt[0] = g:ctrlp_history[s:hisidx] let idx = idx < 0 ? 0 : idx >= hslen ? hslen > 1 ? hslen - 1 : 0 : idx
let prt[1] = '' let g:CtrlP_prompt = [hst[idx], '', '']
let prt[2] = '' let s:hisidx = idx
let s:hstgot = 1
cal s:BuildPrompt() cal s:BuildPrompt()
endfunc endfunc
"}}} "}}}
@ -879,7 +897,7 @@ func! s:AcceptSelection(mode,...) "{{{
" Manually remove the prompt and match window " Manually remove the prompt and match window
if !has('autocmd') | cal s:BufOpen('ControlP', 'del') | endif if !has('autocmd') | cal s:BufOpen('ControlP', 'del') | endif
" Record the input string " Record the input string
cal extend(g:ctrlp_history, [str], 1) cal s:recordhist(str)
" Split the mode string if it's longer than 1 char " Split the mode string if it's longer than 1 char
if len(md) > 1 if len(md) > 1
let mds = split(md, '\zs') let mds = split(md, '\zs')
@ -920,7 +938,7 @@ func! s:AcceptSelection(mode,...) "{{{
if s:normbuf() if s:normbuf()
exe s:normbuf().'winc w' exe s:normbuf().'winc w'
endif endif
let efilpath = escape(filpath, '%#') let filpath = escape(filpath, '%#')
if bufnum > 0 if bufnum > 0
if exists('buftabwinnr') " In a tab if exists('buftabwinnr') " In a tab
exe 'norm!' buftabnr.'gt' exe 'norm!' buftabnr.'gt'
@ -929,9 +947,9 @@ func! s:AcceptSelection(mode,...) "{{{
exe bufwinnr.'winc w' exe bufwinnr.'winc w'
else else
if !s:normbuf() if !s:normbuf()
exe 'bo vne' efilpath exe 'bo vne' filpath
else else
exe 'bo '.cmd.' '.efilpath exe 'bo '.cmd.' '.filpath
endif endif
endif endif
else else
@ -940,7 +958,7 @@ func! s:AcceptSelection(mode,...) "{{{
exe pref 'vne' exe pref 'vne'
let pref = '' let pref = ''
endif | endif endif | endif
exe 'bo '.cmd.' '.efilpath exe 'bo '.cmd.' '.filpath
endif endif
" Jump to line " Jump to line
if exists('s:jmpln') && !empty('s:jmpln') if exists('s:jmpln') && !empty('s:jmpln')
@ -1093,6 +1111,27 @@ func! s:highlight(pat, grp)
endfunc endfunc
"}}} "}}}
" Prompt history {{{
func! s:gethistloc()
let cache_dir = ctrlp#utils#cachedir().ctrlp#utils#lash().'hist'
let cache_file = cache_dir.ctrlp#utils#lash().'cache.txt'
retu [cache_dir, cache_file]
endfunc
func! s:gethistdata()
retu ctrlp#utils#readfile(s:gethistloc()[1])
endfunc
func! s:recordhist(str)
if empty(a:str) | retu | endif
let hst = s:ctrlp_history
cal extend(hst, [a:str], 1)
if len(hst) > s:maxhst
cal remove(hst, s:maxhst, -1)
endif
endfunc
"}}}
" Misc {{{ " Misc {{{
func! s:walker(max, pos, dir, ...) func! s:walker(max, pos, dir, ...)
if a:dir == 1 if a:dir == 1
@ -1123,6 +1162,31 @@ func! s:normbuf()
endfor endfor
retu 0 retu 0
endfunc endfunc
func! s:leavepre()
if s:cconex | cal ctrlp#clearallcaches() | endif
cal ctrlp#utils#writecache(s:ctrlp_history, s:gethistloc()[0], s:gethistloc()[1])
endfunc
func! s:insertcache(str)
let cache_file = ctrlp#utils#cachefile()
if filereadable(cache_file)
let data = readfile(cache_file)
if strlen(a:str) <= strlen(data[0])
let pos = 0
else
let strlen = abs((strlen(a:str) - strlen(data[0])) * 100000)
let fullen = abs(strlen(data[-1]) - strlen(data[0]))
let posi = string(len(data) * strlen / fullen)
let floatpos = stridx(posi, '.')
let posi = substitute(posi, '\.', '', 'g')
let posi = join(insert(split(posi, '\zs'), '.', floatpos - 5), '')
let pos = float2nr(round(str2float(posi)))
endif
cal insert(data, a:str, pos)
cal writefile(data, cache_file)
endif
endfunc
"}}} "}}}
"}}} "}}}
@ -1130,7 +1194,7 @@ if has('autocmd') "{{{
aug CtrlPAug aug CtrlPAug
au! au!
au WinLeave,BufLeave ControlP cal s:BufOpen('ControlP', 'del') au WinLeave,BufLeave ControlP cal s:BufOpen('ControlP', 'del')
au VimLeavePre * if s:cconex | cal ctrlp#clearallcaches() | endif au VimLeavePre * cal s:leavepre()
aug END aug END
endif "}}} endif "}}}

View File

@ -60,7 +60,7 @@ Remember the last input string:
2 - Also remember the position of the selection in the match window. 2 - Also remember the position of the selection in the match window.
0 - Clear the input field each time CtrlP starts. 0 - Clear the input field each time CtrlP starts.
> >
let g:ctrlp_persistent_input = 1 let g:ctrlp_persistent_input = 0
< <
*'g:ctrlp_match_window_reversed'* *'g:ctrlp_match_window_reversed'*
@ -142,8 +142,10 @@ only need to keep the lines that youve changed the values (inside []): >
\ 'PrtDelete()': ['<del>'], \ 'PrtDelete()': ['<del>'],
\ 'PrtDeleteWord()': ['<c-w>'], \ 'PrtDeleteWord()': ['<c-w>'],
\ 'PrtClear()': ['<c-u>'], \ 'PrtClear()': ['<c-u>'],
\ 'PrtSelectMove("j")': ['<c-n>', '<c-j>', '<down>'], \ 'PrtSelectMove("j")': ['<c-j>', '<down>'],
\ 'PrtSelectMove("k")': ['<c-p>', '<c-k>', '<up>'], \ 'PrtSelectMove("k")': ['<c-k>', '<up>'],
\ 'PrtHistory(-1)': ['<c-n>'],
\ 'PrtHistory(1)': ['<c-p>'],
\ 'AcceptSelection("e")': ['<cr>'], \ 'AcceptSelection("e")': ['<cr>'],
\ 'AcceptSelection("h")': ['<c-cr>', '<c-s>', '<c-x>'], \ 'AcceptSelection("h")': ['<c-cr>', '<c-s>', '<c-x>'],
\ 'AcceptSelection("t")': ['<c-t>'], \ 'AcceptSelection("t")': ['<c-t>'],
@ -159,6 +161,7 @@ only need to keep the lines that youve changed the values (inside []): >
\ 'PrtCurLeft()': ['<c-h>', '<left>'], \ 'PrtCurLeft()': ['<c-h>', '<left>'],
\ 'PrtCurRight()': ['<c-l>', '<right>'], \ 'PrtCurRight()': ['<c-l>', '<right>'],
\ 'PrtClearCache()': ['<F5>'], \ 'PrtClearCache()': ['<F5>'],
\ 'CreateNewFile()': ['<c-y>'],
\ 'BufOpen("ControlP", "del")': ['<esc>', '<c-c>', '<c-g>'], \ 'BufOpen("ControlP", "del")': ['<esc>', '<c-c>', '<c-g>'],
\ } \ }
< <
@ -254,6 +257,12 @@ pressing <c-y>:
let g:ctrlp_open_new_file = 3 let g:ctrlp_open_new_file = 3
< <
*'g:ctrlp_max_history'*
The maximum number of input strings you want |CtrlP| to remember. The default
values taken from Vims global |'history'| option. E.g. `set history=50`: >
let g:ctrlp_max_history = &history
<
=============================================================================== ===============================================================================
3. Commands *ctrlp-commands* 3. Commands *ctrlp-commands*
@ -336,12 +345,10 @@ Once inside the prompt:
Force update the match window. Force update the match window.
Use this if |g:ctrlp_live_update| has been set to 0. Use this if |g:ctrlp_live_update| has been set to 0.
<c-n>,
<c-j>, <c-j>,
<down> <down>
Move selection down Move selection down
<c-p>,
<c-k>, <c-k>,
<up> <up>
Move selection up Move selection up
@ -383,6 +390,12 @@ Once inside the prompt:
<c-y> <c-y>
Create a new file and its parent directories. Create a new file and its parent directories.
<c-n>
'Next' string in the prompts history (of accepted input strings)
<c-p>
'Previous' string in the prompts history
<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.
@ -442,8 +455,10 @@ Mercurial repository: https://bitbucket.org/kien/ctrlp.vim
=============================================================================== ===============================================================================
CHANGELOG CHANGELOG
+ New mapping: <c-y> create new file and its parent dirs. + New mappings: <c-y> create new file and its parent dirs.
+ New option: |g:ctrlp_open_new_file| <c-n>, <c-p> next/prev string in the input history.
+ New options: |g:ctrlp_open_new_file|,
|g:ctrlp_max_history|
+ Added a new open-in-horizontal-split mapping: <c-x> + Added a new open-in-horizontal-split mapping: <c-x>
Before 2011/09/19 Before 2011/09/19