Option to :lcd into the selected file's directory

The problem: sometimes I want to open a few files in a directory that hasn't
been bookmarked, but I opened a different file in the same directory sometime
earlier and the file can be found in the MRU list.
This commit is contained in:
Kien N 2012-08-30 10:38:20 +07:00
parent 8d50e9fb6e
commit b50b5a6806
2 changed files with 58 additions and 19 deletions

View File

@ -906,7 +906,7 @@ fu! s:AcceptSelection(mode)
let str = join(s:prompt, '') let str = join(s:prompt, '')
if a:mode == 'e' | if s:SpecInputs(str) | retu | en | en if a:mode == 'e' | if s:SpecInputs(str) | retu | en | en
" Get the selected line " Get the selected line
let line = !empty(s:lines) ? s:lines[line('.') - 1] : '' let line = ctrlp#getcline()
if a:mode != 'e' && !s:itemtype && line == '' if a:mode != 'e' && !s:itemtype && line == ''
\ && str !~ '\v^(\.\.([\/]\.\.)*[\/]?[.\/]*|/|\\|\?|\@.+)$' \ && str !~ '\v^(\.\.([\/]\.\.)*[\/]?[.\/]*|/|\\|\?|\@.+)$'
cal s:CreateNewFile(a:mode) | retu cal s:CreateNewFile(a:mode) | retu
@ -958,7 +958,7 @@ fu! s:MarkToOpen()
\ || ( s:itemtype > 2 && s:getextvar('opmul') != 1 ) \ || ( s:itemtype > 2 && s:getextvar('opmul') != 1 )
retu retu
en en
let line = !empty(s:lines) ? s:lines[line('.') - 1] : '' let line = ctrlp#getcline()
if empty(line) | retu | en if empty(line) | retu | en
let filpath = s:ispath ? fnamemodify(line, ':p') : line let filpath = s:ispath ? fnamemodify(line, ':p') : line
if exists('s:marked') && s:dictindex(s:marked, filpath) > 0 if exists('s:marked') && s:dictindex(s:marked, filpath) > 0
@ -997,7 +997,7 @@ fu! s:OpenMulti(...)
let md = a:0 ? a:1 : ( md == '' ? 'v' : md ) let md = a:0 ? a:1 : ( md == '' ? 'v' : md )
let nopt = exists('g:ctrlp_open_multiple_files') let nopt = exists('g:ctrlp_open_multiple_files')
if !has_marked if !has_marked
let line = !empty(s:lines) ? s:lines[line('.') - 1] : '' let line = ctrlp#getcline()
if line == '' | retu | en if line == '' | retu | en
let marked = { 1 : fnamemodify(line, ':p') } let marked = { 1 : fnamemodify(line, ':p') }
let [nr, ur, jf, nopt] = ['1', 0, 0, 1] let [nr, ur, jf, nopt] = ['1', 0, 0, 1]
@ -1008,16 +1008,8 @@ fu! s:OpenMulti(...)
cal s:unmarksigns() cal s:unmarksigns()
unl! s:marked unl! s:marked
cal s:BuildPrompt(0) cal s:BuildPrompt(0)
elsei !has_marked && md == 'a' elsei !has_marked && md =~ '[axd]'
let [s:marked, key] = [{}, 1] retu s:OpenNoMarks(md, line)
for line in s:lines
let s:marked = extend(s:marked, { key : fnamemodify(line, ':p') })
let key += 1
endfo
cal s:remarksigns()
retu s:BuildPrompt(0)
elsei !has_marked && md == 'x'
retu call(s:openfunc[s:ctype], [md, line])
en en
if md =~ '\v^c(ancel)?$' | retu | en if md =~ '\v^c(ancel)?$' | retu | en
let nr = nr == '0' ? ( nopt ? '' : '1' ) : nr let nr = nr == '0' ? ( nopt ? '' : '1' ) : nr
@ -1077,6 +1069,28 @@ fu! s:OpenMulti(...)
let &swb = swb let &swb = swb
unl! s:tabct unl! s:tabct
endf endf
fu! s:OpenNoMarks(md, line)
if a:md == 'a'
let [s:marked, key] = [{}, 1]
for line in s:lines
let s:marked = extend(s:marked, { key : fnamemodify(line, ':p') })
let key += 1
endfo
cal s:remarksigns()
cal s:BuildPrompt(0)
elsei a:md == 'x'
cal call(s:openfunc[s:ctype], [a:md, a:line])
elsei a:md == 'd'
let dir = fnamemodify(a:line, ':h')
if isdirectory(dir)
cal ctrlp#setdir(dir)
cal ctrlp#switchtype(0)
cal ctrlp#recordhist()
cal s:PrtClear()
en
en
endf
" ** Helper functions {{{1 " ** Helper functions {{{1
" Sorting {{{2 " Sorting {{{2
fu! ctrlp#complen(...) fu! ctrlp#complen(...)
@ -1578,11 +1592,17 @@ fu! s:argmaps(md, i)
let roh = [ let roh = [
\ ['Open Multiple Files', '/h[i]dden/[c]lear', ['i', 'c']], \ ['Open Multiple Files', '/h[i]dden/[c]lear', ['i', 'c']],
\ ['Create a New File', '/[r]eplace', ['r']], \ ['Create a New File', '/[r]eplace', ['r']],
\ ['Open Selected', '/[r]eplace/h[i]dden? Mark [a]ll', ['r', 'i', 'a']], \ ['Open Selected', '/[r]eplace', ['r', 'd', 'a']],
\ ] \ ]
if a:i == 2 && s:openfunc != {} && has_key(s:openfunc, s:ctype) if a:i == 2
let roh[2][1] = '/[r]eplace/h[i]dden/e[x]ternal? Mark [a]ll' if !buflisted(bufnr('^'.fnamemodify(ctrlp#getcline(), ':p').'$'))
let roh[2][2] = ['r', 'i', 'x', 'a'] let roh[2][1] .= '/h[i]dden'
let roh[2][2] += ['i']
en
if s:openfunc != {} && has_key(s:openfunc, s:ctype)
let roh[2][1] .= '/e[x]ternal'
let roh[2][2] += ['x']
en
en en
let str = roh[a:i][0].': [t]ab/[v]ertical/[h]orizontal'.roh[a:i][1].'? ' let str = roh[a:i][0].': [t]ab/[v]ertical/[h]orizontal'.roh[a:i][1].'? '
retu s:choices(str, ['t', 'v', 'h'] + roh[a:i][2], 's:argmaps', [a:md, a:i]) retu s:choices(str, ['t', 'v', 'h'] + roh[a:i][2], 's:argmaps', [a:md, a:i])
@ -1685,7 +1705,7 @@ fu! s:regexfilter(str)
endf endf
fu! s:walker(m, p, d) fu! s:walker(m, p, d)
retu a:d > 0 ? a:p < a:m ? a:p + a:d : 0 : a:p > 0 ? a:p + a:d : a:m retu a:d >= 0 ? a:p < a:m ? a:p + a:d : 0 : a:p > 0 ? a:p + a:d : a:m
endf endf
fu! s:delent(rfunc) fu! s:delent(rfunc)
@ -1892,6 +1912,10 @@ fu! s:getextvar(key)
retu -1 retu -1
endf endf
fu! ctrlp#getcline()
retu !empty(s:lines) ? s:lines[line('.') - 1] : ''
endf
fu! ctrlp#exit() fu! ctrlp#exit()
cal s:PrtExit() cal s:PrtExit()
endf endf

View File

@ -799,7 +799,22 @@ Opening multiple files:~
- Mark/unmark a file to create a new file in its directory using <c-y>. - Mark/unmark a file to create a new file in its directory using <c-y>.
<c-o> <c-o>
Open files marked by <c-z>. - Open files marked by <c-z>.
- When no file has been marked by <c-z>, open a console dialog with the
following options:
Open the selected file:
t - in a tab page.
v - in a vertical split.
h - in a horizontal split.
r - in the current window.
i - as a hidden buffer.
x - (optional) with the function defined in |g:ctrlp_open_func|.
Other options (not shown):
a - mark all files in the match window.
d - change CtrlP's local working directory to the selected file's
directory and switch to find file mode.
Function keys:~ Function keys:~