2012-03-13 16:20:56 +07:00
|
|
|
|
*ctrlp.txt* Fuzzy file, buffer, mru and tag finder. v1.7.3
|
2011-08-22 09:14:00 +07:00
|
|
|
|
*CtrlP* *ControlP* *'ctrlp'* *'ctrl-p'*
|
|
|
|
|
===============================================================================
|
|
|
|
|
# #
|
|
|
|
|
# :::::::: ::::::::::: ::::::::: ::: ::::::::: #
|
|
|
|
|
# :+: :+: :+: :+: :+: :+: :+: :+: #
|
|
|
|
|
# +:+ +:+ +:+ +:+ +:+ +:+ +:+ #
|
|
|
|
|
# +#+ +#+ +#++:++#: +#+ +#++:++#+ #
|
|
|
|
|
# +#+ +#+ +#+ +#+ +#+ +#+ #
|
|
|
|
|
# #+# #+# #+# #+# #+# #+# #+# #
|
|
|
|
|
# ######## ### ### ### ########## ### #
|
|
|
|
|
# #
|
|
|
|
|
===============================================================================
|
|
|
|
|
CONTENTS *ctrlp-contents*
|
|
|
|
|
|
2011-11-03 06:09:12 +07:00
|
|
|
|
1. Intro........................................|ctrlp-intro|
|
|
|
|
|
2. Options......................................|ctrlp-options|
|
|
|
|
|
3. Commands.....................................|ctrlp-commands|
|
|
|
|
|
4. Mappings.....................................|ctrlp-mappings|
|
|
|
|
|
5. Input Formats................................|ctrlp-input-formats|
|
2011-11-28 19:52:28 +07:00
|
|
|
|
6. Extensions...................................|ctrlp-extensions|
|
2011-11-03 06:09:12 +07:00
|
|
|
|
|
2011-08-22 09:14:00 +07:00
|
|
|
|
===============================================================================
|
2012-03-01 18:48:03 +07:00
|
|
|
|
INTRO *ctrlp-intro*
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
2011-12-18 09:58:44 +07:00
|
|
|
|
Full path fuzzy file, buffer, mru and tag finder with an intuitive interface.
|
2011-09-07 22:10:52 +07:00
|
|
|
|
Written in pure Vimscript for MacVim and Vim version 7.0+. Has full support for
|
2011-12-18 09:58:44 +07:00
|
|
|
|
Vim’s |regexp| as search pattern, built-in MRU files monitoring, project’s root
|
2011-11-04 22:35:26 +07:00
|
|
|
|
finder, and more.
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
2012-01-29 00:29:09 +07:00
|
|
|
|
To enable optional extensions (tag, dir, rtscript...), see |ctrlp-extensions|.
|
2011-11-28 19:52:28 +07:00
|
|
|
|
|
2011-08-22 09:14:00 +07:00
|
|
|
|
===============================================================================
|
2012-03-01 18:48:03 +07:00
|
|
|
|
OPTIONS *ctrlp-options*
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
2011-11-12 22:00:50 +07:00
|
|
|
|
Below are the available options and their default values:~
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
|
|
|
|
*'g:ctrlp_map'*
|
|
|
|
|
Use this option to change the mapping to invoke |CtrlP| in |Normal| mode: >
|
|
|
|
|
let g:ctrlp_map = '<c-p>'
|
|
|
|
|
<
|
|
|
|
|
|
2011-12-18 09:58:44 +07:00
|
|
|
|
*'g:ctrlp_cmd'*
|
|
|
|
|
Set the default opening command to use when pressing the above mapping: >
|
|
|
|
|
let g:ctrlp_cmd = 'CtrlP'
|
|
|
|
|
<
|
|
|
|
|
|
2011-08-22 09:14:00 +07:00
|
|
|
|
*'g:loaded_ctrlp'*
|
2011-12-18 09:58:44 +07:00
|
|
|
|
Use this to disable the plugin completely: >
|
2011-08-22 09:14:00 +07:00
|
|
|
|
let g:loaded_ctrlp = 1
|
|
|
|
|
<
|
|
|
|
|
|
2011-09-11 23:53:32 +07:00
|
|
|
|
*'g:ctrlp_by_filename'*
|
2012-03-01 18:33:35 +07:00
|
|
|
|
Set this to 1 to set searching by filename (not full path) as the default: >
|
2011-09-11 23:53:32 +07:00
|
|
|
|
let g:ctrlp_by_filename = 0
|
|
|
|
|
<
|
2012-03-01 18:33:35 +07:00
|
|
|
|
Can be toggled on/off by pressing <c-d> inside the prompt.
|
2011-09-11 23:53:32 +07:00
|
|
|
|
|
2012-03-01 18:33:35 +07:00
|
|
|
|
*'g:ctrlp_regexp'*
|
2011-11-12 22:00:50 +07:00
|
|
|
|
Set this to 1 to set |regexp| search as the default: >
|
2012-03-01 18:33:35 +07:00
|
|
|
|
let g:ctrlp_regexp = 0
|
2011-09-11 23:53:32 +07:00
|
|
|
|
<
|
2012-03-01 18:33:35 +07:00
|
|
|
|
Can be toggled on/off by pressing <c-r> inside the prompt.
|
2011-09-11 23:53:32 +07:00
|
|
|
|
|
2011-10-09 09:30:16 +07:00
|
|
|
|
*'g:ctrlp_match_window_bottom'*
|
|
|
|
|
Set this to 0 to show the match window at the top of the screen: >
|
|
|
|
|
let g:ctrlp_match_window_bottom = 1
|
|
|
|
|
<
|
|
|
|
|
|
2011-08-22 09:14:00 +07:00
|
|
|
|
*'g:ctrlp_match_window_reversed'*
|
2012-03-01 18:33:35 +07:00
|
|
|
|
Change the listing order of the files in the match window. The default setting
|
|
|
|
|
(1) is from bottom to top: >
|
2011-08-22 09:14:00 +07:00
|
|
|
|
let g:ctrlp_match_window_reversed = 1
|
|
|
|
|
<
|
|
|
|
|
|
2011-10-03 03:04:43 +07:00
|
|
|
|
*'g:ctrlp_max_height'*
|
|
|
|
|
Set the maximum height of the match window: >
|
|
|
|
|
let g:ctrlp_max_height = 10
|
|
|
|
|
<
|
|
|
|
|
|
2012-03-01 18:33:35 +07:00
|
|
|
|
*'g:ctrlp_switch_buffer'*
|
|
|
|
|
When opening a file with <cr> or <c-t>, if the file’s already opened somewhere
|
2012-01-29 00:29:09 +07:00
|
|
|
|
|CtrlP| will try to jump to it instead of opening a new instance: >
|
2012-03-01 18:33:35 +07:00
|
|
|
|
let g:ctrlp_switch_buffer = 2
|
2011-10-22 17:19:04 +07:00
|
|
|
|
<
|
2012-01-13 09:13:39 +07:00
|
|
|
|
1 - only jump to the buffer if it’s opened in the current tab.
|
2012-03-01 18:33:35 +07:00
|
|
|
|
2 - jump tab as well if the buffer’s opened in another tab.
|
2012-01-13 09:13:39 +07:00
|
|
|
|
0 - disable this feature.
|
2011-10-22 17:19:04 +07:00
|
|
|
|
|
2012-03-03 22:31:50 +07:00
|
|
|
|
*'g:ctrlp_reuse_window'*
|
|
|
|
|
When opening a file with <cr>, |CtrlP| avoids opening it in windows created by
|
|
|
|
|
plugins, help and quickfix. Use this to setup some exceptions: >
|
|
|
|
|
let g:ctrlp_reuse_window = 'netrw'
|
|
|
|
|
<
|
2012-03-10 06:49:16 +07:00
|
|
|
|
Acceptable values are partial name, filetype or buftype of the special buffers.
|
|
|
|
|
Use |regexp| to specify the pattern.
|
2012-03-03 22:31:50 +07:00
|
|
|
|
Example: >
|
|
|
|
|
let g:ctrlp_reuse_window = 'netrw\|help\|quickfix'
|
|
|
|
|
<
|
|
|
|
|
|
2011-08-22 09:14:00 +07:00
|
|
|
|
*'g:ctrlp_working_path_mode'*
|
2012-01-29 00:29:09 +07:00
|
|
|
|
When starting up, |CtrlP| sets its local working directory according to this
|
|
|
|
|
variable: >
|
|
|
|
|
let g:ctrlp_working_path_mode = 2
|
|
|
|
|
<
|
2011-08-22 09:14:00 +07:00
|
|
|
|
1 - the parent directory of the current file.
|
2012-03-01 18:33:35 +07:00
|
|
|
|
2 - the nearest ancestor that contains one of these directories or files:
|
2012-03-01 18:48:03 +07:00
|
|
|
|
.git/ .hg/ .svn/ .bzr/ _darcs/
|
2011-08-22 09:14:00 +07:00
|
|
|
|
0 - don’t manage working directory.
|
2012-03-01 18:33:35 +07:00
|
|
|
|
Note: you can use b:ctrlp_working_path_mode (a |b:var|) to set this option on a
|
|
|
|
|
per buffer basis.
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
2011-09-06 20:03:31 +07:00
|
|
|
|
*'g:ctrlp_root_markers'*
|
2011-11-12 22:00:50 +07:00
|
|
|
|
Use this to set your own root markers in addition to the default ones. Your
|
|
|
|
|
markers will take precedence: >
|
2011-09-06 20:03:31 +07:00
|
|
|
|
let g:ctrlp_root_markers = ['']
|
|
|
|
|
<
|
2011-11-22 13:38:26 +07:00
|
|
|
|
These markers (builtins and yours) will serve as identifiers for the '/' and
|
2012-03-01 18:48:03 +07:00
|
|
|
|
'\' special inputs (|ctrlp-input-formats| (e)).
|
2011-09-06 20:03:31 +07:00
|
|
|
|
|
2011-09-10 19:51:49 +07:00
|
|
|
|
*'g:ctrlp_use_caching'*
|
2011-09-11 01:54:07 +07:00
|
|
|
|
Set this to 0 to disable per-session caching. When disabled, caching will still
|
|
|
|
|
be enabled for directories that have more than 4000 files: >
|
2011-09-10 19:51:49 +07:00
|
|
|
|
let g:ctrlp_use_caching = 1
|
|
|
|
|
<
|
2011-10-23 17:38:03 +07:00
|
|
|
|
Note: you can quickly purge the cache by pressing <F5> while inside |CtrlP|.
|
2011-09-11 01:54:07 +07:00
|
|
|
|
|
|
|
|
|
*'g:ctrlp_clear_cache_on_exit'*
|
2012-01-29 00:29:09 +07:00
|
|
|
|
Set this to 0 to enable cross-session caching by not deleting the cache files
|
2012-01-10 05:58:59 +07:00
|
|
|
|
upon exiting Vim: >
|
2011-09-11 01:54:07 +07:00
|
|
|
|
let g:ctrlp_clear_cache_on_exit = 1
|
|
|
|
|
<
|
2011-09-10 19:51:49 +07:00
|
|
|
|
|
2011-08-22 09:14:00 +07:00
|
|
|
|
*'g:ctrlp_cache_dir'*
|
2011-11-14 13:58:09 +07:00
|
|
|
|
Set the directory to store the cache files: >
|
2012-01-22 22:51:08 +07:00
|
|
|
|
let g:ctrlp_cache_dir = $HOME.'/.cache/ctrlp'
|
2011-08-22 09:14:00 +07:00
|
|
|
|
<
|
|
|
|
|
|
|
|
|
|
*'g:ctrlp_prompt_mappings'*
|
|
|
|
|
Use this to customize the mappings inside |CtrlP|’s prompt to your liking. You
|
|
|
|
|
only need to keep the lines that you’ve changed the values (inside []): >
|
|
|
|
|
let g:ctrlp_prompt_mappings = {
|
2012-01-06 13:22:55 +07:00
|
|
|
|
\ 'PrtBS()': ['<bs>', '<c-]>'],
|
2011-10-07 21:10:14 +07:00
|
|
|
|
\ 'PrtDelete()': ['<del>'],
|
|
|
|
|
\ 'PrtDeleteWord()': ['<c-w>'],
|
|
|
|
|
\ 'PrtClear()': ['<c-u>'],
|
|
|
|
|
\ 'PrtSelectMove("j")': ['<c-j>', '<down>'],
|
|
|
|
|
\ 'PrtSelectMove("k")': ['<c-k>', '<up>'],
|
|
|
|
|
\ 'PrtHistory(-1)': ['<c-n>'],
|
|
|
|
|
\ 'PrtHistory(1)': ['<c-p>'],
|
2012-01-30 23:03:30 +07:00
|
|
|
|
\ 'AcceptSelection("e")': ['<cr>', '<2-LeftMouse>'],
|
2011-10-07 21:10:14 +07:00
|
|
|
|
\ 'AcceptSelection("h")': ['<c-x>', '<c-cr>', '<c-s>'],
|
2011-11-12 22:00:50 +07:00
|
|
|
|
\ 'AcceptSelection("t")': ['<c-t>', '<MiddleMouse>'],
|
2012-01-06 13:22:55 +07:00
|
|
|
|
\ 'AcceptSelection("v")': ['<c-v>', '<RightMouse>'],
|
2012-01-16 20:14:09 +07:00
|
|
|
|
\ 'ToggleFocus()': ['<s-tab>'],
|
2011-10-07 21:10:14 +07:00
|
|
|
|
\ 'ToggleRegex()': ['<c-r>'],
|
|
|
|
|
\ 'ToggleByFname()': ['<c-d>'],
|
2011-12-18 14:20:51 -08:00
|
|
|
|
\ 'ToggleType(1)': ['<c-f>', '<c-up>'],
|
2011-10-07 21:10:14 +07:00
|
|
|
|
\ 'ToggleType(-1)': ['<c-b>', '<c-down>'],
|
2012-01-30 23:03:30 +07:00
|
|
|
|
\ 'PrtExpandDir()': ['<tab>'],
|
2012-01-30 08:54:06 +07:00
|
|
|
|
\ 'PrtInsert("w")': ['<F2>', '<insert>'],
|
2012-01-06 13:22:55 +07:00
|
|
|
|
\ 'PrtInsert("s")': ['<F3>'],
|
|
|
|
|
\ 'PrtInsert("v")': ['<F4>'],
|
|
|
|
|
\ 'PrtInsert("+")': ['<F6>'],
|
2011-10-07 21:10:14 +07:00
|
|
|
|
\ 'PrtCurStart()': ['<c-a>'],
|
|
|
|
|
\ 'PrtCurEnd()': ['<c-e>'],
|
2012-01-06 13:22:55 +07:00
|
|
|
|
\ 'PrtCurLeft()': ['<c-h>', '<left>', '<c-^>'],
|
2011-10-07 21:10:14 +07:00
|
|
|
|
\ 'PrtCurRight()': ['<c-l>', '<right>'],
|
|
|
|
|
\ 'PrtClearCache()': ['<F5>'],
|
2011-11-28 19:52:28 +07:00
|
|
|
|
\ 'PrtDeleteMRU()': ['<F7>'],
|
2011-10-07 21:10:14 +07:00
|
|
|
|
\ 'CreateNewFile()': ['<c-y>'],
|
|
|
|
|
\ 'MarkToOpen()': ['<c-z>'],
|
|
|
|
|
\ 'OpenMulti()': ['<c-o>'],
|
|
|
|
|
\ 'PrtExit()': ['<esc>', '<c-c>', '<c-g>'],
|
2011-08-22 09:14:00 +07:00
|
|
|
|
\ }
|
|
|
|
|
<
|
2012-01-06 13:22:55 +07:00
|
|
|
|
Note: In some terminals, it’s not possible to remap <c-h> without also changing
|
2012-03-16 03:13:12 +07:00
|
|
|
|
<bs> (|keycodes|). So if pressing <bs> moves the cursor to the left instead of
|
|
|
|
|
deleting a char for you, add this to your |.vimrc| to disable the plugin’s
|
|
|
|
|
default <c-h> mapping: >
|
2012-03-12 08:58:01 +07:00
|
|
|
|
let g:ctrlp_prompt_mappings = { 'PrtCurLeft()': ['<left>', '<c-^>'] }
|
2011-12-13 21:42:57 +07:00
|
|
|
|
<
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
2011-09-07 21:41:43 +07:00
|
|
|
|
*'g:ctrlp_mruf_max'*
|
|
|
|
|
Specify the number of recently opened files you want |CtrlP| to remember: >
|
2011-11-28 19:52:28 +07:00
|
|
|
|
let g:ctrlp_mruf_max = 250
|
2011-09-07 21:41:43 +07:00
|
|
|
|
<
|
|
|
|
|
|
|
|
|
|
*'g:ctrlp_mruf_exclude'*
|
2012-01-17 23:13:39 +07:00
|
|
|
|
Files you don’t want |CtrlP| to remember. Use |regexp| to specify the patterns:
|
2011-09-07 21:41:43 +07:00
|
|
|
|
>
|
|
|
|
|
let g:ctrlp_mruf_exclude = ''
|
|
|
|
|
<
|
|
|
|
|
Examples: >
|
|
|
|
|
let g:ctrlp_mruf_exclude = '/tmp/.*\|/temp/.*' " MacOSX/Linux
|
|
|
|
|
let g:ctrlp_mruf_exclude = '^C:\\dev\\tmp\\.*' " Windows
|
|
|
|
|
<
|
|
|
|
|
|
|
|
|
|
*'g:ctrlp_mruf_include'*
|
|
|
|
|
And if you want |CtrlP| to only remember some files, specify them here: >
|
|
|
|
|
let g:ctrlp_mruf_include = ''
|
|
|
|
|
<
|
|
|
|
|
Example: >
|
2011-09-08 04:01:08 +07:00
|
|
|
|
let g:ctrlp_mruf_include = '\.py$\|\.rb$'
|
2011-09-07 21:41:43 +07:00
|
|
|
|
<
|
|
|
|
|
|
2012-01-16 00:42:14 +07:00
|
|
|
|
*'g:ctrlp_mruf_relative'*
|
|
|
|
|
Set this to 1 to show only MRU files in the current working directory: >
|
|
|
|
|
let g:ctrlp_mruf_relative = 0
|
|
|
|
|
<
|
|
|
|
|
|
2011-11-12 22:00:50 +07:00
|
|
|
|
*'g:ctrlp_mruf_case_sensitive'*
|
|
|
|
|
Match this with your file system case-sensitivity setting to avoid duplicate
|
|
|
|
|
MRU entries: >
|
|
|
|
|
let g:ctrlp_mruf_case_sensitive = 1
|
|
|
|
|
<
|
|
|
|
|
|
2012-01-17 23:13:39 +07:00
|
|
|
|
*'g:ctrlp_mruf_last_entered'*
|
|
|
|
|
Set to 1 to sort the MRU file list to most-recently-entered-buffer order: >
|
|
|
|
|
let g:ctrlp_mruf_last_entered = 0
|
|
|
|
|
<
|
|
|
|
|
|
2011-09-10 07:32:08 +07:00
|
|
|
|
*'g:ctrlp_dotfiles'*
|
2012-02-24 01:19:44 +07:00
|
|
|
|
Set this to 0 if you don’t want |CtrlP| to scan for dotfiles and dotdirs: >
|
2011-09-10 07:32:08 +07:00
|
|
|
|
let g:ctrlp_dotfiles = 1
|
|
|
|
|
<
|
2011-12-18 09:58:44 +07:00
|
|
|
|
You can use |'wildignore'| to exclude anything from the search.
|
2012-01-29 00:29:09 +07:00
|
|
|
|
Examples: >
|
|
|
|
|
" Excluding version control directories
|
2011-09-14 00:17:20 +07:00
|
|
|
|
set wildignore+=*/.git/*,*/.hg/*,*/.svn/* " Linux/MacOSX
|
|
|
|
|
set wildignore+=.git\*,.hg\*,.svn\* " Windows
|
2011-09-12 05:49:42 +07:00
|
|
|
|
<
|
2012-01-13 09:13:39 +07:00
|
|
|
|
Note #1: the `*/` in front of each directory glob is required.
|
2011-09-10 07:32:08 +07:00
|
|
|
|
|
2012-01-06 13:22:55 +07:00
|
|
|
|
Note #2: |wildignore| influences the result of |expand()|, |globpath()| and
|
2012-03-03 22:31:50 +07:00
|
|
|
|
|glob()| which many plugins use to find stuff on the system (e.g. VCS related
|
|
|
|
|
plugins look for .git/, .hg/,... some other plugins look for external *.exe
|
|
|
|
|
tools on Windows). So be a little mindful of what you put in your |wildignore|.
|
2011-10-20 03:58:28 +07:00
|
|
|
|
|
2011-12-18 09:58:44 +07:00
|
|
|
|
*'g:ctrlp_custom_ignore'*
|
|
|
|
|
In addition to |'wildignore'|, use this for files and directories you want only
|
2012-01-06 13:22:55 +07:00
|
|
|
|
|CtrlP| to not show. Use |regexp| to specify the patterns: >
|
2011-12-18 09:58:44 +07:00
|
|
|
|
let g:ctrlp_custom_ignore = ''
|
|
|
|
|
<
|
2012-01-06 13:22:55 +07:00
|
|
|
|
Examples: >
|
|
|
|
|
let g:ctrlp_custom_ignore = '\.git$\|\.hg$\|\.svn$'
|
|
|
|
|
let g:ctrlp_custom_ignore = {
|
|
|
|
|
\ 'dir': '\.git$\|\.hg$\|\.svn$',
|
|
|
|
|
\ 'file': '\.exe$\|\.so$\|\.dll$',
|
2012-01-30 08:54:06 +07:00
|
|
|
|
\ 'link': 'SOME_BAD_SYMBOLIC_LINKS',
|
2012-01-06 13:22:55 +07:00
|
|
|
|
\ }
|
2012-01-17 23:13:39 +07:00
|
|
|
|
<
|
2011-12-18 09:58:44 +07:00
|
|
|
|
|
2011-09-14 21:38:37 +07:00
|
|
|
|
*'g:ctrlp_max_files'*
|
|
|
|
|
The maximum number of files to scan, set to 0 for no limit: >
|
2012-01-30 23:03:30 +07:00
|
|
|
|
let g:ctrlp_max_files = 10000
|
2011-09-14 21:38:37 +07:00
|
|
|
|
<
|
|
|
|
|
|
2011-09-18 18:33:37 +07:00
|
|
|
|
*'g:ctrlp_max_depth'*
|
|
|
|
|
The maximum depth of a directory tree to recurse into: >
|
|
|
|
|
let g:ctrlp_max_depth = 40
|
|
|
|
|
<
|
2011-11-03 06:09:12 +07:00
|
|
|
|
Note: the larger these values, the more memory Vim uses.
|
2011-09-18 18:33:37 +07:00
|
|
|
|
|
2011-09-11 23:53:32 +07:00
|
|
|
|
*'g:ctrlp_user_command'*
|
2012-01-29 00:29:09 +07:00
|
|
|
|
Specify an external tool to use for listing files instead of using Vim’s
|
|
|
|
|
|globpath()|. Use %s in place of the target directory: >
|
2011-09-11 23:53:32 +07:00
|
|
|
|
let g:ctrlp_user_command = ''
|
|
|
|
|
<
|
|
|
|
|
Examples: >
|
2011-09-12 04:26:18 +07:00
|
|
|
|
let g:ctrlp_user_command = 'find %s -type f' " MacOSX/Linux
|
|
|
|
|
let g:ctrlp_user_command = 'dir %s /-n /b /s /a-d' " Windows
|
|
|
|
|
<
|
|
|
|
|
You can also use 'grep', 'findstr' or something else to filter the results.
|
|
|
|
|
Examples: >
|
|
|
|
|
let g:ctrlp_user_command = 'find %s -type f | grep (?!tmp/.*)'
|
|
|
|
|
let g:ctrlp_user_command = 'dir %s /-n /b /s /a-d | findstr .*\.py$'
|
2011-09-11 23:53:32 +07:00
|
|
|
|
<
|
2012-01-13 09:13:39 +07:00
|
|
|
|
Use a version control listing command when inside a repository, this is faster
|
|
|
|
|
when scanning large projects: >
|
2012-01-30 08:54:06 +07:00
|
|
|
|
let g:ctrlp_user_command = [root_marker, listing_command, fallback_command]
|
|
|
|
|
let g:ctrlp_user_command = {
|
|
|
|
|
\ 'types': {
|
|
|
|
|
\ 1: [root_marker_1, listing_command_1],
|
|
|
|
|
\ n: [root_marker_n, listing_command_n],
|
|
|
|
|
\ },
|
|
|
|
|
\ 'fallback': fallback_command
|
|
|
|
|
\ }
|
2011-10-09 02:26:36 +07:00
|
|
|
|
<
|
2011-11-22 13:38:26 +07:00
|
|
|
|
Examples: >
|
2011-10-09 02:26:36 +07:00
|
|
|
|
let g:ctrlp_user_command = ['.git/', 'cd %s && git ls-files']
|
2012-01-06 13:22:55 +07:00
|
|
|
|
let g:ctrlp_user_command = ['.hg/', 'hg --cwd %s locate -I .']
|
2012-01-30 08:54:06 +07:00
|
|
|
|
let g:ctrlp_user_command = {
|
|
|
|
|
\ 'types': {
|
|
|
|
|
\ 1: ['.git/', 'cd %s && git ls-files'],
|
|
|
|
|
\ 2: ['.hg/', 'hg --cwd %s locate -I .'],
|
|
|
|
|
\ },
|
|
|
|
|
\ 'fallback': 'find %s -type f'
|
|
|
|
|
\ }
|
2011-10-09 02:26:36 +07:00
|
|
|
|
<
|
2012-01-30 08:54:06 +07:00
|
|
|
|
If the fallback_command is empty or not defined, |globpath()| will then be used
|
|
|
|
|
when searching outside a repo.
|
2011-09-11 23:53:32 +07:00
|
|
|
|
|
2011-09-29 19:15:33 +07:00
|
|
|
|
*'g:ctrlp_max_history'*
|
|
|
|
|
The maximum number of input strings you want |CtrlP| to remember. The default
|
2011-11-28 19:52:28 +07:00
|
|
|
|
value mirrors Vim’s global |'history'| option: >
|
2011-09-29 19:15:33 +07:00
|
|
|
|
let g:ctrlp_max_history = &history
|
|
|
|
|
<
|
2012-01-10 05:58:59 +07:00
|
|
|
|
Set to 0 to disable prompt’s history. Browse the history with <c-n> and <c-p>.
|
2011-10-03 03:04:43 +07:00
|
|
|
|
|
2012-01-13 09:13:39 +07:00
|
|
|
|
*'g:ctrlp_open_new_file'*
|
|
|
|
|
Use this option to specify how the newly created file is to be opened when
|
|
|
|
|
pressing <c-y>:
|
|
|
|
|
t - in a new tab
|
|
|
|
|
h - in a new horizontal split
|
|
|
|
|
v - in a new vertical split
|
|
|
|
|
r - in the current window
|
|
|
|
|
>
|
|
|
|
|
let g:ctrlp_open_new_file = 'v'
|
|
|
|
|
<
|
|
|
|
|
|
2012-03-01 18:48:03 +07:00
|
|
|
|
*'g:ctrlp_open_multiple_files'*
|
2011-11-12 22:00:50 +07:00
|
|
|
|
If non-zero, this will enable opening multiple files with <c-z> and <c-o>: >
|
2012-03-01 18:48:03 +07:00
|
|
|
|
let g:ctrlp_open_multiple_files = 'v'
|
|
|
|
|
<
|
|
|
|
|
Example: >
|
|
|
|
|
let g:ctrlp_open_multiple_files = '2vr'
|
2011-11-12 22:00:50 +07:00
|
|
|
|
<
|
|
|
|
|
For the number:
|
2012-03-01 18:48:03 +07:00
|
|
|
|
- If given, it’ll be used as the maximum number of windows or tabs to create
|
|
|
|
|
when opening the files (the rest will be opened as hidden buffers).
|
|
|
|
|
- If not given, <c-o> will open all files, each in a new window or new tab.
|
2012-01-13 23:02:17 +07:00
|
|
|
|
For the letters:
|
2012-03-01 18:48:03 +07:00
|
|
|
|
t - each file in a new tab.
|
|
|
|
|
h - each file in a new horizontal split.
|
|
|
|
|
v - each file in a new vertical split.
|
2012-01-13 23:02:17 +07:00
|
|
|
|
Reuse the current window:
|
2012-01-13 09:13:39 +07:00
|
|
|
|
tr,
|
|
|
|
|
hr,
|
|
|
|
|
vr - open the first file in the current window, then the remaining files in
|
|
|
|
|
new splits or new tabs just like with t, h, v.
|
|
|
|
|
|
|
|
|
|
*'g:ctrlp_arg_map'*
|
|
|
|
|
When this is set to 1, the <c-o> and <c-y> mappings will accept one extra key
|
|
|
|
|
as an argument to override their default behavior: >
|
|
|
|
|
let g:ctrlp_arg_map = 0
|
|
|
|
|
<
|
|
|
|
|
Pressing <c-o> or <c-y> will then prompt for a keypress. The key can be:
|
|
|
|
|
t - open in tab(s)
|
|
|
|
|
h - open in horizontal split(s)
|
|
|
|
|
v - open in vertical split(s)
|
|
|
|
|
r - open in current window (for <c-y> only)
|
2012-01-29 00:29:09 +07:00
|
|
|
|
<esc>, <c-c> - cancel and go back to the prompt.
|
2012-01-13 23:02:17 +07:00
|
|
|
|
Any other key - use the behavior specified with |g:ctrlp_open_new_file| and
|
2012-03-01 18:48:03 +07:00
|
|
|
|
|g:ctrlp_open_multiple_files|.
|
2011-09-29 19:15:33 +07:00
|
|
|
|
|
2011-11-22 13:38:26 +07:00
|
|
|
|
*'g:ctrlp_follow_symlinks'*
|
|
|
|
|
Set this to 1 to follow symbolic links when listing files: >
|
|
|
|
|
let g:ctrlp_follow_symlinks = 0
|
|
|
|
|
<
|
2012-01-22 19:20:27 +07:00
|
|
|
|
When enabled, looped internal symlinks will be ignored to avoid duplicates.
|
2011-11-22 13:38:26 +07:00
|
|
|
|
|
2011-11-28 19:52:28 +07:00
|
|
|
|
*'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.
|
|
|
|
|
|
2011-11-30 11:11:14 +07:00
|
|
|
|
*'g:ctrlp_use_migemo'*
|
2011-12-01 16:36:21 +07:00
|
|
|
|
Set this to 1 to use Migemo Pattern for Japanese filenames. Migemo Search only
|
2011-11-30 18:16:08 +09:00
|
|
|
|
works in |regexp| mode. To split the pattern, separate words with space: >
|
2011-11-30 11:11:14 +07:00
|
|
|
|
let g:ctrlp_use_migemo = 0
|
|
|
|
|
<
|
|
|
|
|
|
2012-01-14 16:53:42 +07:00
|
|
|
|
*'g:ctrlp_status_func'*
|
2012-01-16 00:42:14 +07:00
|
|
|
|
Use this to customize the statuslines for the |CtrlP| window: >
|
2012-01-14 16:53:42 +07:00
|
|
|
|
let g:ctrlp_status_func = {}
|
|
|
|
|
<
|
|
|
|
|
Example: >
|
|
|
|
|
let g:ctrlp_status_func = {
|
2012-01-16 00:42:14 +07:00
|
|
|
|
\ 'main': 'Function_Name_1',
|
|
|
|
|
\ 'prog': 'Function_Name_2',
|
2012-01-14 16:53:42 +07:00
|
|
|
|
\ }
|
|
|
|
|
<
|
2012-03-12 08:58:01 +07:00
|
|
|
|
Structure of the functions: >
|
|
|
|
|
function! Function_Name_1(focus, byfname, regex, prev, item, next, marked)
|
2012-03-16 03:13:12 +07:00
|
|
|
|
" Arguments:
|
2012-03-12 08:58:01 +07:00
|
|
|
|
" |
|
2012-03-16 03:13:12 +07:00
|
|
|
|
" +- a:focus : The focus of the prompt: "prt" or "win".
|
|
|
|
|
" |
|
|
|
|
|
" +- a:byfname : In filename mode or in full path mode: "file" or "path".
|
|
|
|
|
" |
|
|
|
|
|
" +- a:regex : In regex mode: 1 or 0.
|
|
|
|
|
" |
|
|
|
|
|
" +- a:prev : The previous search mode.
|
|
|
|
|
" |
|
|
|
|
|
" +- a:item : The current search mode.
|
|
|
|
|
" |
|
|
|
|
|
" +- a:next : The next search mode.
|
|
|
|
|
" |
|
|
|
|
|
" +- a:marked : The number of marked files, or a comma separated list of
|
|
|
|
|
" the filenames.
|
2012-03-12 08:58:01 +07:00
|
|
|
|
|
|
|
|
|
return full_statusline
|
|
|
|
|
endfunction
|
|
|
|
|
|
|
|
|
|
function! Function_Name_2(str)
|
2012-03-16 03:13:12 +07:00
|
|
|
|
" a:str : Either the number of files scanned so far, or a string indicating
|
|
|
|
|
" the current directory is being scanned with a user_command.
|
2012-03-12 08:58:01 +07:00
|
|
|
|
|
|
|
|
|
return full_statusline
|
|
|
|
|
endfunction
|
|
|
|
|
<
|
2012-01-14 16:53:42 +07:00
|
|
|
|
See https://gist.github.com/1610859 for a working example.
|
|
|
|
|
|
2012-03-12 08:58:01 +07:00
|
|
|
|
*'g:ctrlp_match_func'*
|
|
|
|
|
Set an external fuzzy matching function for |CtrlP| to use: >
|
|
|
|
|
let g:ctrlp_match_func = {}
|
|
|
|
|
<
|
|
|
|
|
Example: >
|
|
|
|
|
let g:ctrlp_match_func = { 'match': 'Function_Name' }
|
|
|
|
|
<
|
|
|
|
|
Structure of the function: >
|
|
|
|
|
function! Function_Name(items, str, limit, mmode, ispath, crfile, regex)
|
2012-03-16 03:13:12 +07:00
|
|
|
|
" Arguments:
|
|
|
|
|
" |
|
|
|
|
|
" +- a:items : The full list of items to search in.
|
|
|
|
|
" |
|
|
|
|
|
" +- a:str : The string entered by the user.
|
|
|
|
|
" |
|
|
|
|
|
" +- a:limit : The max height of the match window. Can be used to limit
|
|
|
|
|
" | the number of items to return.
|
|
|
|
|
" |
|
|
|
|
|
" +- a:mmode : The match mode. Can be one of these strings:
|
|
|
|
|
" | + "full-line": match the entire line.
|
|
|
|
|
" | + "filename-only": match only the filename.
|
|
|
|
|
" | + "first-non-tab": match until the first tab char.
|
|
|
|
|
" | + "until-last-tab": match until the last tab char.
|
|
|
|
|
" |
|
|
|
|
|
" +- a:ispath : Is 1 when searching in file, buffer, mru, dir, and rtscript
|
|
|
|
|
" | modes. Is 0 otherwise.
|
|
|
|
|
" |
|
|
|
|
|
" +- a:crfile : The file in the current window. Should be excluded from the
|
|
|
|
|
" | results when a:ispath == 1.
|
2012-03-12 08:58:01 +07:00
|
|
|
|
" |
|
2012-03-16 03:13:12 +07:00
|
|
|
|
" +- a:regex : In regex mode: 1 or 0.
|
2012-03-12 08:58:01 +07:00
|
|
|
|
|
|
|
|
|
return list_of_matched_items
|
|
|
|
|
endfunction
|
|
|
|
|
<
|
|
|
|
|
|
2011-08-22 09:14:00 +07:00
|
|
|
|
===============================================================================
|
2012-03-01 18:48:03 +07:00
|
|
|
|
COMMANDS *ctrlp-commands*
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
|
|
|
|
*:CtrlP*
|
2011-09-12 04:26:18 +07:00
|
|
|
|
:CtrlP [starting-directory]
|
2011-11-28 19:52:28 +07:00
|
|
|
|
Open |CtrlP| in find file mode.
|
|
|
|
|
|
2011-09-11 23:53:32 +07:00
|
|
|
|
If no argument is given, the value of |g:ctrlp_working_path_mode| will be
|
2011-09-13 08:27:27 +07:00
|
|
|
|
used to determine the starting directory.
|
2011-11-03 06:09:12 +07:00
|
|
|
|
You can use <tab> to auto-complete the [starting-directory] when typing it.
|
2011-09-07 21:41:43 +07:00
|
|
|
|
|
2011-09-05 18:05:04 +07:00
|
|
|
|
*:CtrlPBuffer*
|
|
|
|
|
:CtrlPBuffer
|
2011-11-28 19:52:28 +07:00
|
|
|
|
Open |CtrlP| in find buffer mode.
|
2011-09-07 21:41:43 +07:00
|
|
|
|
|
2011-11-12 22:00:50 +07:00
|
|
|
|
*:CtrlPMRU*
|
|
|
|
|
:CtrlPMRU
|
2011-11-28 19:52:28 +07:00
|
|
|
|
Open |CtrlP| in find Most-Recently-Used file mode.
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
2012-03-03 19:25:53 +01:00
|
|
|
|
*:CtrlPClearCache*
|
|
|
|
|
:CtrlPClearCache
|
2011-11-12 22:00:50 +07:00
|
|
|
|
Flush the cache for the current working directory. The same as pressing <F5>
|
2011-11-03 06:09:12 +07:00
|
|
|
|
inside |CtrlP|.
|
2012-01-29 00:29:09 +07:00
|
|
|
|
You can also enable/disable caching with the option |g:ctrlp_use_caching|.
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
2012-03-03 19:25:53 +01:00
|
|
|
|
*:CtrlPClearAllCaches*
|
|
|
|
|
:CtrlPClearAllCaches
|
2012-01-29 00:29:09 +07:00
|
|
|
|
Delete all the cache files saved in |g:ctrlp_cache_dir|.
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
2012-03-04 01:53:34 +07:00
|
|
|
|
*:CtrlPReload*
|
|
|
|
|
:CtrlPReload
|
|
|
|
|
Load new values for the option variables.
|
2011-09-18 18:33:37 +07:00
|
|
|
|
|
2011-11-12 22:00:50 +07:00
|
|
|
|
-------------------------------------------------------------------------------
|
|
|
|
|
The following commands ignore the current value of |g:ctrlp_working_path_mode|:
|
2011-09-11 23:53:32 +07:00
|
|
|
|
|
2011-11-12 22:00:50 +07:00
|
|
|
|
:CtrlPCurWD *:CtrlPCurWD*
|
2011-11-04 22:35:26 +07:00
|
|
|
|
This acts like |:CtrlP| with |path_mode| = 0
|
2011-09-09 01:25:01 +07:00
|
|
|
|
|
2011-11-12 22:00:50 +07:00
|
|
|
|
:CtrlPCurFile *:CtrlPCurFile*
|
2011-11-04 22:35:26 +07:00
|
|
|
|
This acts like |:CtrlP| with |path_mode| = 1
|
2011-09-09 01:16:12 +07:00
|
|
|
|
|
2011-11-12 22:00:50 +07:00
|
|
|
|
:CtrlPRoot *:CtrlPRoot*
|
2011-11-04 22:35:26 +07:00
|
|
|
|
This acts like |:CtrlP| with |path_mode| = 2
|
2011-09-09 01:16:12 +07:00
|
|
|
|
|
2011-08-22 09:14:00 +07:00
|
|
|
|
===============================================================================
|
2012-03-01 18:48:03 +07:00
|
|
|
|
MAPPINGS *ctrlp-mappings*
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
|
|
|
|
*'ctrlp-<c-p>'*
|
|
|
|
|
<c-p>
|
2011-11-28 19:52:28 +07:00
|
|
|
|
Default |Normal| mode mapping to open the |CtrlP| prompt in find file mode.
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
2011-11-12 22:00:50 +07:00
|
|
|
|
Once inside the prompt:~
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
|
|
|
|
<c-r> *'ctrlp-fullregexp'*
|
2012-03-01 18:48:03 +07:00
|
|
|
|
Toggle between the string mode and full |regexp| mode.
|
|
|
|
|
Note: in full |regexp| mode, the prompt’s base is 'r>>' instead of '>>>'
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
2012-01-16 00:42:14 +07:00
|
|
|
|
See also |input-formats| (guide) and |g:ctrlp_regexp_search| (option).
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
|
|
|
|
<c-d>
|
2012-01-29 00:29:09 +07:00
|
|
|
|
Toggle between full-path search and filename only search.
|
2012-03-01 18:48:03 +07:00
|
|
|
|
Note: in filename mode, the prompt’s base is '>d>' instead of '>>>'
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
2011-09-07 21:41:43 +07:00
|
|
|
|
<c-f>, 'forward'
|
|
|
|
|
<c-up>
|
2011-11-28 19:52:28 +07:00
|
|
|
|
Scroll to the 'next' search mode in the sequence.
|
2011-09-07 21:41:43 +07:00
|
|
|
|
|
|
|
|
|
<c-b>, 'backward'
|
|
|
|
|
<c-down>
|
2011-11-28 19:52:28 +07:00
|
|
|
|
Scroll to the 'previous' search mode in the sequence.
|
2011-09-05 18:05:04 +07:00
|
|
|
|
|
2011-09-05 21:59:18 +07:00
|
|
|
|
<tab>
|
2012-01-16 20:14:09 +07:00
|
|
|
|
Auto-complete directory names under the current working directory inside
|
|
|
|
|
the prompt.
|
|
|
|
|
|
|
|
|
|
<s-tab>
|
2011-09-05 21:59:18 +07:00
|
|
|
|
Toggle the focus between the match window and the prompt.
|
|
|
|
|
|
2011-08-22 09:14:00 +07:00
|
|
|
|
<c-j>,
|
|
|
|
|
<down>
|
2012-01-24 09:13:51 +07:00
|
|
|
|
Move selection down.
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
|
|
|
|
<c-k>,
|
|
|
|
|
<up>
|
2012-01-24 09:13:51 +07:00
|
|
|
|
Move selection up.
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
|
|
|
|
<c-a>
|
2012-01-24 09:13:51 +07:00
|
|
|
|
Move the cursor to the 'start' of the prompt.
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
|
|
|
|
<c-e>
|
2012-01-24 09:13:51 +07:00
|
|
|
|
Move the cursor to the 'end' of the prompt.
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
|
|
|
|
<c-h>,
|
2012-01-06 13:22:55 +07:00
|
|
|
|
<left>,
|
|
|
|
|
<c-^>
|
2012-01-24 09:13:51 +07:00
|
|
|
|
Move the cursor one character to the 'left'.
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
|
|
|
|
<c-l>,
|
|
|
|
|
<right>
|
2012-01-24 09:13:51 +07:00
|
|
|
|
Move the cursor one character to the 'right'.
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
2012-01-06 13:22:55 +07:00
|
|
|
|
<c-]>,
|
|
|
|
|
<bs>
|
2012-01-24 09:13:51 +07:00
|
|
|
|
Delete the preceding character.
|
2012-01-06 13:22:55 +07:00
|
|
|
|
|
|
|
|
|
<del>
|
2012-01-24 09:13:51 +07:00
|
|
|
|
Delete the current character.
|
2012-01-06 13:22:55 +07:00
|
|
|
|
|
2011-08-22 09:14:00 +07:00
|
|
|
|
<c-w>
|
2012-01-24 09:13:51 +07:00
|
|
|
|
Delete a preceding inner word.
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
|
|
|
|
<c-u>
|
2012-01-24 09:13:51 +07:00
|
|
|
|
Clear the input field.
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
|
|
|
|
<cr>
|
2011-11-28 19:52:28 +07:00
|
|
|
|
Open selected file in the active window if possible.
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
|
|
|
|
<c-t>
|
2012-01-24 09:13:51 +07:00
|
|
|
|
Open selected file in a new 'tab' after the last tabpage.
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
|
|
|
|
<c-v>
|
2012-01-24 09:13:51 +07:00
|
|
|
|
Open selected file in a 'vertical' split.
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
|
|
|
|
<c-cr>,
|
2011-09-28 20:42:52 +07:00
|
|
|
|
<c-s>,
|
|
|
|
|
<c-x>
|
2012-01-24 09:13:51 +07:00
|
|
|
|
Open selected file in a 'horizontal' split.
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
2011-09-28 21:53:55 +07:00
|
|
|
|
<c-y>
|
|
|
|
|
Create a new file and its parent directories.
|
|
|
|
|
|
2011-09-29 19:15:33 +07:00
|
|
|
|
<c-n>
|
2012-01-24 09:13:51 +07:00
|
|
|
|
Next string in the prompt’s history.
|
2011-09-29 19:15:33 +07:00
|
|
|
|
|
|
|
|
|
<c-p>
|
2012-01-24 09:13:51 +07:00
|
|
|
|
Previous string in the prompt’s history.
|
2011-09-29 19:15:33 +07:00
|
|
|
|
|
2011-10-03 03:04:43 +07:00
|
|
|
|
<c-z>
|
2012-01-16 00:42:14 +07:00
|
|
|
|
- Mark/unmark a file to be opened with <c-o>.
|
2012-01-24 09:13:51 +07:00
|
|
|
|
- Mark/unmark a file to create a new file in its directory using <c-y>.
|
2011-10-03 03:04:43 +07:00
|
|
|
|
|
|
|
|
|
<c-o>
|
|
|
|
|
Open files marked by <c-z>.
|
|
|
|
|
|
2011-09-08 22:50:57 +07:00
|
|
|
|
<F5>
|
2011-11-28 19:52:28 +07:00
|
|
|
|
- Refresh the match window and purge the cache for the current directory.
|
|
|
|
|
- Remove deleted files from MRU list.
|
2011-09-08 22:50:57 +07:00
|
|
|
|
|
2011-11-28 19:52:28 +07:00
|
|
|
|
<F7>
|
2012-02-20 14:58:03 +07:00
|
|
|
|
- Wipe MRU list.
|
|
|
|
|
- Delete MRU entries marked by <c-z>.
|
2011-11-12 22:00:50 +07:00
|
|
|
|
|
2012-01-29 00:29:09 +07:00
|
|
|
|
<insert>
|
|
|
|
|
Insert the word under the cursor (in the active buffer) into the prompt.
|
|
|
|
|
|
2011-08-22 09:14:00 +07:00
|
|
|
|
<esc>,
|
|
|
|
|
<c-c>,
|
|
|
|
|
<c-g>
|
2012-01-29 00:29:09 +07:00
|
|
|
|
Exit |CtrlP|.
|
2012-03-01 18:48:03 +07:00
|
|
|
|
Note: <c-c> can also be used to stop the scan if it’s taking too long.
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
2011-12-13 21:42:57 +07:00
|
|
|
|
Choose your own mappings with |g:ctrlp_prompt_mappings|.
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
2012-01-29 00:29:09 +07:00
|
|
|
|
When inside the match window (press <s-tab> to switch):~
|
2011-09-11 23:53:32 +07:00
|
|
|
|
|
|
|
|
|
a-z
|
|
|
|
|
0-9
|
|
|
|
|
~^-=;`',.+!@#$%&_(){}[]
|
2011-09-15 05:16:15 +07:00
|
|
|
|
Cycle through the lines with the first letter (of paths or filenames) that
|
2011-09-14 21:38:37 +07:00
|
|
|
|
matches that key.
|
2011-09-11 23:53:32 +07:00
|
|
|
|
|
2011-08-22 09:14:00 +07:00
|
|
|
|
===============================================================================
|
2012-03-01 18:48:03 +07:00
|
|
|
|
INPUT FORMATS *ctrlp-input-formats*
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
2011-11-12 22:00:50 +07:00
|
|
|
|
Formats for inputting in the prompt:~
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
2011-11-03 06:09:12 +07:00
|
|
|
|
a) Simple string.
|
|
|
|
|
e.g. 'abc' is understood internally as 'a[^a]\{-}b[^b]\{-}c'
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
2011-09-13 08:27:27 +07:00
|
|
|
|
b) Vim |regexp|. If the input string contains '*' or '|', it’ll be treated as
|
|
|
|
|
a Vim’s |regexp| |pattern| without any modification.
|
2011-08-22 09:14:00 +07:00
|
|
|
|
e.g. 'abc\d*efg' will be read as 'abc\d*efg'.
|
|
|
|
|
|
2012-01-06 13:22:55 +07:00
|
|
|
|
See also |ctrlp-fullregexp| (keymap) and |g:ctrlp_regexp_search| (option).
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
2011-10-03 03:04:43 +07:00
|
|
|
|
c) End the string with a colon ':' followed by a Vim command to execute that
|
2012-01-06 13:22:55 +07:00
|
|
|
|
command after opening the file. If you need to use ':' literally, escape it
|
|
|
|
|
with a backslash: '\:'. When opening multiple files, the command will be
|
|
|
|
|
executed on each opening file.
|
2011-09-05 21:59:18 +07:00
|
|
|
|
e.g. 'abc:45' will open the selected file and jump to line 45.
|
2012-01-16 00:42:14 +07:00
|
|
|
|
'abc:/my\:string' will open the selected file and jump to the first
|
2011-10-03 03:04:43 +07:00
|
|
|
|
instance of 'my:function'.
|
|
|
|
|
'abc:+setf\ myfiletype|50' will open the selected file and set its
|
2012-01-06 13:22:55 +07:00
|
|
|
|
filetype to 'myfiletype', then jump to line 50.
|
2012-01-10 05:58:59 +07:00
|
|
|
|
'abc:diffthis' will open the selected file and run |:diffthis| on the
|
|
|
|
|
first 4 files.
|
2011-10-03 03:04:43 +07:00
|
|
|
|
|
2011-11-03 06:09:12 +07:00
|
|
|
|
See also Vim’s |++opt| and |+cmd|.
|
2011-09-05 21:59:18 +07:00
|
|
|
|
|
2011-11-12 22:00:50 +07:00
|
|
|
|
d) Type exactly two dots '..' at the start of the prompt and press enter to go
|
2011-09-09 19:55:24 +07:00
|
|
|
|
backward in the directory tree by 1 level. If the parent directory is
|
|
|
|
|
large, this might be slow.
|
|
|
|
|
|
2011-12-18 09:58:44 +07:00
|
|
|
|
e) Similarly, submit '/' or '\' to find and go to the project’s root. If the
|
2011-11-12 22:00:50 +07:00
|
|
|
|
project is large, using a VCS listing command to look for files might help
|
|
|
|
|
speeding up the intial scan (see |g:ctrlp_user_command| for more details).
|
|
|
|
|
|
2012-01-16 00:42:14 +07:00
|
|
|
|
f) Type the name of a non-existent file and press <c-y> to create it. Mark a
|
|
|
|
|
file with <c-z> to create the new file in the same directory as the marked
|
|
|
|
|
file.
|
|
|
|
|
e.g. 'parentdir/newfile.txt' will create a directory named 'parentdir' as
|
|
|
|
|
well as 'newfile.txt'.
|
|
|
|
|
If 'some/old/dirs/oldfile.txt' is marked with <c-z>, then 'parentdir'
|
|
|
|
|
and 'newfile.txt' will be created in 'some/old/dirs'. The final path
|
|
|
|
|
will then be 'some/old/dirs/parentdir/newfile.txt'.
|
2011-11-12 22:00:50 +07:00
|
|
|
|
Use '\' in place of '/' on Windows (if |'ssl'| is not set).
|
2011-10-03 03:04:43 +07:00
|
|
|
|
|
2011-11-12 22:00:50 +07:00
|
|
|
|
g) Submit ? to open this help file.
|
2011-10-08 21:42:18 +07:00
|
|
|
|
|
2011-11-28 19:52:28 +07:00
|
|
|
|
===============================================================================
|
2012-03-01 18:48:03 +07:00
|
|
|
|
EXTENSIONS *g:ctrlp-extensions*
|
2011-11-28 19:52:28 +07:00
|
|
|
|
|
|
|
|
|
Extensions are optional. To enable an extension, add its name to the variable
|
|
|
|
|
g:ctrlp_extensions: >
|
2012-03-16 03:13:12 +07:00
|
|
|
|
let g:ctrlp_extensions = ['tag', 'buffertag', 'quickfix', 'dir', 'rtscript',
|
|
|
|
|
\ 'undo', 'line', 'changes']
|
2011-11-28 19:52:28 +07:00
|
|
|
|
<
|
2011-12-03 10:54:18 +07:00
|
|
|
|
The order of the items will be the order they appear on the statusline and when
|
|
|
|
|
using <c-f>, <c-b>.
|
2011-11-28 19:52:28 +07:00
|
|
|
|
|
|
|
|
|
Available extensions:~
|
|
|
|
|
|
2011-12-03 10:54:18 +07:00
|
|
|
|
*:CtrlPTag*
|
2011-11-28 19:52:28 +07:00
|
|
|
|
* Tag mode:~
|
2011-12-01 16:36:21 +07:00
|
|
|
|
- Name: 'tag'
|
2011-11-28 19:52:28 +07:00
|
|
|
|
- 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`
|
|
|
|
|
|
2011-12-21 18:58:08 +07:00
|
|
|
|
*:CtrlPBufTag*
|
2012-01-06 13:22:55 +07:00
|
|
|
|
*:CtrlPBufTagAll*
|
2011-12-21 18:58:08 +07:00
|
|
|
|
* Buffer Tag mode:~
|
|
|
|
|
- Name: 'buffertag'
|
2012-01-06 13:22:55 +07:00
|
|
|
|
- Commands: ':CtrlPBufTag [buffer-name]',
|
|
|
|
|
':CtrlPBufTagAll'.
|
2012-03-12 15:34:40 +07:00
|
|
|
|
- Search for a tag within the current buffer or all listed buffers and jump
|
|
|
|
|
to the definition. Requires |exuberant_ctags| or compatible programs.
|
2011-12-21 18:58:08 +07:00
|
|
|
|
|
2011-12-03 10:54:18 +07:00
|
|
|
|
*:CtrlPQuickfix*
|
2011-11-28 19:52:28 +07:00
|
|
|
|
* Quickfix mode:~
|
2011-12-01 16:36:21 +07:00
|
|
|
|
- Name: 'quickfix'
|
2011-11-28 19:52:28 +07:00
|
|
|
|
- Command: ':CtrlPQuickfix'
|
2011-11-30 16:42:19 +07:00
|
|
|
|
- Search for an entry in the current quickfix errors and jump to it.
|
|
|
|
|
|
2011-12-03 10:54:18 +07:00
|
|
|
|
*:CtrlPDir*
|
2011-11-30 16:42:19 +07:00
|
|
|
|
* Directory mode:~
|
2011-12-01 16:36:21 +07:00
|
|
|
|
- Name: 'dir'
|
2012-01-06 13:22:55 +07:00
|
|
|
|
- Command: ':CtrlPDir [starting-directory]'
|
2011-12-01 16:36:21 +07:00
|
|
|
|
- Search for a directory and change the working directory to it.
|
|
|
|
|
- Mappings:
|
|
|
|
|
+ <cr> change the local working directory for |CtrlP| and keep it open.
|
|
|
|
|
+ <c-t> change the global working directory (exit).
|
|
|
|
|
+ <c-v> change the local working directory for the current window (exit).
|
|
|
|
|
+ <c-x> change the global working directory to |CtrlP|’s current local
|
|
|
|
|
working directory (exit).
|
2011-11-28 19:52:28 +07:00
|
|
|
|
|
2012-01-16 00:42:14 +07:00
|
|
|
|
*:CtrlPRTS*
|
|
|
|
|
* Runtime script mode:~
|
2012-01-22 11:48:44 +07:00
|
|
|
|
- Name: 'rtscript'
|
2012-01-16 00:42:14 +07:00
|
|
|
|
- Command: ':CtrlPRTS'
|
2012-01-29 00:29:09 +07:00
|
|
|
|
- Search for files (vimscripts, docs, snippets...) in runtimepath.
|
2012-01-16 00:42:14 +07:00
|
|
|
|
|
2012-03-12 15:34:40 +07:00
|
|
|
|
*:CtrlPUndo*
|
|
|
|
|
* Undo mode:~
|
|
|
|
|
- Name: 'undo'
|
|
|
|
|
- Command: ':CtrlPUndo'
|
|
|
|
|
- Browse undo history (requires Vim 7.3.005+).
|
|
|
|
|
|
|
|
|
|
*:CtrlPLine*
|
|
|
|
|
* Line mode:~
|
|
|
|
|
- Name: 'line'
|
|
|
|
|
- Command: ':CtrlPLine'
|
2012-03-13 16:20:56 +07:00
|
|
|
|
- Search for a line in all listed buffers.
|
2012-03-12 15:34:40 +07:00
|
|
|
|
|
|
|
|
|
*:CtrlPChange*
|
|
|
|
|
*:CtrlPChangeAll*
|
|
|
|
|
* Change list mode:~
|
|
|
|
|
- Name: 'changes'
|
|
|
|
|
- Commands: ':CtrlPChange [buffer-name]',
|
|
|
|
|
':CtrlPChangeAll'.
|
|
|
|
|
- Search for and jump to a recent change in the current buffer or in all
|
|
|
|
|
listed buffers.
|
|
|
|
|
|
2011-12-21 18:58:08 +07:00
|
|
|
|
-------------------------------------------------------------------------------
|
|
|
|
|
Buffer Tag mode options:~
|
|
|
|
|
|
|
|
|
|
*'g:ctrlp_buftag_ctags_bin'*
|
|
|
|
|
If ctags isn’t in your $PATH, use this to set its location: >
|
|
|
|
|
let g:ctrlp_buftag_ctags_bin = ''
|
|
|
|
|
<
|
|
|
|
|
|
|
|
|
|
*'g:ctrlp_buftag_systemenc'*
|
|
|
|
|
Match this with your OS’s encoding (not Vim’s). The default value mirrors Vim’s
|
|
|
|
|
global |'encoding'| option: >
|
|
|
|
|
let g:ctrlp_buftag_systemenc = &encoding
|
|
|
|
|
<
|
|
|
|
|
|
|
|
|
|
*'g:ctrlp_buftag_types'*
|
|
|
|
|
Use this to set the arguments for ctags, jsctags... for a given filetype: >
|
|
|
|
|
let g:ctrlp_buftag_types = ''
|
|
|
|
|
<
|
|
|
|
|
Examples: >
|
|
|
|
|
let g:ctrlp_buftag_types = {
|
|
|
|
|
\ 'erlang' : '--language-force=erlang --erlang-types=drmf',
|
|
|
|
|
\ 'javascript' : {
|
|
|
|
|
\ 'bin': 'jsctags',
|
|
|
|
|
\ 'args': '-f -',
|
|
|
|
|
\ },
|
|
|
|
|
\ }
|
|
|
|
|
<
|
|
|
|
|
|
2012-02-04 18:41:27 +07:00
|
|
|
|
===============================================================================
|
|
|
|
|
CUSTOMIZATION *ctrlp-customization*
|
|
|
|
|
|
|
|
|
|
Highlighting:~
|
2012-02-04 20:28:03 +07:00
|
|
|
|
* For the |CtrlP| buffer:
|
2012-02-05 16:13:52 +07:00
|
|
|
|
CtrlPNoEntries : the message when no match is found (Error)
|
|
|
|
|
CtrlPMatch : the matched pattern (Identifier)
|
|
|
|
|
CtrlPLinePre : the line prefix '>' in the match window
|
|
|
|
|
CtrlPPrtBase : the prompt’s base (Comment)
|
|
|
|
|
CtrlPPrtText : the prompt’s text (|hl-Normal|)
|
|
|
|
|
CtrlPPrtCursor : the prompt’s cursor when moving over the text (Constant)
|
2012-02-04 18:41:27 +07:00
|
|
|
|
|
|
|
|
|
* In extensions:
|
2012-02-05 16:13:52 +07:00
|
|
|
|
CtrlPTabExtra : the part of each line that’s not matched against (Comment)
|
2012-03-13 16:20:56 +07:00
|
|
|
|
CtrlPBufName : the buffer name an entry belongs to (|hl-Directory|)
|
|
|
|
|
CtrlPTagKind : the kind of the tag in buffer-tag mode (|hl-Title|)
|
|
|
|
|
CtrlPqfLineCol : the line and column numbers in quickfix mode (Comment)
|
2012-03-16 03:13:12 +07:00
|
|
|
|
CtrlPUndoT : the elapsed time in undo mode (|hl-Directory|)
|
|
|
|
|
CtrlPUndoBr : the square brackets [] in undo mode (Comment)
|
|
|
|
|
CtrlPUndoNr : the undo number inside [] in undo mode (String)
|
|
|
|
|
CtrlPUndoSv : the point where the file was saved (Comment)
|
|
|
|
|
CtrlPUndoPo : the current position in the undo tree (|hl-Title|)
|
2012-02-04 18:41:27 +07:00
|
|
|
|
|
|
|
|
|
Statuslines:~
|
|
|
|
|
* Highlight groups:
|
2012-02-05 16:13:52 +07:00
|
|
|
|
CtrlPMode1 : 'prt' or 'win', also for 'regex' (Character)
|
|
|
|
|
CtrlPMode2 : 'file' or 'path', also for the local working dir (|hl-LineNr|)
|
|
|
|
|
CtrlPStats : the scanning status (Function)
|
2012-02-04 18:41:27 +07:00
|
|
|
|
|
2012-02-05 16:13:52 +07:00
|
|
|
|
For rebuilding the statuslines, see |g:ctrlp_status_func|.
|
2012-02-04 18:41:27 +07:00
|
|
|
|
|
2011-11-04 22:35:26 +07:00
|
|
|
|
===============================================================================
|
2012-03-01 18:48:03 +07:00
|
|
|
|
MISCELLANEOUS CONFIGS *ctrlp-miscellaneous-configs*
|
2012-02-27 19:13:35 +07:00
|
|
|
|
|
|
|
|
|
* Use |wildignore| for |g:ctrlp_user_command|:
|
|
|
|
|
>
|
|
|
|
|
function! s:wig2cmd()
|
|
|
|
|
" Change wildignore into space or | separated groups
|
|
|
|
|
" e.g. .aux .out .toc .jpg .bmp .gif
|
|
|
|
|
" or .aux$\|.out$\|.toc$\|.jpg$\|.bmp$\|.gif$
|
|
|
|
|
let pats = ['[*\/]*\([?_.0-9A-Za-z]\+\)\([*\/]*\)\(\\\@<!,\|$\)','\\\@<!,']
|
|
|
|
|
let subs = has('win32') || has('win64') ? ['\1\3', ' '] : ['\1\2\3', '\\|']
|
|
|
|
|
let expr = substitute(&wig, pats[0], subs[0], 'g')
|
|
|
|
|
let expr = substitute(expr, pats[1], subs[1], 'g')
|
|
|
|
|
let expr = substitute(expr, '\\,', ',', 'g')
|
|
|
|
|
|
|
|
|
|
" Set the user_command option
|
|
|
|
|
let g:ctrlp_user_command = has('win32') || has('win64')
|
|
|
|
|
\ ? 'dir %s /-n /b /s /a-d | findstr /V /l "'.expr.'"'
|
|
|
|
|
\ : 'find %s -type f | grep -v "'.expr .'"'
|
|
|
|
|
endfunction
|
|
|
|
|
|
|
|
|
|
call s:wig2cmd()
|
|
|
|
|
<
|
|
|
|
|
(submitted by Rich Alesi <github.com/ralesi>)
|
|
|
|
|
|
2012-03-01 18:33:35 +07:00
|
|
|
|
* A standalone function to set the working directory to the project’s root, or
|
|
|
|
|
to the parent directory of the current file if a root can’t be found:
|
2012-02-27 19:13:35 +07:00
|
|
|
|
>
|
|
|
|
|
function! s:setcwd()
|
|
|
|
|
let cph = expand('%:p:h', 1)
|
|
|
|
|
if match(cph, '\v^<.+>://') >= 0 | retu | en
|
|
|
|
|
for mkr in ['.git/', '.hg/', '.svn/', '.bzr/', '_darcs/', '.vimprojects']
|
|
|
|
|
let wd = call('find'.(mkr =~ '/$' ? 'dir' : 'file'), [mkr, cph.';'])
|
|
|
|
|
if wd != '' | let &acd = 0 | brea | en
|
|
|
|
|
endfo
|
|
|
|
|
exe 'lc!' fnameescape(wd == '' ? cph : substitute(wd, mkr.'$', '.', ''))
|
|
|
|
|
endfunction
|
|
|
|
|
|
|
|
|
|
autocmd BufEnter * call s:setcwd()
|
|
|
|
|
<
|
|
|
|
|
(requires Vim 7.1.299+)
|
|
|
|
|
|
|
|
|
|
===============================================================================
|
2011-11-04 22:35:26 +07:00
|
|
|
|
CREDITS *ctrlp-credits*
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
2012-01-30 23:03:30 +07:00
|
|
|
|
Developed by Kien Nguyen <github.com/kien>.
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
2012-01-30 23:03:30 +07:00
|
|
|
|
Project’s homepage: http://kien.github.com/ctrlp.vim
|
2011-09-05 18:21:42 +07:00
|
|
|
|
Git repository: https://github.com/kien/ctrlp.vim
|
|
|
|
|
Mercurial repository: https://bitbucket.org/kien/ctrlp.vim
|
2011-08-22 09:14:00 +07:00
|
|
|
|
|
2012-01-30 23:03:30 +07:00
|
|
|
|
-------------------------------------------------------------------------------
|
2011-11-09 01:30:53 +07:00
|
|
|
|
Thanks to everyone that has submitted ideas, bug reports or helped debugging on
|
|
|
|
|
gibhub, bitbucket, and through email.
|
|
|
|
|
|
2011-11-12 22:00:50 +07:00
|
|
|
|
Special thanks:~
|
2011-11-09 01:30:53 +07:00
|
|
|
|
|
|
|
|
|
* Woojong Koh <github.com/wjkoh>
|
2012-01-10 05:58:59 +07:00
|
|
|
|
* Simon Ruderich
|
2012-03-04 06:18:04 +07:00
|
|
|
|
* Yasuhiro Matsumoto <github.com/mattn>
|
2012-01-10 05:58:59 +07:00
|
|
|
|
* Ken Earley <github.com/kenearley>
|
2012-03-04 06:18:04 +07:00
|
|
|
|
* Kyo Nagashima <github.com/hail2u>
|
2012-01-10 05:58:59 +07:00
|
|
|
|
* Zak Johnson <github.com/zakj>
|
|
|
|
|
* Diego Viola <github.com/diegoviola>
|
2012-03-04 06:18:04 +07:00
|
|
|
|
* Piet Delport <github.com/pjdelport>
|
2012-01-26 17:11:07 +07:00
|
|
|
|
* Thibault Duplessis <github.com/ornicar>
|
2012-03-04 06:18:04 +07:00
|
|
|
|
* Kent Sibilev <github.com/datanoise>
|
2012-02-12 18:50:15 +07:00
|
|
|
|
* Tacahiroy <github.com/tacahiroy>
|
2012-03-04 06:18:04 +07:00
|
|
|
|
* Luca Pette <github.com/lucapette>
|
2012-01-10 05:58:59 +07:00
|
|
|
|
|
2011-09-07 21:41:43 +07:00
|
|
|
|
===============================================================================
|
2011-11-04 22:35:26 +07:00
|
|
|
|
CHANGELOG *ctrlp-changelog*
|
2011-11-03 06:09:12 +07:00
|
|
|
|
|
2012-03-12 08:58:01 +07:00
|
|
|
|
+ New option: |g:ctrlp_match_func|, allow using a custom fuzzy matcher.
|
2012-03-01 18:48:03 +07:00
|
|
|
|
+ Rename:
|
2012-03-04 01:53:34 +07:00
|
|
|
|
*ClearCtrlPCache* -> |CtrlPClearCache|
|
|
|
|
|
*ClearAllCtrlPCaches* -> |CtrlPClearAllCaches|
|
|
|
|
|
*ResetCtrlP* -> |CtrlPReload|
|
2012-03-04 06:18:04 +07:00
|
|
|
|
|
|
|
|
|
Before 2012/03/02~
|
|
|
|
|
|
|
|
|
|
+ Rename:
|
2012-03-01 18:48:03 +07:00
|
|
|
|
*g:ctrlp_regexp_search* -> |g:ctrlp_regexp|,
|
|
|
|
|
*g:ctrlp_dont_split* -> |g:ctrlp_reuse_window|,
|
|
|
|
|
*g:ctrlp_jump_to_buffer* -> |g:ctrlp_switch_buffer|.
|
|
|
|
|
+ Rename and tweak:
|
|
|
|
|
*g:ctrlp_open_multi* -> |g:ctrlp_open_multiple_files|.
|
|
|
|
|
+ Deprecate *g:ctrlp_highlight_match*
|
2012-02-20 14:58:03 +07:00
|
|
|
|
+ Extend |g:ctrlp_user_command| to support multiple commands.
|
2012-03-01 18:48:03 +07:00
|
|
|
|
+ New option: |g:ctrlp_mruf_last_entered| change MRU to Recently-Entered.
|
2012-01-17 23:13:39 +07:00
|
|
|
|
|
2012-01-16 00:42:14 +07:00
|
|
|
|
Before 2012/01/15~
|
2012-01-13 09:13:39 +07:00
|
|
|
|
|
2012-01-16 20:14:09 +07:00
|
|
|
|
+ New mapping: Switch <tab> and <s-tab>. <tab> is now used for completion
|
|
|
|
|
of directory names under the current working directory.
|
2012-01-14 16:53:42 +07:00
|
|
|
|
+ New options: |g:ctrlp_arg_map| for <c-y>, <c-o> to accept an argument.
|
|
|
|
|
|g:ctrlp_status_func| custom statusline.
|
2012-01-16 00:42:14 +07:00
|
|
|
|
|g:ctrlp_mruf_relative| show only MRU files inside cwd.
|
2012-03-01 18:48:03 +07:00
|
|
|
|
+ Extend g:ctrlp_open_multi with new optional values: tr, hr, vr.
|
2012-01-06 13:22:55 +07:00
|
|
|
|
+ Extend |g:ctrlp_custom_ignore| to specifically filter dir, file and link.
|
|
|
|
|
|
|
|
|
|
Before 2012/01/05~
|
|
|
|
|
|
2011-12-21 18:58:08 +07:00
|
|
|
|
+ New feature: Buffer Tag extension.
|
2012-01-06 13:22:55 +07:00
|
|
|
|
+ New commands: |:CtrlPBufTag|, |:CtrlPBufTagAll|.
|
2011-12-18 09:58:44 +07:00
|
|
|
|
+ New options: |g:ctrlp_cmd|,
|
|
|
|
|
|g:ctrlp_custom_ignore|
|
|
|
|
|
|
2011-12-03 10:54:18 +07:00
|
|
|
|
Before 2011/11/30~
|
|
|
|
|
|
2011-11-30 16:42:19 +07:00
|
|
|
|
+ New features: Tag, Quickfix and Directory extensions.
|
2011-12-03 10:54:18 +07:00
|
|
|
|
+ New commands: |:CtrlPTag|, |:CtrlPQuickfix|, |:CtrlPDir|.
|
2011-11-30 11:11:14 +07:00
|
|
|
|
+ New options: |g:ctrlp_use_migemo|,
|
|
|
|
|
|g:ctrlp_lazy_update|,
|
2011-11-28 19:52:28 +07:00
|
|
|
|
|g:ctrlp_follow_symlinks|
|
2011-11-22 13:38:26 +07:00
|
|
|
|
|
2011-11-12 22:00:50 +07:00
|
|
|
|
Before 2011/11/13~
|
|
|
|
|
|
2012-03-01 18:48:03 +07:00
|
|
|
|
+ New special input: '/' and '\' find root (|ctrlp-input-formats| (e))
|
2011-11-12 22:00:50 +07:00
|
|
|
|
+ Remove ctrlp#SetWorkingPath().
|
2012-03-01 18:48:03 +07:00
|
|
|
|
+ Remove *g:ctrlp_mru_files* and make MRU mode permanent.
|
|
|
|
|
+ Extend g:ctrlp_open_multi, add new ways to open files.
|
|
|
|
|
+ New option: g:ctrlp_dont_split,
|
2011-11-12 22:00:50 +07:00
|
|
|
|
|g:ctrlp_mruf_case_sensitive|
|
2011-11-09 18:07:54 +07:00
|
|
|
|
|
2011-11-12 22:00:50 +07:00
|
|
|
|
Before 2011/10/30~
|
2011-09-07 21:41:43 +07:00
|
|
|
|
|
2011-11-03 06:09:12 +07:00
|
|
|
|
+ New feature: Support for custom extensions.
|
2011-11-12 22:00:50 +07:00
|
|
|
|
<F5> also removes non-existent files from MRU list.
|
2012-03-01 18:48:03 +07:00
|
|
|
|
+ New option: g:ctrlp_jump_to_buffer
|
2011-10-22 21:57:29 +07:00
|
|
|
|
|
2011-11-12 22:00:50 +07:00
|
|
|
|
Before 2011/10/12~
|
2011-10-19 19:00:08 +07:00
|
|
|
|
|
2011-10-03 03:04:43 +07:00
|
|
|
|
+ New features: Open multiple files.
|
2011-11-12 22:00:50 +07:00
|
|
|
|
Pass Vim’s |++opt| and |+cmd| to the opening file
|
2012-03-01 18:48:03 +07:00
|
|
|
|
(|ctrlp-input-formats| (c))
|
2011-10-07 21:10:14 +07:00
|
|
|
|
Auto-complete each dir for |:CtrlP| [starting-directory]
|
2011-10-03 03:04:43 +07:00
|
|
|
|
+ New mappings: <c-z> mark/unmark a file to be opened with <c-o>.
|
|
|
|
|
<c-o> open all marked files.
|
2012-03-01 18:48:03 +07:00
|
|
|
|
+ New option: g:ctrlp_open_multi
|
|
|
|
|
+ Remove *g:ctrlp_persistent_input* *g:ctrlp_live_update* and <c-^>.
|
2011-10-03 03:04:43 +07:00
|
|
|
|
|
2011-11-12 22:00:50 +07:00
|
|
|
|
Before 2011/09/29~
|
2011-10-03 03:04:43 +07:00
|
|
|
|
|
|
|
|
|
+ New mappings: <c-n>, <c-p> next/prev string in the input history.
|
2011-10-23 17:38:03 +07:00
|
|
|
|
<c-y> create a new file and its parent dirs.
|
2011-09-29 19:15:33 +07:00
|
|
|
|
+ New options: |g:ctrlp_open_new_file|,
|
|
|
|
|
|g:ctrlp_max_history|
|
2011-09-28 20:42:52 +07:00
|
|
|
|
+ Added a new open-in-horizontal-split mapping: <c-x>
|
|
|
|
|
|
2011-11-12 22:00:50 +07:00
|
|
|
|
Before 2011/09/19~
|
2011-09-28 20:42:52 +07:00
|
|
|
|
|
2012-03-04 01:53:34 +07:00
|
|
|
|
+ New command: ResetCtrlP
|
2011-09-18 18:33:37 +07:00
|
|
|
|
+ New options: |g:ctrlp_max_files|,
|
|
|
|
|
|g:ctrlp_max_depth|,
|
2012-03-01 18:48:03 +07:00
|
|
|
|
g:ctrlp_live_update
|
2011-10-03 03:04:43 +07:00
|
|
|
|
+ New mapping: <c-^>
|
2011-09-14 21:38:37 +07:00
|
|
|
|
|
2011-11-12 22:00:50 +07:00
|
|
|
|
Before 2011/09/12~
|
2011-09-13 08:27:27 +07:00
|
|
|
|
|
2011-09-11 23:53:32 +07:00
|
|
|
|
+ Ability to cycle through matched lines in the match window.
|
2012-03-01 18:48:03 +07:00
|
|
|
|
+ Extend the behavior of g:ctrlp_persistent_input
|
2011-11-12 22:00:50 +07:00
|
|
|
|
+ Extend the behavior of |:CtrlP|
|
2011-09-18 18:33:37 +07:00
|
|
|
|
+ New options: |g:ctrlp_dotfiles|,
|
|
|
|
|
|g:ctrlp_clear_cache_on_exit|,
|
2012-03-01 18:48:03 +07:00
|
|
|
|
g:ctrlp_highlight_match,
|
2011-09-18 18:33:37 +07:00
|
|
|
|
|g:ctrlp_user_command|
|
2012-03-01 18:48:03 +07:00
|
|
|
|
+ New special input: '..' (|ctrlp-input-formats| (d))
|
2011-09-08 22:50:57 +07:00
|
|
|
|
+ New mapping: <F5>.
|
2011-09-09 19:55:24 +07:00
|
|
|
|
+ New commands: |:CtrlPCurWD|,
|
|
|
|
|
|:CtrlPCurFile|,
|
|
|
|
|
|:CtrlPRoot|
|
2011-09-08 22:50:57 +07:00
|
|
|
|
|
2011-10-03 03:04:43 +07:00
|
|
|
|
+ New feature: Search in most recently used (MRU) files
|
2011-09-07 21:41:43 +07:00
|
|
|
|
+ New mapping: <c-b>.
|
|
|
|
|
+ Extended the behavior of <c-f>.
|
2012-03-01 18:48:03 +07:00
|
|
|
|
+ New options: g:ctrlp_mru_files,
|
2011-09-07 21:41:43 +07:00
|
|
|
|
|g:ctrlp_mruf_max|,
|
|
|
|
|
|g:ctrlp_mruf_exclude|,
|
|
|
|
|
|g:ctrlp_mruf_include|
|
2012-02-24 01:19:44 +07:00
|
|
|
|
+ New command: |:CtrlPMRU|
|
2011-09-07 21:41:43 +07:00
|
|
|
|
|
2011-11-12 22:00:50 +07:00
|
|
|
|
First public release: 2011/09/06~
|
2011-10-07 21:10:14 +07:00
|
|
|
|
|
2011-08-22 09:14:00 +07:00
|
|
|
|
===============================================================================
|
2011-11-28 19:52:28 +07:00
|
|
|
|
vim:ft=help:et:ts=2:sw=2:sts=2:norl
|