mirror of
https://github.com/gryf/.vim.git
synced 2025-12-18 12:00:30 +01:00
Removed bundle_consider, and plugins: buffergator and fuzzyfinder (+l9). Give
a try to ctrlp plugin.
This commit is contained in:
21
.vimrc
21
.vimrc
@@ -126,8 +126,8 @@ map <Leader>wn <Plug>VimwikiNextWord
|
|||||||
map <Leader>wp <Plug>VimwikiPrevWord
|
map <Leader>wp <Plug>VimwikiPrevWord
|
||||||
" }}}
|
" }}}
|
||||||
"FuzzyFinder {{{2
|
"FuzzyFinder {{{2
|
||||||
let g:fuf_file_exclude = '\v\~$|\.(o|bak|swp|pyc|pyo|pyd)$|(^|[/\\])\.(hg|git|bzr|cvs)($|[/\\])'
|
"let g:fuf_file_exclude = '\v\~$|\.(o|bak|swp|pyc|pyo|pyd)$|(^|[/\\])\.(hg|git|bzr|cvs)($|[/\\])'
|
||||||
map <C-F> :FufFile **/<CR>
|
"map <C-F> :FufFile **/<CR>
|
||||||
"}}}
|
"}}}
|
||||||
"ShowMarks {{{2
|
"ShowMarks {{{2
|
||||||
let g:showmarks_ignore_type = "hqprm"
|
let g:showmarks_ignore_type = "hqprm"
|
||||||
@@ -179,16 +179,21 @@ nmap <C-Up> \dk
|
|||||||
nmap <C-Down> \dj
|
nmap <C-Down> \dj
|
||||||
" }}}
|
" }}}
|
||||||
" Buffergator {{{2
|
" Buffergator {{{2
|
||||||
let g:buffergator_split_size=10
|
"let g:buffergator_split_size=10
|
||||||
let g:buffergator_viewport_split_policy='B'
|
"let g:buffergator_viewport_split_policy='B'
|
||||||
let g:buffergator_suppress_keymaps=1
|
"let g:buffergator_suppress_keymaps=1
|
||||||
let g:buffergator_sort_regime="filepath"
|
"let g:buffergator_sort_regime="filepath"
|
||||||
let g:buffergator_display_regime="filepath"
|
"let g:buffergator_display_regime="filepath"
|
||||||
map <Leader>b :BuffergatorToggle<CR>
|
"map <Leader>b :BuffergatorToggle<CR>
|
||||||
" }}}
|
" }}}
|
||||||
"Gundo {{{2
|
"Gundo {{{2
|
||||||
map <Leader>u :GundoToggle<cr>
|
map <Leader>u :GundoToggle<cr>
|
||||||
"}}}
|
"}}}
|
||||||
|
"CtrlP {{{2
|
||||||
|
let g:ctrlp_custom_ignore = '\.git$\|\.hg$\|\.svn$||\.pyo||\.pyc||\.pyd||CVS$'
|
||||||
|
let g:ctrlp_map = '<c-f>'
|
||||||
|
map <Leader>b :CtrlPBuffer<CR>
|
||||||
|
"}}}
|
||||||
"}}}
|
"}}}
|
||||||
"KEYS: User defined keyboard shortcuts {{{
|
"KEYS: User defined keyboard shortcuts {{{
|
||||||
|
|
||||||
|
|||||||
@@ -1,268 +0,0 @@
|
|||||||
*buffergator.txt* Buffer indexing and navigation plugin.
|
|
||||||
|
|
||||||
===============================================================================
|
|
||||||
*buffergator* *buffergator-contents*
|
|
||||||
CONTENTS~
|
|
||||||
|
|
||||||
1. Introduction ........................... |buffergator-introduction|
|
|
||||||
2. Commands ............................... |buffergator-commands|
|
|
||||||
3. Key Mappings (Global) .................. |buffergator-global-keys|
|
|
||||||
4. Key Mappings (Buffer Catalog) .......... |buffergator-buffer-keys|
|
|
||||||
5. Key Mappings (Tab Page Catalog) ........ |buffergator-tabpage-keys|
|
|
||||||
5. Options and Settings ................... |buffergator-options|
|
|
||||||
|
|
||||||
===============================================================================
|
|
||||||
*buffergator-introduction*
|
|
||||||
INTRODUCTION~
|
|
||||||
|
|
||||||
Buffergator is a plugin for listing, navigating between, and selecting buffers
|
|
||||||
to edit. Upon invocation (using the command, ":BuffergatorOpen" or
|
|
||||||
"BuffergatorToggle", or the provided key mapping, "<Leader>b"), a "catalog" of
|
|
||||||
listed buffers are displayed in a separate new window split (vertical or
|
|
||||||
horizontal, based on user options; default = vertical). From this "buffer
|
|
||||||
catalog", a buffer can be selected and opened in an existing window, a new
|
|
||||||
window split (vertical or horizontal), or a new tab page.
|
|
||||||
|
|
||||||
Selected buffers can be "previewed", i.e. opened in a window or tab page, but
|
|
||||||
with focus remaining in the buffer catalog. Even better, you can "walk" up and
|
|
||||||
down the list of buffers shown in the catalog by using <C-N> (or <SPACE>) /
|
|
||||||
<C-P> (or <C-SPACE>). These keys select the next/previous buffer in succession,
|
|
||||||
respectively, opening it for preview without leaving the buffer catalog
|
|
||||||
viewer.
|
|
||||||
|
|
||||||
Buffergator also provides a way to list tab pages and buffers associated with
|
|
||||||
windows in tab pages (the "tab page catalog", which can be invoked using the
|
|
||||||
command ":BuffergatorTabsOpen" or the provided key mapping, "<Leader>t").
|
|
||||||
|
|
||||||
By default, Buffergator provides global key maps that invoke its main
|
|
||||||
commands: "<Leader>b" to open and "<Leader>B" to close the buffer catalog, and
|
|
||||||
"<Leader>t" to open and "<Leader>T" to close the tab page catalog. If you
|
|
||||||
prefer to map other keys, or do not want any keys mapped at all, set
|
|
||||||
"g:buffergator_suppress_keymaps" to 1 in your $VIMRUNTIME.
|
|
||||||
|
|
||||||
===============================================================================
|
|
||||||
*buffergator-commands*
|
|
||||||
COMMANDS~
|
|
||||||
|
|
||||||
These following commands are provided globally by Buffergator:
|
|
||||||
|
|
||||||
:BuffergatorOpen
|
|
||||||
Open the buffer catalog, or go to it if it is already open.
|
|
||||||
|
|
||||||
:BuffergatorClose
|
|
||||||
Close the buffer catalog if it is already open.
|
|
||||||
|
|
||||||
:BuffergatorToggle
|
|
||||||
Open the buffer catalog if it is closed, or close it if
|
|
||||||
it is already open.
|
|
||||||
|
|
||||||
:BuffergatorTabsOpen
|
|
||||||
Open the tab page catalog, or go to it if it is already open.
|
|
||||||
|
|
||||||
:BuffergatorTabsClose
|
|
||||||
Close the tab page catalog if it is already open.
|
|
||||||
|
|
||||||
:BuffergatorTabsToggle
|
|
||||||
Open the tab page catalog if it is closed, or close it if
|
|
||||||
it is already open.
|
|
||||||
|
|
||||||
===============================================================================
|
|
||||||
*buffergator-global-keys*
|
|
||||||
KEY MAPPINGS (GLOBAL)~
|
|
||||||
|
|
||||||
Unless "g:buffergator_suppress_keymaps" is set to 1, then the following
|
|
||||||
key mappings are defined:
|
|
||||||
|
|
||||||
<Leader>b Invokes ":BuffergatorOpen": open the buffer catalog, or go
|
|
||||||
to it if it is already open.
|
|
||||||
|
|
||||||
<Leader>B Invokes ":BuffergatorClose": close the buffer catalog.
|
|
||||||
|
|
||||||
<Leader>t Invokes ":BuffergatorTabsOpen": open the tab page catalog,
|
|
||||||
or go to it if it is already open.
|
|
||||||
|
|
||||||
<Leader>T Invokes ":BuffergatorTabsClose": close the tab page
|
|
||||||
catalog.
|
|
||||||
|
|
||||||
===============================================================================
|
|
||||||
*buffergator-buffer-keys*
|
|
||||||
KEY MAPPINGS (BUFFER CATALOG)~
|
|
||||||
|
|
||||||
Invoking Buffergator results in the listed buffers being displayed in a
|
|
||||||
special Buffergator window, which is referred to as a "buffer catalog viewer".
|
|
||||||
The following key mappings are available when in the viewer.
|
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
|
||||||
Catalog Management~
|
|
||||||
|
|
||||||
cs Cycle through sort regimes.
|
|
||||||
cd Cycle through display regimes.
|
|
||||||
r Update (rebuild/refresh) index.
|
|
||||||
d Delete the selected buffer.
|
|
||||||
D Unconditionally delete the selected buffer.
|
|
||||||
x Wipe the selected buffer.
|
|
||||||
X Unconditionally wipe the selected buffer.
|
|
||||||
q Quit the index/catalog window.
|
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
|
||||||
Open Selected Buffer~
|
|
||||||
|
|
||||||
The following keys all open the currently-selected buffer and switch focus to
|
|
||||||
it. If the key presses are preceded by a number, then the buffer with that
|
|
||||||
number will be selected and opened instead of the current buffer. The catalog
|
|
||||||
buffer will be closed if 'g:buffergator_autodismiss_on_select' evaluates to
|
|
||||||
true; otherwise it will be kept open.
|
|
||||||
|
|
||||||
<CR>, o Open the currently-selected buffer (or, if [count] is
|
|
||||||
given, buffer with number [count]), in previous window.
|
|
||||||
s Open the currently-selected buffer (or, if [count] is
|
|
||||||
given, buffer with number [count]), in a new vertical
|
|
||||||
split.
|
|
||||||
i Open the currently-selected buffer (or, if [count] is
|
|
||||||
given, buffer with number [count]), in a new split.
|
|
||||||
t Open the currently-selected buffer (or, if [count] is
|
|
||||||
given, buffer with number [count]), in a new tab page.
|
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
|
||||||
Preview Selected Buffer~
|
|
||||||
|
|
||||||
The following keys all open the currently-selected buffer, but retain focus on
|
|
||||||
the catalog viewer. If the key presses are preceded by a number, than the
|
|
||||||
buffer with that number will be opened.
|
|
||||||
|
|
||||||
O, go Preview the currently-selected buffer (or, if [count] is
|
|
||||||
given, buffer with number [count]), in the previous
|
|
||||||
window.
|
|
||||||
S, gs Preview the currently-selected buffer (or, if [count] is
|
|
||||||
given, buffer with number [count]), is a new vertical
|
|
||||||
split.
|
|
||||||
I, gi Preview the currently-selected buffer (or, if [count] is
|
|
||||||
given, buffer with number [count]), in a new split
|
|
||||||
T Preview the currently-selected buffer (or, if [count] is
|
|
||||||
given, buffer with number [count]), in a new tab
|
|
||||||
page.
|
|
||||||
<SPACE>, <C-N> Go to the next buffer entry (or, if [count] is
|
|
||||||
given, buffer with number [count]), and preview it in the
|
|
||||||
previous window.
|
|
||||||
<C-SPACE>, <C-P> Go to the previous buffer entry (or, if [count] is
|
|
||||||
given, buffer with number [count]), and preview it in the
|
|
||||||
previous window.
|
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
|
||||||
Go to Existing Viewport Showing Buffer~
|
|
||||||
|
|
||||||
The following keys will try to find the selected buffer in an existing
|
|
||||||
viewport (whether on the current tab page or another). If the key presses are
|
|
||||||
preceded by a number, then the buffer with that number will be the target
|
|
||||||
buffer.
|
|
||||||
|
|
||||||
eo If currently-selected buffer (or, if [count] is
|
|
||||||
given, buffer with number [count]), is showing in an existing
|
|
||||||
viewport on this or any other tab page, go it it;
|
|
||||||
otherwise show it in the previous window.
|
|
||||||
es If currently-selected buffer (or, if [count] is
|
|
||||||
given, buffer with number [count]), is showing in an existing
|
|
||||||
viewport on this or any other tab page, go it it;
|
|
||||||
otherwise show it in a new vertical split.
|
|
||||||
ei If currently-selected buffer (or, if [count] is
|
|
||||||
given, buffer with number [count]), is showing in an existing
|
|
||||||
viewport on this or any other tab page, go it it;
|
|
||||||
otherwise show it in a new horizontal split.
|
|
||||||
et If currently-selected buffer (or, if [count] is
|
|
||||||
given, buffer with number [count]), is showing in an existing
|
|
||||||
viewport on this or any other tab page, go it it;
|
|
||||||
otherwise show it in a new tab page.
|
|
||||||
E If currently-selected buffer (or, if [count] is
|
|
||||||
given, buffer with number [count]), is showing in an existing
|
|
||||||
viewport on this or any other tab page, go it it;
|
|
||||||
otherwise do nothing.
|
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
|
||||||
Window Control~
|
|
||||||
|
|
||||||
A Zoom/unzoom window, expanding to full height (if
|
|
||||||
horizontally split) or full width (if vertically split)
|
|
||||||
|
|
||||||
===============================================================================
|
|
||||||
*buffergator-tabpage-keys*
|
|
||||||
KEY MAPPINGS (TAB PAGE CATALOG)~
|
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
|
||||||
Catalog Management~
|
|
||||||
|
|
||||||
cd Cycle through display regimes.
|
|
||||||
r Update (rebuild/refresh) index.
|
|
||||||
q Quit the index/catalog window.
|
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
|
||||||
Open Selected Tab Page or Tab Page Window~
|
|
||||||
|
|
||||||
The following keys all open the currently-selected tab page or window.
|
|
||||||
|
|
||||||
<CR>, o Open the currently-selected tab page or window.
|
|
||||||
<SPACE> Select the next tab page entry.
|
|
||||||
<C-SPACE> Select the previous tab page entry.
|
|
||||||
<C-N> Select the next tab page window entry.
|
|
||||||
<C-P> Select the previous tab page window entry.
|
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
|
||||||
Window Control~
|
|
||||||
|
|
||||||
A Zoom/unzoom window, expanding to full height (if
|
|
||||||
horizontally split) or full width (if vertically split)
|
|
||||||
|
|
||||||
|
|
||||||
===============================================================================
|
|
||||||
*buffergator-options*
|
|
||||||
OPTIONS AND SETTINGS~
|
|
||||||
|
|
||||||
The following options can be used to customize the behavior of this plugin:
|
|
||||||
|
|
||||||
g:buffergator_viewport_split_policy~
|
|
||||||
Default: "L"
|
|
||||||
Determines how a new Buffergator window will be opened. Can be one of the
|
|
||||||
following values:
|
|
||||||
"L" : vertical left (full screen height)
|
|
||||||
"R" : vertical right (full screen height)
|
|
||||||
"T" : horizontal top (full screen width)
|
|
||||||
"B" : horizontal bottom (full screen width)
|
|
||||||
|
|
||||||
g:buffergator_autodismiss_on_select~
|
|
||||||
Default: 1
|
|
||||||
If true, then selection an entry with <CR> will close the catalog. Otherwise,
|
|
||||||
catalog stays open. Default is 1.
|
|
||||||
|
|
||||||
g:buffergator_autoexpand_on_split~
|
|
||||||
Default: 1
|
|
||||||
If true and running in GUI mode, then the application screen will be expanded
|
|
||||||
to accommodate the Buffergator window.
|
|
||||||
|
|
||||||
g:buffergator_split_size~
|
|
||||||
Default: 40
|
|
||||||
If greater than 0, this will be the width of the Buffergator window in any
|
|
||||||
vertical splitting mode, or its height in any horizontal splitting mode.
|
|
||||||
|
|
||||||
g:buffergator_sort_regime~
|
|
||||||
Default: "bufnum"
|
|
||||||
Sets the default sort regime for buffer listing:
|
|
||||||
"bufnum" : sort by buffer number [default]
|
|
||||||
"basename": sort by buffer file basename (followed by directory)
|
|
||||||
"filepath": sort by full buffer filepath
|
|
||||||
"extension": sort by buffer filename extension (followed by full
|
|
||||||
filepath)
|
|
||||||
"mru": sort by most recently used
|
|
||||||
|
|
||||||
g:buffergator_display_regime~
|
|
||||||
Default: "basename"
|
|
||||||
Sets the default sort regime for buffer listing:
|
|
||||||
"basename": display buffer basename first,
|
|
||||||
followed by directory [default]
|
|
||||||
"filepath": display full buffer filepath
|
|
||||||
"bufname": display buffer name
|
|
||||||
|
|
||||||
g:buffergator_suppress_keymaps~
|
|
||||||
Default: 0
|
|
||||||
If true, then Buffergator will not automatically map "<Leader>b" to
|
|
||||||
open the Buffergator catalog and "<Leader>B" to close it.
|
|
||||||
|
|
||||||
vim:tw=78:ts=8:ft=help:norl:
|
|
||||||
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@@ -1,163 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (c) 2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
if !l9#guardScriptLoading(expand('<sfile>:p'), 0, 0, [])
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" GLOBAL FUNCTIONS {{{1
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#bookmarkdir#createHandler(base)
|
|
||||||
return a:base.concretize(copy(s:handler))
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#bookmarkdir#getSwitchOrder()
|
|
||||||
return g:fuf_bookmarkdir_switchOrder
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#bookmarkdir#getEditableDataNames()
|
|
||||||
return ['items']
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#bookmarkdir#renewCache()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#bookmarkdir#requiresOnCommandPre()
|
|
||||||
return 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#bookmarkdir#onInit()
|
|
||||||
call fuf#defineLaunchCommand('FufBookmarkDir', s:MODE_NAME, '""', [])
|
|
||||||
command! -bang -narg=? FufBookmarkDirAdd call s:bookmark(<q-args>)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" LOCAL FUNCTIONS/VARIABLES {{{1
|
|
||||||
|
|
||||||
let s:MODE_NAME = expand('<sfile>:t:r')
|
|
||||||
let s:OPEN_TYPE_DELETE = -1
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:bookmark(word)
|
|
||||||
let item = {
|
|
||||||
\ 'time' : localtime(),
|
|
||||||
\ }
|
|
||||||
|
|
||||||
let item.path = l9#inputHl('Question', '[fuf] Directory to bookmark:',
|
|
||||||
\ fnamemodify(getcwd(), ':p:~'), 'dir')
|
|
||||||
if item.path !~ '\S'
|
|
||||||
call fuf#echoWarning('Canceled')
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
let item.word = l9#inputHl('Question', '[fuf] Bookmark as:',
|
|
||||||
\ fnamemodify(getcwd(), ':p:~'))
|
|
||||||
if item.word !~ '\S'
|
|
||||||
call fuf#echoWarning('Canceled')
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
let items = fuf#loadDataFile(s:MODE_NAME, 'items')
|
|
||||||
call insert(items, item)
|
|
||||||
call fuf#saveDataFile(s:MODE_NAME, 'items', items)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:findItem(items, word)
|
|
||||||
for item in a:items
|
|
||||||
if item.word ==# a:word
|
|
||||||
return item
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
return {}
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" s:handler {{{1
|
|
||||||
|
|
||||||
let s:handler = {}
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getModeName()
|
|
||||||
return s:MODE_NAME
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPrompt()
|
|
||||||
return fuf#formatPrompt(g:fuf_bookmarkdir_prompt, self.partialMatching, '')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPreviewHeight()
|
|
||||||
return 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.isOpenable(enteredPattern)
|
|
||||||
return 1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePatternSet(patternBase)
|
|
||||||
return fuf#makePatternSet(a:patternBase, 's:interpretPrimaryPatternForNonPath',
|
|
||||||
\ self.partialMatching)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePreviewLines(word, count)
|
|
||||||
return []
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getCompleteItems(patternPrimary)
|
|
||||||
return self.items
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onOpen(word, mode)
|
|
||||||
if a:mode ==# s:OPEN_TYPE_DELETE
|
|
||||||
let items = fuf#loadDataFile(s:MODE_NAME, 'items')
|
|
||||||
call filter(items, 'v:val.word !=# a:word')
|
|
||||||
call fuf#saveDataFile(s:MODE_NAME, 'items', items)
|
|
||||||
let self.reservedMode = self.getModeName()
|
|
||||||
return
|
|
||||||
else
|
|
||||||
let item = s:findItem(fuf#loadDataFile(s:MODE_NAME, 'items'), a:word)
|
|
||||||
if !empty(item)
|
|
||||||
execute ':cd ' . fnameescape(item.path)
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPre()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPost()
|
|
||||||
call fuf#defineKeyMappingInHandler(g:fuf_bookmarkdir_keyDelete,
|
|
||||||
\ 'onCr(' . s:OPEN_TYPE_DELETE . ')')
|
|
||||||
let self.items = fuf#loadDataFile(s:MODE_NAME, 'items')
|
|
||||||
call map(self.items, 'fuf#makeNonPathItem(v:val.word, strftime(g:fuf_timeFormat, v:val.time))')
|
|
||||||
call fuf#mapToSetSerialIndex(self.items, 1)
|
|
||||||
call map(self.items, 'fuf#setAbbrWithFormattedWord(v:val, 1)')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeLeavePost(opened)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
@@ -1,199 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (c) 2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
if !l9#guardScriptLoading(expand('<sfile>:p'), 0, 0, [])
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" GLOBAL FUNCTIONS {{{1
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#bookmarkfile#createHandler(base)
|
|
||||||
return a:base.concretize(copy(s:handler))
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#bookmarkfile#getSwitchOrder()
|
|
||||||
return g:fuf_bookmarkfile_switchOrder
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#bookmarkfile#getEditableDataNames()
|
|
||||||
return ['items']
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#bookmarkfile#renewCache()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#bookmarkfile#requiresOnCommandPre()
|
|
||||||
return 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#bookmarkfile#onInit()
|
|
||||||
call fuf#defineLaunchCommand('FufBookmarkFile', s:MODE_NAME, '""', [])
|
|
||||||
command! -bang -narg=? FufBookmarkFileAdd call s:bookmarkHere(<q-args>)
|
|
||||||
command! -bang -narg=0 -range FufBookmarkFileAddAsSelectedText call s:bookmarkHere(l9#getSelectedText())
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" LOCAL FUNCTIONS/VARIABLES {{{1
|
|
||||||
|
|
||||||
let s:MODE_NAME = expand('<sfile>:t:r')
|
|
||||||
let s:OPEN_TYPE_DELETE = -1
|
|
||||||
|
|
||||||
" opens a:path and jumps to the line matching to a:pattern from a:lnum within
|
|
||||||
" a:range. if not found, jumps to a:lnum.
|
|
||||||
function s:jumpToBookmark(path, mode, pattern, lnum)
|
|
||||||
call fuf#openFile(a:path, a:mode, g:fuf_reuseWindow)
|
|
||||||
call cursor(s:getMatchingLineNumber(getline(1, '$'), a:pattern, a:lnum), 0)
|
|
||||||
normal! zvzz
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:getMatchingLineNumber(lines, pattern, lnumBegin)
|
|
||||||
let l = min([a:lnumBegin, len(a:lines)])
|
|
||||||
for [l0, l1] in map(range(0, g:fuf_bookmarkfile_searchRange),
|
|
||||||
\ '[l + v:val, l - v:val]')
|
|
||||||
if l0 <= len(a:lines) && a:lines[l0 - 1] =~# a:pattern
|
|
||||||
return l0
|
|
||||||
elseif l1 >= 0 && a:lines[l1 - 1] =~# a:pattern
|
|
||||||
return l1
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
return l
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:getLinePattern(lnum)
|
|
||||||
return '\C\V\^' . escape(getline(a:lnum), '\') . '\$'
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:bookmarkHere(word)
|
|
||||||
if !empty(&buftype) || expand('%') !~ '\S'
|
|
||||||
call fuf#echoWarning('Can''t bookmark this buffer.')
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
let item = {
|
|
||||||
\ 'word' : (a:word =~# '\S' ? substitute(a:word, '\n', ' ', 'g')
|
|
||||||
\ : pathshorten(expand('%:p:~')) . '|' . line('.') . '| ' . getline('.')),
|
|
||||||
\ 'path' : expand('%:p'),
|
|
||||||
\ 'lnum' : line('.'),
|
|
||||||
\ 'pattern' : s:getLinePattern(line('.')),
|
|
||||||
\ 'time' : localtime(),
|
|
||||||
\ }
|
|
||||||
let item.word = l9#inputHl('Question', '[fuf] Bookmark as:', item.word)
|
|
||||||
if item.word !~ '\S'
|
|
||||||
call fuf#echoWarning('Canceled')
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
let items = fuf#loadDataFile(s:MODE_NAME, 'items')
|
|
||||||
call insert(items, item)
|
|
||||||
call fuf#saveDataFile(s:MODE_NAME, 'items', items)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:findItem(items, word)
|
|
||||||
for item in a:items
|
|
||||||
if item.word ==# a:word
|
|
||||||
return item
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
return {}
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" s:handler {{{1
|
|
||||||
|
|
||||||
let s:handler = {}
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getModeName()
|
|
||||||
return s:MODE_NAME
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPrompt()
|
|
||||||
return fuf#formatPrompt(g:fuf_bookmarkfile_prompt, self.partialMatching, '')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPreviewHeight()
|
|
||||||
return g:fuf_previewHeight
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.isOpenable(enteredPattern)
|
|
||||||
return 1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePatternSet(patternBase)
|
|
||||||
return fuf#makePatternSet(a:patternBase, 's:interpretPrimaryPatternForNonPath',
|
|
||||||
\ self.partialMatching)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePreviewLines(word, count)
|
|
||||||
let item = s:findItem(fuf#loadDataFile(s:MODE_NAME, 'items'), a:word)
|
|
||||||
let lines = fuf#getFileLines(item.path)
|
|
||||||
if empty(lines)
|
|
||||||
return []
|
|
||||||
endif
|
|
||||||
let index = s:getMatchingLineNumber(lines, item.pattern, item.lnum) - 1
|
|
||||||
return fuf#makePreviewLinesAround(
|
|
||||||
\ lines, [index], a:count, self.getPreviewHeight())
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getCompleteItems(patternPrimary)
|
|
||||||
return self.items
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onOpen(word, mode)
|
|
||||||
if a:mode ==# s:OPEN_TYPE_DELETE
|
|
||||||
let items = fuf#loadDataFile(s:MODE_NAME, 'items')
|
|
||||||
call filter(items, 'v:val.word !=# a:word')
|
|
||||||
call fuf#saveDataFile(s:MODE_NAME, 'items', items)
|
|
||||||
let self.reservedMode = self.getModeName()
|
|
||||||
return
|
|
||||||
else
|
|
||||||
let item = s:findItem(fuf#loadDataFile(s:MODE_NAME, 'items'), a:word)
|
|
||||||
if !empty(item)
|
|
||||||
call s:jumpToBookmark(item.path, a:mode, item.pattern, item.lnum)
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPre()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPost()
|
|
||||||
call fuf#defineKeyMappingInHandler(g:fuf_bookmarkfile_keyDelete,
|
|
||||||
\ 'onCr(' . s:OPEN_TYPE_DELETE . ')')
|
|
||||||
let self.items = fuf#loadDataFile(s:MODE_NAME, 'items')
|
|
||||||
call map(self.items, 'fuf#makeNonPathItem(v:val.word, strftime(g:fuf_timeFormat, v:val.time))')
|
|
||||||
call fuf#mapToSetSerialIndex(self.items, 1)
|
|
||||||
call map(self.items, 'fuf#setAbbrWithFormattedWord(v:val, 1)')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeLeavePost(opened)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
@@ -1,189 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (c) 2007-2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
if !l9#guardScriptLoading(expand('<sfile>:p'), 0, 0, [])
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" GLOBAL FUNCTIONS {{{1
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#buffer#createHandler(base)
|
|
||||||
return a:base.concretize(copy(s:handler))
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#buffer#getSwitchOrder()
|
|
||||||
return g:fuf_buffer_switchOrder
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#buffer#getEditableDataNames()
|
|
||||||
return []
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#buffer#renewCache()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#buffer#requiresOnCommandPre()
|
|
||||||
return 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#buffer#onInit()
|
|
||||||
call fuf#defineLaunchCommand('FufBuffer', s:MODE_NAME, '""', [])
|
|
||||||
augroup fuf#buffer
|
|
||||||
autocmd!
|
|
||||||
autocmd BufEnter * call s:updateBufTimes()
|
|
||||||
autocmd BufWritePost * call s:updateBufTimes()
|
|
||||||
augroup END
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" LOCAL FUNCTIONS/VARIABLES {{{1
|
|
||||||
|
|
||||||
let s:MODE_NAME = expand('<sfile>:t:r')
|
|
||||||
let s:OPEN_TYPE_DELETE = -1
|
|
||||||
|
|
||||||
let s:bufTimes = {}
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:updateBufTimes()
|
|
||||||
let s:bufTimes[bufnr('%')] = localtime()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:makeItem(nr)
|
|
||||||
let fname = (empty(bufname(a:nr))
|
|
||||||
\ ? '[No Name]'
|
|
||||||
\ : fnamemodify(bufname(a:nr), ':p:~:.'))
|
|
||||||
let time = (exists('s:bufTimes[a:nr]') ? s:bufTimes[a:nr] : 0)
|
|
||||||
let item = fuf#makePathItem(fname, strftime(g:fuf_timeFormat, time), 0)
|
|
||||||
let item.index = a:nr
|
|
||||||
let item.bufNr = a:nr
|
|
||||||
let item.time = time
|
|
||||||
let item.abbrPrefix = s:getBufIndicator(a:nr) . ' '
|
|
||||||
return item
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:getBufIndicator(bufNr)
|
|
||||||
if !getbufvar(a:bufNr, '&modifiable')
|
|
||||||
return '[-]'
|
|
||||||
elseif getbufvar(a:bufNr, '&modified')
|
|
||||||
return '[+]'
|
|
||||||
elseif getbufvar(a:bufNr, '&readonly')
|
|
||||||
return '[R]'
|
|
||||||
else
|
|
||||||
return ' '
|
|
||||||
endif
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:compareTimeDescending(i1, i2)
|
|
||||||
return a:i1.time == a:i2.time ? 0 : a:i1.time > a:i2.time ? -1 : +1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:findItem(items, word)
|
|
||||||
for item in a:items
|
|
||||||
if item.word ==# a:word
|
|
||||||
return item
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
return {}
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" s:handler {{{1
|
|
||||||
|
|
||||||
let s:handler = {}
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getModeName()
|
|
||||||
return s:MODE_NAME
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPrompt()
|
|
||||||
return fuf#formatPrompt(g:fuf_buffer_prompt, self.partialMatching, '')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPreviewHeight()
|
|
||||||
return g:fuf_previewHeight
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.isOpenable(enteredPattern)
|
|
||||||
return 1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePatternSet(patternBase)
|
|
||||||
return fuf#makePatternSet(a:patternBase, 's:interpretPrimaryPatternForPath',
|
|
||||||
\ self.partialMatching)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePreviewLines(word, count)
|
|
||||||
let item = s:findItem(self.items, a:word)
|
|
||||||
if empty(item)
|
|
||||||
return []
|
|
||||||
endif
|
|
||||||
return fuf#makePreviewLinesForFile(item.bufNr, a:count, self.getPreviewHeight())
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getCompleteItems(patternPrimary)
|
|
||||||
return self.items
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onOpen(word, mode)
|
|
||||||
" not use bufnr(a:word) in order to handle unnamed buffer
|
|
||||||
let item = s:findItem(self.items, a:word)
|
|
||||||
if empty(item)
|
|
||||||
" do nothing
|
|
||||||
elseif a:mode ==# s:OPEN_TYPE_DELETE
|
|
||||||
execute item.bufNr . 'bdelete'
|
|
||||||
let self.reservedMode = self.getModeName()
|
|
||||||
else
|
|
||||||
call fuf#openBuffer(item.bufNr, a:mode, g:fuf_reuseWindow)
|
|
||||||
endif
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPre()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPost()
|
|
||||||
call fuf#defineKeyMappingInHandler(g:fuf_buffer_keyDelete,
|
|
||||||
\ 'onCr(' . s:OPEN_TYPE_DELETE . ')')
|
|
||||||
let self.items = range(1, bufnr('$'))
|
|
||||||
call filter(self.items, 'buflisted(v:val) && v:val != self.bufNrPrev && v:val != bufnr("%")')
|
|
||||||
call map(self.items, 's:makeItem(v:val)')
|
|
||||||
if g:fuf_buffer_mruOrder
|
|
||||||
call sort(self.items, 's:compareTimeDescending')
|
|
||||||
call fuf#mapToSetSerialIndex(self.items, 1)
|
|
||||||
endif
|
|
||||||
let self.items = fuf#mapToSetAbbrWithSnippedWordAsPath(self.items)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeLeavePost(opened)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
@@ -1,300 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (c) 2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
if !l9#guardScriptLoading(expand('<sfile>:p'), 0, 0, [])
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" GLOBAL FUNCTIONS {{{1
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#buffertag#createHandler(base)
|
|
||||||
return a:base.concretize(copy(s:handler))
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#buffertag#getSwitchOrder()
|
|
||||||
return g:fuf_buffertag_switchOrder
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#buffertag#getEditableDataNames()
|
|
||||||
return []
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#buffertag#renewCache()
|
|
||||||
let s:tagItemsCache = {}
|
|
||||||
let s:tagDataCache = {}
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#buffertag#requiresOnCommandPre()
|
|
||||||
return 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#buffertag#onInit()
|
|
||||||
call fuf#defineLaunchCommand('FufBufferTag', s:MODE_NAME, '""',
|
|
||||||
\ [['g:fuf_buffertag_forAll', 0]])
|
|
||||||
call fuf#defineLaunchCommand('FufBufferTagAll', s:MODE_NAME, '""',
|
|
||||||
\ [['g:fuf_buffertag_forAll', 1]])
|
|
||||||
call fuf#defineLaunchCommand('FufBufferTagWithCursorWord', s:MODE_NAME,
|
|
||||||
\ 'expand(''<cword>'')', [['g:fuf_buffertag_forAll', 0]])
|
|
||||||
call fuf#defineLaunchCommand('FufBufferTagAllWithCursorWord', s:MODE_NAME,
|
|
||||||
\ 'expand(''<cword>'')', [['g:fuf_buffertag_forAll', 1]])
|
|
||||||
call fuf#defineLaunchCommand('FufBufferTagWithSelectedText', s:MODE_NAME,
|
|
||||||
\ 'l9#getSelectedText()', [['g:fuf_buffertag_forAll', 0]])
|
|
||||||
call fuf#defineLaunchCommand('FufBufferTagAllWithSelectedText', s:MODE_NAME,
|
|
||||||
\ 'l9#getSelectedText()', [['g:fuf_buffertag_forAll', 1]])
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag_forAll', 0) " private option
|
|
||||||
" the following settings originate from taglist.vim
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__asm' , '--language-force=asm --asm-types=dlmt')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__aspperl' , '--language-force=asp --asp-types=fsv')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__aspvbs' , '--language-force=asp --asp-types=fsv')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__awk' , '--language-force=awk --awk-types=f')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__beta' , '--language-force=beta --beta-types=fsv')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__c' , '--language-force=c --c-types=dgsutvf')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__cpp' , '--language-force=c++ --c++-types=nvdtcgsuf')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__cs' , '--language-force=c# --c#-types=dtncEgsipm')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__cobol' , '--language-force=cobol --cobol-types=dfgpPs')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__eiffel' , '--language-force=eiffel --eiffel-types=cf')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__erlang' , '--language-force=erlang --erlang-types=drmf')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__expect' , '--language-force=tcl --tcl-types=cfp')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__fortran' , '--language-force=fortran --fortran-types=pbceiklmntvfs')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__html' , '--language-force=html --html-types=af')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__java' , '--language-force=java --java-types=pcifm')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__javascript', '--language-force=javascript --javascript-types=f')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__lisp' , '--language-force=lisp --lisp-types=f')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__lua' , '--language-force=lua --lua-types=f')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__make' , '--language-force=make --make-types=m')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__pascal' , '--language-force=pascal --pascal-types=fp')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__perl' , '--language-force=perl --perl-types=clps')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__php' , '--language-force=php --php-types=cdvf')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__python' , '--language-force=python --python-types=cmf')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__rexx' , '--language-force=rexx --rexx-types=s')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__ruby' , '--language-force=ruby --ruby-types=cfFm')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__scheme' , '--language-force=scheme --scheme-types=sf')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__sh' , '--language-force=sh --sh-types=f')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__csh' , '--language-force=sh --sh-types=f')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__zsh' , '--language-force=sh --sh-types=f')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__slang' , '--language-force=slang --slang-types=nf')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__sml' , '--language-force=sml --sml-types=ecsrtvf')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__sql' , '--language-force=sql --sql-types=cFPrstTvfp')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__tcl' , '--language-force=tcl --tcl-types=cfmp')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__vera' , '--language-force=vera --vera-types=cdefgmpPtTvx')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__verilog' , '--language-force=verilog --verilog-types=mcPertwpvf')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__vim' , '--language-force=vim --vim-types=avf')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag__yacc' , '--language-force=yacc --yacc-types=l')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" LOCAL FUNCTIONS/VARIABLES {{{1
|
|
||||||
|
|
||||||
let s:MODE_NAME = expand('<sfile>:t:r')
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:parseTagLine(line)
|
|
||||||
" tag W:\Win32\SRC7\NCSIM\NCVW32\CUBEFACE.H /^#define CUBEFACE_H$/;" macro line:4
|
|
||||||
let fields = matchlist(a:line, '\v^([^\t]+)\t(.+)\t\/\^(.+)\$\/\;\"\t(.+)\tline\:(\d+)')
|
|
||||||
if empty(fields)
|
|
||||||
return {}
|
|
||||||
endif
|
|
||||||
return {
|
|
||||||
\ 'tag' : fields[1],
|
|
||||||
\ 'fname' : fields[2],
|
|
||||||
\ 'pattern': fields[3],
|
|
||||||
\ 'kind' : fields[4],
|
|
||||||
\ 'lnum' : str2nr(fields[5]),
|
|
||||||
\ }
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
let s:TEMP_VARIABLES_GROUP = expand('<sfile>:p')
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:getFileType(bufNr)
|
|
||||||
let ft = getbufvar(a:bufNr, '&filetype')
|
|
||||||
if !empty(ft) || bufloaded(a:bufNr)
|
|
||||||
return ft
|
|
||||||
endif
|
|
||||||
let ft = getbufvar(a:bufNr, 'fuf_buffertag_filetype')
|
|
||||||
if !empty(ft)
|
|
||||||
return ft
|
|
||||||
endif
|
|
||||||
call l9#tempvariables#set(s:TEMP_VARIABLES_GROUP, '&eventignore', 'FileType')
|
|
||||||
call l9#tempvariables#set(s:TEMP_VARIABLES_GROUP, '&filetype', &filetype)
|
|
||||||
" from taglist.vim
|
|
||||||
execute 'doautocmd filetypedetect BufRead ' . bufname(a:bufNr)
|
|
||||||
let ft = &filetype
|
|
||||||
call l9#tempvariables#end(s:TEMP_VARIABLES_GROUP)
|
|
||||||
call setbufvar(a:bufNr, 'fuf_buffertag_filetype', ft)
|
|
||||||
return ft
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:makeCtagsCmd(bufNr)
|
|
||||||
let ft = s:getFileType(a:bufNr)
|
|
||||||
if !exists('g:fuf_buffertag__{ft}')
|
|
||||||
return ''
|
|
||||||
endif
|
|
||||||
"
|
|
||||||
let cmd = join([g:fuf_buffertag_ctagsPath,
|
|
||||||
\ '-f - --sort=no --excmd=pattern --fields=nKs',
|
|
||||||
\ g:fuf_buffertag__{ft},
|
|
||||||
\ shellescape(fnamemodify(bufname(a:bufNr), ':p'))])
|
|
||||||
return cmd
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:getTagItems(bufNr)
|
|
||||||
let cmd = s:makeCtagsCmd(a:bufNr)
|
|
||||||
if empty(cmd)
|
|
||||||
return []
|
|
||||||
elseif !exists('s:tagItemsCache[cmd]') ||
|
|
||||||
\ s:tagItemsCache[cmd].time < getftime(expand(bufname(a:bufNr)))
|
|
||||||
let items = split(system(cmd), "\n")
|
|
||||||
if v:shell_error
|
|
||||||
call fuf#echoError([cmd] + items)
|
|
||||||
throw "Command error"
|
|
||||||
endif
|
|
||||||
call map(items, 's:parseTagLine(v:val)')
|
|
||||||
call filter(items, '!empty(v:val)')
|
|
||||||
let s:tagItemsCache[cmd] = {
|
|
||||||
\ 'time' : localtime(),
|
|
||||||
\ 'items' : items,
|
|
||||||
\ }
|
|
||||||
endif
|
|
||||||
return s:tagItemsCache[cmd].items
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:makeItem(tag, itemMap)
|
|
||||||
let menu = fnamemodify(a:itemMap[a:tag][0].fname, ':t')
|
|
||||||
\ . ' [' . a:itemMap[a:tag][0].kind . ']'
|
|
||||||
if len(a:itemMap[a:tag]) > 1
|
|
||||||
let menu .= ' (' . len(a:itemMap[a:tag]) . ')'
|
|
||||||
endif
|
|
||||||
let item = fuf#makeNonPathItem(a:tag, menu)
|
|
||||||
return item
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:getTagData(bufNrs)
|
|
||||||
let key = join([0] + sort(copy(a:bufNrs)), "\n")
|
|
||||||
let bufNames = map(copy(a:bufNrs), 'bufname(v:val)')
|
|
||||||
if !exists('s:tagDataCache[key]') ||
|
|
||||||
\ fuf#countModifiedFiles(bufNames, s:tagDataCache[key].time) > 0
|
|
||||||
let itemMap = {}
|
|
||||||
for item in l9#concat(map(copy(a:bufNrs), 's:getTagItems(v:val)'))
|
|
||||||
if !exists('itemMap[item.tag]')
|
|
||||||
let itemMap[item.tag] = []
|
|
||||||
endif
|
|
||||||
call add(itemMap[item.tag], item)
|
|
||||||
endfor
|
|
||||||
let items = sort(keys(itemMap))
|
|
||||||
call map(items, 's:makeItem(v:val, itemMap)')
|
|
||||||
call fuf#mapToSetSerialIndex(items, 1)
|
|
||||||
call map(items, 'fuf#setAbbrWithFormattedWord(v:val, 1)')
|
|
||||||
let s:tagDataCache[key] = {
|
|
||||||
\ 'time' : localtime(),
|
|
||||||
\ 'itemMap': itemMap,
|
|
||||||
\ 'items' : items,
|
|
||||||
\ }
|
|
||||||
endif
|
|
||||||
return [s:tagDataCache[key].items, s:tagDataCache[key].itemMap]
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:jumpToTag(item, mode)
|
|
||||||
call fuf#openFile(a:item.fname, a:mode, g:fuf_reuseWindow)
|
|
||||||
call cursor(a:item.lnum, 1)
|
|
||||||
normal! zvzz
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" s:handler {{{1
|
|
||||||
|
|
||||||
let s:handler = {}
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getModeName()
|
|
||||||
return s:MODE_NAME
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPrompt()
|
|
||||||
return fuf#formatPrompt(g:fuf_buffertag_prompt, self.partialMatching, '')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPreviewHeight()
|
|
||||||
return 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.isOpenable(enteredPattern)
|
|
||||||
return 1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePatternSet(patternBase)
|
|
||||||
return fuf#makePatternSet(a:patternBase, 's:interpretPrimaryPatternForNonPath',
|
|
||||||
\ self.partialMatching)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePreviewLines(word, count)
|
|
||||||
return []
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getCompleteItems(patternPrimary)
|
|
||||||
return self.items
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onOpen(word, mode)
|
|
||||||
if !exists('self.itemMap[a:word][0]')
|
|
||||||
call fuf#echoError('Definition not found:' . a:word)
|
|
||||||
return
|
|
||||||
elseif len(self.itemMap[a:word]) == 1
|
|
||||||
let i = 0
|
|
||||||
else
|
|
||||||
let list = map(fuf#mapToSetSerialIndex(copy(self.itemMap[a:word]), 1),
|
|
||||||
\ 'printf(" %2d: %s|%d| [%s] %s",v:val.index, fnamemodify(v:val.fname, ":~:."), v:val.lnum, v:val.kind, v:val.pattern)')
|
|
||||||
let i = inputlist(['Select a definition of "' . a:word . '":'] + list) - 1
|
|
||||||
endif
|
|
||||||
if 0 <= i && i < len(self.itemMap[a:word])
|
|
||||||
call s:jumpToTag(self.itemMap[a:word][i], a:mode)
|
|
||||||
endif
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPre()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPost()
|
|
||||||
if g:fuf_buffertag_forAll
|
|
||||||
let bufNrs = filter(range(1, bufnr('$')), 'buflisted(v:val)')
|
|
||||||
else
|
|
||||||
let bufNrs = [self.bufNrPrev]
|
|
||||||
endif
|
|
||||||
let [self.items, self.itemMap] = s:getTagData(bufNrs)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeLeavePost(opened)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
@@ -1,137 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (c) 2007-2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
if !l9#guardScriptLoading(expand('<sfile>:p'), 0, 0, [])
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" GLOBAL FUNCTIONS {{{1
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#callbackfile#createHandler(base)
|
|
||||||
return a:base.concretize(copy(s:handler))
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#callbackfile#getSwitchOrder()
|
|
||||||
return -1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#callbackfile#getEditableDataNames()
|
|
||||||
return []
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#callbackfile#renewCache()
|
|
||||||
let s:cache = {}
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#callbackfile#requiresOnCommandPre()
|
|
||||||
return 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#callbackfile#onInit()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#callbackfile#launch(initialPattern, partialMatching, prompt, exclude, listener)
|
|
||||||
let s:prompt = (empty(a:prompt) ? '>' : a:prompt)
|
|
||||||
let s:exclude = a:exclude
|
|
||||||
let s:listener = a:listener
|
|
||||||
call fuf#launch(s:MODE_NAME, a:initialPattern, a:partialMatching)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" LOCAL FUNCTIONS/VARIABLES {{{1
|
|
||||||
|
|
||||||
let s:MODE_NAME = expand('<sfile>:t:r')
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:enumItems(dir)
|
|
||||||
let key = getcwd() . g:fuf_ignoreCase . s:exclude . "\n" . a:dir
|
|
||||||
if !exists('s:cache[key]')
|
|
||||||
let s:cache[key] = fuf#enumExpandedDirsEntries(a:dir, s:exclude)
|
|
||||||
if isdirectory(a:dir)
|
|
||||||
call insert(s:cache[key], fuf#makePathItem(a:dir . '.', '', 0))
|
|
||||||
endif
|
|
||||||
call fuf#mapToSetSerialIndex(s:cache[key], 1)
|
|
||||||
call fuf#mapToSetAbbrWithSnippedWordAsPath(s:cache[key])
|
|
||||||
endif
|
|
||||||
return s:cache[key]
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" s:handler {{{1
|
|
||||||
|
|
||||||
let s:handler = {}
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getModeName()
|
|
||||||
return s:MODE_NAME
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPrompt()
|
|
||||||
return fuf#formatPrompt(s:prompt, self.partialMatching, '')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPreviewHeight()
|
|
||||||
return g:fuf_previewHeight
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.isOpenable(enteredPattern)
|
|
||||||
return a:enteredPattern =~# '[^/\\]$'
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePatternSet(patternBase)
|
|
||||||
return fuf#makePatternSet(a:patternBase, 's:interpretPrimaryPatternForPathTail',
|
|
||||||
\ self.partialMatching)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePreviewLines(word, count)
|
|
||||||
return fuf#makePreviewLinesForFile(a:word, a:count, self.getPreviewHeight())
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getCompleteItems(patternPrimary)
|
|
||||||
let items = copy(s:enumItems(fuf#splitPath(a:patternPrimary).head))
|
|
||||||
return filter(items, 'bufnr("^" . v:val.word . "$") != self.bufNrPrev')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onOpen(word, mode)
|
|
||||||
call s:listener.onComplete(a:word, a:mode)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPre()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPost()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeLeavePost(opened)
|
|
||||||
if !a:opened && exists('s:listener.onAbort()')
|
|
||||||
call s:listener.onAbort()
|
|
||||||
endif
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
@@ -1,139 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (c) 2007-2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
if !l9#guardScriptLoading(expand('<sfile>:p'), 0, 0, [])
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" GLOBAL FUNCTIONS {{{1
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#callbackitem#createHandler(base)
|
|
||||||
return a:base.concretize(copy(s:handler))
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#callbackitem#getSwitchOrder()
|
|
||||||
return -1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#callbackitem#getEditableDataNames()
|
|
||||||
return []
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#callbackitem#renewCache()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#callbackitem#requiresOnCommandPre()
|
|
||||||
return 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#callbackitem#onInit()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#callbackitem#launch(initialPattern, partialMatching, prompt, listener, items, forPath)
|
|
||||||
let s:prompt = (empty(a:prompt) ? '>' : a:prompt)
|
|
||||||
let s:listener = a:listener
|
|
||||||
let s:forPath = a:forPath
|
|
||||||
let s:items = copy(a:items)
|
|
||||||
if s:forPath
|
|
||||||
call map(s:items, 'fuf#makePathItem(v:val, "", 1)')
|
|
||||||
call fuf#mapToSetSerialIndex(s:items, 1)
|
|
||||||
call fuf#mapToSetAbbrWithSnippedWordAsPath(s:items)
|
|
||||||
else
|
|
||||||
call map(s:items, 'fuf#makeNonPathItem(v:val, "")')
|
|
||||||
call fuf#mapToSetSerialIndex(s:items, 1)
|
|
||||||
call map(s:items, 'fuf#setAbbrWithFormattedWord(v:val, 1)')
|
|
||||||
endif
|
|
||||||
call fuf#launch(s:MODE_NAME, a:initialPattern, a:partialMatching)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" LOCAL FUNCTIONS/VARIABLES {{{1
|
|
||||||
|
|
||||||
let s:MODE_NAME = expand('<sfile>:t:r')
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" s:handler {{{1
|
|
||||||
|
|
||||||
let s:handler = {}
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getModeName()
|
|
||||||
return s:MODE_NAME
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPrompt()
|
|
||||||
return fuf#formatPrompt(s:prompt, self.partialMatching, '')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPreviewHeight()
|
|
||||||
if s:forPath
|
|
||||||
return g:fuf_previewHeight
|
|
||||||
endif
|
|
||||||
return 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.isOpenable(enteredPattern)
|
|
||||||
return 1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePatternSet(patternBase)
|
|
||||||
let parser = (s:forPath
|
|
||||||
\ ? 's:interpretPrimaryPatternForPath'
|
|
||||||
\ : 's:interpretPrimaryPatternForNonPath')
|
|
||||||
return fuf#makePatternSet(a:patternBase, parser, self.partialMatching)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePreviewLines(word, count)
|
|
||||||
if s:forPath
|
|
||||||
return fuf#makePreviewLinesForFile(a:word, a:count, self.getPreviewHeight())
|
|
||||||
endif
|
|
||||||
return []
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getCompleteItems(patternPrimary)
|
|
||||||
return s:items
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onOpen(word, mode)
|
|
||||||
call s:listener.onComplete(a:word, a:mode)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPre()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPost()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeLeavePost(opened)
|
|
||||||
if !a:opened && exists('s:listener.onAbort()')
|
|
||||||
call s:listener.onAbort()
|
|
||||||
endif
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
@@ -1,172 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (c) 2007-2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
if !l9#guardScriptLoading(expand('<sfile>:p'), 0, 0, [])
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" GLOBAL FUNCTIONS {{{1
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#changelist#createHandler(base)
|
|
||||||
return a:base.concretize(copy(s:handler))
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#changelist#getSwitchOrder()
|
|
||||||
return g:fuf_changelist_switchOrder
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#changelist#getEditableDataNames()
|
|
||||||
return []
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#changelist#renewCache()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#changelist#requiresOnCommandPre()
|
|
||||||
return 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#changelist#onInit()
|
|
||||||
call fuf#defineLaunchCommand('FufChangeList', s:MODE_NAME, '""', [])
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" LOCAL FUNCTIONS/VARIABLES {{{1
|
|
||||||
|
|
||||||
let s:MODE_NAME = expand('<sfile>:t:r')
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:getChangesLines()
|
|
||||||
redir => result
|
|
||||||
:silent changes
|
|
||||||
redir END
|
|
||||||
return split(result, "\n")
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:parseChangesLine(line)
|
|
||||||
" return matchlist(a:line, '^\(.\)\s\+\(\d\+\)\s\(.*\)$')
|
|
||||||
let elements = matchlist(a:line, '\v^(.)\s*(\d+)\s+(\d+)\s+(\d+)\s*(.*)$')
|
|
||||||
if empty(elements)
|
|
||||||
return {}
|
|
||||||
endif
|
|
||||||
return {
|
|
||||||
\ 'prefix': elements[1],
|
|
||||||
\ 'count' : elements[2],
|
|
||||||
\ 'lnum' : elements[3],
|
|
||||||
\ 'text' : printf('|%d:%d|%s', elements[3], elements[4], elements[5]),
|
|
||||||
\ }
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:makeItem(line)
|
|
||||||
let parsed = s:parseChangesLine(a:line)
|
|
||||||
if empty(parsed)
|
|
||||||
return {}
|
|
||||||
endif
|
|
||||||
let item = fuf#makeNonPathItem(parsed.text, '')
|
|
||||||
let item.abbrPrefix = parsed.prefix
|
|
||||||
let item.lnum = parsed.lnum
|
|
||||||
return item
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" s:handler {{{1
|
|
||||||
|
|
||||||
let s:handler = {}
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getModeName()
|
|
||||||
return s:MODE_NAME
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPrompt()
|
|
||||||
return fuf#formatPrompt(g:fuf_changelist_prompt, self.partialMatching, '')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPreviewHeight()
|
|
||||||
return g:fuf_previewHeight
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.isOpenable(enteredPattern)
|
|
||||||
return 1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePatternSet(patternBase)
|
|
||||||
return fuf#makePatternSet(a:patternBase, 's:interpretPrimaryPatternForNonPath',
|
|
||||||
\ self.partialMatching)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePreviewLines(word, count)
|
|
||||||
let items = filter(copy(self.items), 'v:val.word ==# a:word')
|
|
||||||
if empty(items)
|
|
||||||
return []
|
|
||||||
endif
|
|
||||||
let lines = fuf#getFileLines(self.bufNrPrev)
|
|
||||||
return fuf#makePreviewLinesAround(
|
|
||||||
\ lines, [items[0].lnum - 1], a:count, self.getPreviewHeight())
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getCompleteItems(patternPrimary)
|
|
||||||
return self.items
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onOpen(word, mode)
|
|
||||||
call fuf#prejump(a:mode)
|
|
||||||
let older = 0
|
|
||||||
for line in reverse(s:getChangesLines())
|
|
||||||
if stridx(line, '>') == 0
|
|
||||||
let older = 1
|
|
||||||
endif
|
|
||||||
let parsed = s:parseChangesLine(line)
|
|
||||||
if !empty(parsed) && parsed.text ==# a:word
|
|
||||||
if parsed.count != 0
|
|
||||||
execute 'normal! ' . parsed.count . (older ? 'g;' : 'g,') . 'zvzz'
|
|
||||||
endif
|
|
||||||
break
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPre()
|
|
||||||
let self.items = s:getChangesLines()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPost()
|
|
||||||
call map(self.items, 's:makeItem(v:val)')
|
|
||||||
call filter(self.items, '!empty(v:val)')
|
|
||||||
call reverse(self.items)
|
|
||||||
call fuf#mapToSetSerialIndex(self.items, 1)
|
|
||||||
call map(self.items, 'fuf#setAbbrWithFormattedWord(v:val, 1)')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeLeavePost(opened)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
|
|
||||||
@@ -1,199 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (c) 2007-2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
if !l9#guardScriptLoading(expand('<sfile>:p'), 0, 0, [])
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" GLOBAL FUNCTIONS {{{1
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#coveragefile#createHandler(base)
|
|
||||||
return a:base.concretize(copy(s:handler))
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#coveragefile#getSwitchOrder()
|
|
||||||
return g:fuf_coveragefile_switchOrder
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#coveragefile#getEditableDataNames()
|
|
||||||
return ['coverages']
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#coveragefile#renewCache()
|
|
||||||
let s:cache = {}
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#coveragefile#requiresOnCommandPre()
|
|
||||||
return 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#coveragefile#onInit()
|
|
||||||
call fuf#defineLaunchCommand('FufCoverageFile', s:MODE_NAME, '""', [])
|
|
||||||
call l9#defineVariableDefault('g:fuf_coveragefile_name', '') " private option
|
|
||||||
command! -bang -narg=0 FufCoverageFileRegister call s:registerCoverage()
|
|
||||||
command! -bang -narg=? FufCoverageFileChange call s:changeCoverage(<q-args>)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" LOCAL FUNCTIONS/VARIABLES {{{1
|
|
||||||
|
|
||||||
let s:MODE_NAME = expand('<sfile>:t:r')
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:enumItems()
|
|
||||||
let key = join([getcwd(), g:fuf_ignoreCase, g:fuf_coveragefile_exclude,
|
|
||||||
\ g:fuf_coveragefile_globPatterns], "\n")
|
|
||||||
if !exists('s:cache[key]')
|
|
||||||
let s:cache[key] = l9#concat(map(copy(g:fuf_coveragefile_globPatterns),
|
|
||||||
\ 'fuf#glob(v:val)'))
|
|
||||||
call filter(s:cache[key], 'filereadable(v:val)') " filter out directories
|
|
||||||
call map(s:cache[key], 'fuf#makePathItem(fnamemodify(v:val, ":~:."), "", 0)')
|
|
||||||
if len(g:fuf_coveragefile_exclude)
|
|
||||||
call filter(s:cache[key], 'v:val.word !~ g:fuf_coveragefile_exclude')
|
|
||||||
endif
|
|
||||||
call fuf#mapToSetSerialIndex(s:cache[key], 1)
|
|
||||||
call fuf#mapToSetAbbrWithSnippedWordAsPath(s:cache[key])
|
|
||||||
endif
|
|
||||||
return s:cache[key]
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:registerCoverage()
|
|
||||||
let patterns = []
|
|
||||||
while 1
|
|
||||||
let pattern = l9#inputHl('Question', '[fuf] Glob pattern for coverage (<Esc> and end):',
|
|
||||||
\ '', 'file')
|
|
||||||
if pattern !~ '\S'
|
|
||||||
break
|
|
||||||
endif
|
|
||||||
call add(patterns, pattern)
|
|
||||||
endwhile
|
|
||||||
if empty(patterns)
|
|
||||||
call fuf#echoWarning('Canceled')
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
echo '[fuf] patterns: ' . string(patterns)
|
|
||||||
let name = l9#inputHl('Question', '[fuf] Coverage name:')
|
|
||||||
if name !~ '\S'
|
|
||||||
call fuf#echoWarning('Canceled')
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
let coverages = fuf#loadDataFile(s:MODE_NAME, 'coverages')
|
|
||||||
call insert(coverages, {'name': name, 'patterns': patterns})
|
|
||||||
call fuf#saveDataFile(s:MODE_NAME, 'coverages', coverages)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:createChangeCoverageListener()
|
|
||||||
let listener = {}
|
|
||||||
|
|
||||||
function listener.onComplete(name, method)
|
|
||||||
call s:changeCoverage(a:name)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
return listener
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:changeCoverage(name)
|
|
||||||
let coverages = fuf#loadDataFile(s:MODE_NAME, 'coverages')
|
|
||||||
if a:name !~ '\S'
|
|
||||||
let names = map(copy(coverages), 'v:val.name')
|
|
||||||
call fuf#callbackitem#launch('', 0, '>Coverage>', s:createChangeCoverageListener(), names, 0)
|
|
||||||
return
|
|
||||||
else
|
|
||||||
let name = a:name
|
|
||||||
endif
|
|
||||||
call filter(coverages, 'v:val.name ==# name')
|
|
||||||
if empty(coverages)
|
|
||||||
call fuf#echoError('Coverage not found: ' . name)
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
call fuf#setOneTimeVariables(
|
|
||||||
\ ['g:fuf_coveragefile_globPatterns', coverages[0].patterns],
|
|
||||||
\ ['g:fuf_coveragefile_name' , a:name]
|
|
||||||
\ )
|
|
||||||
FufCoverageFile
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" s:handler {{{1
|
|
||||||
|
|
||||||
let s:handler = {}
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getModeName()
|
|
||||||
return s:MODE_NAME
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPrompt()
|
|
||||||
let nameString = (empty(g:fuf_coveragefile_name) ? ''
|
|
||||||
\ : '[' . g:fuf_coveragefile_name . ']')
|
|
||||||
return fuf#formatPrompt(g:fuf_coveragefile_prompt, self.partialMatching,
|
|
||||||
\ nameString)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPreviewHeight()
|
|
||||||
return g:fuf_previewHeight
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.isOpenable(enteredPattern)
|
|
||||||
return 1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePatternSet(patternBase)
|
|
||||||
return fuf#makePatternSet(a:patternBase, 's:interpretPrimaryPatternForPath',
|
|
||||||
\ self.partialMatching)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePreviewLines(word, count)
|
|
||||||
return fuf#makePreviewLinesForFile(a:word, a:count, self.getPreviewHeight())
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getCompleteItems(patternPrimary)
|
|
||||||
return self.items
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onOpen(word, mode)
|
|
||||||
call fuf#openFile(a:word, a:mode, g:fuf_reuseWindow)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPre()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPost()
|
|
||||||
" NOTE: Comparing filenames is faster than bufnr('^' . fname . '$')
|
|
||||||
let bufNamePrev = fnamemodify(bufname(self.bufNrPrev), ':~:.')
|
|
||||||
let self.items = copy(s:enumItems())
|
|
||||||
call filter(self.items, 'v:val.word !=# bufNamePrev')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeLeavePost(opened)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
@@ -1,132 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (c) 2007-2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
if !l9#guardScriptLoading(expand('<sfile>:p'), 0, 0, [])
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" GLOBAL FUNCTIONS {{{1
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#dir#createHandler(base)
|
|
||||||
return a:base.concretize(copy(s:handler))
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#dir#getSwitchOrder()
|
|
||||||
return g:fuf_dir_switchOrder
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#dir#getEditableDataNames()
|
|
||||||
return []
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#dir#renewCache()
|
|
||||||
let s:cache = {}
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#dir#requiresOnCommandPre()
|
|
||||||
return 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#dir#onInit()
|
|
||||||
call fuf#defineLaunchCommand('FufDir' , s:MODE_NAME, '""', [])
|
|
||||||
call fuf#defineLaunchCommand('FufDirWithFullCwd' , s:MODE_NAME, 'fnamemodify(getcwd(), '':p'')', [])
|
|
||||||
call fuf#defineLaunchCommand('FufDirWithCurrentBufferDir', s:MODE_NAME, 'expand(''%:~:.'')[:-1-len(expand(''%:~:.:t''))]', [])
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" LOCAL FUNCTIONS/VARIABLES {{{1
|
|
||||||
|
|
||||||
let s:MODE_NAME = expand('<sfile>:t:r')
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:enumItems(dir)
|
|
||||||
let key = getcwd() . g:fuf_ignoreCase . g:fuf_dir_exclude . "\n" . a:dir
|
|
||||||
if !exists('s:cache[key]')
|
|
||||||
let s:cache[key] = fuf#enumExpandedDirsEntries(a:dir, g:fuf_dir_exclude)
|
|
||||||
call filter(s:cache[key], 'v:val.word =~# ''[/\\]$''')
|
|
||||||
if isdirectory(a:dir)
|
|
||||||
call insert(s:cache[key], fuf#makePathItem(a:dir . '.', '', 0))
|
|
||||||
endif
|
|
||||||
call fuf#mapToSetSerialIndex(s:cache[key], 1)
|
|
||||||
call fuf#mapToSetAbbrWithSnippedWordAsPath(s:cache[key])
|
|
||||||
endif
|
|
||||||
return s:cache[key]
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" s:handler {{{1
|
|
||||||
|
|
||||||
let s:handler = {}
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getModeName()
|
|
||||||
return s:MODE_NAME
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPrompt()
|
|
||||||
return fuf#formatPrompt(g:fuf_dir_prompt, self.partialMatching, '')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPreviewHeight()
|
|
||||||
return g:fuf_previewHeight
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.isOpenable(enteredPattern)
|
|
||||||
return a:enteredPattern =~# '[^/\\]$'
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePatternSet(patternBase)
|
|
||||||
return fuf#makePatternSet(a:patternBase, 's:interpretPrimaryPatternForPathTail',
|
|
||||||
\ self.partialMatching)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePreviewLines(word, count)
|
|
||||||
return fuf#makePreviewLinesAround(
|
|
||||||
\ fuf#glob(fnamemodify(a:word, ':p') . '*'),
|
|
||||||
\ [], a:count, self.getPreviewHeight())
|
|
||||||
return
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getCompleteItems(patternPrimary)
|
|
||||||
return s:enumItems(fuf#splitPath(a:patternPrimary).head)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onOpen(word, mode)
|
|
||||||
execute ':cd ' . fnameescape(a:word)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPre()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPost()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeLeavePost(opened)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
@@ -1,139 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (c) 2007-2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
if !l9#guardScriptLoading(expand('<sfile>:p'), 0, 0, [])
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" GLOBAL FUNCTIONS {{{1
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#file#createHandler(base)
|
|
||||||
return a:base.concretize(copy(s:handler))
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#file#getSwitchOrder()
|
|
||||||
return g:fuf_file_switchOrder
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#file#getEditableDataNames()
|
|
||||||
return []
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#file#renewCache()
|
|
||||||
let s:cache = {}
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#file#requiresOnCommandPre()
|
|
||||||
return 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#file#onInit()
|
|
||||||
call fuf#defineLaunchCommand('FufFile' , s:MODE_NAME, '""', [])
|
|
||||||
call fuf#defineLaunchCommand('FufFileWithFullCwd' , s:MODE_NAME, 'fnamemodify(getcwd(), '':p'')', [])
|
|
||||||
call fuf#defineLaunchCommand('FufFileWithCurrentBufferDir', s:MODE_NAME, 'expand(''%:~:.'')[:-1-len(expand(''%:~:.:t''))]', [])
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" LOCAL FUNCTIONS/VARIABLES {{{1
|
|
||||||
|
|
||||||
let s:MODE_NAME = expand('<sfile>:t:r')
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:enumItems(dir)
|
|
||||||
let key = join([getcwd(), g:fuf_ignoreCase, g:fuf_file_exclude, a:dir], "\n")
|
|
||||||
if !exists('s:cache[key]')
|
|
||||||
let s:cache[key] = fuf#enumExpandedDirsEntries(a:dir, g:fuf_file_exclude)
|
|
||||||
call fuf#mapToSetSerialIndex(s:cache[key], 1)
|
|
||||||
call fuf#mapToSetAbbrWithSnippedWordAsPath(s:cache[key])
|
|
||||||
endif
|
|
||||||
return s:cache[key]
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:enumNonCurrentItems(dir, bufNrPrev, cache)
|
|
||||||
let key = a:dir . 'AVOIDING EMPTY KEY'
|
|
||||||
if !exists('a:cache[key]')
|
|
||||||
" NOTE: Comparing filenames is faster than bufnr('^' . fname . '$')
|
|
||||||
let bufNamePrev = bufname(a:bufNrPrev)
|
|
||||||
let a:cache[key] =
|
|
||||||
\ filter(copy(s:enumItems(a:dir)), 'v:val.word !=# bufNamePrev')
|
|
||||||
endif
|
|
||||||
return a:cache[key]
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" s:handler {{{1
|
|
||||||
|
|
||||||
let s:handler = {}
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getModeName()
|
|
||||||
return s:MODE_NAME
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPrompt()
|
|
||||||
return fuf#formatPrompt(g:fuf_file_prompt, self.partialMatching, '')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPreviewHeight()
|
|
||||||
return g:fuf_previewHeight
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.isOpenable(enteredPattern)
|
|
||||||
return a:enteredPattern =~# '[^/\\]$'
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePatternSet(patternBase)
|
|
||||||
return fuf#makePatternSet(a:patternBase, 's:interpretPrimaryPatternForPathTail',
|
|
||||||
\ self.partialMatching)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePreviewLines(word, count)
|
|
||||||
return fuf#makePreviewLinesForFile(a:word, a:count, self.getPreviewHeight())
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getCompleteItems(patternPrimary)
|
|
||||||
return s:enumNonCurrentItems(
|
|
||||||
\ fuf#splitPath(a:patternPrimary).head, self.bufNrPrev, self.cache)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onOpen(word, mode)
|
|
||||||
call fuf#openFile(a:word, a:mode, g:fuf_reuseWindow)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPre()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPost()
|
|
||||||
let self.cache = {}
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeLeavePost(opened)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
@@ -1,123 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (c) 2007-2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
if !l9#guardScriptLoading(expand('<sfile>:p'), 0, 0, [])
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" GLOBAL FUNCTIONS {{{1
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#givencmd#createHandler(base)
|
|
||||||
return a:base.concretize(copy(s:handler))
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#givencmd#getSwitchOrder()
|
|
||||||
return -1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#givencmd#getEditableDataNames()
|
|
||||||
return []
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#givencmd#renewCache()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#givencmd#requiresOnCommandPre()
|
|
||||||
return 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#givencmd#onInit()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#givencmd#launch(initialPattern, partialMatching, prompt, items)
|
|
||||||
let s:prompt = (empty(a:prompt) ? '>' : a:prompt)
|
|
||||||
let s:items = copy(a:items)
|
|
||||||
call map(s:items, 'fuf#makeNonPathItem(v:val, "")')
|
|
||||||
call fuf#mapToSetSerialIndex(s:items, 1)
|
|
||||||
call map(s:items, 'fuf#setAbbrWithFormattedWord(v:val, 1)')
|
|
||||||
call fuf#launch(s:MODE_NAME, a:initialPattern, a:partialMatching)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" LOCAL FUNCTIONS/VARIABLES {{{1
|
|
||||||
|
|
||||||
let s:MODE_NAME = expand('<sfile>:t:r')
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" s:handler {{{1
|
|
||||||
|
|
||||||
let s:handler = {}
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getModeName()
|
|
||||||
return s:MODE_NAME
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPrompt()
|
|
||||||
return fuf#formatPrompt(s:prompt, self.partialMatching, '')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPreviewHeight()
|
|
||||||
return 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.isOpenable(enteredPattern)
|
|
||||||
return 1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePatternSet(patternBase)
|
|
||||||
return fuf#makePatternSet(a:patternBase, 's:interpretPrimaryPatternForNonPath',
|
|
||||||
\ self.partialMatching)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePreviewLines(word, count)
|
|
||||||
return []
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getCompleteItems(patternPrimary)
|
|
||||||
return s:items
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onOpen(word, mode)
|
|
||||||
if a:word[0] =~# '[:/?]'
|
|
||||||
call histadd(a:word[0], a:word[1:])
|
|
||||||
endif
|
|
||||||
call feedkeys(a:word . "\<CR>", 'n')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPre()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPost()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeLeavePost(opened)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
@@ -1,123 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (c) 2007-2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
if !l9#guardScriptLoading(expand('<sfile>:p'), 0, 0, [])
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" GLOBAL FUNCTIONS {{{1
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#givendir#createHandler(base)
|
|
||||||
return a:base.concretize(copy(s:handler))
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#givendir#getSwitchOrder()
|
|
||||||
return -1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#givendir#getEditableDataNames()
|
|
||||||
return []
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#givendir#renewCache()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#givendir#requiresOnCommandPre()
|
|
||||||
return 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#givendir#onInit()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#givendir#launch(initialPattern, partialMatching, prompt, items)
|
|
||||||
let s:prompt = (empty(a:prompt) ? '>' : a:prompt)
|
|
||||||
let s:items = map(copy(a:items), 'substitute(v:val, ''[/\\]\?$'', "", "")')
|
|
||||||
let s:items = map(s:items, 'fuf#makePathItem(v:val, "", 0)')
|
|
||||||
call fuf#mapToSetSerialIndex(s:items, 1)
|
|
||||||
call fuf#mapToSetAbbrWithSnippedWordAsPath(s:items)
|
|
||||||
call fuf#launch(s:MODE_NAME, a:initialPattern, a:partialMatching)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" LOCAL FUNCTIONS/VARIABLES {{{1
|
|
||||||
|
|
||||||
let s:MODE_NAME = expand('<sfile>:t:r')
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" s:handler {{{1
|
|
||||||
|
|
||||||
let s:handler = {}
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getModeName()
|
|
||||||
return s:MODE_NAME
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPrompt()
|
|
||||||
return fuf#formatPrompt(s:prompt, self.partialMatching, '')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPreviewHeight()
|
|
||||||
return g:fuf_previewHeight
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.isOpenable(enteredPattern)
|
|
||||||
return 1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePatternSet(patternBase)
|
|
||||||
return fuf#makePatternSet(a:patternBase, 's:interpretPrimaryPatternForPath',
|
|
||||||
\ self.partialMatching)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePreviewLines(word, count)
|
|
||||||
return fuf#makePreviewLinesAround(
|
|
||||||
\ fuf#glob(fnamemodify(a:word, ':p') . '*'),
|
|
||||||
\ [], a:count, self.getPreviewHeight())
|
|
||||||
return
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getCompleteItems(patternPrimary)
|
|
||||||
return s:items
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onOpen(word, mode)
|
|
||||||
execute ':cd ' . fnameescape(a:word)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPre()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPost()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeLeavePost(opened)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
@@ -1,121 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (c) 2007-2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
if !l9#guardScriptLoading(expand('<sfile>:p'), 0, 0, [])
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" GLOBAL FUNCTIONS {{{1
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#givenfile#createHandler(base)
|
|
||||||
return a:base.concretize(copy(s:handler))
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#givenfile#getSwitchOrder()
|
|
||||||
return -1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#givenfile#getEditableDataNames()
|
|
||||||
return []
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#givenfile#renewCache()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#givenfile#requiresOnCommandPre()
|
|
||||||
return 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#givenfile#onInit()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#givenfile#launch(initialPattern, partialMatching, prompt, items)
|
|
||||||
let s:prompt = (empty(a:prompt) ? '>' : a:prompt)
|
|
||||||
let s:items = map(copy(a:items), 'fuf#makePathItem(v:val, "", 0)')
|
|
||||||
call fuf#mapToSetSerialIndex(s:items, 1)
|
|
||||||
call map(s:items, 'fuf#setAbbrWithFormattedWord(v:val, 1)')
|
|
||||||
call fuf#launch(s:MODE_NAME, a:initialPattern, a:partialMatching)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" LOCAL FUNCTIONS/VARIABLES {{{1
|
|
||||||
|
|
||||||
let s:MODE_NAME = expand('<sfile>:t:r')
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" s:handler {{{1
|
|
||||||
|
|
||||||
let s:handler = {}
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getModeName()
|
|
||||||
return s:MODE_NAME
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPrompt()
|
|
||||||
return fuf#formatPrompt(s:prompt, self.partialMatching, '')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPreviewHeight()
|
|
||||||
return g:fuf_previewHeight
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.isOpenable(enteredPattern)
|
|
||||||
return 1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePatternSet(patternBase)
|
|
||||||
return fuf#makePatternSet(a:patternBase, 's:interpretPrimaryPatternForPath',
|
|
||||||
\ self.partialMatching)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePreviewLines(word, count)
|
|
||||||
return fuf#makePreviewLinesForFile(a:word, a:count, self.getPreviewHeight())
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getCompleteItems(patternPrimary)
|
|
||||||
return s:items
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onOpen(word, mode)
|
|
||||||
call fuf#openFile(a:word, a:mode, g:fuf_reuseWindow)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPre()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPost()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeLeavePost(opened)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
@@ -1,198 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (c) 2007-2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
if !l9#guardScriptLoading(expand('<sfile>:p'), 0, 0, [])
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" GLOBAL FUNCTIONS {{{1
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#help#createHandler(base)
|
|
||||||
return a:base.concretize(copy(s:handler))
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#help#getSwitchOrder()
|
|
||||||
return g:fuf_help_switchOrder
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#help#getEditableDataNames()
|
|
||||||
return []
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#help#renewCache()
|
|
||||||
let s:cache = {}
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#help#requiresOnCommandPre()
|
|
||||||
return 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#help#onInit()
|
|
||||||
call fuf#defineLaunchCommand('FufHelp' , s:MODE_NAME, '""', [])
|
|
||||||
call fuf#defineLaunchCommand('FufHelpWithCursorWord', s:MODE_NAME, 'expand(''<cword>'')', [])
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" LOCAL FUNCTIONS/VARIABLES {{{1
|
|
||||||
|
|
||||||
let s:MODE_NAME = expand('<sfile>:t:r')
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:getCurrentHelpTagFiles()
|
|
||||||
let prefix = 'doc' . l9#getPathSeparator()
|
|
||||||
let tagFiles = split(globpath(&runtimepath, prefix . 'tags' ), "\n")
|
|
||||||
\ + split(globpath(&runtimepath, prefix . 'tags-??'), "\n")
|
|
||||||
return sort(map(tagFiles, 'fnamemodify(v:val, ":p")'))
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:parseHelpTagEntry(line, tagFile)
|
|
||||||
let elements = split(a:line, "\t")
|
|
||||||
if len(elements) != 3 || elements[0][0] ==# '!'
|
|
||||||
return {}
|
|
||||||
endif
|
|
||||||
let suffix = matchstr(a:tagFile, '-\zs..$')
|
|
||||||
if empty(suffix)
|
|
||||||
let suffix = '@en'
|
|
||||||
else
|
|
||||||
let suffix = '@' . suffix
|
|
||||||
endif
|
|
||||||
let dir = fnamemodify(a:tagFile, ':h') . l9#getPathSeparator()
|
|
||||||
return {
|
|
||||||
\ 'word' : elements[0] . suffix,
|
|
||||||
\ 'path' : dir . elements[1],
|
|
||||||
\ 'pattern': elements[2][1:],
|
|
||||||
\ }
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:getHelpTagEntries(tagFile)
|
|
||||||
let names = map(l9#readFile(a:tagFile), 's:parseHelpTagEntry(v:val, a:tagFile)')
|
|
||||||
return filter(names, '!empty(v:val)')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:parseHelpTagFiles(tagFiles, key)
|
|
||||||
let cacheName = 'cache-' . l9#hash224(a:key)
|
|
||||||
let cacheTime = fuf#getDataFileTime(s:MODE_NAME, cacheName)
|
|
||||||
if cacheTime != -1 && fuf#countModifiedFiles(a:tagFiles, cacheTime) == 0
|
|
||||||
return fuf#loadDataFile(s:MODE_NAME, cacheName)
|
|
||||||
endif
|
|
||||||
let items = l9#unique(l9#concat(map(copy(a:tagFiles), 's:getHelpTagEntries(v:val)')))
|
|
||||||
let items = map(items, 'extend(v:val, fuf#makeNonPathItem(v:val.word, ""))')
|
|
||||||
call fuf#mapToSetSerialIndex(items, 1)
|
|
||||||
let items = map(items, 'fuf#setAbbrWithFormattedWord(v:val, 1)')
|
|
||||||
call fuf#saveDataFile(s:MODE_NAME, cacheName, items)
|
|
||||||
return items
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:enumHelpTags(tagFiles)
|
|
||||||
if !len(a:tagFiles)
|
|
||||||
return []
|
|
||||||
endif
|
|
||||||
let key = join([g:fuf_ignoreCase] + a:tagFiles, "\n")
|
|
||||||
if !exists('s:cache[key]') || fuf#countModifiedFiles(a:tagFiles, s:cache[key].time)
|
|
||||||
let s:cache[key] = {
|
|
||||||
\ 'time' : localtime(),
|
|
||||||
\ 'items' : s:parseHelpTagFiles(a:tagFiles, key)
|
|
||||||
\ }
|
|
||||||
endif
|
|
||||||
return s:cache[key].items
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:getMatchingIndex(lines, pattern)
|
|
||||||
if empty(a:pattern)
|
|
||||||
return -1
|
|
||||||
endif
|
|
||||||
for i in range(len(a:lines))
|
|
||||||
if stridx(a:lines[i], a:pattern) >= 0
|
|
||||||
return i
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
return -1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" s:handler {{{1
|
|
||||||
|
|
||||||
let s:handler = {}
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getModeName()
|
|
||||||
return s:MODE_NAME
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPrompt()
|
|
||||||
return fuf#formatPrompt(g:fuf_help_prompt, self.partialMatching, '')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPreviewHeight()
|
|
||||||
return g:fuf_previewHeight
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.isOpenable(enteredPattern)
|
|
||||||
return 1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePatternSet(patternBase)
|
|
||||||
return fuf#makePatternSet(a:patternBase, 's:interpretPrimaryPatternForNonPath',
|
|
||||||
\ self.partialMatching)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePreviewLines(word, count)
|
|
||||||
let items = filter(copy(s:enumHelpTags(self.tagFiles)), 'v:val.word ==# a:word')
|
|
||||||
if empty(items)
|
|
||||||
return []
|
|
||||||
endif
|
|
||||||
let lines = fuf#getFileLines(items[0].path)
|
|
||||||
let index = s:getMatchingIndex(lines, items[0].pattern)
|
|
||||||
return [items[0].path . ':'] + fuf#makePreviewLinesAround(
|
|
||||||
\ lines, (index < 0 ? [] : [index]), a:count, self.getPreviewHeight() - 1)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getCompleteItems(patternPrimary)
|
|
||||||
return s:enumHelpTags(self.tagFiles)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onOpen(word, mode)
|
|
||||||
call fuf#openHelp(a:word, a:mode)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPre()
|
|
||||||
let self.tagFiles = s:getCurrentHelpTagFiles()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPost()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeLeavePost(opened)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
@@ -1,182 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (c) 2007-2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
if !l9#guardScriptLoading(expand('<sfile>:p'), 0, 0, [])
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" GLOBAL FUNCTIONS {{{1
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#jumplist#createHandler(base)
|
|
||||||
return a:base.concretize(copy(s:handler))
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#jumplist#getSwitchOrder()
|
|
||||||
return g:fuf_jumplist_switchOrder
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#jumplist#getEditableDataNames()
|
|
||||||
return []
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#jumplist#renewCache()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#jumplist#requiresOnCommandPre()
|
|
||||||
return 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#jumplist#onInit()
|
|
||||||
call fuf#defineLaunchCommand('FufJumpList', s:MODE_NAME, '""', [])
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" LOCAL FUNCTIONS/VARIABLES {{{1
|
|
||||||
|
|
||||||
let s:MODE_NAME = expand('<sfile>:t:r')
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:getJumpsLines()
|
|
||||||
redir => result
|
|
||||||
:silent jumps
|
|
||||||
redir END
|
|
||||||
return split(result, "\n")
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:parseJumpsLine(line, bufnrPrev)
|
|
||||||
"return matchlist(a:line, '^\(.\)\s\+\(\d\+\)\s\(.*\)$')
|
|
||||||
let elements = matchlist(a:line, '\v^(.)\s*(\d+)\s+(\d+)\s+(\d+)\s*(.*)$')
|
|
||||||
if empty(elements)
|
|
||||||
return {}
|
|
||||||
endif
|
|
||||||
let linePrevBuffer = join(getbufline(a:bufnrPrev, elements[3]))
|
|
||||||
if stridx(linePrevBuffer, elements[5]) >= 0
|
|
||||||
let fname = bufname(a:bufnrPrev)
|
|
||||||
let text = elements[5]
|
|
||||||
else
|
|
||||||
let fname = elements[5]
|
|
||||||
let text = join(getbufline('^' . elements[5] . '$', elements[3]))
|
|
||||||
endif
|
|
||||||
return {
|
|
||||||
\ 'prefix': elements[1],
|
|
||||||
\ 'count' : elements[2],
|
|
||||||
\ 'lnum' : elements[3],
|
|
||||||
\ 'fname' : fname,
|
|
||||||
\ 'text' : printf('%s|%d:%d|%s', fname, elements[3], elements[4], text),
|
|
||||||
\ }
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:makeItem(line, bufnrPrev)
|
|
||||||
let parsed = s:parseJumpsLine(a:line, a:bufnrPrev)
|
|
||||||
if empty(parsed)
|
|
||||||
return {}
|
|
||||||
endif
|
|
||||||
let item = fuf#makeNonPathItem(parsed.text, '')
|
|
||||||
let item.abbrPrefix = parsed.prefix
|
|
||||||
let item.lnum = parsed.lnum
|
|
||||||
let item.fname = parsed.fname
|
|
||||||
return item
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" s:handler {{{1
|
|
||||||
|
|
||||||
let s:handler = {}
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getModeName()
|
|
||||||
return s:MODE_NAME
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPrompt()
|
|
||||||
return fuf#formatPrompt(g:fuf_jumplist_prompt, self.partialMatching, '')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPreviewHeight()
|
|
||||||
return g:fuf_previewHeight
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.isOpenable(enteredPattern)
|
|
||||||
return 1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePatternSet(patternBase)
|
|
||||||
return fuf#makePatternSet(a:patternBase, 's:interpretPrimaryPatternForNonPath',
|
|
||||||
\ self.partialMatching)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePreviewLines(word, count)
|
|
||||||
let items = filter(copy(self.items), 'v:val.word ==# a:word')
|
|
||||||
if empty(items)
|
|
||||||
return []
|
|
||||||
endif
|
|
||||||
let lines = fuf#getFileLines(items[0].fname)
|
|
||||||
return fuf#makePreviewLinesAround(
|
|
||||||
\ lines, [items[0].lnum - 1], a:count, self.getPreviewHeight())
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getCompleteItems(patternPrimary)
|
|
||||||
return self.items
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onOpen(word, mode)
|
|
||||||
call fuf#prejump(a:mode)
|
|
||||||
let older = 0
|
|
||||||
for line in reverse(s:getJumpsLines())
|
|
||||||
if stridx(line, '>') == 0
|
|
||||||
let older = 1
|
|
||||||
endif
|
|
||||||
let parsed = s:parseJumpsLine(line, self.bufNrPrev)
|
|
||||||
if !empty(parsed) && parsed.text ==# a:word
|
|
||||||
if parsed.count != 0
|
|
||||||
execute 'normal! ' . parsed.count . (older ? "\<C-o>" : "\<C-i>") . 'zvzz'
|
|
||||||
endif
|
|
||||||
break
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPre()
|
|
||||||
let self.items = s:getJumpsLines()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPost()
|
|
||||||
call map(self.items, 's:makeItem(v:val, self.bufNrPrev)')
|
|
||||||
call filter(self.items, '!empty(v:val)')
|
|
||||||
call reverse(self.items)
|
|
||||||
call fuf#mapToSetSerialIndex(self.items, 1)
|
|
||||||
call map(self.items, 'fuf#setAbbrWithFormattedWord(v:val, 1)')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeLeavePost(opened)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
|
|
||||||
@@ -1,135 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (c) 2007-2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
if !l9#guardScriptLoading(expand('<sfile>:p'), 0, 0, [])
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" GLOBAL FUNCTIONS {{{1
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#line#createHandler(base)
|
|
||||||
return a:base.concretize(copy(s:handler))
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#line#getSwitchOrder()
|
|
||||||
return g:fuf_line_switchOrder
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#line#getEditableDataNames()
|
|
||||||
return []
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#line#renewCache()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#line#requiresOnCommandPre()
|
|
||||||
return 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#line#onInit()
|
|
||||||
call fuf#defineLaunchCommand('FufLine', s:MODE_NAME, '""', [])
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" LOCAL FUNCTIONS/VARIABLES {{{1
|
|
||||||
|
|
||||||
let s:MODE_NAME = expand('<sfile>:t:r')
|
|
||||||
let s:OPEN_TYPE_DELETE = -1
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" s:handler {{{1
|
|
||||||
|
|
||||||
let s:handler = {}
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getModeName()
|
|
||||||
return s:MODE_NAME
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPrompt()
|
|
||||||
return fuf#formatPrompt(g:fuf_line_prompt, self.partialMatching, '')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPreviewHeight()
|
|
||||||
return g:fuf_previewHeight
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.isOpenable(enteredPattern)
|
|
||||||
return 1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePatternSet(patternBase)
|
|
||||||
return fuf#makePatternSet(a:patternBase, 's:interpretPrimaryPatternForNonPath',
|
|
||||||
\ self.partialMatching)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePreviewLines(word, count)
|
|
||||||
let items = filter(copy(self.items), 'v:val.word ==# a:word')
|
|
||||||
if empty(items)
|
|
||||||
return []
|
|
||||||
endif
|
|
||||||
let lines = fuf#getFileLines(self.bufNrPrev)
|
|
||||||
return fuf#makePreviewLinesAround(
|
|
||||||
\ lines, [items[0].index - 1], a:count, self.getPreviewHeight())
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getCompleteItems(patternPrimary)
|
|
||||||
return self.items
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onOpen(word, mode)
|
|
||||||
call fuf#prejump(a:mode)
|
|
||||||
call filter(self.items, 'v:val.word ==# a:word')
|
|
||||||
if empty(self.items)
|
|
||||||
return
|
|
||||||
execute 'cc ' . self.items[0].index
|
|
||||||
endif
|
|
||||||
call cursor(self.items[0].index, 0)
|
|
||||||
normal! zvzz
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPre()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPost()
|
|
||||||
let tab = repeat(' ', getbufvar(self.bufNrPrev, '&tabstop'))
|
|
||||||
let self.items = getbufline(self.bufNrPrev, 1, '$')
|
|
||||||
let lnumFormat = '%' . len(string(len(self.items) + 1)) . 'd|'
|
|
||||||
for i in range(len(self.items))
|
|
||||||
let self.items[i] = printf(lnumFormat, i + 1)
|
|
||||||
\ . substitute(self.items[i], "\t", tab, 'g')
|
|
||||||
endfor
|
|
||||||
call map(self.items, 'fuf#makeNonPathItem(v:val, "")')
|
|
||||||
call fuf#mapToSetSerialIndex(self.items, 1)
|
|
||||||
call map(self.items, 'fuf#setAbbrWithFormattedWord(v:val, 0)')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeLeavePost(opened)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
@@ -1,134 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (c) 2007-2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
if !l9#guardScriptLoading(expand('<sfile>:p'), 0, 0, [])
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" GLOBAL FUNCTIONS {{{1
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#mrucmd#createHandler(base)
|
|
||||||
return a:base.concretize(copy(s:handler))
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#mrucmd#getSwitchOrder()
|
|
||||||
return g:fuf_mrucmd_switchOrder
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#mrucmd#getEditableDataNames()
|
|
||||||
return ['items']
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#mrucmd#renewCache()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#mrucmd#requiresOnCommandPre()
|
|
||||||
return 1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#mrucmd#onInit()
|
|
||||||
call fuf#defineLaunchCommand('FufMruCmd', s:MODE_NAME, '""', [])
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#mrucmd#onCommandPre(cmd)
|
|
||||||
if getcmdtype() =~# '^[:/?]'
|
|
||||||
call s:updateInfo(a:cmd)
|
|
||||||
endif
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" LOCAL FUNCTIONS/VARIABLES {{{1
|
|
||||||
|
|
||||||
let s:MODE_NAME = expand('<sfile>:t:r')
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:updateInfo(cmd)
|
|
||||||
let items = fuf#loadDataFile(s:MODE_NAME, 'items')
|
|
||||||
let items = fuf#updateMruList(
|
|
||||||
\ items, { 'word' : a:cmd, 'time' : localtime() },
|
|
||||||
\ g:fuf_mrucmd_maxItem, g:fuf_mrucmd_exclude)
|
|
||||||
call fuf#saveDataFile(s:MODE_NAME, 'items', items)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" s:handler {{{1
|
|
||||||
|
|
||||||
let s:handler = {}
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getModeName()
|
|
||||||
return s:MODE_NAME
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPrompt()
|
|
||||||
return fuf#formatPrompt(g:fuf_mrucmd_prompt, self.partialMatching, '')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPreviewHeight()
|
|
||||||
return 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.isOpenable(enteredPattern)
|
|
||||||
return 1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePatternSet(patternBase)
|
|
||||||
return fuf#makePatternSet(a:patternBase, 's:interpretPrimaryPatternForNonPath',
|
|
||||||
\ self.partialMatching)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePreviewLines(word, count)
|
|
||||||
return []
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getCompleteItems(patternPrimary)
|
|
||||||
return self.items
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onOpen(word, mode)
|
|
||||||
call s:updateInfo(a:word)
|
|
||||||
call histadd(a:word[0], a:word[1:])
|
|
||||||
call feedkeys(a:word . "\<CR>", 'n')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPre()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPost()
|
|
||||||
let self.items = fuf#loadDataFile(s:MODE_NAME, 'items')
|
|
||||||
call map(self.items, 'fuf#makeNonPathItem(v:val.word, strftime(g:fuf_timeFormat, v:val.time))')
|
|
||||||
call fuf#mapToSetSerialIndex(self.items, 1)
|
|
||||||
call map(self.items, 'fuf#setAbbrWithFormattedWord(v:val, 1)')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeLeavePost(opened)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
@@ -1,234 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (c) 2007-2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
if !l9#guardScriptLoading(expand('<sfile>:p'), 0, 0, [])
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" GLOBAL FUNCTIONS {{{1
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#mrufile#createHandler(base)
|
|
||||||
return a:base.concretize(copy(s:handler))
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#mrufile#getSwitchOrder()
|
|
||||||
return g:fuf_mrufile_switchOrder
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#mrufile#getEditableDataNames()
|
|
||||||
return ['items', 'itemdirs']
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#mrufile#renewCache()
|
|
||||||
let s:cache = {}
|
|
||||||
let s:aroundCache = {}
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#mrufile#requiresOnCommandPre()
|
|
||||||
return 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#mrufile#onInit()
|
|
||||||
call fuf#defineLaunchCommand('FufMruFile', s:MODE_NAME, '""', [])
|
|
||||||
call fuf#defineLaunchCommand('FufMruFileInCwd', s:MODE_NAME,
|
|
||||||
\ '""', [['g:fuf_mrufile_underCwd', 1]])
|
|
||||||
call l9#defineVariableDefault('g:fuf_mrufile_underCwd', 0) " private option
|
|
||||||
call l9#defineVariableDefault('g:fuf_mrufile_searchAroundLevel', -1) " private option
|
|
||||||
augroup fuf#mrufile
|
|
||||||
autocmd!
|
|
||||||
autocmd BufEnter * call s:updateData()
|
|
||||||
autocmd BufWritePost * call s:updateData()
|
|
||||||
augroup END
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" LOCAL FUNCTIONS/VARIABLES {{{1
|
|
||||||
|
|
||||||
let s:MODE_NAME = expand('<sfile>:t:r')
|
|
||||||
let s:OPEN_TYPE_EXPAND = -1
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:updateData()
|
|
||||||
if !empty(&buftype) || !filereadable(expand('%'))
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
let items = fuf#loadDataFile(s:MODE_NAME, 'items')
|
|
||||||
let items = fuf#updateMruList(
|
|
||||||
\ items, { 'word' : expand('%:p'), 'time' : localtime() },
|
|
||||||
\ g:fuf_mrufile_maxItem, g:fuf_mrufile_exclude)
|
|
||||||
call fuf#saveDataFile(s:MODE_NAME, 'items', items)
|
|
||||||
call s:removeItemFromCache(expand('%:p'))
|
|
||||||
let itemDirs = fuf#loadDataFile(s:MODE_NAME, 'itemdirs')
|
|
||||||
let itemDirs = fuf#updateMruList(
|
|
||||||
\ itemDirs, { 'word' : expand('%:p:h') },
|
|
||||||
\ g:fuf_mrufile_maxItemDir, g:fuf_mrufile_exclude)
|
|
||||||
call fuf#saveDataFile(s:MODE_NAME, 'itemdirs', itemDirs)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:removeItemFromCache(word)
|
|
||||||
for items in values(s:cache)
|
|
||||||
if exists('items[a:word]')
|
|
||||||
unlet items[a:word]
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" returns empty value if invalid item
|
|
||||||
function s:formatItemUsingCache(item)
|
|
||||||
if a:item.word !~ '\S'
|
|
||||||
return {}
|
|
||||||
endif
|
|
||||||
if !exists('s:cache[a:item.word]')
|
|
||||||
if filereadable(a:item.word)
|
|
||||||
let s:cache[a:item.word] = fuf#makePathItem(
|
|
||||||
\ fnamemodify(a:item.word, ':p:~'), strftime(g:fuf_timeFormat, a:item.time), 0)
|
|
||||||
else
|
|
||||||
let s:cache[a:item.word] = {}
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
return s:cache[a:item.word]
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:expandSearchDir(dir, level)
|
|
||||||
let dirs = [a:dir]
|
|
||||||
let dirPrev = a:dir
|
|
||||||
for i in range(a:level)
|
|
||||||
let dirPrev = l9#concatPaths([dirPrev, '*'])
|
|
||||||
call add(dirs, dirPrev)
|
|
||||||
endfor
|
|
||||||
let dirPrev = a:dir
|
|
||||||
for i in range(a:level)
|
|
||||||
let dirPrevPrev = dirPrev
|
|
||||||
let dirPrev = fnamemodify(dirPrev, ':h')
|
|
||||||
if dirPrevPrev ==# dirPrev
|
|
||||||
break
|
|
||||||
endif
|
|
||||||
call add(dirs, dirPrev)
|
|
||||||
endfor
|
|
||||||
return dirs
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:listAroundFiles(dir)
|
|
||||||
if !exists('s:aroundCache[a:dir]')
|
|
||||||
let s:aroundCache[a:dir] = [a:dir] +
|
|
||||||
\ fuf#glob(l9#concatPaths([a:dir, '*' ])) +
|
|
||||||
\ fuf#glob(l9#concatPaths([a:dir, '.*']))
|
|
||||||
call filter(s:aroundCache[a:dir], 'filereadable(v:val)')
|
|
||||||
call map(s:aroundCache[a:dir], 'fuf#makePathItem(fnamemodify(v:val, ":~"), "", 0)')
|
|
||||||
if len(g:fuf_mrufile_exclude)
|
|
||||||
call filter(s:aroundCache[a:dir], 'v:val.word !~ g:fuf_mrufile_exclude')
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
return s:aroundCache[a:dir]
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" s:handler {{{1
|
|
||||||
|
|
||||||
let s:handler = {}
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getModeName()
|
|
||||||
return s:MODE_NAME
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPrompt()
|
|
||||||
let cwdString = (g:fuf_mrufile_underCwd ? '[CWD]' : '')
|
|
||||||
let levelString = (g:fuf_mrufile_searchAroundLevel < 0 ? ''
|
|
||||||
\ : '[Around:' . g:fuf_mrufile_searchAroundLevel . ']')
|
|
||||||
return fuf#formatPrompt(g:fuf_mrufile_prompt, self.partialMatching, cwdString . levelString)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPreviewHeight()
|
|
||||||
return g:fuf_previewHeight
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.isOpenable(enteredPattern)
|
|
||||||
return 1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePatternSet(patternBase)
|
|
||||||
return fuf#makePatternSet(a:patternBase, 's:interpretPrimaryPatternForPath',
|
|
||||||
\ self.partialMatching)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePreviewLines(word, count)
|
|
||||||
return fuf#makePreviewLinesForFile(a:word, a:count, self.getPreviewHeight())
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getCompleteItems(patternPrimary)
|
|
||||||
return self.items
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onOpen(word, mode)
|
|
||||||
if a:mode ==# s:OPEN_TYPE_EXPAND
|
|
||||||
let nextLevel = (self.searchAroundLevel < 0 ? 0 : self.searchAroundLevel + 1)
|
|
||||||
call fuf#setOneTimeVariables(['g:fuf_mrufile_searchAroundLevel', nextLevel])
|
|
||||||
let self.reservedMode = self.getModeName()
|
|
||||||
return
|
|
||||||
else
|
|
||||||
call fuf#openFile(a:word, a:mode, g:fuf_reuseWindow)
|
|
||||||
endif
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPre()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPost()
|
|
||||||
let self.searchAroundLevel = g:fuf_mrufile_searchAroundLevel
|
|
||||||
call fuf#defineKeyMappingInHandler(g:fuf_mrufile_keyExpand,
|
|
||||||
\ 'onCr(' . s:OPEN_TYPE_EXPAND . ')')
|
|
||||||
if self.searchAroundLevel < 0
|
|
||||||
let self.items = fuf#loadDataFile(s:MODE_NAME, 'items')
|
|
||||||
call map(self.items, 's:formatItemUsingCache(v:val)')
|
|
||||||
else
|
|
||||||
let self.items = fuf#loadDataFile(s:MODE_NAME, 'itemdirs')
|
|
||||||
call map(self.items, 's:expandSearchDir(v:val.word, g:fuf_mrufile_searchAroundLevel)')
|
|
||||||
let self.items = l9#concat(self.items)
|
|
||||||
let self.items = l9#unique(self.items)
|
|
||||||
call map(self.items, 's:listAroundFiles(v:val)')
|
|
||||||
let self.items = l9#concat(self.items)
|
|
||||||
endif
|
|
||||||
" NOTE: Comparing filenames is faster than bufnr('^' . fname . '$')
|
|
||||||
let bufNamePrev = fnamemodify(bufname(self.bufNrPrev), ':p:~')
|
|
||||||
call filter(self.items, '!empty(v:val) && v:val.word !=# bufNamePrev')
|
|
||||||
if g:fuf_mrufile_underCwd
|
|
||||||
let cwd = fnamemodify(getcwd(), ':p:~')
|
|
||||||
call filter(self.items, 'stridx(v:val.word, cwd) == 0')
|
|
||||||
endif
|
|
||||||
call fuf#mapToSetSerialIndex(self.items, 1)
|
|
||||||
call fuf#mapToSetAbbrWithSnippedWordAsPath(self.items)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeLeavePost(opened)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
@@ -1,154 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (c) 2007-2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
if !l9#guardScriptLoading(expand('<sfile>:p'), 0, 0, [])
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" GLOBAL FUNCTIONS {{{1
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#quickfix#createHandler(base)
|
|
||||||
return a:base.concretize(copy(s:handler))
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#quickfix#getSwitchOrder()
|
|
||||||
return g:fuf_quickfix_switchOrder
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#quickfix#getEditableDataNames()
|
|
||||||
return []
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#quickfix#renewCache()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#quickfix#requiresOnCommandPre()
|
|
||||||
return 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#quickfix#onInit()
|
|
||||||
call fuf#defineLaunchCommand('FufQuickfix', s:MODE_NAME, '""', [])
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" LOCAL FUNCTIONS/VARIABLES {{{1
|
|
||||||
|
|
||||||
let s:MODE_NAME = expand('<sfile>:t:r')
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:getJumpsLines()
|
|
||||||
redir => result
|
|
||||||
:silent jumps
|
|
||||||
redir END
|
|
||||||
return split(result, "\n")
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:parseJumpsLine(line)
|
|
||||||
return matchlist(a:line, '^\(.\)\s\+\(\d\+\)\s\(.*\)$')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:makeItem(qfItem)
|
|
||||||
if !a:qfItem.valid
|
|
||||||
return {}
|
|
||||||
endif
|
|
||||||
let item = fuf#makeNonPathItem(
|
|
||||||
\ printf('%s|%d:%d|%s', bufname(a:qfItem.bufnr), a:qfItem.lnum,
|
|
||||||
\ a:qfItem.col, matchstr(a:qfItem.text, '\s*\zs.*\S'))
|
|
||||||
\ , '')
|
|
||||||
let item.bufnr = a:qfItem.bufnr
|
|
||||||
let item.lnum = a:qfItem.lnum
|
|
||||||
return item
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" s:handler {{{1
|
|
||||||
|
|
||||||
let s:handler = {}
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getModeName()
|
|
||||||
return s:MODE_NAME
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPrompt()
|
|
||||||
return fuf#formatPrompt(g:fuf_quickfix_prompt, self.partialMatching, '')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPreviewHeight()
|
|
||||||
return g:fuf_previewHeight
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.isOpenable(enteredPattern)
|
|
||||||
return 1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePatternSet(patternBase)
|
|
||||||
return fuf#makePatternSet(a:patternBase, 's:interpretPrimaryPatternForNonPath',
|
|
||||||
\ self.partialMatching)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePreviewLines(word, count)
|
|
||||||
let items = filter(copy(self.items), 'v:val.word ==# a:word')
|
|
||||||
if empty(items)
|
|
||||||
return []
|
|
||||||
endif
|
|
||||||
let lines = fuf#getFileLines(items[0].bufnr)
|
|
||||||
return fuf#makePreviewLinesAround(
|
|
||||||
\ lines, [items[0].lnum - 1], a:count, self.getPreviewHeight())
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getCompleteItems(patternPrimary)
|
|
||||||
return self.items
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onOpen(word, mode)
|
|
||||||
call fuf#prejump(a:mode)
|
|
||||||
call filter(self.items, 'v:val.word ==# a:word')
|
|
||||||
if !empty(self.items)
|
|
||||||
execute 'cc ' . self.items[0].index
|
|
||||||
endif
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPre()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPost()
|
|
||||||
let self.items = getqflist()
|
|
||||||
call map(self.items, 's:makeItem(v:val)')
|
|
||||||
call fuf#mapToSetSerialIndex(self.items, 1)
|
|
||||||
call filter(self.items, 'exists("v:val.word")')
|
|
||||||
call map(self.items, 'fuf#setAbbrWithFormattedWord(v:val, 1)')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeLeavePost(opened)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
|
|
||||||
@@ -1,178 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (c) 2007-2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
if !l9#guardScriptLoading(expand('<sfile>:p'), 0, 0, [])
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" GLOBAL FUNCTIONS {{{1
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#tag#createHandler(base)
|
|
||||||
return a:base.concretize(copy(s:handler))
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#tag#getSwitchOrder()
|
|
||||||
return g:fuf_tag_switchOrder
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#tag#getEditableDataNames()
|
|
||||||
return []
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#tag#renewCache()
|
|
||||||
let s:cache = {}
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#tag#requiresOnCommandPre()
|
|
||||||
return 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#tag#onInit()
|
|
||||||
call fuf#defineLaunchCommand('FufTag' , s:MODE_NAME, '""', [])
|
|
||||||
call fuf#defineLaunchCommand('FufTagWithCursorWord', s:MODE_NAME, 'expand(''<cword>'')', [])
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" LOCAL FUNCTIONS/VARIABLES {{{1
|
|
||||||
|
|
||||||
let s:MODE_NAME = expand('<sfile>:t:r')
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:getTagNames(tagFile)
|
|
||||||
let names = map(l9#readFile(a:tagFile), 'matchstr(v:val, ''^[^!\t][^\t]*'')')
|
|
||||||
return filter(names, 'v:val =~# ''\S''')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:parseTagFiles(tagFiles, key)
|
|
||||||
let cacheName = 'cache-' . l9#hash224(a:key)
|
|
||||||
let cacheTime = fuf#getDataFileTime(s:MODE_NAME, cacheName)
|
|
||||||
if cacheTime != -1 && fuf#countModifiedFiles(a:tagFiles, cacheTime) == 0
|
|
||||||
return fuf#loadDataFile(s:MODE_NAME, cacheName)
|
|
||||||
endif
|
|
||||||
let items = l9#unique(l9#concat(map(copy(a:tagFiles), 's:getTagNames(v:val)')))
|
|
||||||
let items = map(items, 'fuf#makeNonPathItem(v:val, "")')
|
|
||||||
call fuf#mapToSetSerialIndex(items, 1)
|
|
||||||
let items = map(items, 'fuf#setAbbrWithFormattedWord(v:val, 1)')
|
|
||||||
call fuf#saveDataFile(s:MODE_NAME, cacheName, items)
|
|
||||||
return items
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:enumTags(tagFiles)
|
|
||||||
if !len(a:tagFiles)
|
|
||||||
return []
|
|
||||||
endif
|
|
||||||
let key = join([g:fuf_ignoreCase] + a:tagFiles, "\n")
|
|
||||||
if !exists('s:cache[key]') || fuf#countModifiedFiles(a:tagFiles, s:cache[key].time)
|
|
||||||
let s:cache[key] = {
|
|
||||||
\ 'time' : localtime(),
|
|
||||||
\ 'items' : s:parseTagFiles(a:tagFiles, key)
|
|
||||||
\ }
|
|
||||||
endif
|
|
||||||
return s:cache[key].items
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:getMatchingIndex(lines, cmd)
|
|
||||||
if a:cmd !~# '\D'
|
|
||||||
return str2nr(a:cmd)
|
|
||||||
endif
|
|
||||||
let pattern = matchstr(a:cmd, '^\/\^\zs.*\ze\$\/$')
|
|
||||||
if empty(pattern)
|
|
||||||
return -1
|
|
||||||
endif
|
|
||||||
for i in range(len(a:lines))
|
|
||||||
if a:lines[i] ==# pattern
|
|
||||||
return i
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
return -1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" s:handler {{{1
|
|
||||||
|
|
||||||
let s:handler = {}
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getModeName()
|
|
||||||
return s:MODE_NAME
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPrompt()
|
|
||||||
return fuf#formatPrompt(g:fuf_tag_prompt, self.partialMatching, '')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPreviewHeight()
|
|
||||||
return g:fuf_previewHeight
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.isOpenable(enteredPattern)
|
|
||||||
return 1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePatternSet(patternBase)
|
|
||||||
return fuf#makePatternSet(a:patternBase, 's:interpretPrimaryPatternForNonPath',
|
|
||||||
\ self.partialMatching)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" 'cmd' is '/^hoge hoge$/' or line number
|
|
||||||
function s:handler.makePreviewLines(word, count)
|
|
||||||
let tags = taglist('^' . a:word . '$')
|
|
||||||
if empty(tags)
|
|
||||||
return []
|
|
||||||
endif
|
|
||||||
let i = a:count % len(tags)
|
|
||||||
let title = printf('(%d/%d) %s', i + 1, len(tags), tags[i].filename)
|
|
||||||
let lines = fuf#getFileLines(tags[i].filename)
|
|
||||||
let index = s:getMatchingIndex(lines, tags[i].cmd)
|
|
||||||
return [title] + fuf#makePreviewLinesAround(
|
|
||||||
\ lines, (index < 0 ? [] : [index]), 0, self.getPreviewHeight() - 1)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getCompleteItems(patternPrimary)
|
|
||||||
return s:enumTags(self.tagFiles)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onOpen(word, mode)
|
|
||||||
call fuf#openTag(a:word, a:mode)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPre()
|
|
||||||
let self.tagFiles = fuf#getCurrentTagFiles()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPost()
|
|
||||||
let &l:tags = join(self.tagFiles, ',')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeLeavePost(opened)
|
|
||||||
let &l:tags = ''
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
@@ -1,159 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (c) 2007-2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
if !l9#guardScriptLoading(expand('<sfile>:p'), 0, 0, [])
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" GLOBAL FUNCTIONS {{{1
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#taggedfile#createHandler(base)
|
|
||||||
return a:base.concretize(copy(s:handler))
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#taggedfile#getSwitchOrder()
|
|
||||||
return g:fuf_taggedfile_switchOrder
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#taggedfile#getEditableDataNames()
|
|
||||||
return []
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#taggedfile#renewCache()
|
|
||||||
let s:cache = {}
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#taggedfile#requiresOnCommandPre()
|
|
||||||
return 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function fuf#taggedfile#onInit()
|
|
||||||
call fuf#defineLaunchCommand('FufTaggedFile', s:MODE_NAME, '""', [])
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" LOCAL FUNCTIONS/VARIABLES {{{1
|
|
||||||
|
|
||||||
let s:MODE_NAME = expand('<sfile>:t:r')
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:getTaggedFileList(tagfile)
|
|
||||||
execute 'cd ' . fnamemodify(a:tagfile, ':h')
|
|
||||||
let result = map(l9#readFile(a:tagfile), 'matchstr(v:val, ''^[^!\t][^\t]*\t\zs[^\t]\+'')')
|
|
||||||
call map(l9#readFile(a:tagfile), 'fnamemodify(v:val, ":p")')
|
|
||||||
cd -
|
|
||||||
call map(l9#readFile(a:tagfile), 'fnamemodify(v:val, ":~:.")')
|
|
||||||
return filter(result, 'v:val =~# ''[^/\\ ]$''')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:parseTagFiles(tagFiles, key)
|
|
||||||
let cacheName = 'cache-' . l9#hash224(a:key)
|
|
||||||
let cacheTime = fuf#getDataFileTime(s:MODE_NAME, cacheName)
|
|
||||||
if cacheTime != -1 && fuf#countModifiedFiles(a:tagFiles, cacheTime) == 0
|
|
||||||
return fuf#loadDataFile(s:MODE_NAME, cacheName)
|
|
||||||
endif
|
|
||||||
let items = l9#unique(l9#concat(map(copy(a:tagFiles), 's:getTaggedFileList(v:val)')))
|
|
||||||
call map(items, 'fuf#makePathItem(v:val, "", 0)')
|
|
||||||
call fuf#mapToSetSerialIndex(items, 1)
|
|
||||||
call fuf#mapToSetAbbrWithSnippedWordAsPath(items)
|
|
||||||
call fuf#saveDataFile(s:MODE_NAME, cacheName, items)
|
|
||||||
return items
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:enumTaggedFiles(tagFiles)
|
|
||||||
if !len(a:tagFiles)
|
|
||||||
return []
|
|
||||||
endif
|
|
||||||
let key = join([getcwd(), g:fuf_ignoreCase] + a:tagFiles, "\n")
|
|
||||||
if !exists('s:cache[key]') || fuf#countModifiedFiles(a:tagFiles, s:cache[key].time)
|
|
||||||
let s:cache[key] = {
|
|
||||||
\ 'time' : localtime(),
|
|
||||||
\ 'items' : s:parseTagFiles(a:tagFiles, key)
|
|
||||||
\ }
|
|
||||||
endif
|
|
||||||
return s:cache[key].items
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" s:handler {{{1
|
|
||||||
|
|
||||||
let s:handler = {}
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getModeName()
|
|
||||||
return s:MODE_NAME
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPrompt()
|
|
||||||
return fuf#formatPrompt(g:fuf_taggedfile_prompt, self.partialMatching, '')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getPreviewHeight()
|
|
||||||
return g:fuf_previewHeight
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.isOpenable(enteredPattern)
|
|
||||||
return 1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePatternSet(patternBase)
|
|
||||||
return fuf#makePatternSet(a:patternBase, 's:interpretPrimaryPatternForPath',
|
|
||||||
\ self.partialMatching)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.makePreviewLines(word, count)
|
|
||||||
return fuf#makePreviewLinesForFile(a:word, a:count, self.getPreviewHeight())
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.getCompleteItems(patternPrimary)
|
|
||||||
return self.items
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onOpen(word, mode)
|
|
||||||
call fuf#openFile(a:word, a:mode, g:fuf_reuseWindow)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPre()
|
|
||||||
let self.tagFiles = fuf#getCurrentTagFiles()
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeEnterPost()
|
|
||||||
" NOTE: Comparing filenames is faster than bufnr('^' . fname . '$')
|
|
||||||
let bufNamePrev = fnamemodify(bufname(self.bufNrPrev), ':p:~:.')
|
|
||||||
" NOTE: Don't do this in onModeEnterPre()
|
|
||||||
" because that should return in a short time.
|
|
||||||
let self.items = copy(s:enumTaggedFiles(self.tagFiles))
|
|
||||||
call filter(self.items, 'v:val.word !=# bufNamePrev')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:handler.onModeLeavePost(opened)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
File diff suppressed because it is too large
Load Diff
@@ -1,158 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (c) 2007-2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
" GetLatestVimScripts: 1984 1 :AutoInstall: FuzzyFinder
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
try
|
|
||||||
if !l9#guardScriptLoading(expand('<sfile>:p'), 702, 101, [])
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
catch /E117/
|
|
||||||
echoerr '***** L9 library must be installed! *****'
|
|
||||||
finish
|
|
||||||
endtry
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" LOCAL FUNCTIONS {{{1
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:initialize()
|
|
||||||
"---------------------------------------------------------------------------
|
|
||||||
call l9#defineVariableDefault('g:fuf_modesDisable' , [ 'mrufile', 'mrucmd', ])
|
|
||||||
call l9#defineVariableDefault('g:fuf_keyOpen' , '<CR>')
|
|
||||||
call l9#defineVariableDefault('g:fuf_keyOpenSplit' , '<C-j>')
|
|
||||||
call l9#defineVariableDefault('g:fuf_keyOpenVsplit' , '<C-k>')
|
|
||||||
call l9#defineVariableDefault('g:fuf_keyOpenTabpage' , '<C-l>')
|
|
||||||
call l9#defineVariableDefault('g:fuf_keyPreview' , '<C-@>')
|
|
||||||
call l9#defineVariableDefault('g:fuf_keyNextMode' , '<C-t>')
|
|
||||||
call l9#defineVariableDefault('g:fuf_keyPrevMode' , '<C-y>')
|
|
||||||
call l9#defineVariableDefault('g:fuf_keyPrevPattern' , '<C-s>')
|
|
||||||
call l9#defineVariableDefault('g:fuf_keyNextPattern' , '<C-_>')
|
|
||||||
call l9#defineVariableDefault('g:fuf_keySwitchMatching', '<C-\><C-\>')
|
|
||||||
call l9#defineVariableDefault('g:fuf_dataDir' , '~/.vim-fuf-data')
|
|
||||||
call l9#defineVariableDefault('g:fuf_abbrevMap' , {})
|
|
||||||
call l9#defineVariableDefault('g:fuf_patternSeparator' , ';')
|
|
||||||
call l9#defineVariableDefault('g:fuf_promptHighlight' , 'Question')
|
|
||||||
call l9#defineVariableDefault('g:fuf_ignoreCase' , 1)
|
|
||||||
call l9#defineVariableDefault('g:fuf_splitPathMatching', 1)
|
|
||||||
call l9#defineVariableDefault('g:fuf_fuzzyRefining' , 0)
|
|
||||||
call l9#defineVariableDefault('g:fuf_smartBs' , 1)
|
|
||||||
call l9#defineVariableDefault('g:fuf_reuseWindow' , 1)
|
|
||||||
call l9#defineVariableDefault('g:fuf_timeFormat' , '(%Y-%m-%d %H:%M:%S)')
|
|
||||||
call l9#defineVariableDefault('g:fuf_learningLimit' , 100)
|
|
||||||
call l9#defineVariableDefault('g:fuf_enumeratingLimit' , 50)
|
|
||||||
call l9#defineVariableDefault('g:fuf_maxMenuWidth' , 78)
|
|
||||||
call l9#defineVariableDefault('g:fuf_previewHeight' , 0)
|
|
||||||
call l9#defineVariableDefault('g:fuf_autoPreview' , 0)
|
|
||||||
call l9#defineVariableDefault('g:fuf_useMigemo' , 0)
|
|
||||||
"---------------------------------------------------------------------------
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffer_prompt' , '>Buffer[]>')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffer_switchOrder', 10)
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffer_mruOrder' , 1)
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffer_keyDelete' , '<C-]>')
|
|
||||||
"---------------------------------------------------------------------------
|
|
||||||
call l9#defineVariableDefault('g:fuf_file_prompt' , '>File[]>')
|
|
||||||
call l9#defineVariableDefault('g:fuf_file_switchOrder', 20)
|
|
||||||
call l9#defineVariableDefault('g:fuf_file_exclude' , '\v\~$|\.(o|exe|dll|bak|orig|sw[po])$|(^|[/\\])\.(hg|git|bzr)($|[/\\])')
|
|
||||||
"---------------------------------------------------------------------------
|
|
||||||
call l9#defineVariableDefault('g:fuf_coveragefile_prompt' , '>CoverageFile[]>')
|
|
||||||
call l9#defineVariableDefault('g:fuf_coveragefile_switchOrder', 30)
|
|
||||||
call l9#defineVariableDefault('g:fuf_coveragefile_exclude' , '\v\~$|\.(o|exe|dll|bak|orig|sw[po])$|(^|[/\\])\.(hg|git|bzr)($|[/\\])')
|
|
||||||
call l9#defineVariableDefault('g:fuf_coveragefile_globPatterns', ['**/.*', '**/*'])
|
|
||||||
"---------------------------------------------------------------------------
|
|
||||||
call l9#defineVariableDefault('g:fuf_dir_prompt' , '>Dir[]>')
|
|
||||||
call l9#defineVariableDefault('g:fuf_dir_switchOrder', 40)
|
|
||||||
call l9#defineVariableDefault('g:fuf_dir_exclude' , '\v(^|[/\\])\.(hg|git|bzr)($|[/\\])')
|
|
||||||
"---------------------------------------------------------------------------
|
|
||||||
call l9#defineVariableDefault('g:fuf_mrufile_prompt' , '>MRU-File[]>')
|
|
||||||
call l9#defineVariableDefault('g:fuf_mrufile_switchOrder', 50)
|
|
||||||
call l9#defineVariableDefault('g:fuf_mrufile_exclude' , '\v\~$|\.(o|exe|dll|bak|orig|sw[po])$|^(\/\/|\\\\|\/mnt\/|\/media\/)')
|
|
||||||
call l9#defineVariableDefault('g:fuf_mrufile_maxItem' , 200)
|
|
||||||
call l9#defineVariableDefault('g:fuf_mrufile_maxItemDir' , 50)
|
|
||||||
call l9#defineVariableDefault('g:fuf_mrufile_keyExpand' , '<C-]>')
|
|
||||||
"---------------------------------------------------------------------------
|
|
||||||
call l9#defineVariableDefault('g:fuf_mrucmd_prompt' , '>MRU-Cmd[]>')
|
|
||||||
call l9#defineVariableDefault('g:fuf_mrucmd_switchOrder', 60)
|
|
||||||
call l9#defineVariableDefault('g:fuf_mrucmd_exclude' , '^$')
|
|
||||||
call l9#defineVariableDefault('g:fuf_mrucmd_maxItem' , 200)
|
|
||||||
"---------------------------------------------------------------------------
|
|
||||||
call l9#defineVariableDefault('g:fuf_bookmarkfile_prompt' , '>Bookmark-File[]>')
|
|
||||||
call l9#defineVariableDefault('g:fuf_bookmarkfile_switchOrder', 70)
|
|
||||||
call l9#defineVariableDefault('g:fuf_bookmarkfile_searchRange', 400)
|
|
||||||
call l9#defineVariableDefault('g:fuf_bookmarkfile_keyDelete' , '<C-]>')
|
|
||||||
"---------------------------------------------------------------------------
|
|
||||||
call l9#defineVariableDefault('g:fuf_bookmarkdir_prompt' , '>Bookmark-Dir[]>')
|
|
||||||
call l9#defineVariableDefault('g:fuf_bookmarkdir_switchOrder', 80)
|
|
||||||
call l9#defineVariableDefault('g:fuf_bookmarkdir_keyDelete' , '<C-]>')
|
|
||||||
"---------------------------------------------------------------------------
|
|
||||||
call l9#defineVariableDefault('g:fuf_tag_prompt' , '>Tag[]>')
|
|
||||||
call l9#defineVariableDefault('g:fuf_tag_switchOrder', 90)
|
|
||||||
"---------------------------------------------------------------------------
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag_prompt' , '>Buffer-Tag[]>')
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag_switchOrder', 100)
|
|
||||||
call l9#defineVariableDefault('g:fuf_buffertag_ctagsPath' , 'ctags')
|
|
||||||
"---------------------------------------------------------------------------
|
|
||||||
call l9#defineVariableDefault('g:fuf_taggedfile_prompt' , '>Tagged-File[]>')
|
|
||||||
call l9#defineVariableDefault('g:fuf_taggedfile_switchOrder', 110)
|
|
||||||
"---------------------------------------------------------------------------
|
|
||||||
call l9#defineVariableDefault('g:fuf_jumplist_prompt' , '>Jump-List[]>')
|
|
||||||
call l9#defineVariableDefault('g:fuf_jumplist_switchOrder', 120)
|
|
||||||
"---------------------------------------------------------------------------
|
|
||||||
call l9#defineVariableDefault('g:fuf_changelist_prompt' , '>Change-List[]>')
|
|
||||||
call l9#defineVariableDefault('g:fuf_changelist_switchOrder', 130)
|
|
||||||
"---------------------------------------------------------------------------
|
|
||||||
call l9#defineVariableDefault('g:fuf_quickfix_prompt' , '>Quickfix[]>')
|
|
||||||
call l9#defineVariableDefault('g:fuf_quickfix_switchOrder', 140)
|
|
||||||
"---------------------------------------------------------------------------
|
|
||||||
call l9#defineVariableDefault('g:fuf_line_prompt' , '>Line[]>')
|
|
||||||
call l9#defineVariableDefault('g:fuf_line_switchOrder', 150)
|
|
||||||
"---------------------------------------------------------------------------
|
|
||||||
call l9#defineVariableDefault('g:fuf_help_prompt' , '>Help[]>')
|
|
||||||
call l9#defineVariableDefault('g:fuf_help_switchOrder', 160)
|
|
||||||
"---------------------------------------------------------------------------
|
|
||||||
command! -bang -narg=0 FufEditDataFile call fuf#editDataFile()
|
|
||||||
command! -bang -narg=0 FufRenewCache call s:renewCachesOfAllModes()
|
|
||||||
"---------------------------------------------------------------------------
|
|
||||||
call fuf#addMode('buffer')
|
|
||||||
call fuf#addMode('file')
|
|
||||||
call fuf#addMode('coveragefile')
|
|
||||||
call fuf#addMode('dir')
|
|
||||||
call fuf#addMode('mrufile')
|
|
||||||
call fuf#addMode('mrucmd')
|
|
||||||
call fuf#addMode('bookmarkfile')
|
|
||||||
call fuf#addMode('bookmarkdir')
|
|
||||||
call fuf#addMode('tag')
|
|
||||||
call fuf#addMode('buffertag')
|
|
||||||
call fuf#addMode('taggedfile')
|
|
||||||
call fuf#addMode('jumplist')
|
|
||||||
call fuf#addMode('changelist')
|
|
||||||
call fuf#addMode('quickfix')
|
|
||||||
call fuf#addMode('line')
|
|
||||||
call fuf#addMode('help')
|
|
||||||
call fuf#addMode('givenfile')
|
|
||||||
call fuf#addMode('givendir')
|
|
||||||
call fuf#addMode('givencmd')
|
|
||||||
call fuf#addMode('callbackfile')
|
|
||||||
call fuf#addMode('callbackitem')
|
|
||||||
"---------------------------------------------------------------------------
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:renewCachesOfAllModes()
|
|
||||||
for m in fuf#getModeNames()
|
|
||||||
call fuf#{m}#renewCache()
|
|
||||||
endfor
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" INITIALIZATION {{{1
|
|
||||||
|
|
||||||
call s:initialize()
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
8
bundle/git_ctrlp/.gitignore
vendored
Normal file
8
bundle/git_ctrlp/.gitignore
vendored
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
.hgignore
|
||||||
|
*.markdown
|
||||||
|
*.zip
|
||||||
|
wiki.md
|
||||||
|
note.txt
|
||||||
|
tags
|
||||||
|
.hg/*
|
||||||
|
tmp/*
|
||||||
@@ -2,7 +2,7 @@
|
|||||||
" File: autoload/ctrlp.vim
|
" File: autoload/ctrlp.vim
|
||||||
" Description: Fuzzy file, buffer, mru and tag finder.
|
" Description: Fuzzy file, buffer, mru and tag finder.
|
||||||
" Author: Kien Nguyen <github.com/kien>
|
" Author: Kien Nguyen <github.com/kien>
|
||||||
" Version: 1.6.9
|
" Version: 1.7.1
|
||||||
" =============================================================================
|
" =============================================================================
|
||||||
|
|
||||||
" Static variables {{{1
|
" Static variables {{{1
|
||||||
@@ -18,13 +18,13 @@ fu! s:opts()
|
|||||||
\ 'g:ctrlp_dotfiles': ['s:dotfiles', 1],
|
\ 'g:ctrlp_dotfiles': ['s:dotfiles', 1],
|
||||||
\ 'g:ctrlp_extensions': ['s:extensions', []],
|
\ 'g:ctrlp_extensions': ['s:extensions', []],
|
||||||
\ 'g:ctrlp_follow_symlinks': ['s:folsym', 0],
|
\ 'g:ctrlp_follow_symlinks': ['s:folsym', 0],
|
||||||
\ 'g:ctrlp_highlight_match': ['s:mathi', [1, 'Identifier']],
|
\ 'g:ctrlp_highlight_match': ['s:mathi', [1, 'CtrlPMatch']],
|
||||||
\ 'g:ctrlp_jump_to_buffer': ['s:jmptobuf', 2],
|
\ 'g:ctrlp_jump_to_buffer': ['s:jmptobuf', 2],
|
||||||
\ 'g:ctrlp_lazy_update': ['s:lazy', 0],
|
\ 'g:ctrlp_lazy_update': ['s:lazy', 0],
|
||||||
\ 'g:ctrlp_match_window_bottom': ['s:mwbottom', 1],
|
\ 'g:ctrlp_match_window_bottom': ['s:mwbottom', 1],
|
||||||
\ 'g:ctrlp_match_window_reversed': ['s:mwreverse', 1],
|
\ 'g:ctrlp_match_window_reversed': ['s:mwreverse', 1],
|
||||||
\ 'g:ctrlp_max_depth': ['s:maxdepth', 40],
|
\ 'g:ctrlp_max_depth': ['s:maxdepth', 40],
|
||||||
\ 'g:ctrlp_max_files': ['s:maxfiles', 20000],
|
\ 'g:ctrlp_max_files': ['s:maxfiles', 10000],
|
||||||
\ 'g:ctrlp_max_height': ['s:mxheight', 10],
|
\ 'g:ctrlp_max_height': ['s:mxheight', 10],
|
||||||
\ 'g:ctrlp_max_history': ['s:maxhst', hst],
|
\ 'g:ctrlp_max_history': ['s:maxhst', hst],
|
||||||
\ 'g:ctrlp_open_multi': ['s:opmul', '1v'],
|
\ 'g:ctrlp_open_multi': ['s:opmul', '1v'],
|
||||||
@@ -62,9 +62,11 @@ fu! s:opts()
|
|||||||
\ 'PrtSelectMove("k")': ['<c-k>', '<up>'],
|
\ 'PrtSelectMove("k")': ['<c-k>', '<up>'],
|
||||||
\ 'PrtSelectMove("t")': ['<home>'],
|
\ 'PrtSelectMove("t")': ['<home>'],
|
||||||
\ 'PrtSelectMove("b")': ['<end>'],
|
\ 'PrtSelectMove("b")': ['<end>'],
|
||||||
|
\ 'PrtSelectMove("u")': ['<PageUp>'],
|
||||||
|
\ 'PrtSelectMove("d")': ['<PageDown>'],
|
||||||
\ 'PrtHistory(-1)': ['<c-n>'],
|
\ 'PrtHistory(-1)': ['<c-n>'],
|
||||||
\ 'PrtHistory(1)': ['<c-p>'],
|
\ 'PrtHistory(1)': ['<c-p>'],
|
||||||
\ 'AcceptSelection("e")': ['<cr>', '<c-m>', '<2-LeftMouse>'],
|
\ 'AcceptSelection("e")': ['<cr>', '<2-LeftMouse>'],
|
||||||
\ 'AcceptSelection("h")': ['<c-x>', '<c-cr>', '<c-s>'],
|
\ 'AcceptSelection("h")': ['<c-x>', '<c-cr>', '<c-s>'],
|
||||||
\ 'AcceptSelection("t")': ['<c-t>', '<MiddleMouse>'],
|
\ 'AcceptSelection("t")': ['<c-t>', '<MiddleMouse>'],
|
||||||
\ 'AcceptSelection("v")': ['<c-v>', '<RightMouse>'],
|
\ 'AcceptSelection("v")': ['<c-v>', '<RightMouse>'],
|
||||||
@@ -73,7 +75,7 @@ fu! s:opts()
|
|||||||
\ 'ToggleByFname()': ['<c-d>'],
|
\ 'ToggleByFname()': ['<c-d>'],
|
||||||
\ 'ToggleType(1)': ['<c-f>', '<c-up>'],
|
\ 'ToggleType(1)': ['<c-f>', '<c-up>'],
|
||||||
\ 'ToggleType(-1)': ['<c-b>', '<c-down>'],
|
\ 'ToggleType(-1)': ['<c-b>', '<c-down>'],
|
||||||
\ 'PrtExpandDir()': ['<tab>', '<c-i>'],
|
\ 'PrtExpandDir()': ['<tab>'],
|
||||||
\ 'PrtInsert("w")': ['<F2>', '<insert>'],
|
\ 'PrtInsert("w")': ['<F2>', '<insert>'],
|
||||||
\ 'PrtInsert("s")': ['<F3>'],
|
\ 'PrtInsert("s")': ['<F3>'],
|
||||||
\ 'PrtInsert("v")': ['<F4>'],
|
\ 'PrtInsert("v")': ['<F4>'],
|
||||||
@@ -114,7 +116,7 @@ fu! s:opts()
|
|||||||
" Global options
|
" Global options
|
||||||
let s:glbs = { 'magic': 1, 'to': 1, 'tm': 0, 'sb': 1, 'hls': 0, 'im': 0,
|
let s:glbs = { 'magic': 1, 'to': 1, 'tm': 0, 'sb': 1, 'hls': 0, 'im': 0,
|
||||||
\ 'report': 9999, 'sc': 0, 'ss': 0, 'siso': 0, 'mfd': 200, 'mouse': 'n',
|
\ 'report': 9999, 'sc': 0, 'ss': 0, 'siso': 0, 'mfd': 200, 'mouse': 'n',
|
||||||
\ 'gcr': 'a:blinkon0', 'ic': 1, 'scs': 1 }
|
\ 'gcr': 'a:blinkon0', 'ic': 1, 'scs': 1, 'lmap': '' }
|
||||||
if s:lazy
|
if s:lazy
|
||||||
cal extend(s:glbs, { 'ut': ( s:lazy > 1 ? s:lazy : 250 ) })
|
cal extend(s:glbs, { 'ut': ( s:lazy > 1 ? s:lazy : 250 ) })
|
||||||
en
|
en
|
||||||
@@ -124,7 +126,7 @@ cal s:opts()
|
|||||||
let s:lash = ctrlp#utils#lash()
|
let s:lash = ctrlp#utils#lash()
|
||||||
|
|
||||||
" Limiters
|
" Limiters
|
||||||
let [s:compare_lim, s:nocache_lim, s:mltipats_lim] = [3000, 4000, 2000]
|
let [s:compare_lim, s:nocache_lim] = [3000, 4000]
|
||||||
|
|
||||||
" Regexp
|
" Regexp
|
||||||
let s:fpats = {
|
let s:fpats = {
|
||||||
@@ -133,6 +135,18 @@ let s:fpats = {
|
|||||||
\ '^\S\*$': '\*',
|
\ '^\S\*$': '\*',
|
||||||
\ '^\S\\?$': '\\?',
|
\ '^\S\\?$': '\\?',
|
||||||
\ }
|
\ }
|
||||||
|
|
||||||
|
" Highlight groups
|
||||||
|
let s:hlgrps = {
|
||||||
|
\ 'NoEntries': 'Error',
|
||||||
|
\ 'Mode1': 'Character',
|
||||||
|
\ 'Mode2': 'LineNr',
|
||||||
|
\ 'Stats': 'Function',
|
||||||
|
\ 'Match': 'Identifier',
|
||||||
|
\ 'PrtBase': 'Comment',
|
||||||
|
\ 'PrtText': 'Normal',
|
||||||
|
\ 'PrtCursor': 'Constant',
|
||||||
|
\ }
|
||||||
" * Open & Close {{{1
|
" * Open & Close {{{1
|
||||||
fu! s:Open()
|
fu! s:Open()
|
||||||
if exists('g:ctrlp_log') && g:ctrlp_log
|
if exists('g:ctrlp_log') && g:ctrlp_log
|
||||||
@@ -157,7 +171,8 @@ fu! s:Open()
|
|||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:Close()
|
fu! s:Close()
|
||||||
try | noa bun! | cat | noa clo! | endt
|
try | noa bun!
|
||||||
|
cat | noa clo! | endt
|
||||||
cal s:unmarksigns()
|
cal s:unmarksigns()
|
||||||
for key in keys(s:glbs)
|
for key in keys(s:glbs)
|
||||||
sil! exe 'let &'.key.' = s:glb_'.key
|
sil! exe 'let &'.key.' = s:glb_'.key
|
||||||
@@ -168,7 +183,7 @@ fu! s:Close()
|
|||||||
exe s:winres[0]
|
exe s:winres[0]
|
||||||
en
|
en
|
||||||
unl! s:focus s:hisidx s:hstgot s:marked s:statypes s:cline s:init s:savestr
|
unl! s:focus s:hisidx s:hstgot s:marked s:statypes s:cline s:init s:savestr
|
||||||
\ g:ctrlp_nolimit
|
\ s:winh g:ctrlp_nolimit
|
||||||
cal ctrlp#recordhist()
|
cal ctrlp#recordhist()
|
||||||
cal s:onexit()
|
cal s:onexit()
|
||||||
if exists('g:ctrlp_log') && g:ctrlp_log
|
if exists('g:ctrlp_log') && g:ctrlp_log
|
||||||
@@ -178,12 +193,10 @@ fu! s:Close()
|
|||||||
endf
|
endf
|
||||||
" * Clear caches {{{1
|
" * Clear caches {{{1
|
||||||
fu! ctrlp#clr(...)
|
fu! ctrlp#clr(...)
|
||||||
exe 'let g:ctrlp_new'.( exists('a:1') ? a:1 : 'cache' ).' = 1'
|
exe 'let g:ctrlp_new'.( a:0 ? a:1 : 'cache' ).' = 1'
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! ctrlp#clra(...)
|
fu! ctrlp#clra()
|
||||||
if !exists('a:1') && ( has('dialog_gui') || has('dialog_con') ) &&
|
|
||||||
\ confirm("Delete all cache files?", "&OK\n&Cancel") != 1 | retu | en
|
|
||||||
let cache_dir = ctrlp#utils#cachedir()
|
let cache_dir = ctrlp#utils#cachedir()
|
||||||
if isdirectory(cache_dir)
|
if isdirectory(cache_dir)
|
||||||
let cache_files = split(s:glbpath(cache_dir, '**', 1), "\n")
|
let cache_files = split(s:glbpath(cache_dir, '**', 1), "\n")
|
||||||
@@ -194,8 +207,6 @@ fu! ctrlp#clra(...)
|
|||||||
endf
|
endf
|
||||||
|
|
||||||
fu! ctrlp#reset()
|
fu! ctrlp#reset()
|
||||||
if ( has('dialog_gui') || has('dialog_con') ) &&
|
|
||||||
\ confirm("Reset and apply new options?", "&OK\n&Cancel") != 1 | retu | en
|
|
||||||
cal s:opts()
|
cal s:opts()
|
||||||
cal ctrlp#utils#opts()
|
cal ctrlp#utils#opts()
|
||||||
cal ctrlp#mrufiles#opts()
|
cal ctrlp#mrufiles#opts()
|
||||||
@@ -211,18 +222,19 @@ fu! s:Files()
|
|||||||
cal s:GlobPath(cwd, 0)
|
cal s:GlobPath(cwd, 0)
|
||||||
el
|
el
|
||||||
sil! cal ctrlp#progress('Indexing...')
|
sil! cal ctrlp#progress('Indexing...')
|
||||||
try | cal s:UserCmd(cwd, lscmd) | cat | retu [] | endt
|
try | cal s:UserCmd(cwd, lscmd)
|
||||||
|
cat | retu [] | endt
|
||||||
en
|
en
|
||||||
" Remove base directory
|
" Remove base directory
|
||||||
cal ctrlp#rmbasedir(g:ctrlp_allfiles)
|
cal ctrlp#rmbasedir(g:ctrlp_allfiles)
|
||||||
let read_cache = 0
|
let read_cache = 0
|
||||||
|
if len(g:ctrlp_allfiles) <= s:compare_lim
|
||||||
|
cal sort(g:ctrlp_allfiles, 'ctrlp#complen')
|
||||||
|
en
|
||||||
el
|
el
|
||||||
let g:ctrlp_allfiles = ctrlp#utils#readfile(cafile)
|
let g:ctrlp_allfiles = ctrlp#utils#readfile(cafile)
|
||||||
let read_cache = 1
|
let read_cache = 1
|
||||||
en
|
en
|
||||||
if len(g:ctrlp_allfiles) <= s:compare_lim
|
|
||||||
cal sort(g:ctrlp_allfiles, 'ctrlp#complen')
|
|
||||||
en
|
|
||||||
cal s:writecache(read_cache, cafile)
|
cal s:writecache(read_cache, cafile)
|
||||||
retu g:ctrlp_allfiles
|
retu g:ctrlp_allfiles
|
||||||
endf
|
endf
|
||||||
@@ -264,9 +276,20 @@ fu! s:lsCmd()
|
|||||||
" Try the secondary_command
|
" Try the secondary_command
|
||||||
retu len(cmd) == 3 ? cmd[2] : ''
|
retu len(cmd) == 3 ? cmd[2] : ''
|
||||||
en
|
en
|
||||||
unl! s:vcsroot
|
unl s:vcsroot
|
||||||
let s:vcscmd = s:lash == '\' ? 1 : 0
|
let s:vcscmd = s:lash == '\' ? 1 : 0
|
||||||
retu cmd[1]
|
retu cmd[1]
|
||||||
|
elsei type(cmd) == 4 && has_key(cmd, 'types')
|
||||||
|
for key in sort(keys(cmd['types']), 's:compval')
|
||||||
|
cal s:findroot(getcwd(), cmd['types'][key][0], 0, 1)
|
||||||
|
if exists('s:vcsroot') | brea | en
|
||||||
|
endfo
|
||||||
|
if !exists('s:vcsroot')
|
||||||
|
retu has_key(cmd, 'fallback') ? cmd['fallback'] : ''
|
||||||
|
en
|
||||||
|
unl s:vcsroot
|
||||||
|
let s:vcscmd = s:lash == '\' ? 1 : 0
|
||||||
|
retu cmd['types'][key][1]
|
||||||
en
|
en
|
||||||
endf
|
endf
|
||||||
fu! s:Buffers() "{{{1
|
fu! s:Buffers() "{{{1
|
||||||
@@ -285,79 +308,60 @@ endf
|
|||||||
fu! s:MatchIt(items, pat, limit, mfunc)
|
fu! s:MatchIt(items, pat, limit, mfunc)
|
||||||
let newitems = []
|
let newitems = []
|
||||||
for item in a:items
|
for item in a:items
|
||||||
if call(a:mfunc, [item, a:pat]) >= 0 | cal add(newitems, item) | en
|
try | if call(a:mfunc, [item, a:pat]) >= 0
|
||||||
|
cal add(newitems, item)
|
||||||
|
en | cat | brea | endt
|
||||||
if a:limit > 0 && len(newitems) >= a:limit | brea | en
|
if a:limit > 0 && len(newitems) >= a:limit | brea | en
|
||||||
endfo
|
endfo
|
||||||
retu newitems
|
retu newitems
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:MatchedItems(items, pats, limit, bfn)
|
fu! s:MatchedItems(items, pat, limit)
|
||||||
let [items, pats, limit] = [a:items, a:pats, a:limit]
|
let [items, pat, limit] = [a:items, a:pat, a:limit]
|
||||||
" If items is longer than s:mltipats_lim, use only the last pattern
|
|
||||||
if len(items) >= s:mltipats_lim || ( exists('s:height') && s:height > 20 )
|
|
||||||
let pats = [pats[-1]]
|
|
||||||
en
|
|
||||||
cal map(pats, 'substitute(v:val, "\\\~", "\\\\\\~", "g")')
|
|
||||||
if !s:regexp | cal map(pats, 'escape(v:val, ".")') | en
|
|
||||||
let [type, ipt, mfunc] = [s:type(1), s:ispathitem(), 'match']
|
let [type, ipt, mfunc] = [s:type(1), s:ispathitem(), 'match']
|
||||||
if s:byfname && ipt && a:bfn
|
if s:byfname && ipt
|
||||||
let mfunc = 's:matchfname'
|
let mfunc = 's:matchfname'
|
||||||
elsei s:itemtype > 2
|
elsei s:itemtype > 2
|
||||||
let types = { 'tabs': 's:matchtabs', 'tabe': 's:matchtabe' }
|
let types = { 'tabs': 's:matchtabs', 'tabe': 's:matchtabe' }
|
||||||
if has_key(types, type) | let mfunc = types[type] | en
|
if has_key(types, type) | let mfunc = types[type] | en
|
||||||
en
|
en
|
||||||
" Loop through the patterns
|
let newitems = s:MatchIt(items, pat, limit, mfunc)
|
||||||
for pat in pats
|
|
||||||
" If newitems is small, set it as items to search in
|
|
||||||
if exists('newitems') && len(newitems) < limit
|
|
||||||
let items = copy(newitems)
|
|
||||||
en
|
|
||||||
if empty(items) " End here
|
|
||||||
retu exists('newitems') ? newitems : []
|
|
||||||
el " Start here, go back up if have 2 or more in pats
|
|
||||||
" Loop through the items
|
|
||||||
let newitems = s:MatchIt(items, pat, limit, mfunc)
|
|
||||||
en
|
|
||||||
endfo
|
|
||||||
let s:matches = len(newitems)
|
let s:matches = len(newitems)
|
||||||
retu newitems
|
retu newitems
|
||||||
endf
|
endf
|
||||||
fu! s:SplitPattern(str, ...) "{{{1
|
fu! s:SplitPattern(str) "{{{1
|
||||||
let str = s:sanstail(a:str)
|
let str = a:str
|
||||||
if s:migemo && s:regexp && len(str) > 0 && executable('cmigemo')
|
if s:migemo && s:regexp && len(str) > 0 && executable('cmigemo')
|
||||||
let str = s:migemo(str)
|
let str = s:migemo(str)
|
||||||
en
|
en
|
||||||
let s:savestr = str
|
let s:savestr = str
|
||||||
if s:regexp || match(str, '\\\(zs\|ze\|<\|>\)\|[*|]') >= 0
|
if s:regexp || match(str, '\\\(<\|>\)\|[*|]') >= 0
|
||||||
let array = [s:regexfilter(str)]
|
let pat = s:regexfilter(str)
|
||||||
el
|
el
|
||||||
let array = split(str, '\zs')
|
let lst = split(str, '\zs')
|
||||||
if exists('+ssl') && !&ssl
|
if exists('+ssl') && !&ssl
|
||||||
cal map(array, 'substitute(v:val, "\\", "\\\\\\", "g")')
|
cal map(lst, 'escape(v:val, ''\'')')
|
||||||
en
|
en
|
||||||
" Literal ^ and $
|
for each in ['^', '$', '.']
|
||||||
for each in ['^', '$']
|
cal map(lst, 'escape(v:val, each)')
|
||||||
cal map(array, 'substitute(v:val, "\\\'.each.'", "\\\\\\'.each.'", "g")')
|
|
||||||
endfo
|
endfo
|
||||||
en
|
en
|
||||||
" Build the new pattern
|
if exists('lst')
|
||||||
let nitem = !empty(array) ? array[0] : ''
|
let pat = ''
|
||||||
let newpats = [nitem]
|
if !empty(lst)
|
||||||
if len(array) > 1
|
let pat = lst[0]
|
||||||
for item in range(1, len(array) - 1)
|
for item in range(1, len(lst) - 1)
|
||||||
" Separator
|
let pat .= '[^'.lst[item - 1].']\{-}'.lst[item]
|
||||||
let sep = a:0 ? a:1 : '[^'.array[item-1].']\{-}'
|
endfo
|
||||||
let nitem .= sep.array[item]
|
en
|
||||||
cal add(newpats, nitem)
|
|
||||||
endfo
|
|
||||||
en
|
en
|
||||||
retu newpats
|
retu escape(pat, '~')
|
||||||
endf
|
endf
|
||||||
" * BuildPrompt() {{{1
|
" * BuildPrompt() {{{1
|
||||||
fu! s:Render(lines, pat, bfn)
|
fu! s:Render(lines, pat)
|
||||||
let lines = a:lines
|
let lines = a:lines
|
||||||
" Setup the match window
|
" Setup the match window
|
||||||
let s:height = min([len(lines), s:mxheight])
|
let s:height = min([len(lines), s:winh])
|
||||||
sil! exe '%d _ | res' s:height
|
sil! exe '%d _ | res' s:height
|
||||||
" Print the new items
|
" Print the new items
|
||||||
if empty(lines)
|
if empty(lines)
|
||||||
@@ -379,8 +383,7 @@ fu! s:Render(lines, pat, bfn)
|
|||||||
let s:matched = copy(lines)
|
let s:matched = copy(lines)
|
||||||
cal map(lines, '"> ".v:val')
|
cal map(lines, '"> ".v:val')
|
||||||
cal setline(1, lines)
|
cal setline(1, lines)
|
||||||
exe 'keepj norm!' s:mwreverse ? 'G' : 'gg'
|
exe 'keepj norm!' ( s:mwreverse ? 'G' : 'gg' ).'1|'
|
||||||
keepj norm! 1|
|
|
||||||
cal s:unmarksigns()
|
cal s:unmarksigns()
|
||||||
cal s:remarksigns()
|
cal s:remarksigns()
|
||||||
if exists('s:cline') && !exists('g:ctrlp_nolimit')
|
if exists('s:cline') && !exists('g:ctrlp_nolimit')
|
||||||
@@ -388,35 +391,29 @@ fu! s:Render(lines, pat, bfn)
|
|||||||
en
|
en
|
||||||
" Highlighting
|
" Highlighting
|
||||||
if s:dohighlight()
|
if s:dohighlight()
|
||||||
cal s:highlight(a:pat, s:mathi[1] == '' ? 'Identifier' : s:mathi[1], a:bfn)
|
cal s:highlight(a:pat, s:mathi[1] == '' ? 'Identifier' : s:mathi[1])
|
||||||
en
|
en
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:Update(str)
|
fu! s:Update(str)
|
||||||
" Get the previous string if existed
|
" Get the previous string if existed
|
||||||
let oldstr = exists('s:savestr') ? s:savestr : ''
|
let oldstr = exists('s:savestr') ? s:savestr : ''
|
||||||
let pats = s:SplitPattern(a:str)
|
|
||||||
" Get the new string sans tail
|
" Get the new string sans tail
|
||||||
let notail = substitute(a:str, '\\\\', '\', 'g')
|
let str = s:sanstail(a:str)
|
||||||
let notail = substitute(notail, '\\\@<!:\([^:]\|\\:\)*$', '', '')
|
|
||||||
let notail = substitute(notail, '\\\ze:', '', 'g')
|
|
||||||
" Stop if the string's unchanged
|
" Stop if the string's unchanged
|
||||||
if notail == oldstr && !empty(notail) && !exists('s:force')
|
if str == oldstr && !empty(str) && !exists('s:force')
|
||||||
retu
|
retu
|
||||||
en
|
en
|
||||||
let bfn = s:byfname && notail != '' && match(notail, '\v/|\\:@!') < 0
|
let pat = s:SplitPattern(str)
|
||||||
if s:byfname && s:regexp && match(notail, '\\:\@!') >= 0
|
let lines = exists('g:ctrlp_nolimit') && empty(str) ? copy(g:ctrlp_lines)
|
||||||
let bfn = s:byfname
|
\ : s:MatchedItems(g:ctrlp_lines, pat, s:winh)
|
||||||
en
|
cal s:Render(lines, pat)
|
||||||
let lines = exists('g:ctrlp_nolimit') && empty(notail) ? copy(g:ctrlp_lines)
|
|
||||||
\ : s:MatchedItems(g:ctrlp_lines, copy(pats), s:mxheight, bfn)
|
|
||||||
cal s:Render(lines, pats[-1], bfn)
|
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:ForceUpdate()
|
fu! s:ForceUpdate()
|
||||||
let [estr, prt] = ['"\', copy(s:prompt)]
|
let [estr, prt] = ['"\', copy(s:prompt)]
|
||||||
cal map(prt, 'escape(v:val, estr)')
|
cal map(prt, 'escape(v:val, estr)')
|
||||||
cal s:Update(join(prt, ''))
|
sil! cal s:Update(join(prt, ''))
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:BuildPrompt(upd, ...)
|
fu! s:BuildPrompt(upd, ...)
|
||||||
@@ -426,15 +423,15 @@ fu! s:BuildPrompt(upd, ...)
|
|||||||
let str = join(prt, '')
|
let str = join(prt, '')
|
||||||
let lazy = empty(str) || exists('s:force') || !has('autocmd') ? 0 : s:lazy
|
let lazy = empty(str) || exists('s:force') || !has('autocmd') ? 0 : s:lazy
|
||||||
if a:upd && !lazy && ( s:matches || s:regexp
|
if a:upd && !lazy && ( s:matches || s:regexp
|
||||||
\ || match(str, '[*|]') >= 0 || match(str, '\\\:\([^:]\|\\:\)*$') >= 0 )
|
\ || match(str, '\(\\\(<\|>\)\|[*|]\)\|\(\\\:\([^:]\|\\:\)*$\)') >= 0 )
|
||||||
sil! cal s:Update(str)
|
sil! cal s:Update(str)
|
||||||
en
|
en
|
||||||
sil! cal ctrlp#statusline()
|
sil! cal ctrlp#statusline()
|
||||||
" Toggling
|
" Toggling
|
||||||
let [hiactive, hicursor, base] = exists('a:1') && !a:1
|
let [hiactive, hicursor, base] = a:0 && !a:1
|
||||||
\ ? ['Comment', 'Comment', tr(base, '>', '-')]
|
\ ? ['CtrlPPrtBase', 'CtrlPPrtBase', tr(base, '>', '-')]
|
||||||
\ : ['Normal', 'Constant', base]
|
\ : ['CtrlPPrtText', 'CtrlPPrtCursor', base]
|
||||||
let hibase = 'Comment'
|
let hibase = 'CtrlPPrtBase'
|
||||||
" Build it
|
" Build it
|
||||||
redr
|
redr
|
||||||
exe 'echoh' hibase '| echon "'.base.'"
|
exe 'echoh' hibase '| echon "'.base.'"
|
||||||
@@ -442,7 +439,7 @@ fu! s:BuildPrompt(upd, ...)
|
|||||||
\ | echoh' hicursor '| echon "'.prt[1].'"
|
\ | echoh' hicursor '| echon "'.prt[1].'"
|
||||||
\ | echoh' hiactive '| echon "'.prt[2].'" | echoh None'
|
\ | echoh' hiactive '| echon "'.prt[2].'" | echoh None'
|
||||||
" Append the cursor at the end
|
" Append the cursor at the end
|
||||||
if empty(prt[1]) && ( !exists('a:1') || ( exists('a:1') && a:1 ) )
|
if empty(prt[1]) && !( a:0 && !a:1 )
|
||||||
exe 'echoh' hibase '| echon "_" | echoh None'
|
exe 'echoh' hibase '| echon "_" | echoh None'
|
||||||
en
|
en
|
||||||
endf
|
endf
|
||||||
@@ -456,22 +453,22 @@ endf
|
|||||||
|
|
||||||
fu! s:PrtAdd(char)
|
fu! s:PrtAdd(char)
|
||||||
unl! s:hstgot
|
unl! s:hstgot
|
||||||
let s:prompt[0] = s:prompt[0] . a:char
|
let s:prompt[0] .= a:char
|
||||||
cal s:BuildPrompt(1)
|
cal s:BuildPrompt(1)
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:PrtBS()
|
fu! s:PrtBS()
|
||||||
unl! s:hstgot
|
unl! s:hstgot
|
||||||
let [prt, s:matches] = [s:prompt, 1]
|
let [prt, s:matches] = [s:prompt, 1]
|
||||||
let prt[0] = strpart(prt[0], -1, strlen(prt[0]))
|
let prt[0] = substitute(prt[0], '.$', '', '')
|
||||||
cal s:BuildPrompt(1)
|
cal s:BuildPrompt(1)
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:PrtDelete()
|
fu! s:PrtDelete()
|
||||||
unl! s:hstgot
|
unl! s:hstgot
|
||||||
let [prt, s:matches] = [s:prompt, 1]
|
let [prt, s:matches] = [s:prompt, 1]
|
||||||
let prt[1] = strpart(prt[2], 0, 1)
|
let prt[1] = matchstr(prt[2], '^.')
|
||||||
let prt[2] = strpart(prt[2], 1)
|
let prt[2] = substitute(prt[2], '^.', '', '')
|
||||||
cal s:BuildPrompt(1)
|
cal s:BuildPrompt(1)
|
||||||
endf
|
endf
|
||||||
|
|
||||||
@@ -513,43 +510,42 @@ fu! s:PrtCurLeft()
|
|||||||
if !empty(s:prompt[0])
|
if !empty(s:prompt[0])
|
||||||
let prt = s:prompt
|
let prt = s:prompt
|
||||||
let prt[2] = prt[1] . prt[2]
|
let prt[2] = prt[1] . prt[2]
|
||||||
let prt[1] = strpart(prt[0], strlen(prt[0]) - 1)
|
let prt[1] = matchstr(prt[0], '.$')
|
||||||
let prt[0] = strpart(prt[0], -1, strlen(prt[0]))
|
let prt[0] = substitute(prt[0], '.$', '', '')
|
||||||
en
|
en
|
||||||
cal s:BuildPrompt(0)
|
cal s:BuildPrompt(0)
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:PrtCurRight()
|
fu! s:PrtCurRight()
|
||||||
let prt = s:prompt
|
let prt = s:prompt
|
||||||
let prt[0] = prt[0] . prt[1]
|
let prt[0] .= prt[1]
|
||||||
let prt[1] = strpart(prt[2], 0, 1)
|
let prt[1] = matchstr(prt[2], '^.')
|
||||||
let prt[2] = strpart(prt[2], 1)
|
let prt[2] = substitute(prt[2], '^.', '', '')
|
||||||
cal s:BuildPrompt(0)
|
cal s:BuildPrompt(0)
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:PrtCurStart()
|
fu! s:PrtCurStart()
|
||||||
let prt = s:prompt
|
let str = join(s:prompt, '')
|
||||||
let str = join(prt, '')
|
let s:prompt = ['', matchstr(str, '^.'), substitute(str, '^.', '', '')]
|
||||||
let [prt[0], prt[1], prt[2]] = ['', strpart(str, 0, 1), strpart(str, 1)]
|
|
||||||
cal s:BuildPrompt(0)
|
cal s:BuildPrompt(0)
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:PrtCurEnd()
|
fu! s:PrtCurEnd()
|
||||||
let prt = s:prompt
|
let s:prompt = [join(s:prompt, ''), '', '']
|
||||||
let [prt[0], prt[1], prt[2]] = [join(prt, ''), '', '']
|
|
||||||
cal s:BuildPrompt(0)
|
cal s:BuildPrompt(0)
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:PrtSelectMove(dir)
|
fu! s:PrtSelectMove(dir)
|
||||||
let torb = { 't': 'gg', 'b': 'G' }
|
let wht = winheight(0)
|
||||||
exe 'keepj norm!' ( a:dir =~ '^[tb]$' ? torb[a:dir] : a:dir )
|
let dirs = {'t': 'gg','b': 'G','j': 'j','k': 'k','u': wht.'k','d': wht.'j'}
|
||||||
|
exe 'keepj norm!' dirs[a:dir]
|
||||||
if !exists('g:ctrlp_nolimit') | let s:cline = line('.') | en
|
if !exists('g:ctrlp_nolimit') | let s:cline = line('.') | en
|
||||||
if line('$') > winheight(0) | cal s:BuildPrompt(0, s:Focus()) | en
|
if line('$') > winheight(0) | cal s:BuildPrompt(0, s:Focus()) | en
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:PrtSelectJump(char, ...)
|
fu! s:PrtSelectJump(char, ...)
|
||||||
let lines = copy(s:matched)
|
let lines = copy(s:matched)
|
||||||
if exists('a:1')
|
if a:0
|
||||||
cal map(lines, 'split(v:val, ''[\/]\ze[^\/]\+$'')[-1]')
|
cal map(lines, 'split(v:val, ''[\/]\ze[^\/]\+$'')[-1]')
|
||||||
en
|
en
|
||||||
" Cycle through matches, use s:jmpchr to store last jump
|
" Cycle through matches, use s:jmpchr to store last jump
|
||||||
@@ -619,15 +615,16 @@ endf
|
|||||||
" * MapKeys() {{{1
|
" * MapKeys() {{{1
|
||||||
fu! s:MapKeys(...)
|
fu! s:MapKeys(...)
|
||||||
" Normal keys
|
" Normal keys
|
||||||
let pfunc = exists('a:1') && !a:1 ? 'PrtSelectJump' : 'PrtAdd'
|
let pfunc = a:0 && !a:1 ? 'PrtSelectJump' : 'PrtAdd'
|
||||||
let dojmp = s:byfname && pfunc == 'PrtSelectJump' ? ', 1' : ''
|
let dojmp = s:byfname && pfunc == 'PrtSelectJump' ? ', 1' : ''
|
||||||
for each in range(32, 126)
|
for each in range(32, 126)
|
||||||
let cmd = "nn \<buffer> \<silent> \<char-%d> :\<c-u>cal \<SID>%s(\"%s\"%s)\<cr>"
|
let cmd = "nn \<buffer> \<silent> \<char-%d> :\<c-u>cal \<SID>%s(\"%s\"%s)\<cr>"
|
||||||
exe printf(cmd, each, pfunc, escape(nr2char(each), '"|\'), dojmp)
|
exe printf(cmd, each, pfunc, escape(nr2char(each), '"|\'), dojmp)
|
||||||
endfo
|
endfo
|
||||||
if exists('a:2') | retu | en
|
|
||||||
" Special keys
|
" Special keys
|
||||||
cal call('s:MapSpecs', exists('a:1') && !a:1 ? [1] : [])
|
if a:0 < 2
|
||||||
|
cal call('s:MapSpecs', a:0 && !a:1 ? [1] : [])
|
||||||
|
en
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:MapSpecs(...)
|
fu! s:MapSpecs(...)
|
||||||
@@ -638,7 +635,7 @@ fu! s:MapSpecs(...)
|
|||||||
exe s:lcmap.' <esc>['.each
|
exe s:lcmap.' <esc>['.each
|
||||||
endfo
|
endfo
|
||||||
en
|
en
|
||||||
if exists('a:1')
|
if a:0
|
||||||
for ke in s:prtunmaps | for kp in s:prtmaps[ke]
|
for ke in s:prtunmaps | for kp in s:prtmaps[ke]
|
||||||
exe s:lcmap kp '<Nop>'
|
exe s:lcmap kp '<Nop>'
|
||||||
endfo | endfo
|
endfo | endfo
|
||||||
@@ -677,11 +674,11 @@ fu! s:ToggleType(dir)
|
|||||||
let s:itemtype = s:walker(g:ctrlp_builtins + ext, s:itemtype, a:dir)
|
let s:itemtype = s:walker(g:ctrlp_builtins + ext, s:itemtype, a:dir)
|
||||||
if s:byfname && !s:ispathitem() | let s:byfname = 0 | en
|
if s:byfname && !s:ispathitem() | let s:byfname = 0 | en
|
||||||
unl! g:ctrlp_nolimit
|
unl! g:ctrlp_nolimit
|
||||||
cal s:SetLines(s:itemtype)
|
|
||||||
cal s:PrtSwitcher()
|
|
||||||
if has('syntax') && exists('g:syntax_on')
|
if has('syntax') && exists('g:syntax_on')
|
||||||
cal s:syntax()
|
cal s:syntax()
|
||||||
en
|
en
|
||||||
|
cal s:SetLines(s:itemtype)
|
||||||
|
cal s:PrtSwitcher()
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:PrtSwitcher()
|
fu! s:PrtSwitcher()
|
||||||
@@ -691,12 +688,12 @@ 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) | if type(a:1)
|
if a:0 && strlen(a:1) | if type(a:1)
|
||||||
cal ctrlp#setdir(a:1) | retu
|
cal ctrlp#setdir(a:1) | retu
|
||||||
el
|
el
|
||||||
let pathmode = a:1
|
let pathmode = a:1
|
||||||
en | en
|
en | en
|
||||||
if !exists('a:2')
|
if a:0 < 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
|
||||||
cal ctrlp#setdir(s:crfpath)
|
cal ctrlp#setdir(s:crfpath)
|
||||||
@@ -716,11 +713,11 @@ endf
|
|||||||
fu! ctrlp#acceptfile(mode, matchstr, ...)
|
fu! ctrlp#acceptfile(mode, matchstr, ...)
|
||||||
let [md, filpath] = [a:mode, fnamemodify(a:matchstr, ':p')]
|
let [md, filpath] = [a:mode, fnamemodify(a:matchstr, ':p')]
|
||||||
cal s:PrtExit()
|
cal s:PrtExit()
|
||||||
let [bufnr, tail] = [bufnr(filpath), s:tail()]
|
let [bufnr, tail] = [bufnr('^'.filpath.'$'), s:tail()]
|
||||||
|
let j2l = a:0 ? a:1 : str2nr(matchstr(tail, '^ +\D*\zs\d\+\ze\D*'))
|
||||||
if s:jmptobuf && bufnr > 0 && md =~ 'e\|t'
|
if s:jmptobuf && bufnr > 0 && md =~ 'e\|t'
|
||||||
let [jmpb, bufwinnr] = [1, bufwinnr(bufnr)]
|
let [jmpb, bufwinnr] = [1, bufwinnr(bufnr)]
|
||||||
let buftab = s:jmptobuf > 1 ? s:buftab(bufnr, md) : [0, 0]
|
let buftab = s:jmptobuf > 1 ? s:buftab(bufnr, md) : [0, 0]
|
||||||
let j2l = a:0 ? a:1 : str2nr(matchstr(tail, '^ +\D*\zs\d\+\ze\D*'))
|
|
||||||
en
|
en
|
||||||
" Switch to existing buffer or open new one
|
" Switch to existing buffer or open new one
|
||||||
if exists('jmpb') && bufwinnr > 0 && md != 't'
|
if exists('jmpb') && bufwinnr > 0 && md != 't'
|
||||||
@@ -739,11 +736,15 @@ fu! ctrlp#acceptfile(mode, matchstr, ...)
|
|||||||
\ md == 'v' || s:splitwin == 3 ? ( useb ? 'vert sb' : 'vne' ) :
|
\ md == 'v' || s:splitwin == 3 ? ( useb ? 'vert sb' : 'vne' ) :
|
||||||
\ call('ctrlp#normcmd', useb ? ['b', 'bo vert sb'] : ['e'])
|
\ call('ctrlp#normcmd', useb ? ['b', 'bo vert sb'] : ['e'])
|
||||||
" Reset &switchbuf option
|
" Reset &switchbuf option
|
||||||
let [swb, &swb] = [&swb, '']
|
if useb
|
||||||
|
let [swb, &swb] = [&swb, '']
|
||||||
|
en
|
||||||
" Open new window/buffer
|
" Open new window/buffer
|
||||||
let fid = useb ? bufnr : filpath
|
let args = [cmd, useb ? bufnr : filpath, a:0 ? ' +'.a:1 : tail, useb, j2l]
|
||||||
cal call('s:openfile', a:0 ? [cmd, fid, ' +'.a:1] : [cmd, fid])
|
cal call('s:openfile', args)
|
||||||
let &swb = swb
|
if useb
|
||||||
|
let &swb = swb
|
||||||
|
en
|
||||||
en
|
en
|
||||||
endf
|
endf
|
||||||
|
|
||||||
@@ -805,7 +806,7 @@ fu! s:CreateNewFile(...) "{{{1
|
|||||||
let optyp = str | en | el | let optyp = fname
|
let optyp = str | en | el | let optyp = fname
|
||||||
en
|
en
|
||||||
if !exists('optyp') | retu | en
|
if !exists('optyp') | retu | en
|
||||||
let filpath = fnamemodify(optyp, ':p')
|
let [filpath, tail] = [fnamemodify(optyp, ':p'), s:tail()]
|
||||||
cal s:insertcache(str)
|
cal s:insertcache(str)
|
||||||
cal s:PrtExit()
|
cal s:PrtExit()
|
||||||
let cmd = md == 'r' ? ctrlp#normcmd('e') :
|
let cmd = md == 'r' ? ctrlp#normcmd('e') :
|
||||||
@@ -813,7 +814,7 @@ fu! s:CreateNewFile(...) "{{{1
|
|||||||
\ s:newfop =~ '2\|h' || ( a:0 && a:1 == 'h' ) || md == 'h' ? 'new' :
|
\ s:newfop =~ '2\|h' || ( a:0 && a:1 == 'h' ) || md == 'h' ? 'new' :
|
||||||
\ s:newfop =~ '3\|v' || ( a:0 && a:1 == 'v' ) || md == 'v' ? 'vne' :
|
\ s:newfop =~ '3\|v' || ( a:0 && a:1 == 'v' ) || md == 'v' ? 'vne' :
|
||||||
\ ctrlp#normcmd('e')
|
\ ctrlp#normcmd('e')
|
||||||
cal s:openfile(cmd, filpath)
|
cal s:openfile(cmd, filpath, tail)
|
||||||
endf
|
endf
|
||||||
" * OpenMulti() {{{1
|
" * OpenMulti() {{{1
|
||||||
fu! s:MarkToOpen()
|
fu! s:MarkToOpen()
|
||||||
@@ -860,8 +861,9 @@ fu! s:OpenMulti()
|
|||||||
cal s:sanstail(join(s:prompt, ''))
|
cal s:sanstail(join(s:prompt, ''))
|
||||||
cal s:PrtExit()
|
cal s:PrtExit()
|
||||||
" Move the cursor to a reusable window
|
" Move the cursor to a reusable window
|
||||||
let emptytail = empty(s:tail())
|
let tail = s:tail()
|
||||||
let useb = bufnr(mkd[0]) > 0 && emptytail
|
let emptytail = empty(tail)
|
||||||
|
let useb = bufnr('^'.mkd[0].'$') > 0 && emptytail
|
||||||
let fst = call('ctrlp#normcmd', useb ? ['b', 'bo vert sb'] : ['e'])
|
let fst = call('ctrlp#normcmd', useb ? ['b', 'bo vert sb'] : ['e'])
|
||||||
" Check if it's a replaceable buffer
|
" Check if it's a replaceable buffer
|
||||||
let repabl = ( empty(bufname('%')) && empty(&l:ft) ) || s:nosplit()
|
let repabl = ( empty(bufname('%')) && empty(&l:ft) ) || s:nosplit()
|
||||||
@@ -871,12 +873,12 @@ fu! s:OpenMulti()
|
|||||||
let [swb, &swb] = [&swb, '']
|
let [swb, &swb] = [&swb, '']
|
||||||
" Open the files
|
" Open the files
|
||||||
for va in mkd
|
for va in mkd
|
||||||
let bufnr = bufnr(va)
|
let bufnr = bufnr('^'.va.'$')
|
||||||
let useb = bufnr > 0 && emptytail
|
let useb = bufnr > 0 && emptytail
|
||||||
let snd = md != '' && has_key(cmds, md)
|
let snd = md != '' && has_key(cmds, md)
|
||||||
\ ? ( useb ? cmds[md][0] : cmds[md][1] ) : ( useb ? 'vert sb' : 'vne' )
|
\ ? ( useb ? cmds[md][0] : cmds[md][1] ) : ( useb ? 'vert sb' : 'vne' )
|
||||||
let fid = useb ? bufnr : va
|
let fid = useb ? bufnr : va
|
||||||
cal s:openfile(ic == 1 && ( ucr == 'r' || repabl ) ? fst : snd, fid)
|
cal s:openfile(ic == 1 && ( ucr == 'r' || repabl ) ? fst : snd, fid, tail)
|
||||||
if ( nr != '' && nr > 1 && nr < ic ) || ( nr == '' && ic > 1 )
|
if ( nr != '' && nr > 1 && nr < ic ) || ( nr == '' && ic > 1 )
|
||||||
sil! hid clo! | el | let ic += 1
|
sil! hid clo! | el | let ic += 1
|
||||||
en
|
en
|
||||||
@@ -906,8 +908,9 @@ endf
|
|||||||
|
|
||||||
fu! s:comparent(s1, s2)
|
fu! s:comparent(s1, s2)
|
||||||
" By same parent dir
|
" By same parent dir
|
||||||
if match(s:crfpath, escape(getcwd(), '.^$*\')) >= 0
|
let cwd = getcwd()
|
||||||
let [as1, as2] = [fnamemodify(a:s1, ':p'), fnamemodify(a:s2, ':p')]
|
if match(s:crfpath, escape(cwd, '.^$*\')) >= 0
|
||||||
|
let [as1, as2] = [cwd.s:lash().a:s1, cwd.s:lash().a:s2]
|
||||||
let [loc1, loc2] = [s:getparent(as1), s:getparent(as2)]
|
let [loc1, loc2] = [s:getparent(as1), s:getparent(as2)]
|
||||||
if loc1 == s:crfpath && loc2 != s:crfpath | retu -1 | en
|
if loc1 == s:crfpath && loc2 != s:crfpath | retu -1 | en
|
||||||
if loc2 == s:crfpath && loc1 != s:crfpath | retu 1 | en
|
if loc2 == s:crfpath && loc1 != s:crfpath | retu 1 | en
|
||||||
@@ -917,13 +920,14 @@ fu! s:comparent(s1, s2)
|
|||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:matchlens(str, pat, ...)
|
fu! s:matchlens(str, pat, ...)
|
||||||
if empty(a:pat) || index(['^','$'], a:pat) >= 0 | retu {} | en
|
if empty(a:pat) || index(['^', '$'], a:pat) >= 0 | retu {} | en
|
||||||
let st = exists('a:1') ? a:1 : 0
|
let st = a:0 ? a:1 : 0
|
||||||
let lens = exists('a:2') ? a:2 : {}
|
let lens = a:0 >= 2 ? a:2 : {}
|
||||||
let nr = exists('a:3') ? a:3 : 0
|
let nr = a:0 >= 3 ? a:3 : 0
|
||||||
if match(a:str, a:pat, st) != -1
|
if nr > 20 | retu {} | en
|
||||||
|
if match(a:str, a:pat, st) >= 0
|
||||||
let [mst, mnd] = [matchstr(a:str, a:pat, st), matchend(a:str, a:pat, st)]
|
let [mst, mnd] = [matchstr(a:str, a:pat, st), matchend(a:str, a:pat, st)]
|
||||||
let lens = extend(lens, { nr : [len(mst), mst] })
|
let lens = extend(lens, { nr : [strlen(mst), mst] })
|
||||||
let lens = s:matchlens(a:str, a:pat, mnd, lens, nr + 1)
|
let lens = s:matchlens(a:str, a:pat, mnd, lens, nr + 1)
|
||||||
en
|
en
|
||||||
retu lens
|
retu lens
|
||||||
@@ -944,6 +948,10 @@ fu! s:mixedsort(s1, s2)
|
|||||||
en
|
en
|
||||||
retu 2 * cml + cln
|
retu 2 * cml + cln
|
||||||
endf
|
endf
|
||||||
|
|
||||||
|
fu! s:compval(...)
|
||||||
|
retu a:1 - a:2
|
||||||
|
endf
|
||||||
" Statusline {{{2
|
" Statusline {{{2
|
||||||
fu! ctrlp#statusline()
|
fu! ctrlp#statusline()
|
||||||
if !exists('s:statypes')
|
if !exists('s:statypes')
|
||||||
@@ -970,12 +978,12 @@ fu! ctrlp#statusline()
|
|||||||
let args = [focus, byfname, s:regexp, prv, item, nxt, marked]
|
let args = [focus, byfname, s:regexp, prv, item, nxt, marked]
|
||||||
let &l:stl = call(s:status['main'], args)
|
let &l:stl = call(s:status['main'], args)
|
||||||
el
|
el
|
||||||
let item = '%#Character# '.item.' %*'
|
let item = '%#CtrlPMode1# '.item.' %*'
|
||||||
let focus = '%#LineNr# '.focus.' %*'
|
let focus = '%#CtrlPMode2# '.focus.' %*'
|
||||||
let byfname = '%#Character# '.byfname.' %*'
|
let byfname = '%#CtrlPMode1# '.byfname.' %*'
|
||||||
let regex = s:regexp ? '%#LineNr# regex %*' : ''
|
let regex = s:regexp ? '%#CtrlPMode2# regex %*' : ''
|
||||||
let slider = ' <'.prv.'>={'.item.'}=<'.nxt.'>'
|
let slider = ' <'.prv.'>={'.item.'}=<'.nxt.'>'
|
||||||
let dir = ' %=%<%#LineNr# '.getcwd().' %*'
|
let dir = ' %=%<%#CtrlPMode2# '.getcwd().' %*'
|
||||||
let &l:stl = focus.byfname.regex.slider.marked.dir
|
let &l:stl = focus.byfname.regex.slider.marked.dir
|
||||||
en
|
en
|
||||||
endf
|
endf
|
||||||
@@ -988,7 +996,7 @@ endf
|
|||||||
fu! ctrlp#progress(enum)
|
fu! ctrlp#progress(enum)
|
||||||
if has('macunix') || has('mac') | sl 1m | en
|
if has('macunix') || has('mac') | sl 1m | en
|
||||||
let &l:stl = has_key(s:status, 'prog') ? call(s:status['prog'], [a:enum])
|
let &l:stl = has_key(s:status, 'prog') ? call(s:status['prog'], [a:enum])
|
||||||
\ : '%#Function# '.a:enum.' %* %=%<%#LineNr# '.getcwd().' %*'
|
\ : '%#CtrlPStats# '.a:enum.' %* %=%<%#CtrlPMode2# '.getcwd().' %*'
|
||||||
redr
|
redr
|
||||||
endf
|
endf
|
||||||
" Paths {{{2
|
" Paths {{{2
|
||||||
@@ -1114,37 +1122,37 @@ fu! ctrlp#fnesc(path)
|
|||||||
endf
|
endf
|
||||||
|
|
||||||
fu! ctrlp#setdir(path, ...)
|
fu! ctrlp#setdir(path, ...)
|
||||||
let cmd = exists('a:1') ? a:1 : 'lc!'
|
let cmd = a:0 ? a:1 : 'lc!'
|
||||||
try
|
sil! exe cmd ctrlp#fnesc(a:path)
|
||||||
exe cmd.' '.ctrlp#fnesc(a:path)
|
|
||||||
cat
|
|
||||||
cal ctrlp#msg("Can't change working directory.")
|
|
||||||
endt
|
|
||||||
endf
|
endf
|
||||||
" Highlighting {{{2
|
" Highlighting {{{2
|
||||||
fu! s:syntax()
|
fu! s:syntax()
|
||||||
|
for [ke, va] in items(s:hlgrps) | if !hlexists('CtrlP'.ke)
|
||||||
|
exe 'hi link CtrlP'.ke va
|
||||||
|
en | endfo
|
||||||
|
if !hlexists('CtrlPLinePre')
|
||||||
|
\ && synIDattr(synIDtrans(hlID('Normal')), 'bg') !~ '^-1$\|^$'
|
||||||
|
sil! exe 'hi CtrlPLinePre '.( has("gui_running") ? 'gui' : 'cterm' ).'fg=bg'
|
||||||
|
en
|
||||||
sy match CtrlPNoEntries '^ == NO ENTRIES ==$'
|
sy match CtrlPNoEntries '^ == NO ENTRIES ==$'
|
||||||
sy match CtrlPLinePre '^>'
|
if hlexists('CtrlPLinePre')
|
||||||
hi link CtrlPNoEntries Error
|
sy match CtrlPLinePre '^>'
|
||||||
if exists('g:colors_name')
|
|
||||||
exe 'hi CtrlPLinePre '.( has("gui_running") ? 'gui' : 'cterm' ).'fg=bg'
|
|
||||||
en
|
en
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:highlight(pat, grp, bfn)
|
fu! s:highlight(pat, grp)
|
||||||
cal clearmatches()
|
cal clearmatches()
|
||||||
if !empty(a:pat) && s:ispathitem()
|
if !empty(a:pat) && s:ispathitem()
|
||||||
let pat = substitute(a:pat, '\~', '\\~', 'g')
|
let pat = s:regexp ? substitute(a:pat, '\\\@<!\^', '^> \\zs', 'g') : a:pat
|
||||||
let pat = s:regexp
|
if s:byfname
|
||||||
\ ? substitute(pat, '\\\@<!\^', '^> \\zs', 'g')
|
" Match only filename
|
||||||
\ : escape(pat, '.')
|
|
||||||
" Match only filename
|
|
||||||
if s:byfname && a:bfn
|
|
||||||
let pat = substitute(pat, '\[\^\(.\{-}\)\]\\{-}', '[^\\/\1]\\{-}', 'g')
|
let pat = substitute(pat, '\[\^\(.\{-}\)\]\\{-}', '[^\\/\1]\\{-}', 'g')
|
||||||
let pat = substitute(pat, '$', '\\ze[^\\/]*$', 'g')
|
let pat = substitute(pat, '\$\@<!$', '\\ze[^\\/]*$', 'g')
|
||||||
en
|
en
|
||||||
cal matchadd(a:grp, '\c'.pat)
|
cal matchadd(a:grp, '\c'.pat)
|
||||||
cal matchadd('CtrlPLinePre', '^>')
|
if hlexists('CtrlPLinePre')
|
||||||
|
cal matchadd('CtrlPLinePre', '^>')
|
||||||
|
en
|
||||||
en
|
en
|
||||||
endf
|
endf
|
||||||
|
|
||||||
@@ -1268,7 +1276,7 @@ endf
|
|||||||
fu! s:leavepre()
|
fu! s:leavepre()
|
||||||
if s:clrex && ( !has('clientserver') ||
|
if s:clrex && ( !has('clientserver') ||
|
||||||
\ ( has('clientserver') && len(split(serverlist(), "\n")) == 1 ) )
|
\ ( has('clientserver') && len(split(serverlist(), "\n")) == 1 ) )
|
||||||
cal ctrlp#clra(1)
|
cal ctrlp#clra()
|
||||||
en
|
en
|
||||||
endf
|
endf
|
||||||
|
|
||||||
@@ -1313,6 +1321,7 @@ fu! s:argmaps(md, ...)
|
|||||||
endf
|
endf
|
||||||
" Misc {{{2
|
" Misc {{{2
|
||||||
fu! s:getenv()
|
fu! s:getenv()
|
||||||
|
let s:winh = min([s:mxheight, &lines])
|
||||||
let [s:cwd, s:winres] = [getcwd(), [winrestcmd(), &lines, winnr('$')]]
|
let [s:cwd, s:winres] = [getcwd(), [winrestcmd(), &lines, winnr('$')]]
|
||||||
let [s:crfile, s:crfpath] = [expand('%:p', 1), expand('%:p:h', 1)]
|
let [s:crfile, s:crfpath] = [expand('%:p', 1), expand('%:p:h', 1)]
|
||||||
let [s:crword, s:crline] = [expand('<cword>'), getline('.')]
|
let [s:crword, s:crline] = [expand('<cword>'), getline('.')]
|
||||||
@@ -1347,31 +1356,26 @@ fu! s:migemo(str)
|
|||||||
let [tokens, str, cmd] = [split(str, '\s'), '', 'cmigemo -v -w %s -d %s']
|
let [tokens, str, cmd] = [split(str, '\s'), '', 'cmigemo -v -w %s -d %s']
|
||||||
for token in tokens
|
for token in tokens
|
||||||
let rtn = system(printf(cmd, shellescape(token), shellescape(dict)))
|
let rtn = system(printf(cmd, shellescape(token), shellescape(dict)))
|
||||||
let str .= !v:shell_error && len(rtn) > 0 ? '.*'.rtn : token
|
let str .= !v:shell_error && strlen(rtn) > 0 ? '.*'.rtn : token
|
||||||
endfo
|
endfo
|
||||||
en
|
en
|
||||||
retu str
|
retu str
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! ctrlp#msg(msg)
|
fu! s:openfile(cmd, fid, tail, ...)
|
||||||
redr | echoh Identifier | echon "CtrlP: ".a:msg | echoh None
|
|
||||||
endf
|
|
||||||
|
|
||||||
fu! s:openfile(cmd, filpath, ...)
|
|
||||||
let cmd = a:cmd =~ '^[eb]$' && &modified ? 'hid '.a:cmd : a:cmd
|
let cmd = a:cmd =~ '^[eb]$' && &modified ? 'hid '.a:cmd : a:cmd
|
||||||
let cmd = cmd =~ '^tab' ? tabpagenr('$').cmd : cmd
|
let cmd = cmd =~ '^tab' ? tabpagenr('$').cmd : cmd
|
||||||
let tail = a:0 ? a:1 : s:tail()
|
let j2l = a:0 && a:1 ? a:2 : 0
|
||||||
try
|
exe cmd.( a:0 && a:1 ? '' : a:tail ) ctrlp#fnesc(a:fid)
|
||||||
exe cmd.tail.' '.ctrlp#fnesc(a:filpath)
|
if j2l
|
||||||
cat
|
exe j2l
|
||||||
fina
|
en
|
||||||
if !empty(tail)
|
if !empty(a:tail) || j2l
|
||||||
sil! norm! zvzz
|
sil! norm! zvzz
|
||||||
en
|
en
|
||||||
if exists('*haslocaldir')
|
if exists('*haslocaldir')
|
||||||
cal ctrlp#setdir(getcwd(), haslocaldir() ? 'lc!' : 'cd!')
|
cal ctrlp#setdir(getcwd(), haslocaldir() ? 'lc!' : 'cd!')
|
||||||
en
|
en
|
||||||
endt
|
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:writecache(read_cache, cache_file)
|
fu! s:writecache(read_cache, cache_file)
|
||||||
@@ -1494,9 +1498,11 @@ fu! ctrlp#init(type, ...)
|
|||||||
cal s:Open()
|
cal s:Open()
|
||||||
cal s:SetWD(a:0 ? a:1 : '')
|
cal s:SetWD(a:0 ? a:1 : '')
|
||||||
cal s:MapKeys()
|
cal s:MapKeys()
|
||||||
|
if has('syntax') && exists('g:syntax_on')
|
||||||
|
cal s:syntax()
|
||||||
|
en
|
||||||
cal s:SetLines(a:type)
|
cal s:SetLines(a:type)
|
||||||
cal s:BuildPrompt(1)
|
cal s:BuildPrompt(1)
|
||||||
if has('syntax') && exists('g:syntax_on') | cal s:syntax() | en
|
|
||||||
endf
|
endf
|
||||||
if has('autocmd') "{{{1
|
if has('autocmd') "{{{1
|
||||||
aug CtrlPAug
|
aug CtrlPAug
|
||||||
@@ -165,9 +165,6 @@ fu! s:esctagscmd(bin, args, ...)
|
|||||||
let last = s:enc != &enc ? s:enc : !empty($LANG) ? $LANG : &enc
|
let last = s:enc != &enc ? s:enc : !empty($LANG) ? $LANG : &enc
|
||||||
let cmd = iconv(cmd, &enc, last)
|
let cmd = iconv(cmd, &enc, last)
|
||||||
en
|
en
|
||||||
if empty(cmd)
|
|
||||||
cal ctrlp#msg("Encoding conversion failed!")
|
|
||||||
en
|
|
||||||
retu cmd
|
retu cmd
|
||||||
endf
|
endf
|
||||||
|
|
||||||
@@ -196,7 +193,7 @@ fu! s:parseline(line)
|
|||||||
let eval = '\v^([^\t]+)\t(.+)\t\/\^(.+)\$\/\;\"\t(.+)\tline(no)?\:(\d+)'
|
let eval = '\v^([^\t]+)\t(.+)\t\/\^(.+)\$\/\;\"\t(.+)\tline(no)?\:(\d+)'
|
||||||
let vals = matchlist(a:line, eval)
|
let vals = matchlist(a:line, eval)
|
||||||
if empty(vals) | retu '' | en
|
if empty(vals) | retu '' | en
|
||||||
let [bufnr, bufname] = [bufnr(vals[2]), fnamemodify(vals[2], ':p:t')]
|
let [bufnr, bufname] = [bufnr('^'.vals[2].'$'), fnamemodify(vals[2], ':p:t')]
|
||||||
retu vals[1].' '.vals[4].'|'.bufnr.':'.bufname.'|'.vals[6].'| '.vals[3]
|
retu vals[1].' '.vals[4].'|'.bufnr.':'.bufname.'|'.vals[6].'| '.vals[3]
|
||||||
endf
|
endf
|
||||||
" Public {{{1
|
" Public {{{1
|
||||||
@@ -208,8 +205,10 @@ fu! ctrlp#buffertag#init(fname)
|
|||||||
let tftype = get(split(getbufvar(each, '&ft'), '\.'), 0, '')
|
let tftype = get(split(getbufvar(each, '&ft'), '\.'), 0, '')
|
||||||
cal extend(lines, s:process(each, tftype))
|
cal extend(lines, s:process(each, tftype))
|
||||||
endfo
|
endfo
|
||||||
|
if !hlexists('CtrlPTabExtra')
|
||||||
|
hi link CtrlPTabExtra Comment
|
||||||
|
en
|
||||||
sy match CtrlPTabExtra '\zs\t.*\ze$'
|
sy match CtrlPTabExtra '\zs\t.*\ze$'
|
||||||
hi link CtrlPTabExtra Comment
|
|
||||||
retu lines
|
retu lines
|
||||||
endf
|
endf
|
||||||
|
|
||||||
@@ -57,13 +57,13 @@ fu! ctrlp#dir#init(...)
|
|||||||
cal s:globdirs(s:cwd, 0)
|
cal s:globdirs(s:cwd, 0)
|
||||||
cal ctrlp#rmbasedir(g:ctrlp_alldirs)
|
cal ctrlp#rmbasedir(g:ctrlp_alldirs)
|
||||||
let read_cache = 0
|
let read_cache = 0
|
||||||
|
if len(g:ctrlp_alldirs) <= s:compare_lim
|
||||||
|
cal sort(g:ctrlp_alldirs, 'ctrlp#complen')
|
||||||
|
en
|
||||||
el
|
el
|
||||||
let g:ctrlp_alldirs = ctrlp#utils#readfile(cafile)
|
let g:ctrlp_alldirs = ctrlp#utils#readfile(cafile)
|
||||||
let read_cache = 1
|
let read_cache = 1
|
||||||
en
|
en
|
||||||
if len(g:ctrlp_alldirs) <= s:compare_lim
|
|
||||||
cal sort(g:ctrlp_alldirs, 'ctrlp#complen')
|
|
||||||
en
|
|
||||||
if !read_cache
|
if !read_cache
|
||||||
cal ctrlp#utils#writecache(g:ctrlp_alldirs, cadir, cafile)
|
cal ctrlp#utils#writecache(g:ctrlp_alldirs, cadir, cafile)
|
||||||
let g:ctrlp_newdir = 0
|
let g:ctrlp_newdir = 0
|
||||||
@@ -35,7 +35,7 @@ fu! ctrlp#line#init()
|
|||||||
for each in bufs
|
for each in bufs
|
||||||
let from_file = readfile(each)
|
let from_file = readfile(each)
|
||||||
cal map(from_file, 'tr(v:val, '' '', '' '')')
|
cal map(from_file, 'tr(v:val, '' '', '' '')')
|
||||||
let [id, len_ff, bufnr] = [1, len(from_file), bufnr(each)]
|
let [id, len_ff, bufnr] = [1, len(from_file), bufnr('^'.each.'$')]
|
||||||
wh id <= len_ff
|
wh id <= len_ff
|
||||||
let from_file[id-1] .= ' #:'.bufnr.':'.id
|
let from_file[id-1] .= ' #:'.bufnr.':'.id
|
||||||
let id += 1
|
let id += 1
|
||||||
@@ -43,8 +43,10 @@ fu! ctrlp#line#init()
|
|||||||
cal filter(from_file, 'v:val !~ ''^\s*\t#:\d\+:\d\+$''')
|
cal filter(from_file, 'v:val !~ ''^\s*\t#:\d\+:\d\+$''')
|
||||||
cal extend(lines, from_file)
|
cal extend(lines, from_file)
|
||||||
endfo
|
endfo
|
||||||
|
if !hlexists('CtrlPTabExtra')
|
||||||
|
hi link CtrlPTabExtra Comment
|
||||||
|
en
|
||||||
sy match CtrlPTabExtra '\zs\t.*\ze$'
|
sy match CtrlPTabExtra '\zs\t.*\ze$'
|
||||||
hi link CtrlPTabExtra Comment
|
|
||||||
retu lines
|
retu lines
|
||||||
endf
|
endf
|
||||||
|
|
||||||
@@ -8,10 +8,10 @@
|
|||||||
fu! ctrlp#mrufiles#opts()
|
fu! ctrlp#mrufiles#opts()
|
||||||
let opts = {
|
let opts = {
|
||||||
\ 'g:ctrlp_mruf_max': ['s:max', 250],
|
\ 'g:ctrlp_mruf_max': ['s:max', 250],
|
||||||
\ 'g:ctrlp_mruf_include': ['s:include', ''],
|
\ 'g:ctrlp_mruf_include': ['s:in', ''],
|
||||||
\ 'g:ctrlp_mruf_exclude': ['s:exclude', ''],
|
\ 'g:ctrlp_mruf_exclude': ['s:ex', ''],
|
||||||
\ 'g:ctrlp_mruf_case_sensitive': ['s:csen', 1],
|
\ 'g:ctrlp_mruf_case_sensitive': ['s:csen', 1],
|
||||||
\ 'g:ctrlp_mruf_relative': ['s:relate', 0],
|
\ 'g:ctrlp_mruf_relative': ['s:re', 0],
|
||||||
\ 'g:ctrlp_mruf_last_entered': ['s:mre', 0],
|
\ 'g:ctrlp_mruf_last_entered': ['s:mre', 0],
|
||||||
\ }
|
\ }
|
||||||
for [ke, va] in items(opts)
|
for [ke, va] in items(opts)
|
||||||
@@ -24,11 +24,10 @@ fu! ctrlp#mrufiles#list(bufnr, ...) "{{{1
|
|||||||
if s:locked | retu | en
|
if s:locked | retu | en
|
||||||
let bufnr = a:bufnr + 0
|
let bufnr = a:bufnr + 0
|
||||||
if bufnr > 0
|
if bufnr > 0
|
||||||
let filename = fnamemodify(bufname(bufnr), ':p')
|
let fn = fnamemodify(bufname(bufnr), ':p')
|
||||||
if empty(filename) || !empty(&bt)
|
let fn = exists('+ssl') ? tr(fn, '/', '\') : fn
|
||||||
\ || ( !empty(s:include) && filename !~# s:include )
|
if empty(fn) || !empty(&bt) || ( !empty(s:in) && fn !~# s:in )
|
||||||
\ || ( !empty(s:exclude) && filename =~# s:exclude )
|
\ || ( !empty(s:ex) && fn =~# s:ex ) || !filereadable(fn)
|
||||||
\ || !filereadable(filename)
|
|
||||||
retu
|
retu
|
||||||
en
|
en
|
||||||
en
|
en
|
||||||
@@ -45,31 +44,34 @@ fu! ctrlp#mrufiles#list(bufnr, ...) "{{{1
|
|||||||
" Remove non-existent files
|
" Remove non-existent files
|
||||||
if a:0 && a:1 == 1
|
if a:0 && a:1 == 1
|
||||||
cal filter(mrufs, '!empty(ctrlp#utils#glob(v:val, 1)) && !s:excl(v:val)')
|
cal filter(mrufs, '!empty(ctrlp#utils#glob(v:val, 1)) && !s:excl(v:val)')
|
||||||
|
if exists('+ssl')
|
||||||
|
cal map(mrufs, 'tr(v:val, ''/'', ''\'')')
|
||||||
|
cal filter(mrufs, 'count(mrufs, v:val) == 1')
|
||||||
|
en
|
||||||
cal ctrlp#utils#writecache(mrufs, s:cadir, s:cafile)
|
cal ctrlp#utils#writecache(mrufs, s:cadir, s:cafile)
|
||||||
en
|
en
|
||||||
" Return the list with the active buffer removed
|
" Return the list with the active buffer removed
|
||||||
if bufnr == -1
|
if bufnr == -1
|
||||||
let crf = fnamemodify(bufname(winbufnr(winnr('#'))), ':p')
|
let crf = fnamemodify(bufname(winbufnr(winnr('#'))), ':p')
|
||||||
|
let crf = exists('+ssl') ? tr(crf, '/', '\') : crf
|
||||||
let mrufs = empty(crf) ? mrufs : filter(mrufs, 'v:val !='.s:csen.' crf')
|
let mrufs = empty(crf) ? mrufs : filter(mrufs, 'v:val !='.s:csen.' crf')
|
||||||
if s:relate
|
if s:re
|
||||||
let cwd = getcwd()
|
let cwd = exists('+ssl') ? tr(getcwd(), '/', '\') : getcwd()
|
||||||
cal filter(mrufs, '!stridx(v:val, cwd)')
|
cal filter(mrufs, '!stridx(v:val, cwd)')
|
||||||
cal ctrlp#rmbasedir(mrufs)
|
|
||||||
el
|
|
||||||
cal map(mrufs, 'fnamemodify(v:val, '':.'')')
|
|
||||||
en
|
en
|
||||||
|
cal map(mrufs, 'fnamemodify(v:val, '':.'')')
|
||||||
retu mrufs
|
retu mrufs
|
||||||
en
|
en
|
||||||
" Remove old entry
|
" Remove old entry
|
||||||
cal filter(mrufs, 'v:val !='.s:csen.' filename')
|
cal filter(mrufs, 'v:val !='.s:csen.' fn')
|
||||||
" Insert new one
|
" Insert new one
|
||||||
cal insert(mrufs, filename)
|
cal insert(mrufs, fn)
|
||||||
" Remove oldest entry or entries
|
" Remove oldest entry or entries
|
||||||
if len(mrufs) > s:max | cal remove(mrufs, s:max, -1) | en
|
if len(mrufs) > s:max | cal remove(mrufs, s:max, -1) | en
|
||||||
cal ctrlp#utils#writecache(mrufs, s:cadir, s:cafile)
|
cal ctrlp#utils#writecache(mrufs, s:cadir, s:cafile)
|
||||||
endf "}}}
|
endf "}}}
|
||||||
fu! s:excl(fname) "{{{
|
fu! s:excl(fn) "{{{
|
||||||
retu !empty(s:exclude) && a:fname =~# s:exclude
|
retu !empty(s:ex) && a:fn =~# s:ex
|
||||||
endf "}}}
|
endf "}}}
|
||||||
fu! ctrlp#mrufiles#init() "{{{1
|
fu! ctrlp#mrufiles#init() "{{{1
|
||||||
let s:locked = 0
|
let s:locked = 0
|
||||||
@@ -30,8 +30,10 @@ endf
|
|||||||
" Public {{{1
|
" Public {{{1
|
||||||
fu! ctrlp#quickfix#init()
|
fu! ctrlp#quickfix#init()
|
||||||
let g:ctrlp_nolimit = 1
|
let g:ctrlp_nolimit = 1
|
||||||
|
if !hlexists('CtrlPqfLineCol')
|
||||||
|
hi link CtrlPqfLineCol Search
|
||||||
|
en
|
||||||
sy match CtrlPqfLineCol '|\zs\d\+:\d\+\ze|'
|
sy match CtrlPqfLineCol '|\zs\d\+:\d\+\ze|'
|
||||||
hi def link CtrlPqfLineCol Search
|
|
||||||
retu map(getqflist(), 's:lineout(v:val)')
|
retu map(getqflist(), 's:lineout(v:val)')
|
||||||
endf
|
endf
|
||||||
|
|
||||||
@@ -43,13 +45,9 @@ fu! ctrlp#quickfix#accept(mode, str)
|
|||||||
let cmd = md == 't' ? 'tabe' : md == 'h' ? 'new' : md == 'v' ? 'vne'
|
let cmd = md == 't' ? 'tabe' : md == 'h' ? 'new' : md == 'v' ? 'vne'
|
||||||
\ : ctrlp#normcmd('e')
|
\ : ctrlp#normcmd('e')
|
||||||
let cmd = cmd == 'e' && &modified ? 'hid e' : cmd
|
let cmd = cmd == 'e' && &modified ? 'hid e' : cmd
|
||||||
try
|
exe cmd ctrlp#fnesc(filpath)
|
||||||
exe cmd.' '.ctrlp#fnesc(filpath)
|
cal cursor(items[2], items[3])
|
||||||
cat
|
sil! norm! zvzz
|
||||||
cal ctrlp#msg("Invalid command or argument.")
|
|
||||||
fina
|
|
||||||
cal cursor(items[2], items[3]) | sil! norm! zvzz
|
|
||||||
endt
|
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! ctrlp#quickfix#id()
|
fu! ctrlp#quickfix#id()
|
||||||
@@ -12,7 +12,7 @@ let [g:loaded_ctrlp_rtscript, g:ctrlp_newrts] = [1, 0]
|
|||||||
|
|
||||||
let s:rtscript_var = {
|
let s:rtscript_var = {
|
||||||
\ 'init': 'ctrlp#rtscript#init()',
|
\ 'init': 'ctrlp#rtscript#init()',
|
||||||
\ 'accept': 'ctrlp#rtscript#accept',
|
\ 'accept': 'ctrlp#acceptfile',
|
||||||
\ 'lname': 'runtime scripts',
|
\ 'lname': 'runtime scripts',
|
||||||
\ 'sname': 'rts',
|
\ 'sname': 'rts',
|
||||||
\ 'type': 'path',
|
\ 'type': 'path',
|
||||||
@@ -24,18 +24,23 @@ let g:ctrlp_ext_vars = exists('g:ctrlp_ext_vars') && !empty(g:ctrlp_ext_vars)
|
|||||||
let s:id = g:ctrlp_builtins + len(g:ctrlp_ext_vars)
|
let s:id = g:ctrlp_builtins + len(g:ctrlp_ext_vars)
|
||||||
" Public {{{1
|
" Public {{{1
|
||||||
fu! ctrlp#rtscript#init()
|
fu! ctrlp#rtscript#init()
|
||||||
if g:ctrlp_newrts || !exists('g:ctrlp_rtscache')
|
if g:ctrlp_newrts
|
||||||
|
\ || !( exists('g:ctrlp_rtscache') && g:ctrlp_rtscache[0] == &rtp )
|
||||||
sil! cal ctrlp#progress('Indexing...')
|
sil! cal ctrlp#progress('Indexing...')
|
||||||
let entries = split(globpath(&rtp, '**/*.*'), "\n")
|
let entries = split(globpath(&rtp, '**/*.*'), "\n")
|
||||||
cal filter(entries, 'index(entries, v:val, v:key + 1) < 0')
|
cal filter(entries, 'count(entries, v:val) == 1')
|
||||||
cal map(entries, 'fnamemodify(v:val, '':.'')')
|
let [entries, echoed] = [ctrlp#dirnfile(entries)[1], 1]
|
||||||
let [g:ctrlp_rtscache, g:ctrlp_newrts] = [ctrlp#dirnfile(entries)[1], 0]
|
el
|
||||||
|
let [entries, results] = g:ctrlp_rtscache[2:3]
|
||||||
en
|
en
|
||||||
retu g:ctrlp_rtscache
|
let cwd = getcwd()
|
||||||
endf
|
if g:ctrlp_newrts
|
||||||
|
\ || !( exists('g:ctrlp_rtscache') && g:ctrlp_rtscache[:1] == [&rtp, cwd] )
|
||||||
fu! ctrlp#rtscript#accept(mode, str)
|
if !exists('echoed') | sil! cal ctrlp#progress('Processing...') | en
|
||||||
cal ctrlp#acceptfile(a:mode, a:str)
|
let results = map(copy(entries), 'fnamemodify(v:val, '':.'')')
|
||||||
|
en
|
||||||
|
let [g:ctrlp_rtscache, g:ctrlp_newrts] = [[&rtp, cwd, entries, results], 0]
|
||||||
|
retu results
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! ctrlp#rtscript#id()
|
fu! ctrlp#rtscript#id()
|
||||||
@@ -72,8 +72,10 @@ fu! ctrlp#tag#init(tagfiles)
|
|||||||
let alltags = s:filter(ctrlp#utils#readfile(each))
|
let alltags = s:filter(ctrlp#utils#readfile(each))
|
||||||
cal extend(g:ctrlp_alltags, alltags)
|
cal extend(g:ctrlp_alltags, alltags)
|
||||||
endfo
|
endfo
|
||||||
|
if !hlexists('CtrlPTabExtra')
|
||||||
|
hi link CtrlPTabExtra Comment
|
||||||
|
en
|
||||||
sy match CtrlPTabExtra '\zs\t.*\ze$'
|
sy match CtrlPTabExtra '\zs\t.*\ze$'
|
||||||
hi link CtrlPTabExtra Comment
|
|
||||||
retu g:ctrlp_alltags
|
retu g:ctrlp_alltags
|
||||||
endf
|
endf
|
||||||
|
|
||||||
@@ -90,19 +92,15 @@ fu! ctrlp#tag#accept(mode, str)
|
|||||||
\ }
|
\ }
|
||||||
let cmd = fnd[0] == 1 ? cmds[md][0] : cmds[md][1]
|
let cmd = fnd[0] == 1 ? cmds[md][0] : cmds[md][1]
|
||||||
let cmd = cmd == 'tj' && &modified ? 'hid '.cmd : cmd
|
let cmd = cmd == 'tj' && &modified ? 'hid '.cmd : cmd
|
||||||
try
|
let cmd = cmd =~ '^tab' ? tabpagenr('$').cmd : cmd
|
||||||
let cmd = cmd =~ '^tab' ? tabpagenr('$').cmd : cmd
|
if fnd[0] == 1
|
||||||
if fnd[0] == 1
|
if cmd != ''
|
||||||
if cmd != ''
|
exe cmd
|
||||||
exe cmd
|
|
||||||
en
|
|
||||||
exe fnd[1].'ta' tg
|
|
||||||
el
|
|
||||||
exe cmd.' '.tg
|
|
||||||
en
|
en
|
||||||
cat
|
exe fnd[1].'ta' tg
|
||||||
cal ctrlp#msg("Tag not found.")
|
el
|
||||||
endt
|
exe cmd tg
|
||||||
|
en
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! ctrlp#tag#id()
|
fu! ctrlp#tag#id()
|
||||||
@@ -80,12 +80,14 @@ fu! s:humantime(nr)
|
|||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:syntax()
|
fu! s:syntax()
|
||||||
|
for [ke, va] in items({'T': 'Directory', 'Br': 'Comment', 'Nr': 'String'})
|
||||||
|
if !hlexists('CtrlPUndo'.ke)
|
||||||
|
exe 'hi link CtrlPUndo'.ke va
|
||||||
|
en
|
||||||
|
endfo
|
||||||
sy match CtrlPUndoT '\d\+ \zs[^ ]\+\ze'
|
sy match CtrlPUndoT '\d\+ \zs[^ ]\+\ze'
|
||||||
sy match CtrlPUndoBr '\[\|\]'
|
sy match CtrlPUndoBr '\[\|\]'
|
||||||
sy match CtrlPUndoNr '\[\d\+\]$' contains=CtrlPUndoBr
|
sy match CtrlPUndoNr '\[\d\+\]$' contains=CtrlPUndoBr
|
||||||
hi link CtrlPUndoT Directory
|
|
||||||
hi link CtrlPUndoBr Comment
|
|
||||||
hi link CtrlPUndoNr String
|
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! s:dict2list(dict)
|
fu! s:dict2list(dict)
|
||||||
@@ -33,9 +33,9 @@ fu! ctrlp#utils#cachedir()
|
|||||||
endf
|
endf
|
||||||
|
|
||||||
fu! ctrlp#utils#cachefile(...)
|
fu! ctrlp#utils#cachefile(...)
|
||||||
let tail = exists('a:1') ? '.'.a:1 : ''
|
let tail = a:0 ? '.'.a:1 : ''
|
||||||
let cache_file = substitute(getcwd(), '\([\/]\|^\a\zs:\)', '%', 'g').tail.'.txt'
|
let cache_file = substitute(getcwd(), '\([\/]\|^\a\zs:\)', '%', 'g').tail.'.txt'
|
||||||
retu exists('a:1') ? cache_file : s:cache_dir.s:lash(s:cache_dir).cache_file
|
retu a:0 ? cache_file : s:cache_dir.s:lash(s:cache_dir).cache_file
|
||||||
endf
|
endf
|
||||||
|
|
||||||
fu! ctrlp#utils#readfile(file)
|
fu! ctrlp#utils#readfile(file)
|
||||||
@@ -58,9 +58,9 @@ fu! ctrlp#utils#mkdir(dir)
|
|||||||
endf
|
endf
|
||||||
|
|
||||||
fu! ctrlp#utils#writecache(lines, ...)
|
fu! ctrlp#utils#writecache(lines, ...)
|
||||||
if isdirectory(ctrlp#utils#mkdir(exists('a:1') ? a:1 : s:cache_dir))
|
if isdirectory(ctrlp#utils#mkdir(a:0 ? a:1 : s:cache_dir))
|
||||||
sil! cal writefile(a:lines, exists('a:2') ? a:2 : ctrlp#utils#cachefile())
|
sil! cal writefile(a:lines, a:0 >= 2 ? a:2 : ctrlp#utils#cachefile())
|
||||||
if !exists('a:1')
|
if !a:0
|
||||||
let g:ctrlp_newcache = 0
|
let g:ctrlp_newcache = 0
|
||||||
en
|
en
|
||||||
en
|
en
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
*ctrlp.txt* Fuzzy file, buffer, mru and tag finder. v1.6.9
|
*ctrlp.txt* Fuzzy file, buffer, mru and tag finder. v1.7.1
|
||||||
*CtrlP* *ControlP* *'ctrlp'* *'ctrl-p'*
|
*CtrlP* *ControlP* *'ctrlp'* *'ctrl-p'*
|
||||||
===============================================================================
|
===============================================================================
|
||||||
# #
|
# #
|
||||||
@@ -28,7 +28,7 @@ Written in pure Vimscript for MacVim and Vim version 7.0+. Has full support for
|
|||||||
Vim’s |regexp| as search pattern, built-in MRU files monitoring, project’s root
|
Vim’s |regexp| as search pattern, built-in MRU files monitoring, project’s root
|
||||||
finder, and more.
|
finder, and more.
|
||||||
|
|
||||||
To enable optional extensions (tag, quickfix, dir...), see |ctrlp-extensions|.
|
To enable optional extensions (tag, dir, rtscript...), see |ctrlp-extensions|.
|
||||||
|
|
||||||
===============================================================================
|
===============================================================================
|
||||||
2. Options *ctrlp-options*
|
2. Options *ctrlp-options*
|
||||||
@@ -77,8 +77,8 @@ Set the maximum height of the match window: >
|
|||||||
<
|
<
|
||||||
|
|
||||||
*'g:ctrlp_jump_to_buffer'*
|
*'g:ctrlp_jump_to_buffer'*
|
||||||
When opening a file, if it's already opened somewhere |CtrlP| will try to jump
|
When opening a file with <cr> or <c-t>, if the file's already opened somewhere
|
||||||
to it instead of opening a new window or new tab: >
|
|CtrlP| will try to jump to it instead of opening a new instance: >
|
||||||
let g:ctrlp_jump_to_buffer = 2
|
let g:ctrlp_jump_to_buffer = 2
|
||||||
<
|
<
|
||||||
1 - only jump to the buffer if it’s opened in the current tab.
|
1 - only jump to the buffer if it’s opened in the current tab.
|
||||||
@@ -86,8 +86,10 @@ to it instead of opening a new window or new tab: >
|
|||||||
0 - disable this feature.
|
0 - disable this feature.
|
||||||
|
|
||||||
*'g:ctrlp_working_path_mode'*
|
*'g:ctrlp_working_path_mode'*
|
||||||
When starting up the prompt, temporarily set the working directory (i.e. the
|
When starting up, |CtrlP| sets its local working directory according to this
|
||||||
|current-directory|) to:
|
variable: >
|
||||||
|
let g:ctrlp_working_path_mode = 2
|
||||||
|
<
|
||||||
1 - the parent directory of the current file.
|
1 - the parent directory of the current file.
|
||||||
2 - the nearest ancestor that contains one of these directories/files:
|
2 - the nearest ancestor that contains one of these directories/files:
|
||||||
.git/
|
.git/
|
||||||
@@ -96,9 +98,6 @@ When starting up the prompt, temporarily set the working directory (i.e. the
|
|||||||
_darcs/
|
_darcs/
|
||||||
root.dir
|
root.dir
|
||||||
0 - don’t manage working directory.
|
0 - don’t manage working directory.
|
||||||
>
|
|
||||||
let g:ctrlp_working_path_mode = 2
|
|
||||||
<
|
|
||||||
|
|
||||||
*'g:ctrlp_root_markers'*
|
*'g:ctrlp_root_markers'*
|
||||||
Use this to set your own root markers in addition to the default ones. Your
|
Use this to set your own root markers in addition to the default ones. Your
|
||||||
@@ -106,7 +105,7 @@ markers will take precedence: >
|
|||||||
let g:ctrlp_root_markers = ['']
|
let g:ctrlp_root_markers = ['']
|
||||||
<
|
<
|
||||||
These markers (builtins and yours) will serve as identifiers for the '/' and
|
These markers (builtins and yours) will serve as identifiers for the '/' and
|
||||||
'\' special inputs (section 5.e)
|
'\' special inputs (section 5.e).
|
||||||
|
|
||||||
*'g:ctrlp_use_caching'*
|
*'g:ctrlp_use_caching'*
|
||||||
Set this to 0 to disable per-session caching. When disabled, caching will still
|
Set this to 0 to disable per-session caching. When disabled, caching will still
|
||||||
@@ -116,7 +115,7 @@ be enabled for directories that have more than 4000 files: >
|
|||||||
Note: you can quickly purge the cache by pressing <F5> while inside |CtrlP|.
|
Note: you can quickly purge the cache by pressing <F5> while inside |CtrlP|.
|
||||||
|
|
||||||
*'g:ctrlp_clear_cache_on_exit'*
|
*'g:ctrlp_clear_cache_on_exit'*
|
||||||
Set this to 0 to enable cross-sessions caching by not clearing the cache files
|
Set this to 0 to enable cross-session caching by not deleting the cache files
|
||||||
upon exiting Vim: >
|
upon exiting Vim: >
|
||||||
let g:ctrlp_clear_cache_on_exit = 1
|
let g:ctrlp_clear_cache_on_exit = 1
|
||||||
<
|
<
|
||||||
@@ -138,7 +137,7 @@ only need to keep the lines that you’ve changed the values (inside []): >
|
|||||||
\ 'PrtSelectMove("k")': ['<c-k>', '<up>'],
|
\ 'PrtSelectMove("k")': ['<c-k>', '<up>'],
|
||||||
\ 'PrtHistory(-1)': ['<c-n>'],
|
\ 'PrtHistory(-1)': ['<c-n>'],
|
||||||
\ 'PrtHistory(1)': ['<c-p>'],
|
\ 'PrtHistory(1)': ['<c-p>'],
|
||||||
\ 'AcceptSelection("e")': ['<cr>', '<c-m>', '<2-LeftMouse>'],
|
\ 'AcceptSelection("e")': ['<cr>', '<2-LeftMouse>'],
|
||||||
\ 'AcceptSelection("h")': ['<c-x>', '<c-cr>', '<c-s>'],
|
\ 'AcceptSelection("h")': ['<c-x>', '<c-cr>', '<c-s>'],
|
||||||
\ 'AcceptSelection("t")': ['<c-t>', '<MiddleMouse>'],
|
\ 'AcceptSelection("t")': ['<c-t>', '<MiddleMouse>'],
|
||||||
\ 'AcceptSelection("v")': ['<c-v>', '<RightMouse>'],
|
\ 'AcceptSelection("v")': ['<c-v>', '<RightMouse>'],
|
||||||
@@ -147,8 +146,8 @@ only need to keep the lines that you’ve changed the values (inside []): >
|
|||||||
\ 'ToggleByFname()': ['<c-d>'],
|
\ 'ToggleByFname()': ['<c-d>'],
|
||||||
\ 'ToggleType(1)': ['<c-f>', '<c-up>'],
|
\ 'ToggleType(1)': ['<c-f>', '<c-up>'],
|
||||||
\ 'ToggleType(-1)': ['<c-b>', '<c-down>'],
|
\ 'ToggleType(-1)': ['<c-b>', '<c-down>'],
|
||||||
\ 'PrtExpandDir()': ['<tab>', '<c-i>'],
|
\ 'PrtExpandDir()': ['<tab>'],
|
||||||
\ 'PrtInsert("w")': ['<F2>'],
|
\ 'PrtInsert("w")': ['<F2>', '<insert>'],
|
||||||
\ 'PrtInsert("s")': ['<F3>'],
|
\ 'PrtInsert("s")': ['<F3>'],
|
||||||
\ 'PrtInsert("v")': ['<F4>'],
|
\ 'PrtInsert("v")': ['<F4>'],
|
||||||
\ 'PrtInsert("+")': ['<F6>'],
|
\ 'PrtInsert("+")': ['<F6>'],
|
||||||
@@ -165,8 +164,9 @@ only need to keep the lines that you’ve changed the values (inside []): >
|
|||||||
\ }
|
\ }
|
||||||
<
|
<
|
||||||
Note: In some terminals, it’s not possible to remap <c-h> without also changing
|
Note: In some terminals, it’s not possible to remap <c-h> without also changing
|
||||||
<bs>. So if pressing <bs> moves the cursor to the left instead of deleting a
|
<bs> (|key-codes|). So if pressing <bs> moves the cursor to the left instead of
|
||||||
char for you, add this to your |vimrc| to change the default <c-h> mapping: >
|
deleting a char for you, add this to your |vimrc| to change the default <c-h>
|
||||||
|
mapping: >
|
||||||
let g:ctrlp_prompt_mappings = {
|
let g:ctrlp_prompt_mappings = {
|
||||||
\ 'PrtBS()': ['<bs>', '<c-]>', '<c-h>'],
|
\ 'PrtBS()': ['<bs>', '<c-]>', '<c-h>'],
|
||||||
\ 'PrtCurLeft()': ['<left>', '<c-^>'],
|
\ 'PrtCurLeft()': ['<left>', '<c-^>'],
|
||||||
@@ -217,7 +217,8 @@ Set this to 0 if you don’t want |CtrlP| to search for dotfiles and dotdirs: >
|
|||||||
let g:ctrlp_dotfiles = 1
|
let g:ctrlp_dotfiles = 1
|
||||||
<
|
<
|
||||||
You can use |'wildignore'| to exclude anything from the search.
|
You can use |'wildignore'| to exclude anything from the search.
|
||||||
e.g. exclude version control directories: >
|
Examples: >
|
||||||
|
" Excluding version control directories
|
||||||
set wildignore+=*/.git/*,*/.hg/*,*/.svn/* " Linux/MacOSX
|
set wildignore+=*/.git/*,*/.hg/*,*/.svn/* " Linux/MacOSX
|
||||||
set wildignore+=.git\*,.hg\*,.svn\* " Windows
|
set wildignore+=.git\*,.hg\*,.svn\* " Windows
|
||||||
<
|
<
|
||||||
@@ -225,7 +226,7 @@ Note #1: the `*/` in front of each directory glob is required.
|
|||||||
|
|
||||||
Note #2: |wildignore| influences the result of |expand()|, |globpath()| and
|
Note #2: |wildignore| influences the result of |expand()|, |globpath()| and
|
||||||
|glob()| which many plugins use to find stuff on the system (e.g. fugitive.vim
|
|glob()| which many plugins use to find stuff on the system (e.g. fugitive.vim
|
||||||
looks for .git/, some other plugins look for external exe tools on Windows).
|
looks for .git/, some other plugins look for external .exe tools on Windows).
|
||||||
So be a little mindful of what you put in your |wildignore|.
|
So be a little mindful of what you put in your |wildignore|.
|
||||||
|
|
||||||
*'g:ctrlp_custom_ignore'*
|
*'g:ctrlp_custom_ignore'*
|
||||||
@@ -238,7 +239,7 @@ Examples: >
|
|||||||
let g:ctrlp_custom_ignore = {
|
let g:ctrlp_custom_ignore = {
|
||||||
\ 'dir': '\.git$\|\.hg$\|\.svn$',
|
\ 'dir': '\.git$\|\.hg$\|\.svn$',
|
||||||
\ 'file': '\.exe$\|\.so$\|\.dll$',
|
\ 'file': '\.exe$\|\.so$\|\.dll$',
|
||||||
\ 'link': 'some$\|bad$\|symbolic$\|links$',
|
\ 'link': 'SOME_BAD_SYMBOLIC_LINKS',
|
||||||
\ }
|
\ }
|
||||||
<
|
<
|
||||||
|
|
||||||
@@ -250,7 +251,7 @@ the highlight group that’ll be used: >
|
|||||||
|
|
||||||
*'g:ctrlp_max_files'*
|
*'g:ctrlp_max_files'*
|
||||||
The maximum number of files to scan, set to 0 for no limit: >
|
The maximum number of files to scan, set to 0 for no limit: >
|
||||||
let g:ctrlp_max_files = 20000
|
let g:ctrlp_max_files = 10000
|
||||||
<
|
<
|
||||||
|
|
||||||
*'g:ctrlp_max_depth'*
|
*'g:ctrlp_max_depth'*
|
||||||
@@ -260,8 +261,8 @@ The maximum depth of a directory tree to recurse into: >
|
|||||||
Note: the larger these values, the more memory Vim uses.
|
Note: the larger these values, the more memory Vim uses.
|
||||||
|
|
||||||
*'g:ctrlp_user_command'*
|
*'g:ctrlp_user_command'*
|
||||||
Specify an external tool to use for listing files instead of Vim’s globpath().
|
Specify an external tool to use for listing files instead of using Vim’s
|
||||||
Use %s in place of the target directory: >
|
|globpath()|. Use %s in place of the target directory: >
|
||||||
let g:ctrlp_user_command = ''
|
let g:ctrlp_user_command = ''
|
||||||
<
|
<
|
||||||
Examples: >
|
Examples: >
|
||||||
@@ -275,14 +276,28 @@ Examples: >
|
|||||||
<
|
<
|
||||||
Use a version control listing command when inside a repository, this is faster
|
Use a version control listing command when inside a repository, this is faster
|
||||||
when scanning large projects: >
|
when scanning large projects: >
|
||||||
let g:ctrlp_user_command = [repo_marker, vcs_ls_command, fallback_command]
|
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
|
||||||
|
\ }
|
||||||
<
|
<
|
||||||
If the fallback_command is empty or not defined, |globpath()| will then be used
|
|
||||||
when searching outside a repo.
|
|
||||||
Examples: >
|
Examples: >
|
||||||
let g:ctrlp_user_command = ['.git/', 'cd %s && git ls-files']
|
let g:ctrlp_user_command = ['.git/', 'cd %s && git ls-files']
|
||||||
let g:ctrlp_user_command = ['.hg/', 'hg --cwd %s locate -I .']
|
let g:ctrlp_user_command = ['.hg/', 'hg --cwd %s locate -I .']
|
||||||
|
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'
|
||||||
|
\ }
|
||||||
<
|
<
|
||||||
|
If the fallback_command is empty or not defined, |globpath()| will then be used
|
||||||
|
when searching outside a repo.
|
||||||
|
|
||||||
*'g:ctrlp_max_history'*
|
*'g:ctrlp_max_history'*
|
||||||
The maximum number of input strings you want |CtrlP| to remember. The default
|
The maximum number of input strings you want |CtrlP| to remember. The default
|
||||||
@@ -332,7 +347,7 @@ Pressing <c-o> or <c-y> will then prompt for a keypress. The key can be:
|
|||||||
h - open in horizontal split(s)
|
h - open in horizontal split(s)
|
||||||
v - open in vertical split(s)
|
v - open in vertical split(s)
|
||||||
r - open in current window (for <c-y> only)
|
r - open in current window (for <c-y> only)
|
||||||
<esc>, <c-c> - cancel and go back to |CtrlP|
|
<esc>, <c-c> - cancel and go back to the prompt.
|
||||||
Any other key - use the behavior specified with |g:ctrlp_open_new_file| and
|
Any other key - use the behavior specified with |g:ctrlp_open_new_file| and
|
||||||
|g:ctrlp_open_multi|.
|
|g:ctrlp_open_multi|.
|
||||||
|
|
||||||
@@ -401,10 +416,11 @@ See https://gist.github.com/1610859 for a working example.
|
|||||||
:ClearCtrlPCache
|
:ClearCtrlPCache
|
||||||
Flush the cache for the current working directory. The same as pressing <F5>
|
Flush the cache for the current working directory. The same as pressing <F5>
|
||||||
inside |CtrlP|.
|
inside |CtrlP|.
|
||||||
|
You can also enable/disable caching with the option |g:ctrlp_use_caching|.
|
||||||
|
|
||||||
*:ClearAllCtrlPCaches*
|
*:ClearAllCtrlPCaches*
|
||||||
:ClearAllCtrlPCaches
|
:ClearAllCtrlPCaches
|
||||||
Delete all the cache files saved in |ctrlp_cache_dir|.
|
Delete all the cache files saved in |g:ctrlp_cache_dir|.
|
||||||
|
|
||||||
*:ResetCtrlP*
|
*:ResetCtrlP*
|
||||||
:ResetCtrlP
|
:ResetCtrlP
|
||||||
@@ -438,7 +454,7 @@ Once inside the prompt:~
|
|||||||
See also |input-formats| (guide) and |g:ctrlp_regexp_search| (option).
|
See also |input-formats| (guide) and |g:ctrlp_regexp_search| (option).
|
||||||
|
|
||||||
<c-d>
|
<c-d>
|
||||||
Toggle between full path search and filename only search.
|
Toggle between full-path search and filename only search.
|
||||||
(note: in filename mode, the prompt’s base is '>d>' instead of '>>>')
|
(note: in filename mode, the prompt’s base is '>d>' instead of '>>>')
|
||||||
|
|
||||||
<c-f>, 'forward'
|
<c-f>, 'forward'
|
||||||
@@ -529,14 +545,18 @@ Once inside the prompt:~
|
|||||||
<F7>
|
<F7>
|
||||||
Clear MRU list.
|
Clear MRU list.
|
||||||
|
|
||||||
|
<insert>
|
||||||
|
Insert the word under the cursor (in the active buffer) into the prompt.
|
||||||
|
|
||||||
<esc>,
|
<esc>,
|
||||||
<c-c>,
|
<c-c>,
|
||||||
<c-g>
|
<c-g>
|
||||||
Exit |CtrlP|. <c-c> can also be used to stop the scan.
|
Exit |CtrlP|.
|
||||||
|
<c-c> can also be used to stop the scan if it’s taking too long.
|
||||||
|
|
||||||
Choose 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 <s-tab> to switch):~
|
||||||
|
|
||||||
a-z
|
a-z
|
||||||
0-9
|
0-9
|
||||||
@@ -643,7 +663,7 @@ Available extensions:~
|
|||||||
* Runtime script mode:~
|
* Runtime script mode:~
|
||||||
- Name: 'rtscript'
|
- Name: 'rtscript'
|
||||||
- Command: ':CtrlPRTS'
|
- Command: ':CtrlPRTS'
|
||||||
- Search for files (vimscripts, docs...) in runtimepath.
|
- Search for files (vimscripts, docs, snippets...) in runtimepath.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
Buffer Tag mode options:~
|
Buffer Tag mode options:~
|
||||||
@@ -674,49 +694,42 @@ Examples: >
|
|||||||
<
|
<
|
||||||
|
|
||||||
===============================================================================
|
===============================================================================
|
||||||
EXTENDING *ctrlp-extending*
|
CUSTOMIZATION *ctrlp-customization*
|
||||||
|
|
||||||
Extending |CtrlP| is very simple. Simply create a vim file following a short
|
Highlighting:~
|
||||||
guidelines, place it in autoload/ctrlp/ and add its name to your .vimrc.
|
* For the |CtrlP| buffer:
|
||||||
|
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)
|
||||||
|
|
||||||
To see how it works, get the sample.vim from the extensions branch on the main
|
* In extensions:
|
||||||
git repository (https://github.com/kien/ctrlp.vim/tree/extensions), and place
|
CtrlPTabExtra : the part of each line that’s not matched against (Comment)
|
||||||
it along with the parent directories somewhere in your runtimepath. Then put
|
CtrlPqfLineCol : the line and column numbers in quickfix mode (|hl-Search|)
|
||||||
this into your .vimrc: >
|
CtrlPUndoT : the elapsed time in undo mode (|hl-Directory|)
|
||||||
let g:ctrlp_extensions = ['sample']
|
CtrlPUndoBr : the square brackets [] in undo mode (Comment)
|
||||||
<
|
CtrlPUndoNr : the undo number inside [] in undo mode (String)
|
||||||
A new search type will show up the next time you open |CtrlP|.
|
|
||||||
|
|
||||||
For more details, check out the comments inside sample.vim.~
|
Statuslines:~
|
||||||
|
* Highlight groups:
|
||||||
|
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)
|
||||||
|
|
||||||
===============================================================================
|
For rebuilding the statuslines, see |g:ctrlp_status_func|.
|
||||||
USER-CONFIGURATION *ctrlp-user-config*
|
|
||||||
|
|
||||||
Some miscellaneous configurations:~
|
|
||||||
|
|
||||||
+) |g:ctrlp_user_command| config that makes use of your |wildignore| setting:
|
|
||||||
https://github.com/kien/ctrlp.vim/issues/70 by Rich Alesi
|
|
||||||
|
|
||||||
===============================================================================
|
===============================================================================
|
||||||
CREDITS *ctrlp-credits*
|
CREDITS *ctrlp-credits*
|
||||||
|
|
||||||
Developed by Kien Nguyen <github.com/kien>, initially based on the Command-T
|
Developed by Kien Nguyen <github.com/kien>.
|
||||||
and the LustyExplorer plugins. No code was taken from these plugins, but I did
|
|
||||||
clone the majority of their (awesome) interfaces and the way they work.
|
|
||||||
|
|
||||||
This was originally written as a module for a would-be larger plugin called
|
Project’s homepage: http://kien.github.com/ctrlp.vim
|
||||||
AutoDoc.vim which I’ve stopped developing because of lost of interest. I really
|
|
||||||
liked the way Command-T and LustyExplorer deal with user’s input, so I wrote a
|
|
||||||
pure Vimscript version of their prompt window, intended to use it for the
|
|
||||||
aforementioned plugin.
|
|
||||||
|
|
||||||
Homepage: http://kien.github.com/ctrlp.vim
|
|
||||||
Git repository: https://github.com/kien/ctrlp.vim
|
Git repository: https://github.com/kien/ctrlp.vim
|
||||||
Mercurial repository: https://bitbucket.org/kien/ctrlp.vim
|
Mercurial repository: https://bitbucket.org/kien/ctrlp.vim
|
||||||
|
|
||||||
===============================================================================
|
-------------------------------------------------------------------------------
|
||||||
THANKS *ctrlp-thanks*
|
|
||||||
|
|
||||||
Thanks to everyone that has submitted ideas, bug reports or helped debugging on
|
Thanks to everyone that has submitted ideas, bug reports or helped debugging on
|
||||||
gibhub, bitbucket, and through email.
|
gibhub, bitbucket, and through email.
|
||||||
|
|
||||||
@@ -742,6 +755,7 @@ Special thanks:~
|
|||||||
* Zak Johnson <github.com/zakj>
|
* Zak Johnson <github.com/zakj>
|
||||||
* Diego Viola <github.com/diegoviola>
|
* Diego Viola <github.com/diegoviola>
|
||||||
* Thibault Duplessis <github.com/ornicar>
|
* Thibault Duplessis <github.com/ornicar>
|
||||||
|
* Tacahiroy <github.com/tacahiroy>
|
||||||
Bugfixes/Corrections.
|
Bugfixes/Corrections.
|
||||||
|
|
||||||
===============================================================================
|
===============================================================================
|
||||||
79
bundle/git_ctrlp/readme.md
Normal file
79
bundle/git_ctrlp/readme.md
Normal file
@@ -0,0 +1,79 @@
|
|||||||
|
# ctrlp.vim
|
||||||
|
Full path fuzzy __file__, __buffer__, __mru__ and __tag__ finder for Vim.
|
||||||
|
|
||||||
|
* Written in pure Vimscript for MacVim and Vim 7.0+.
|
||||||
|
* Full support for Vim’s regexp as search pattern.
|
||||||
|
* Built-in Most Recently Used (MRU) files monitoring.
|
||||||
|
* Built-in project’s root finder.
|
||||||
|
* Open Multiple Files.
|
||||||
|
* [Extensible][3].
|
||||||
|
|
||||||
|
![ctrlp][1]
|
||||||
|
|
||||||
|
## Basic Usage
|
||||||
|
* Press `<c-p>` or run `:CtrlP` to invoke CtrlP in find file mode.
|
||||||
|
* Or run `:CtrlPBuffer` or `:CtrlPMRU` to invoke CtrlP in buffer or MRU mode.
|
||||||
|
|
||||||
|
Once CtrlP is open:
|
||||||
|
|
||||||
|
* Press `<c-f>` and `<c-b>` to switch between find file, buffer, and MRU file modes.
|
||||||
|
* Press `<c-d>` to switch to filename only search instead of full path.
|
||||||
|
* Press `<F5>` to purge the cache for the current directory and get new files.
|
||||||
|
* Use `*` or `|` in the prompt to submit the string as a Vim’s regexp pattern.
|
||||||
|
* Or press `<c-r>` to switch to regexp mode.
|
||||||
|
* End the input string with a colon `:` followed by a command to execute after opening the file.
|
||||||
|
e.g. `abc:45` will open the file matched the pattern and jump to line 45.
|
||||||
|
* Submit two dots `..` as the input string to go backward the directory tree by 1 level.
|
||||||
|
* Use `<c-y>` to create a new file and its parent dirs.
|
||||||
|
* Use `<c-z>` to mark/unmark files and `<c-o>` to open them.
|
||||||
|
|
||||||
|
## Basic Options
|
||||||
|
* Change the mapping to invoke CtrlP:
|
||||||
|
|
||||||
|
```vim
|
||||||
|
let g:ctrlp_map = '<c-p>'
|
||||||
|
```
|
||||||
|
|
||||||
|
* When CtrlP is invoked, it automatically sets the working directory according to this variable:
|
||||||
|
|
||||||
|
```vim
|
||||||
|
let g:ctrlp_working_path_mode = 2
|
||||||
|
```
|
||||||
|
|
||||||
|
0 - don’t manage working directory.
|
||||||
|
1 - the parent directory of the current file.
|
||||||
|
2 - the nearest ancestor that contains one of these directories or files:
|
||||||
|
|
||||||
|
.git/
|
||||||
|
.hg/
|
||||||
|
.bzr/
|
||||||
|
_darcs/
|
||||||
|
root.dir
|
||||||
|
|
||||||
|
* If you want to exclude directories or files from the search, you can use the Vim’s option `wildignore`
|
||||||
|
and/or the option `g:ctrlp_custom_ignore`. Examples:
|
||||||
|
|
||||||
|
```vim
|
||||||
|
set wildignore+=*/.git/*,*/.hg/*,*/.svn/* " for Linux/MacOSX
|
||||||
|
set wildignore+=.git\*,.hg\*,.svn\* " for Windows
|
||||||
|
|
||||||
|
let g:ctrlp_custom_ignore = '\.git$\|\.hg$\|\.svn$'
|
||||||
|
let g:ctrlp_custom_ignore = {
|
||||||
|
\ 'dir': '\.git$\|\.hg$\|\.svn$',
|
||||||
|
\ 'file': '\.exe$\|\.so$\|\.dll$',
|
||||||
|
\ 'link': 'some_bad_symbolic_links',
|
||||||
|
\ }
|
||||||
|
```
|
||||||
|
|
||||||
|
* Use a custom file listing command with:
|
||||||
|
|
||||||
|
```vim
|
||||||
|
let g:ctrlp_user_command = 'find %s -type f' " MacOSX/Linux
|
||||||
|
let g:ctrlp_user_command = 'dir %s /-n /b /s /a-d' " Windows
|
||||||
|
```
|
||||||
|
|
||||||
|
_Check [the docs][2] for more mappings, commands and options._
|
||||||
|
|
||||||
|
[1]: http://i.imgur.com/yIynr.png
|
||||||
|
[2]: https://github.com/kien/ctrlp.vim/blob/master/doc/ctrlp.txt
|
||||||
|
[3]: https://github.com/kien/ctrlp.vim/tree/extensions
|
||||||
@@ -1,8 +1,8 @@
|
|||||||
let current_file = expand('%:p')
|
let current_file = expand('%:p')
|
||||||
|
|
||||||
if match(current_file, '\cicard') < 0
|
if match(current_file, '\cicard') < 0
|
||||||
source $HOME/.vim/indent/python_pep8.vim
|
ru! indent/python_pep8.vim
|
||||||
else
|
else
|
||||||
let g:pep8_exclude=['W191']
|
let g:pep8_exclude=['W191']
|
||||||
source $VIMRUNTIME/indent/python.vim
|
ru! indent/python.vim
|
||||||
endif
|
endif
|
||||||
|
|||||||
@@ -1,570 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (c) 2009-2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
if exists('g:loaded_autoload_l9')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_autoload_l9 = 1
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" COMPATIBILITY TEST {{{1
|
|
||||||
|
|
||||||
"
|
|
||||||
let s:L9_VERSION_CURRENT = 101
|
|
||||||
let s:L9_VERSION_PASSABLE = 101
|
|
||||||
|
|
||||||
" returns true if given version is compatible.
|
|
||||||
function l9#isCompatible(ver)
|
|
||||||
return
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
let s:VERSION_FACTOR = str2float('0.01')
|
|
||||||
|
|
||||||
" returns false if the caller script should finish.
|
|
||||||
" a:vimVersion: if 0, don't check vim version
|
|
||||||
" a:l9Version: same rule as v:version
|
|
||||||
function l9#guardScriptLoading(path, vimVersion, l9Version, exprs)
|
|
||||||
let loadedVarName = 'g:loaded_' . substitute(a:path, '\W', '_', 'g')
|
|
||||||
if exists(loadedVarName)
|
|
||||||
return 0
|
|
||||||
elseif a:vimVersion > 0 && a:vimVersion > v:version
|
|
||||||
echoerr a:path . ' requires Vim version ' . string(a:vimVersion * s:VERSION_FACTOR)
|
|
||||||
return 0
|
|
||||||
elseif a:l9Version > 0 && (a:l9Version > s:L9_VERSION_CURRENT ||
|
|
||||||
\ a:l9Version < s:L9_VERSION_PASSABLE)
|
|
||||||
echoerr a:path . ' requires L9 library version ' . string(a:l9Version * s:VERSION_FACTOR)
|
|
||||||
return 0
|
|
||||||
endif
|
|
||||||
for expr in a:exprs
|
|
||||||
if !eval(expr)
|
|
||||||
echoerr a:path . ' requires: ' . expr
|
|
||||||
return 0
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
let {loadedVarName} = 1
|
|
||||||
return 1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function l9#getVersion()
|
|
||||||
return s:L9_VERSION_CURRENT
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" LIST {{{1
|
|
||||||
|
|
||||||
" Removes duplicates (unstable)
|
|
||||||
" This function doesn't change the list of argument.
|
|
||||||
function l9#unique(items)
|
|
||||||
let sorted = sort(a:items)
|
|
||||||
if len(sorted) < 2
|
|
||||||
return sorted
|
|
||||||
endif
|
|
||||||
let last = remove(sorted, 0)
|
|
||||||
let result = [last]
|
|
||||||
for item in sorted
|
|
||||||
if item != last
|
|
||||||
call add(result, item)
|
|
||||||
let last = item
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
return result
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" Removes duplicates (stable)
|
|
||||||
" This function doesn't change the list of argument.
|
|
||||||
function l9#uniqueStably(items)
|
|
||||||
let result = []
|
|
||||||
for item in a:items
|
|
||||||
if count(result, item, &ignorecase) == 0
|
|
||||||
call add(result, item)
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
return result
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" [ [0], [1,2], [3] ] -> [ 0, 1, 2, 3 ]
|
|
||||||
" This function doesn't change the list of argument.
|
|
||||||
function l9#concat(items)
|
|
||||||
let result = []
|
|
||||||
for l in a:items
|
|
||||||
let result += l
|
|
||||||
endfor
|
|
||||||
return result
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" [ [0,1,2], [3,4], [5,6,7,8] ] -> [ [0,3,5],[1,4,6] ]
|
|
||||||
" This function doesn't change the list of argument.
|
|
||||||
function l9#zip(items)
|
|
||||||
let result = []
|
|
||||||
for i in range(min(map(copy(a:items), 'len(v:val)')))
|
|
||||||
call add(result, map(copy(a:items), 'v:val[i]'))
|
|
||||||
endfor
|
|
||||||
return result
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" filter() with the maximum number of items
|
|
||||||
" This function doesn't change the list of argument.
|
|
||||||
function l9#filterWithLimit(items, expr, limit)
|
|
||||||
if a:limit <= 0
|
|
||||||
return filter(copy(a:items), a:expr)
|
|
||||||
endif
|
|
||||||
let result = []
|
|
||||||
let stride = a:limit * 3 / 2 " x1.5
|
|
||||||
for i in range(0, len(a:items) - 1, stride)
|
|
||||||
let result += filter(a:items[i : i + stride - 1], a:expr)
|
|
||||||
if len(result) >= a:limit
|
|
||||||
return remove(result, 0, a:limit - 1)
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
return result
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" Removes if a:expr is evaluated as non-zero and returns removed items.
|
|
||||||
" This function change the list of argument.
|
|
||||||
function l9#removeIf(items, expr)
|
|
||||||
let removed = filter(copy(a:items), a:expr)
|
|
||||||
call filter(a:items, '!( ' . a:expr . ')')
|
|
||||||
return removed
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" NUMERIC {{{1
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" STRING {{{1
|
|
||||||
|
|
||||||
" Snips a:str and add a:mask if the length of a:str is more than a:len
|
|
||||||
function l9#snipHead(str, len, mask)
|
|
||||||
if a:len >= len(a:str)
|
|
||||||
return a:str
|
|
||||||
elseif a:len <= len(a:mask)
|
|
||||||
return a:mask
|
|
||||||
endif
|
|
||||||
return a:mask . a:str[-a:len + len(a:mask):]
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" Snips a:str and add a:mask if the length of a:str is more than a:len
|
|
||||||
function l9#snipTail(str, len, mask)
|
|
||||||
if a:len >= len(a:str)
|
|
||||||
return a:str
|
|
||||||
elseif a:len <= len(a:mask)
|
|
||||||
return a:mask
|
|
||||||
endif
|
|
||||||
return a:str[:a:len - 1 - len(a:mask)] . a:mask
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" Snips a:str and add a:mask if the length of a:str is more than a:len
|
|
||||||
function l9#snipMid(str, len, mask)
|
|
||||||
if a:len >= len(a:str)
|
|
||||||
return a:str
|
|
||||||
elseif a:len <= len(a:mask)
|
|
||||||
return a:mask
|
|
||||||
endif
|
|
||||||
let len_head = (a:len - len(a:mask)) / 2
|
|
||||||
let len_tail = a:len - len(a:mask) - len_head
|
|
||||||
return (len_head > 0 ? a:str[: len_head - 1] : '') . a:mask .
|
|
||||||
\ (len_tail > 0 ? a:str[-len_tail :] : '')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function l9#hash224(str)
|
|
||||||
let a = 0x00000800 " shift 11 bit (if unsigned)
|
|
||||||
let b = 0x001fffff " extract 11 bit (if unsigned)
|
|
||||||
let nHash = 7
|
|
||||||
let hashes = repeat([0], nHash)
|
|
||||||
for i in range(len(a:str))
|
|
||||||
let iHash = i % nHash
|
|
||||||
let hashes[iHash] = hashes[iHash] * a + hashes[iHash] / b
|
|
||||||
let hashes[iHash] += char2nr(a:str[i])
|
|
||||||
endfor
|
|
||||||
return join(map(hashes, 'printf("%08x", v:val)'), '')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" wildcard -> regexp
|
|
||||||
function l9#convertWildcardToRegexp(expr)
|
|
||||||
let re = escape(a:expr, '\')
|
|
||||||
for [pat, sub] in [ [ '*', '\\.\\*' ], [ '?', '\\.' ], [ '[', '\\[' ], ]
|
|
||||||
let re = substitute(re, pat, sub, 'g')
|
|
||||||
endfor
|
|
||||||
return '\V' . re
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" LINES {{{1
|
|
||||||
|
|
||||||
" Removes from the line matching with a:begin first to the line matching with
|
|
||||||
" a:end next and returns removed lines.
|
|
||||||
" If matching range is not found, returns []
|
|
||||||
function l9#removeLinesBetween(lines, begin, end)
|
|
||||||
for i in range(len(a:lines) - 1)
|
|
||||||
if a:lines[i] =~ a:begin
|
|
||||||
break
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
for j in range(i + 1, len(a:lines) - 1)
|
|
||||||
if a:lines[j] =~ a:end
|
|
||||||
let g:l0 += [a:lines[i : j]]
|
|
||||||
return remove(a:lines, i, j)
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
return []
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" PATH {{{1
|
|
||||||
|
|
||||||
" returns the path separator charactor.
|
|
||||||
function l9#getPathSeparator()
|
|
||||||
return (!&shellslash && (has('win32') || has('win64')) ? '\' : '/')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" [ 'a', 'b/', '/c' ] -> 'a/b/c'
|
|
||||||
function l9#concatPaths(paths)
|
|
||||||
let result = ''
|
|
||||||
for p in a:paths
|
|
||||||
if empty(p)
|
|
||||||
continue
|
|
||||||
elseif empty(result)
|
|
||||||
let result = p
|
|
||||||
else
|
|
||||||
let result = substitute(result, '[/\\]$', '', '') . l9#getPathSeparator()
|
|
||||||
\ . substitute(p, '^[/\\]', '', '')
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
return result
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" path: '/a/b/c/d', dir: '/a/b' => 'c/d'
|
|
||||||
function l9#modifyPathRelativeToDir(path, dir)
|
|
||||||
let pathFull = fnamemodify(a:path, ':p')
|
|
||||||
let dirFull = fnamemodify(a:dir, ':p')
|
|
||||||
if len(pathFull) < len(dirFull) || pathFull[:len(dirFull) - 1] !=# dirFull
|
|
||||||
return pathFull
|
|
||||||
endif
|
|
||||||
return pathFull[len(dirFull):]
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" FILE {{{1
|
|
||||||
|
|
||||||
" Almost same as readfile().
|
|
||||||
function l9#readFile(...)
|
|
||||||
let args = copy(a:000)
|
|
||||||
let args[0] = expand(args[0])
|
|
||||||
try
|
|
||||||
return call('readfile', args)
|
|
||||||
catch
|
|
||||||
endtry
|
|
||||||
return []
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" Almost same as writefile().
|
|
||||||
function l9#writeFile(...)
|
|
||||||
let args = copy(a:000)
|
|
||||||
let args[1] = expand(args[1])
|
|
||||||
let dir = fnamemodify(args[1], ':h')
|
|
||||||
try
|
|
||||||
if !isdirectory(dir)
|
|
||||||
call mkdir(dir, 'p')
|
|
||||||
endif
|
|
||||||
return call('writefile', args)
|
|
||||||
catch
|
|
||||||
endtry
|
|
||||||
return -1 " -1 is error code.
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" BUFFER {{{1
|
|
||||||
|
|
||||||
" :wall/:wall! wrapper. Useful for writing readonly buffers.
|
|
||||||
function l9#writeAll()
|
|
||||||
try
|
|
||||||
silent update " NOTE: avoiding a problem with a buftype=acwrite buffer.
|
|
||||||
silent wall
|
|
||||||
catch /^Vim/ " E45, E505
|
|
||||||
if l9#inputHl('Question', v:exception . "\nWrite readonly files? (Y/N) : ", 'Y') ==? 'y'
|
|
||||||
redraw
|
|
||||||
:wall!
|
|
||||||
endif
|
|
||||||
endtry
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" Loads given files with :edit command
|
|
||||||
function l9#loadFilesToBuffers(files)
|
|
||||||
for file in filter(copy(a:files), '!bufloaded(v:val)')
|
|
||||||
execute 'edit ' . fnameescape(file)
|
|
||||||
if !exists('bufNrFirst')
|
|
||||||
let bufNrFirst = bufnr('%')
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
if exists('bufNrFirst')
|
|
||||||
execute bufNrFirst . 'buffer'
|
|
||||||
endif
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" Deletes all buffers except given files with :bdelete command
|
|
||||||
function l9#deleteAllBuffersExcept(files)
|
|
||||||
let bufNrExcepts = map(copy(a:files), 'bufnr("^" . v:val . "$")')
|
|
||||||
for bufNr in filter(range(1, bufnr('$')), 'bufloaded(v:val)')
|
|
||||||
if count(bufNrExcepts, bufNr) == 0
|
|
||||||
execute bufNr . 'bdelete'
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" WINDOW {{{1
|
|
||||||
|
|
||||||
" move current window to next tabpage.
|
|
||||||
function l9#shiftWinNextTabpage()
|
|
||||||
if tabpagenr('$') < 2
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
let bufnr = bufnr('%')
|
|
||||||
tabnext
|
|
||||||
execute bufnr . 'sbuffer'
|
|
||||||
tabprevious
|
|
||||||
if winnr('$') > 1
|
|
||||||
close
|
|
||||||
tabnext
|
|
||||||
else
|
|
||||||
close " if tabpage is closed, next tabpage will become current
|
|
||||||
endif
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" move current window to previous tabpage.
|
|
||||||
function l9#shiftWinPrevTabpage()
|
|
||||||
if tabpagenr('$') < 2
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
let bufnr = bufnr('%')
|
|
||||||
tabprevious
|
|
||||||
execute bufnr . 'sbuffer'
|
|
||||||
tabnext
|
|
||||||
close
|
|
||||||
tabprevious
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" move to a window containing specified buffer.
|
|
||||||
" returns 0 if the buffer is not found.
|
|
||||||
function l9#moveToBufferWindowInCurrentTabpage(bufNr)
|
|
||||||
if bufnr('%') == a:bufNr
|
|
||||||
return 1
|
|
||||||
elseif count(tabpagebuflist(), a:bufNr) == 0
|
|
||||||
return 0
|
|
||||||
endif
|
|
||||||
execute bufwinnr(a:bufNr) . 'wincmd w'
|
|
||||||
return 1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" returns 0 if the buffer is not found.
|
|
||||||
function s:moveToOtherTabpageOpeningBuffer(bufNr)
|
|
||||||
for tabNr in range(1, tabpagenr('$'))
|
|
||||||
if tabNr != tabpagenr() && count(tabpagebuflist(tabNr), a:bufNr) > 0
|
|
||||||
execute 'tabnext ' . tabNr
|
|
||||||
return 1
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
return 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" move to a window containing specified buffer.
|
|
||||||
" returns 0 if the buffer is not found.
|
|
||||||
function l9#moveToBufferWindowInOtherTabpage(bufNr)
|
|
||||||
if !s:moveToOtherTabpageOpeningBuffer(a:bufNr)
|
|
||||||
return 0
|
|
||||||
endif
|
|
||||||
return l9#moveToBufferWindowInCurrentTabpage(a:bufNr)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" COMMAND LINE {{{1
|
|
||||||
|
|
||||||
" echo/echomsg with highlighting.
|
|
||||||
function l9#echoHl(hl, msg, prefix, addingHistory)
|
|
||||||
let echoCmd = (a:addingHistory ? 'echomsg' : 'echo')
|
|
||||||
execute "echohl " . a:hl
|
|
||||||
try
|
|
||||||
for l in (type(a:msg) == type([]) ? a:msg : split(a:msg, "\n"))
|
|
||||||
execute echoCmd . ' a:prefix . l'
|
|
||||||
endfor
|
|
||||||
finally
|
|
||||||
echohl None
|
|
||||||
endtry
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" input() with highlighting.
|
|
||||||
" This function can take list as {completion} argument.
|
|
||||||
function l9#inputHl(hl, ...)
|
|
||||||
execute "echohl " . a:hl
|
|
||||||
try
|
|
||||||
let args = copy(a:000)
|
|
||||||
if len(args) > 2 && type(args[2]) == type([])
|
|
||||||
let s:candidatesForInputHl = args[2]
|
|
||||||
let args[2] = 'custom,l9#completeForInputHl'
|
|
||||||
endif
|
|
||||||
let s = call('input', args)
|
|
||||||
unlet! s:candidatesForInputHl
|
|
||||||
finally
|
|
||||||
echohl None
|
|
||||||
endtry
|
|
||||||
redraw " needed to show following echo to next line.
|
|
||||||
return s
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" only called by l9#inputHl() for completion.
|
|
||||||
function l9#completeForInputHl(lead, line, pos)
|
|
||||||
return join(s:candidatesForInputHl, "\n")
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" VISUAL MODE {{{1
|
|
||||||
|
|
||||||
" returns last selected text in Visual mode.
|
|
||||||
function l9#getSelectedText()
|
|
||||||
let reg_ = [@", getregtype('"')]
|
|
||||||
let regA = [@a, getregtype('a')]
|
|
||||||
if mode() =~# "[vV\<C-v>]"
|
|
||||||
silent normal! "aygv
|
|
||||||
else
|
|
||||||
let pos = getpos('.')
|
|
||||||
silent normal! gv"ay
|
|
||||||
call setpos('.', pos)
|
|
||||||
endif
|
|
||||||
let text = @a
|
|
||||||
call setreg('"', reg_[0], reg_[1])
|
|
||||||
call setreg('a', regA[0], regA[1])
|
|
||||||
return text
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" EVAL {{{1
|
|
||||||
|
|
||||||
" loads given text as Vim script with :source command
|
|
||||||
function l9#loadScript(text)
|
|
||||||
let lines = (type(a:text) == type([]) ? a:text : split(a:text, "\n"))
|
|
||||||
let fname = tempname()
|
|
||||||
call writefile(lines, fname)
|
|
||||||
source `=fname`
|
|
||||||
call delete(fname)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" VARIABLES {{{1
|
|
||||||
|
|
||||||
"
|
|
||||||
function l9#defineVariableDefault(name, default)
|
|
||||||
if !exists(a:name)
|
|
||||||
let {a:name} = a:default
|
|
||||||
endif
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" GREP {{{1
|
|
||||||
|
|
||||||
" Execute :vimgrep and opens the quickfix window if matches are found.
|
|
||||||
"
|
|
||||||
" a:pattern: search pattern. If ommitted, last search pattern (@/) is used.
|
|
||||||
" a:files: List of files
|
|
||||||
function l9#grepFiles(pattern, files)
|
|
||||||
let target = join(map(a:files, 'escape(v:val, " ")'), ' ')
|
|
||||||
let pattern = (a:pattern[0] ==# '/' ? a:pattern[1:] : a:pattern)
|
|
||||||
let pattern = (empty(pattern) ? @/ : pattern)
|
|
||||||
try
|
|
||||||
execute printf('vimgrep/%s/j %s', pattern, target)
|
|
||||||
catch /^Vim/
|
|
||||||
call setqflist([])
|
|
||||||
endtry
|
|
||||||
call l9#quickfix#sort()
|
|
||||||
call l9#quickfix#openIfNotEmpty(1, 0)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" Execute :vimgrep for buffers using l9#grepFiles()
|
|
||||||
" See also: :L9GrepBuffer :L9GrepBufferAll
|
|
||||||
function l9#grepBuffers(pattern, bufNrs)
|
|
||||||
let files = map(filter(a:bufNrs, 'bufloaded(v:val)'), 'bufname(v:val)')
|
|
||||||
call l9#grepFiles(a:pattern, files)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" SIGN {{{1
|
|
||||||
|
|
||||||
" Highlights lines using :sign define and :sign place.
|
|
||||||
"
|
|
||||||
" a:linehl, a:text, a:texthl: See |signs|. Ignored if empty string.
|
|
||||||
" a:locations: List of [{buffer number}, {line number}] for highlighting
|
|
||||||
function l9#placeSign(linehl, text, texthl, locations)
|
|
||||||
let argLinehl = (empty(a:linehl) ? '' : 'linehl=' . a:linehl)
|
|
||||||
let argText = (empty(a:text) ? '' : 'text=' . a:text)
|
|
||||||
let argTexthl = (empty(a:texthl) ? '' : 'texthl=' . a:texthl)
|
|
||||||
let name = 'l9--' . a:linehl . '--' . a:text . '--' . a:texthl
|
|
||||||
execute printf('sign define %s linehl=%s text=%s texthl=%s',
|
|
||||||
\ name, a:linehl, a:text, a:texthl)
|
|
||||||
for [bufNr, lnum] in a:locations
|
|
||||||
execute printf('sign place 1 line=%d name=%s buffer=%d', lnum, name, bufNr)
|
|
||||||
endfor
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" NOTIFY EXTERNALLY {{{1
|
|
||||||
|
|
||||||
" Notify a message using an external program.
|
|
||||||
" Currently supports Balloonly, Screen, and Tmux.
|
|
||||||
function l9#notifyExternally(msg)
|
|
||||||
return l9#notifyBalloonly(a:msg)
|
|
||||||
\ || l9#notifyScreen(a:msg)
|
|
||||||
\ || l9#notifyTmux(a:msg)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function l9#notifyBalloonly(msg)
|
|
||||||
if !(has('win32') || has('win64')) || !executable(g:l9_balloonly)
|
|
||||||
return 0
|
|
||||||
endif
|
|
||||||
execute 'silent !start ' . shellescape(g:l9_balloonly) . ' 4000 "l9" ' . shellescape(a:msg)
|
|
||||||
return 1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function l9#notifyScreen(msg)
|
|
||||||
if !has('unix') || has('gui_running') || $WINDOW !~ '\d' || !executable('screen')
|
|
||||||
return 0
|
|
||||||
endif
|
|
||||||
call system('screen -X wall ' . shellescape('l9: ' . a:msg))
|
|
||||||
return 1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function l9#notifyTmux(msg)
|
|
||||||
if !has('unix') || has('gui_running') || empty($TMUX) || !executable('tmux')
|
|
||||||
return 0
|
|
||||||
endif
|
|
||||||
call system('tmux display-message ' . shellescape('l9: ' . a:msg))
|
|
||||||
return 1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
@@ -1,92 +0,0 @@
|
|||||||
#!/usr/bin/env python
|
|
||||||
|
|
||||||
from __future__ import with_statement
|
|
||||||
import vim
|
|
||||||
import os
|
|
||||||
import subprocess
|
|
||||||
import threading
|
|
||||||
import Queue
|
|
||||||
|
|
||||||
|
|
||||||
class Asyncer:
|
|
||||||
|
|
||||||
def __init__(self):
|
|
||||||
self._workers = {}
|
|
||||||
|
|
||||||
def execute(self, var_key, var_command, var_cwd, var_input, var_appends):
|
|
||||||
key = vim.eval(var_key)
|
|
||||||
command = vim.eval(var_command)
|
|
||||||
cwd = vim.eval(var_cwd)
|
|
||||||
input = vim.eval(var_input)
|
|
||||||
appends = vim.eval(var_appends)
|
|
||||||
if key not in self._workers:
|
|
||||||
self._workers[key] = Worker()
|
|
||||||
self._workers[key].start()
|
|
||||||
self._workers[key].put(Executor(command, cwd, input, appends))
|
|
||||||
|
|
||||||
def print_output(self, var_key):
|
|
||||||
key = vim.eval(var_key)
|
|
||||||
if key not in self._workers:
|
|
||||||
return
|
|
||||||
for l in self._workers[key].copy_outputs():
|
|
||||||
print l,
|
|
||||||
|
|
||||||
def print_worker_keys(self):
|
|
||||||
for k in self._workers.keys():
|
|
||||||
print k
|
|
||||||
|
|
||||||
def print_active_worker_keys(self):
|
|
||||||
for k in self._workers.keys():
|
|
||||||
print k
|
|
||||||
|
|
||||||
|
|
||||||
class Worker(threading.Thread):
|
|
||||||
|
|
||||||
def __init__(self):
|
|
||||||
threading.Thread.__init__(self)
|
|
||||||
self._queue = Queue.Queue()
|
|
||||||
self._lines = []
|
|
||||||
self._lock = threading.Lock()
|
|
||||||
|
|
||||||
def run(self):
|
|
||||||
while True:
|
|
||||||
self._queue.get().execute(self)
|
|
||||||
self._queue.task_done()
|
|
||||||
|
|
||||||
def put(self, executor):
|
|
||||||
self._queue.put(executor)
|
|
||||||
|
|
||||||
def clear_outputs(self):
|
|
||||||
with self._lock:
|
|
||||||
self._lines = []
|
|
||||||
|
|
||||||
def record_output(self, line):
|
|
||||||
with self._lock:
|
|
||||||
self._lines.append(line)
|
|
||||||
|
|
||||||
def copy_outputs(self):
|
|
||||||
with self._lock:
|
|
||||||
return self._lines[:]
|
|
||||||
|
|
||||||
|
|
||||||
class Executor:
|
|
||||||
|
|
||||||
def __init__(self, command, cwd, input, appends):
|
|
||||||
self._command = command
|
|
||||||
self._cwd = cwd
|
|
||||||
self._input = input
|
|
||||||
self._appends = appends
|
|
||||||
|
|
||||||
def execute(self, worker):
|
|
||||||
if not self._appends:
|
|
||||||
worker.clear_outputs()
|
|
||||||
os.chdir(self._cwd)
|
|
||||||
p = subprocess.Popen(self._command, shell=True, stdin=subprocess.PIPE,
|
|
||||||
stdout=subprocess.PIPE, stderr=subprocess.STDOUT)
|
|
||||||
p.stdin.write(self._input)
|
|
||||||
line = p.stdout.readline()
|
|
||||||
while line:
|
|
||||||
worker.record_output(line)
|
|
||||||
line = p.stdout.readline()
|
|
||||||
|
|
||||||
|
|
||||||
@@ -1,67 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (C) 2009-2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
if !l9#guardScriptLoading(expand('<sfile>:p'), 0, 0, ['has("python")'])
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" ASYNC EXECUTE {{{1
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:checkKey(key)
|
|
||||||
if a:key =~ '\n' || a:key !~ '\S'
|
|
||||||
throw "Asyncer: Invalid key: " . a:key
|
|
||||||
endif
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function l9#async#execute(key, cmd, cwd, input, appends)
|
|
||||||
call s:checkKey(a:key)
|
|
||||||
python asyncer.execute('a:key', 'a:cmd', 'a:cwd', 'a:input', 'a:appends')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function l9#async#read(key)
|
|
||||||
call s:checkKey(a:key)
|
|
||||||
redir => result
|
|
||||||
silent python asyncer.print_output('a:key')
|
|
||||||
redir END
|
|
||||||
" NOTE: "\n" is somehow inserted by redir.
|
|
||||||
return (result[0] ==# "\n" ? result[1:] : result)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function l9#async#listWorkers()
|
|
||||||
redir => result
|
|
||||||
silent python asyncer.print_worker_keys()
|
|
||||||
redir END
|
|
||||||
return split(result, "\n")
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function l9#async#listActiveWorkers()
|
|
||||||
redir => result
|
|
||||||
silent python asyncer.print_active_worker_keys()
|
|
||||||
redir END
|
|
||||||
return split(result, "\n")
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" INITIALIZATION {{{1
|
|
||||||
|
|
||||||
let s:ASYNC_PY_PATH = fnamemodify(expand('<sfile>:p:h'), ':p') . 'async.py'
|
|
||||||
|
|
||||||
pyfile `=s:ASYNC_PY_PATH`
|
|
||||||
python asyncer = Asyncer()
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
|
|
||||||
|
|
||||||
@@ -1,107 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (C) 2009-2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
if !l9#guardScriptLoading(expand('<sfile>:p'), 0, 0, [])
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" QUICKFIX {{{1
|
|
||||||
|
|
||||||
" Returns non-zero if quickfix window is opened.
|
|
||||||
function l9#quickfix#isWindowOpened()
|
|
||||||
return count(map(range(1, winnr('$')), 'getwinvar(v:val, "&buftype")'), 'quickfix') > 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" Opens quickfix window if quickfix is not empty, and echo the number of errors.
|
|
||||||
"
|
|
||||||
" a:onlyRecognized: if non-zero, opens only if quickfix has recognized errors.
|
|
||||||
" a:holdCursor: if non-zero, the cursor won't move to quickfix window.
|
|
||||||
function l9#quickfix#openIfNotEmpty(onlyRecognized, holdCursor)
|
|
||||||
let numErrors = len(filter(getqflist(), 'v:val.valid'))
|
|
||||||
let numOthers = len(getqflist()) - numErrors
|
|
||||||
if numErrors > 0 || (!a:onlyRecognized && numOthers > 0)
|
|
||||||
copen
|
|
||||||
if a:holdCursor
|
|
||||||
wincmd p
|
|
||||||
endif
|
|
||||||
else
|
|
||||||
cclose
|
|
||||||
endif
|
|
||||||
redraw
|
|
||||||
if numOthers > 0
|
|
||||||
echo printf('Quickfix: %d(+%d)', numErrors, numOthers)
|
|
||||||
else
|
|
||||||
echo printf('Quickfix: %d', numErrors)
|
|
||||||
endif
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" Toggles Quickfix window
|
|
||||||
function l9#quickfix#toggleWindow()
|
|
||||||
if l9#quickfix#isWindowOpened()
|
|
||||||
cclose
|
|
||||||
else
|
|
||||||
call l9#quickfix#openIfNotEmpty(0, 0)
|
|
||||||
endif
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" Creates quickfix list form given lines and opens the quickfix window if
|
|
||||||
" errors exists.
|
|
||||||
"
|
|
||||||
" a:lines:
|
|
||||||
" a:jump: if non-zero, jump to the first error.
|
|
||||||
function l9#quickfix#setMakeResult(lines)
|
|
||||||
cexpr a:lines
|
|
||||||
call l9#quickfix#openIfNotEmpty(0, 1)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" Compares quickfix entries for sorting.
|
|
||||||
function l9#quickfix#compareEntries(e0, e1)
|
|
||||||
if a:e0.bufnr != a:e1.bufnr
|
|
||||||
let i0 = bufname(a:e0.bufnr)
|
|
||||||
let i1 = bufname(a:e1.bufnr)
|
|
||||||
elseif a:e0.lnum != a:e1.lnum
|
|
||||||
let i0 = a:e0.lnum
|
|
||||||
let i1 = a:e1.lnum
|
|
||||||
elseif a:e0.col != a:e1.col
|
|
||||||
let i0 = a:e0.col
|
|
||||||
let i1 = a:e1.col
|
|
||||||
else
|
|
||||||
return 0
|
|
||||||
endif
|
|
||||||
return (i0 > i1 ? +1 : -1)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" Sorts quickfix
|
|
||||||
function l9#quickfix#sort()
|
|
||||||
call setqflist(sort(getqflist(), 'l9#quickfix#compareEntries'), 'r')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" Highlights Quickfix lines by :sign.
|
|
||||||
" Inspired by errormarker plugin.
|
|
||||||
"
|
|
||||||
" You can customize the highlighting via L9ErrorLine and L9WarningLine
|
|
||||||
" highlight groups.
|
|
||||||
function l9#quickfix#placeSign()
|
|
||||||
let warnings = []
|
|
||||||
let errors = []
|
|
||||||
for e in filter(getqflist(), 'v:val.valid')
|
|
||||||
let warning = (e.type ==? 'w' || e.text =~? '^\s*warning:')
|
|
||||||
call add((warning ? warnings : errors), [e.bufnr, e.lnum])
|
|
||||||
endfor
|
|
||||||
sign unplace *
|
|
||||||
call l9#placeSign('L9WarningLine', '>>', '', warnings)
|
|
||||||
call l9#placeSign('L9ErrorLine', '>>', '', errors)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
highlight default L9ErrorLine ctermfg=white ctermbg=52 guibg=#5F0000
|
|
||||||
highlight default L9WarningLine ctermfg=white ctermbg=17 guibg=#00005F
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
|
|
||||||
@@ -1,112 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (C) 2009-2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
if !l9#guardScriptLoading(expand('<sfile>:p'), 0, 0, [])
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" TEMPORARY BUFFER {{{1
|
|
||||||
|
|
||||||
" each key is a buffer name.
|
|
||||||
let s:dataMap = {}
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:onBufDelete(bufname)
|
|
||||||
if exists('s:dataMap[a:bufname].listener.onClose')
|
|
||||||
call s:dataMap[a:bufname].listener.onClose(s:dataMap[a:bufname].written)
|
|
||||||
endif
|
|
||||||
if bufnr('%') == s:dataMap[a:bufname].bufNr && winnr('#') != 0
|
|
||||||
" if winnr('#') returns 0, "wincmd p" causes ringing the bell.
|
|
||||||
wincmd p
|
|
||||||
endif
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function s:onBufWriteCmd(bufname)
|
|
||||||
if !exists('s:dataMap[a:bufname].listener.onWrite') ||
|
|
||||||
\ s:dataMap[a:bufname].listener.onWrite(getline(1, '$'))
|
|
||||||
setlocal nomodified
|
|
||||||
let s:dataMap[a:bufname].written = 1
|
|
||||||
call l9#tempbuffer#close(a:bufname)
|
|
||||||
else
|
|
||||||
endif
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" a:bufname:
|
|
||||||
" a:height: Window height. If 0, default height is used.
|
|
||||||
" If less than 0, the window becomes full-screen.
|
|
||||||
" a:listener:
|
|
||||||
" a:listener.onClose(written)
|
|
||||||
function l9#tempbuffer#openScratch(bufname, filetype, lines, topleft, vertical, height, listener)
|
|
||||||
let openCmdPrefix = (a:topleft ? 'topleft ' : '')
|
|
||||||
\ . (a:vertical ? 'vertical ' : '')
|
|
||||||
\ . (a:height > 0 ? a:height : '')
|
|
||||||
if !exists('s:dataMap[a:bufname]') || !bufexists(s:dataMap[a:bufname].bufNr)
|
|
||||||
execute openCmdPrefix . 'new'
|
|
||||||
else
|
|
||||||
call l9#tempbuffer#close(a:bufname)
|
|
||||||
execute openCmdPrefix . 'split'
|
|
||||||
execute 'silent ' . s:dataMap[a:bufname].bufNr . 'buffer'
|
|
||||||
endif
|
|
||||||
if a:height < 0
|
|
||||||
only
|
|
||||||
endif
|
|
||||||
setlocal buflisted noswapfile bufhidden=delete modifiable noreadonly buftype=nofile
|
|
||||||
let &l:filetype = a:filetype
|
|
||||||
silent file `=a:bufname`
|
|
||||||
call setline(1, a:lines)
|
|
||||||
setlocal nomodified
|
|
||||||
augroup L9TempBuffer
|
|
||||||
autocmd! * <buffer>
|
|
||||||
execute printf('autocmd BufDelete <buffer> call s:onBufDelete (%s)', string(a:bufname))
|
|
||||||
execute printf('autocmd BufWriteCmd <buffer> nested call s:onBufWriteCmd(%s)', string(a:bufname))
|
|
||||||
augroup END
|
|
||||||
let s:dataMap[a:bufname] = {
|
|
||||||
\ 'bufNr': bufnr('%'),
|
|
||||||
\ 'written': 0,
|
|
||||||
\ 'listener': a:listener,
|
|
||||||
\ }
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function l9#tempbuffer#openReadOnly(bufname, filetype, lines, topleft, vertical, height, listener)
|
|
||||||
call l9#tempbuffer#openScratch(a:bufname, a:filetype, a:lines, a:topleft, a:vertical, a:height, a:listener)
|
|
||||||
setlocal nomodifiable readonly
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" a:listener:
|
|
||||||
" a:listener.onClose(written)
|
|
||||||
" a:listener.onWrite(lines)
|
|
||||||
function l9#tempbuffer#openWritable(bufname, filetype, lines, topleft, vertical, height, listener)
|
|
||||||
call l9#tempbuffer#openScratch(a:bufname, a:filetype, a:lines, a:topleft, a:vertical, a:height, a:listener)
|
|
||||||
setlocal buftype=acwrite
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" makes specified temp buffer current.
|
|
||||||
function l9#tempbuffer#moveTo(bufname)
|
|
||||||
return l9#moveToBufferWindowInCurrentTabpage(s:dataMap[a:bufname].bufNr) ||
|
|
||||||
\ l9#moveToBufferWindowInOtherTabpage(s:dataMap[a:bufname].bufNr)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function l9#tempbuffer#close(bufname)
|
|
||||||
if !l9#tempbuffer#isOpen(a:bufname)
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
execute printf('%dbdelete!', s:dataMap[a:bufname].bufNr)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
"
|
|
||||||
function l9#tempbuffer#isOpen(bufname)
|
|
||||||
return exists('s:dataMap[a:bufname]') && bufloaded(s:dataMap[a:bufname].bufNr)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
|
|
||||||
@@ -1,60 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (C) 2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
if !l9#guardScriptLoading(expand('<sfile>:p'), 0, 0, [])
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" TEMPORARY VARIABLES {{{1
|
|
||||||
|
|
||||||
"
|
|
||||||
let s:origMap = {}
|
|
||||||
|
|
||||||
" set temporary variables
|
|
||||||
function l9#tempvariables#set(group, name, value)
|
|
||||||
if !exists('s:origMap[a:group]')
|
|
||||||
let s:origMap[a:group] = {}
|
|
||||||
endif
|
|
||||||
if !exists('s:origMap[a:group][a:name]')
|
|
||||||
let s:origMap[a:group][a:name] = eval(a:name)
|
|
||||||
endif
|
|
||||||
execute 'let ' . a:name . ' = a:value'
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" set temporary variables
|
|
||||||
function l9#tempvariables#setList(group, variables)
|
|
||||||
for [name, value] in a:variables
|
|
||||||
call l9#tempvariables#set(a:group, name, value)
|
|
||||||
unlet value " to avoid E706
|
|
||||||
endfor
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" get temporary variables
|
|
||||||
function l9#tempvariables#getList(group)
|
|
||||||
if !exists('s:origMap[a:group]')
|
|
||||||
return []
|
|
||||||
endif
|
|
||||||
return map(keys(s:origMap[a:group]), '[v:val, eval(v:val)]')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" restore original variables and clean up.
|
|
||||||
function l9#tempvariables#end(group)
|
|
||||||
if !exists('s:origMap[a:group]')
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
for [name, value] in items(s:origMap[a:group])
|
|
||||||
execute 'let ' . name . ' = value'
|
|
||||||
unlet value " to avoid E706
|
|
||||||
endfor
|
|
||||||
unlet s:origMap[a:group]
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
|
|
||||||
@@ -1,73 +0,0 @@
|
|||||||
*l9.txt* Vim-script library
|
|
||||||
|
|
||||||
Copyright (c) 2009-2010 Takeshi NISHIDA
|
|
||||||
|
|
||||||
l9 *l9*
|
|
||||||
|
|
||||||
INTRODUCTION |l9-introduction|
|
|
||||||
INSTALLATION |l9-installation|
|
|
||||||
USAGE |l9-usage|
|
|
||||||
CHANGELOG |l9-changelog|
|
|
||||||
ABOUT |l9-about|
|
|
||||||
|
|
||||||
==============================================================================
|
|
||||||
INTRODUCTION *l9-introduction*
|
|
||||||
|
|
||||||
l9 is a Vim-script library, which provides some utility functions and commands
|
|
||||||
for programming in Vim.
|
|
||||||
|
|
||||||
==============================================================================
|
|
||||||
INSTALLATION *l9-installation*
|
|
||||||
|
|
||||||
Put all files into your runtime directory. If you have the zip file, extract
|
|
||||||
it to your runtime directory.
|
|
||||||
|
|
||||||
You should place the files as follows:
|
|
||||||
>
|
|
||||||
<your runtime directory>/plugin/l9.vim
|
|
||||||
<your runtime directory>/doc/l9.txt
|
|
||||||
...
|
|
||||||
<
|
|
||||||
If you are disgusted to make your runtime directory confused with a lot of
|
|
||||||
plugins, put each of the plugins into a directory individually and just add
|
|
||||||
the directory path to 'runtimepath'. It's easy to uninstall the plugin.
|
|
||||||
|
|
||||||
Then update your help tags files to enable fuzzyfinder help. See
|
|
||||||
|add-local-help| for details.
|
|
||||||
|
|
||||||
==============================================================================
|
|
||||||
USAGE *l9-usage*
|
|
||||||
|
|
||||||
See source code.
|
|
||||||
|
|
||||||
==============================================================================
|
|
||||||
CHANGELOG *l9-changelog*
|
|
||||||
|
|
||||||
1.1:
|
|
||||||
- Added l9#zip()
|
|
||||||
- Added l9#tempvariables#getList()
|
|
||||||
- Changed l9#guardScriptLoading()
|
|
||||||
- Removed l9#tempvariables#swap()
|
|
||||||
|
|
||||||
1.0.1:
|
|
||||||
- Fixed a bug that floating point numbers weren't evaluated correctly and
|
|
||||||
caused errors on some non-English locales.
|
|
||||||
|
|
||||||
1.0:
|
|
||||||
- First release.
|
|
||||||
|
|
||||||
|
|
||||||
==============================================================================
|
|
||||||
ABOUT *l9-about* *l9-contact* *l9-author*
|
|
||||||
|
|
||||||
Author: Takeshi NISHIDA <ns9tks@DELETE-ME.gmail.com>
|
|
||||||
Licence: MIT Licence
|
|
||||||
URL: http://www.vim.org/scripts/script.php?script_id=3252
|
|
||||||
http://bitbucket.org/ns9tks/vim-l9/
|
|
||||||
|
|
||||||
Bugs/Issues/Suggestions/Improvements ~
|
|
||||||
|
|
||||||
Please submit to http://bitbucket.org/ns9tks/vim-l9/issues/ .
|
|
||||||
|
|
||||||
==============================================================================
|
|
||||||
vim:tw=78:ts=8:ft=help:norl:
|
|
||||||
@@ -1,108 +0,0 @@
|
|||||||
"=============================================================================
|
|
||||||
" Copyright (C) 2009-2010 Takeshi NISHIDA
|
|
||||||
"
|
|
||||||
" GetLatestVimScripts: 3252 1 :AutoInstall: L9
|
|
||||||
"=============================================================================
|
|
||||||
" LOAD GUARD {{{1
|
|
||||||
|
|
||||||
if !l9#guardScriptLoading(expand('<sfile>:p'), 702, 0, [])
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" OPTIONS: {{{1
|
|
||||||
|
|
||||||
call l9#defineVariableDefault('g:l9_balloonly', 'balloonly.exe')
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" ASSERTION: {{{1
|
|
||||||
|
|
||||||
" This command has effect only if $L9_DEBUG is non-zero.
|
|
||||||
" Used as follows:
|
|
||||||
" L9Assert a:i > 0
|
|
||||||
" This command can't interpret script-local variables directly.
|
|
||||||
" NG: L9Assert s:a == 1
|
|
||||||
" OK: execute 'L9Assert ' . s:a . ' == 1'
|
|
||||||
"
|
|
||||||
if $L9_DEBUG
|
|
||||||
command -nargs=* L9Assert call eval((<args>) ? 0 : s:handleFailedAssersion(<q-args>))
|
|
||||||
|
|
||||||
function s:handleFailedAssersion(expr)
|
|
||||||
echoerr '[L9Assert] Assersion failure: ' . a:expr
|
|
||||||
if input('[L9Assert] Continue? (Y/N) ', 'Y') !=? 'Y'
|
|
||||||
throw 'L9Assert ' . a:expr
|
|
||||||
endif
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
else
|
|
||||||
command -nargs=* L9Assert :
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" TIMER: {{{1
|
|
||||||
|
|
||||||
" These commands have effect only if $L9_TIMER is non-zero.
|
|
||||||
" Used as follows:
|
|
||||||
" L9Timer foo
|
|
||||||
" ... (1)
|
|
||||||
" L9Timer bar
|
|
||||||
" ... (2)
|
|
||||||
" L9TimerStop
|
|
||||||
" ...
|
|
||||||
" L9TimerDump <- shows each elapsed time of (1) and (2)
|
|
||||||
"
|
|
||||||
if $L9_TIMER
|
|
||||||
command -nargs=1 L9Timer call s:timerBegin(<q-args>)
|
|
||||||
command -nargs=0 L9TimerStop call s:timerStop()
|
|
||||||
command -nargs=0 L9TimerDump call s:timerDump()
|
|
||||||
|
|
||||||
let s:timerData = []
|
|
||||||
let s:timerTagMaxLen = 0
|
|
||||||
|
|
||||||
function s:timerBegin(tag)
|
|
||||||
L9TimerStop
|
|
||||||
let s:timerCurrent = {'tag': strftime('%c ') . a:tag . ' ', 'time': reltime()}
|
|
||||||
let s:timerTagMaxLen = max([len(s:timerCurrent.tag), s:timerTagMaxLen])
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
function s:timerStop()
|
|
||||||
if !exists('s:timerCurrent')
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
let s:timerCurrent.time = reltimestr(reltime(s:timerCurrent.time))
|
|
||||||
call add(s:timerData, s:timerCurrent)
|
|
||||||
unlet s:timerCurrent
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
function s:timerDump()
|
|
||||||
L9TimerStop
|
|
||||||
let lines = map(s:timerData, 'v:val.tag . repeat(" ", s:timerTagMaxLen - len(v:val.tag)) . v:val.time')
|
|
||||||
call l9#tempbuffer#openReadOnly('[l9-timer]', '', lines, 0, 0, 0, {})
|
|
||||||
let s:timerData = []
|
|
||||||
let s:timerTagMaxLen = 0
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
else
|
|
||||||
command -nargs=1 L9Timer :
|
|
||||||
command -nargs=0 L9TimerStop :
|
|
||||||
command -nargs=0 L9TimerDump :
|
|
||||||
endif
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" GREP BUFFER: {{{1
|
|
||||||
|
|
||||||
" Grep for current buffer by l9#grepBuffers()
|
|
||||||
" Used as :L9GrepBuffer/pattern
|
|
||||||
command -nargs=? L9GrepBuffer call l9#grepBuffers(<q-args>, [bufnr('%')])
|
|
||||||
|
|
||||||
" Grep for all buffers by l9#grepBuffers()
|
|
||||||
" Used as :L9GrepBufferAll/pattern
|
|
||||||
command -nargs=? L9GrepBufferAll call l9#grepBuffers(<q-args>, range(1, bufnr('$')))
|
|
||||||
|
|
||||||
" }}}1
|
|
||||||
"=============================================================================
|
|
||||||
" vim: set fdm=marker:
|
|
||||||
@@ -1,8 +0,0 @@
|
|||||||
# ctrlp.vim
|
|
||||||
Fuzzy __file__, __buffer__, __mru__ and __tag__ finder for Vim.
|
|
||||||
|
|
||||||
* [**Project's homepage**][1]
|
|
||||||
* [**Main git repository**][2]
|
|
||||||
|
|
||||||
[1]: http://kien.github.com/ctrlp.vim
|
|
||||||
[2]: https://github.com/kien/ctrlp.vim
|
|
||||||
@@ -1,105 +0,0 @@
|
|||||||
*fontzoom.txt* The fontsize controller in gVim.
|
|
||||||
|
|
||||||
Version: 0.1.1
|
|
||||||
Modified: thinca <thinca+vim@gmail.com>
|
|
||||||
License: Creative Commons Attribution 2.1 Japan License
|
|
||||||
<http://creativecommons.org/licenses/by/2.1/jp/deed.en>
|
|
||||||
|
|
||||||
==============================================================================
|
|
||||||
CONTENTS *fontzoom-contents*
|
|
||||||
|
|
||||||
INTRODUCTION |fontzoom-introduction|
|
|
||||||
INTERFACE |fontzoom-interface|
|
|
||||||
KEY MAPPINGS |fontzoom-key-mappings|
|
|
||||||
COMMANDS |fontzoom-commands|
|
|
||||||
SETTINGS |fontzoom-settings|
|
|
||||||
LIMITATION |fontzoom-limitation|
|
|
||||||
CHANGELOG |fontzoom-changelog|
|
|
||||||
|
|
||||||
|
|
||||||
==============================================================================
|
|
||||||
INTRODUCTION *fontzoom-introduction*
|
|
||||||
|
|
||||||
*fontzoom* is a Vim plugin to control gui fontsize. You can change fontsize
|
|
||||||
with + and - keys(when default setting). You can also use the [count].
|
|
||||||
This plugin remember 'guifont', 'lines', and 'columns' when you change
|
|
||||||
fontsize first. And tries to keep the size of the window as much as possible.
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
==============================================================================
|
|
||||||
INTERFACE *fontzoom-interface*
|
|
||||||
|
|
||||||
------------------------------------------------------------------------------
|
|
||||||
KEY MAPPINGS *fontzoom-key-mappings*
|
|
||||||
|
|
||||||
<Plug>(fontzoom-learger) *<Plug>(fontzoom-learger)*
|
|
||||||
Fontsize is made large [count] point.
|
|
||||||
|
|
||||||
<Plug>(fontzoom-smaller) *<Plug>(fontzoom-smaller)*
|
|
||||||
Fontsize is made small [count] point.
|
|
||||||
|
|
||||||
|
|
||||||
*g:fontzoom_no_default_key_mappings*
|
|
||||||
The following key mappings will be also available unless
|
|
||||||
g:fontzoom_no_default_key_mappings is defined:
|
|
||||||
|
|
||||||
{lhs} {rhs}
|
|
||||||
-------- -----------------------------
|
|
||||||
+ <Plug>(fontzoom-larger)
|
|
||||||
- <Plug>(fontzoom-smaller)
|
|
||||||
<C-ScrollWheelUp> <Plug>(fontzoom-larger)
|
|
||||||
<C-ScrollWheelDown> <Plug>(fontzoom-smaller)
|
|
||||||
|
|
||||||
------------------------------------------------------------------------------
|
|
||||||
COMMANDS *fontzoom-commands*
|
|
||||||
|
|
||||||
:Fontzoom *:Fontzoom*
|
|
||||||
Show fontsize in current.
|
|
||||||
|
|
||||||
:Fontzoom +[N]
|
|
||||||
Fontsize is made large [N] point.
|
|
||||||
|
|
||||||
:Fontzoom -[N]
|
|
||||||
Fontsize is made small [N] point.
|
|
||||||
|
|
||||||
:Fontzoom [N]
|
|
||||||
Fontsize is changed into [N] points.
|
|
||||||
|
|
||||||
:Fontzoom!
|
|
||||||
Fontsize is changed into initial size. All arguments
|
|
||||||
are ignored.
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
==============================================================================
|
|
||||||
SETTINGS *fontzoom-settings*
|
|
||||||
|
|
||||||
g:fontzoom_pattern *g:fontzoom_pattern*
|
|
||||||
Pick out the Fontsize from font name. The pattern
|
|
||||||
must match to the Fontsize. |/\zs| and |/\ze| are
|
|
||||||
convenient.
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
==============================================================================
|
|
||||||
LIMITATION *fontzoom-limitation*
|
|
||||||
|
|
||||||
- 'guifont' should contain fontsize that matches to |g:fontzoom_pattern|.
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
==============================================================================
|
|
||||||
CHANGELOG *fontzoom-changelog*
|
|
||||||
|
|
||||||
0.1.1 2011-02-24
|
|
||||||
- Added default key mappings.
|
|
||||||
- <C-ScrollWheelUp> and <C-ScrollWheelDown>.
|
|
||||||
|
|
||||||
0.1.0 2009-12-25
|
|
||||||
- Initial version.
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
==============================================================================
|
|
||||||
vim:tw=78:fo=tcq2mM:ts=8:ft=help:norl
|
|
||||||
@@ -1,69 +0,0 @@
|
|||||||
" The fontsize controller in gVim.
|
|
||||||
" Version: 0.1.1
|
|
||||||
" Author : thinca <thinca+vim@gmail.com>
|
|
||||||
" License: Creative Commons Attribution 2.1 Japan License
|
|
||||||
" <http://creativecommons.org/licenses/by/2.1/jp/deed.en>
|
|
||||||
|
|
||||||
if exists('g:loaded_fontzoom') || !has('gui_running')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
let g:loaded_fontzoom = 1
|
|
||||||
|
|
||||||
let s:save_cpo = &cpo
|
|
||||||
set cpo&vim
|
|
||||||
|
|
||||||
|
|
||||||
function! s:fontzoom(size, reset)
|
|
||||||
if a:reset
|
|
||||||
if exists('s:keep') " Reset font size.
|
|
||||||
let [&guifont, &lines, &columns] = s:keep
|
|
||||||
unlet! s:keep
|
|
||||||
endif
|
|
||||||
elseif a:size == ''
|
|
||||||
echo matchstr(&guifont, g:fontzoom_pattern)
|
|
||||||
else
|
|
||||||
let size = (a:size =~ '^[+-]' ? 'submatch(0)' : '') . a:size
|
|
||||||
if !exists('s:keep')
|
|
||||||
let s:keep = [&guifont, &lines, &columns]
|
|
||||||
endif
|
|
||||||
let &guifont = join(map(split(&guifont, '\\\@<!,'),
|
|
||||||
\ printf('substitute(v:val, %s, %s, "g")',
|
|
||||||
\ string(g:fontzoom_pattern),
|
|
||||||
\ string('\=max([1,' . size . '])'))), ',')
|
|
||||||
" Keep window size if possible.
|
|
||||||
let [&lines, &columns] = s:keep[1:]
|
|
||||||
endif
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if !exists('g:fontzoom_pattern')
|
|
||||||
" TODO: X11 is not tested because I do not have the environment.
|
|
||||||
let g:fontzoom_pattern =
|
|
||||||
\ has('win32') || has('win64') ||
|
|
||||||
\ has('mac') || has('macunix') ? ':h\zs\d\+':
|
|
||||||
\ has('gui_gtk') ? '\s\+\zs\d\+$':
|
|
||||||
\ has('X11') ? '\v%([^-]*-){6}\zs\d+\ze%(-[^-]*){7}':
|
|
||||||
\ '*Unknown system*'
|
|
||||||
endif
|
|
||||||
|
|
||||||
|
|
||||||
" Commands.
|
|
||||||
command! -narg=? -bang -bar Fontzoom call s:fontzoom(<q-args>, <bang>0)
|
|
||||||
|
|
||||||
" Key mappings.
|
|
||||||
nnoremap <silent> <Plug>(fontzoom-larger)
|
|
||||||
\ :<C-u>Fontzoom +<C-r>=v:count1<CR><CR>
|
|
||||||
nnoremap <silent> <Plug>(fontzoom-smaller)
|
|
||||||
\ :<C-u>Fontzoom -<C-r>=v:count1<CR><CR>
|
|
||||||
|
|
||||||
if !exists('g:fontzoom_no_default_key_mappings')
|
|
||||||
\ || !g:fontzoom_no_default_key_mappings
|
|
||||||
silent! nmap <unique> <silent> + <Plug>(fontzoom-larger)
|
|
||||||
silent! nmap <unique> <silent> - <Plug>(fontzoom-smaller)
|
|
||||||
silent! nmap <unique> <silent> <C-ScrollWheelUp> <Plug>(fontzoom-larger)
|
|
||||||
silent! nmap <unique> <silent> <C-ScrollWheelDown> <Plug>(fontzoom-smaller)
|
|
||||||
endif
|
|
||||||
|
|
||||||
let &cpo = s:save_cpo
|
|
||||||
unlet s:save_cpo
|
|
||||||
Reference in New Issue
Block a user