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:
parent
8d50e9fb6e
commit
b50b5a6806
@ -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
|
||||||
|
@ -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:~
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user