Merge branch 'update-vital-over'

This commit is contained in:
haya14busa 2014-06-07 02:24:48 +09:00
commit bf093abbdf
9 changed files with 313 additions and 39 deletions

View File

@ -59,6 +59,43 @@ function! s:unload()
let s:loaded = {} let s:loaded = {}
endfunction endfunction
function! s:exists(name)
return s:_get_module_path(a:name) !=# ''
endfunction
function! s:search(pattern)
let target = substitute(a:pattern, '\.', '/', 'g')
let tailpath = printf('autoload/vital/%s/%s.vim', s:self_version, target)
let paths = s:_runtime_files(tailpath)
let modules = sort(map(paths, 's:_file2module(v:val)'))
return s:_uniq(modules)
endfunction
function! s:expand_modules(entry, all)
if type(a:entry) == type([])
let candidates = s:_concat(map(copy(a:entry), 's:search(v:val)'))
if empty(candidates)
throw printf('vital: Any of module %s is not found', string(a:entry))
endif
if eval(join(map(copy(candidates), 'has_key(a:all, v:val)'), '+'))
let modules = []
else
let modules = [candidates[0]]
endif
else
let modules = s:search(a:entry)
if empty(modules)
throw printf('vital: Module %s is not found', a:entry)
endif
endif
call filter(modules, '!has_key(a:all, v:val)')
for module in modules
let a:all[module] = 1
endfor
return modules
endfunction
function! s:_import(name) function! s:_import(name)
if type(a:name) == type(0) if type(a:name) == type(0)
return s:_build_module(a:name) return s:_build_module(a:name)
@ -89,19 +126,16 @@ function! s:_get_module_path(name)
if a:name ==# '' if a:name ==# ''
let tailpath = printf('autoload/vital/%s.vim', s:self_version) let tailpath = printf('autoload/vital/%s.vim', s:self_version)
elseif a:name =~# '\v^\u\w*%(\.\u\w*)*$' elseif a:name =~# '\v^\u\w*%(\.\u\w*)*$'
let target = '/' . substitute(a:name, '\W\+', '/', 'g') let target = substitute(a:name, '\W\+', '/', 'g')
let tailpath = printf('autoload/vital/%s%s.vim', s:self_version, target) let tailpath = printf('autoload/vital/%s/%s.vim', s:self_version, target)
else else
throw 'vital: Invalid module name: ' . a:name throw 'vital: Invalid module name: ' . a:name
endif endif
if s:globpath_third_arg let paths = s:_runtime_files(tailpath)
let paths = split(globpath(&runtimepath, tailpath, 1), "\n")
else
let paths = split(globpath(&runtimepath, tailpath), "\n")
endif
call filter(paths, 'filereadable(v:val)') call filter(paths, 'filereadable(v:val)')
return s:_unify_path(get(paths, 0, '')) let path = get(paths, 0, '')
return path !=# '' ? s:_unify_path(path) : ''
endfunction endfunction
function! s:_scripts() function! s:_scripts()
@ -116,13 +150,19 @@ function! s:_scripts()
return scripts return scripts
endfunction endfunction
function! s:_file2module(file)
let filename = fnamemodify(a:file, ':p:gs?[\\/]\+?/?')
let tail = matchstr(filename, 'autoload/vital/_\w\+/\zs.*\ze\.vim$')
return join(split(tail, '[\\/]\+'), '.')
endfunction
if filereadable(expand('<sfile>:r') . '.VIM') if filereadable(expand('<sfile>:r') . '.VIM')
function! s:_unify_path(path) function! s:_unify_path(path)
" Note: On windows, vim can't expand path names from 8.3 formats. " Note: On windows, vim can't expand path names from 8.3 formats.
" So if getting full path via <sfile> and $HOME was set as 8.3 format, " So if getting full path via <sfile> and $HOME was set as 8.3 format,
" vital load duplicated scripts. Below's :~ avoid this issue. " vital load duplicated scripts. Below's :~ avoid this issue.
return tolower(fnamemodify(resolve(fnamemodify( return tolower(fnamemodify(resolve(fnamemodify(
\ a:path, ':p:gs?[\\/]\+?/?')), ':~')) \ a:path, ':p')), ':~:gs?[\\/]\+?/?'))
endfunction endfunction
else else
function! s:_unify_path(path) function! s:_unify_path(path)
@ -130,6 +170,16 @@ else
endfunction endfunction
endif endif
if s:globpath_third_arg
function! s:_runtime_files(path)
return split(globpath(&runtimepath, a:path, 1), "\n")
endfunction
else
function! s:_runtime_files(path)
return split(globpath(&runtimepath, a:path), "\n")
endfunction
endif
" Copy from System.Filepath " Copy from System.Filepath
if has('win16') || has('win32') || has('win64') if has('win16') || has('win32') || has('win64')
function! s:_is_absolute_path(path) function! s:_is_absolute_path(path)
@ -155,7 +205,11 @@ function! s:_build_module(sid)
if has_key(module, '_vital_loaded') if has_key(module, '_vital_loaded')
let V = vital#{s:self_version}#new() let V = vital#{s:self_version}#new()
if has_key(module, '_vital_depends') if has_key(module, '_vital_depends')
call call(V.load, module._vital_depends(), V) let all = {}
let modules =
\ s:_concat(map(module._vital_depends(),
\ 's:expand_modules(v:val, all)'))
call call(V.load, modules, V)
endif endif
try try
call module._vital_loaded(V) call module._vital_loaded(V)
@ -188,6 +242,33 @@ else
endfunction endfunction
endif endif
if exists('*uniq')
function! s:_uniq(list)
return uniq(a:list)
endfunction
else
function! s:_uniq(list)
let i = len(a:list) - 1
while 0 < i
if a:list[i] ==# a:list[i - 1]
call remove(a:list, i)
let i -= 2
else
let i -= 1
endif
endwhile
return a:list
endfunction
endif
function! s:_concat(lists)
let result_list = []
for list in a:lists
let result_list += list
endfor
return result_list
endfunction
function! s:_redir(cmd) function! s:_redir(cmd)
let [save_verbose, save_verbosefile] = [&verbose, &verbosefile] let [save_verbose, save_verbosefile] = [&verbose, &verbosefile]
set verbose=0 verbosefile= set verbose=0 verbosefile=

View File

@ -29,13 +29,8 @@ function! s:conj(xs, x)
endfunction endfunction
" Removes duplicates from a list. " Removes duplicates from a list.
function! s:uniq(list, ...) function! s:uniq(list)
if a:0 return s:uniq_by(a:list, 'v:val')
echomsg "Vital.Data.List.uniq() with 2 arguments is deprecated! Please use uniq_by() instead, if you still want to use the 2nd argument."
return s:uniq_by(a:list, a:1)
else
return s:uniq_by(a:list, 'v:val')
endif
endfunction endfunction
" Removes duplicates from a list. " Removes duplicates from a list.
@ -203,6 +198,18 @@ function! s:or(xs)
return s:any('v:val', a:xs) return s:any('v:val', a:xs)
endfunction endfunction
function! s:map_accum(expr, xs, init)
let memo = []
let init = a:init
for x in a:xs
let expr = substitute(a:expr, 'v:memo', init, 'g')
let expr = substitute(expr, 'v:val', x, 'g')
let [tmp, init] = eval(expr)
call add(memo, tmp)
endfor
return memo
endfunction
" similar to Haskell's Prelude.foldl " similar to Haskell's Prelude.foldl
function! s:foldl(f, init, xs) function! s:foldl(f, init, xs)
let memo = a:init let memo = a:init

View File

@ -8,6 +8,7 @@ function! s:_vital_loaded(V)
let s:String = s:V.import("Over.String") let s:String = s:V.import("Over.String")
let s:Signals = s:V.import("Over.Signals") let s:Signals = s:V.import("Over.Signals")
let s:Module = s:V.import("Over.Commandline.Modules") let s:Module = s:V.import("Over.Commandline.Modules")
let s:List = s:V.import("Data.List")
let s:base.variables.modules = s:Signals.make() let s:base.variables.modules = s:Signals.make()
function! s:base.variables.modules.get_slot(val) function! s:base.variables.modules.get_slot(val)
return a:val.slot.module return a:val.slot.module
@ -20,6 +21,7 @@ function! s:_vital_depends()
\ "Over.String", \ "Over.String",
\ "Over.Signals", \ "Over.Signals",
\ "Over.Commandline.Modules", \ "Over.Commandline.Modules",
\ "Data.List",
\ ] \ ]
endfunction endfunction
@ -247,6 +249,20 @@ function! s:base.exit(...)
endfunction endfunction
function! s:base.enable_keymapping()
let self.variables.enable_keymapping = 1
endfunction
function! s:base.disable_keymapping()
let self.variables.enable_keymapping = 0
endfunction
function! s:base.is_enable_keymapping()
return self.variables.enable_keymapping
endfunction
" function! s:base.cancel() " function! s:base.cancel()
" call self.exit(1) " call self.exit(1)
" call self._on_cancel() " call self._on_cancel()
@ -315,6 +331,7 @@ function! s:base._init()
let self.variables.input = "" let self.variables.input = ""
let self.variables.exit = 0 let self.variables.exit = 0
let self.variables.exit_code = 1 let self.variables.exit_code = 1
let self.variables.enable_keymapping = 1
call self.hl_cursor_off() call self.hl_cursor_off()
if !hlexists(self.highlights.cursor) if !hlexists(self.highlights.cursor)
execute "highlight link " . self.highlights.cursor . " Cursor" execute "highlight link " . self.highlights.cursor . " Cursor"
@ -343,25 +360,43 @@ function! s:base._execute(command)
endfunction endfunction
function! s:base._input(input, ...)
let self.variables.input_key = a:input
if self.is_enable_keymapping()
let key = s:_unmap(self._get_keymapping(), a:input)
else
let key = a:input
endif
for char in s:_split_keys(key)
let self.variables.input_key = char
let self.variables.char = char
call self.setchar(self.variables.char)
call self.callevent("on_char_pre")
call self.insert(self.variables.input)
call self.callevent("on_char")
endfor
endfunction
function! s:base._main(...) function! s:base._main(...)
try try
call self._init() call self._init()
let self.line = deepcopy(s:String.make(get(a:, 1, ""))) let self.line = deepcopy(s:String.make(get(a:, 1, "")))
call self.callevent("on_enter") call self.callevent("on_enter")
call self.draw()
while !self._is_exit() while !self._is_exit()
try try
call self.draw() " call self.callevent("on_update")
" if !getchar(1)
let self.variables.input_key = s:_getchar() " continue
let self.variables.char = s:_unmap(self._get_keymapping(), self.variables.input_key) " endif
" let self.variables.char = s:_unmap(self._get_keymapping(), self.get_tap_key() . self.variables.input_key) "
" call self._input(s:_getchar(0))
call self.setchar(self.variables.char) " call self.draw()
call self._input(s:_getchar())
call self.callevent("on_char_pre") call self.draw()
call self.insert(self.variables.input)
call self.callevent("on_char")
catch catch
call self.callevent("on_exception") call self.callevent("on_exception")
endtry endtry
@ -400,6 +435,10 @@ endfunction
function! s:_unmap(mapping, key) function! s:_unmap(mapping, key)
let keys = s:_split_keys(a:key)
if len(keys) > 1
return join(map(keys, 's:_unmap(a:mapping, v:val)'), '')
endif
if !has_key(a:mapping, a:key) if !has_key(a:mapping, a:key)
return a:key return a:key
endif endif
@ -426,11 +465,151 @@ function! s:base._get_keymapping()
endfunction endfunction
function! s:_getchar() function! s:_getchar(...)
let char = getchar() let char = call("getchar", a:000)
return type(char) == type(0) ? nr2char(char) : char return type(char) == type(0) ? nr2char(char) : char
endfunction endfunction
function! s:_split(str, pat)
let pat = '\%#=2' . a:pat
let list = split(a:str, pat . '\zs')
return s:List.flatten(map(list, 'v:val == a:pat ? a:pat : v:val =~ pat . ''$'' ? split(v:val, pat) + [a:pat] : v:val'))
endfunction
function! s:_split_keystring(str, pats, ...)
if a:str =~ '^<Over>(.\{-})$'
\ || a:str =~ "^\<Plug>(.\\{-})$"
return [a:str]
endif
let pats = a:pats
let index = get(a:, 1, 0)
if !exists("+regexpengine")
\ || index > len(pats)
\ || len(filter(copy(pats), 'a:str =~ ''\%#=2'' . v:val')) == 0
if len(filter(copy(pats), 'a:str ==# v:val')) == 0
return split(a:str, '\zs')
else
return [a:str]
endif
endif
if len(filter(copy(pats), 'a:str == v:val')) == 1
return [a:str]
endif
let result = []
let pat = pats[index]
let list = s:_split(a:str, pat)
let result += eval(join(map(list, "s:_split_keystring(v:val, pats, index+1)"), "+"))
return result
endfunction
let s:special_keys = [
\ "\<BS>",
\ "\<Down>",
\ "\<Up>",
\ "\<Left>",
\ "\<Right>",
\ "\<Home>",
\ "\<End>",
\ "\<Insert>",
\ "\<Delete>",
\ "\<PageUp>",
\ "\<PageDown>",
\ "\<F1>",
\ "\<F2>",
\ "\<F3>",
\ "\<F4>",
\ "\<F5>",
\ "\<F6>",
\ "\<F7>",
\ "\<F8>",
\ "\<F9>",
\ "\<F10>",
\ "\<F11>",
\ "\<F12>",
\ "\<A-BS>",
\ "\<A-Down>",
\ "\<A-Up>",
\ "\<A-Left>",
\ "\<A-Right>",
\ "\<A-Home>",
\ "\<A-End>",
\ "\<A-Insert>",
\ "\<A-Delete>",
\ "\<A-PageUp>",
\ "\<A-PageDown>",
\ "\<A-F1>",
\ "\<A-F2>",
\ "\<A-F3>",
\ "\<A-F4>",
\ "\<A-F5>",
\ "\<A-F6>",
\ "\<A-F7>",
\ "\<A-F8>",
\ "\<A-F9>",
\ "\<A-F10>",
\ "\<A-F11>",
\ "\<A-F12>",
\ "\<A-Tab>",
\ "\<C-BS>",
\ "\<C-Down>",
\ "\<C-Up>",
\ "\<C-Left>",
\ "\<C-Right>",
\ "\<C-Home>",
\ "\<C-End>",
\ "\<C-Insert>",
\ "\<C-Delete>",
\ "\<C-PageUp>",
\ "\<C-PageDown>",
\ "\<C-Tab>",
\ "\<C-F1>",
\ "\<C-F2>",
\ "\<C-F3>",
\ "\<C-F4>",
\ "\<C-F5>",
\ "\<C-F6>",
\ "\<C-F7>",
\ "\<C-F8>",
\ "\<C-F9>",
\ "\<C-F10>",
\ "\<C-F11>",
\ "\<C-F12>",
\ "\<S-Down>",
\ "\<S-Up>",
\ "\<S-Left>",
\ "\<S-Right>",
\ "\<S-Home>",
\ "\<S-Insert>",
\ "\<S-PageUp>",
\ "\<S-PageDown>",
\ "\<S-F1>",
\ "\<S-F2>",
\ "\<S-F3>",
\ "\<S-F4>",
\ "\<S-F5>",
\ "\<S-F6>",
\ "\<S-F7>",
\ "\<S-F8>",
\ "\<S-F9>",
\ "\<S-F10>",
\ "\<S-F11>",
\ "\<S-F12>",
\ "\<S-Tab>",
\]
" \ "\<S-Delete>", -> conflict with 4
" \ "\<S-End>", -> conflict with 7
function! s:_split_keys(str)
return s:_split_keystring(a:str, s:special_keys)
endfunction
let &cpo = s:save_cpo let &cpo = s:save_cpo
unlet s:save_cpo unlet s:save_cpo

View File

@ -29,10 +29,12 @@ let s:hooks = [
\ "leave", \ "leave",
\ "char", \ "char",
\ "char_pre", \ "char_pre",
\ "draw",
\ "draw_pre",
\ "execute_pre", \ "execute_pre",
\ "execute_failed", \ "execute_failed",
\ "execute", \ "execute",
\ "cancel" \ "exception",
\] \]
let s:hooks_camel = [ let s:hooks_camel = [
@ -40,10 +42,12 @@ let s:hooks_camel = [
\ "Leave", \ "Leave",
\ "Char", \ "Char",
\ "CharPre", \ "CharPre",
\ "Draw",
\ "DrawPre",
\ "ExecutePre", \ "ExecutePre",
\ "ExecuteFailed", \ "ExecuteFailed",
\ "Execute", \ "Execute",
\ "Cancel" \ "Exception",
\] \]

View File

@ -66,7 +66,7 @@ endfunction
function! s:_as_echon(str) function! s:_as_echon(str)
return "echon " . string(a:str) return "echon " . strtrans(string(a:str))
endfunction endfunction

View File

@ -12,7 +12,7 @@ function! s:module.histories()
endfunction endfunction
function! s:module.enter(...) function! s:module.on_enter(...)
let s:cmdhist = [] let s:cmdhist = []
let s:count = 0 let s:count = 0
endfunction endfunction

View File

@ -51,9 +51,9 @@ function! s:module.on_char_pre(cmdline)
call a:cmdline.setline(self.old_line) call a:cmdline.setline(self.old_line)
call a:cmdline.setpos(self.old_pos) call a:cmdline.setpos(self.old_pos)
let char = a:cmdline.input_key() let char = a:cmdline.input_key()
if char =~ '^[0-9a-zA-z.%#:/"\-*]$' if char =~ '^[0-9a-zA-z.%#:/"\-*+]$'
execute "let regist = @" . char let register = tr(getreg(char), "\n", "\r")
call a:cmdline.setchar(regist) call a:cmdline.setchar(register)
elseif char == "=" elseif char == "="
call a:cmdline.setchar(s:input(a:cmdline)) call a:cmdline.setchar(s:input(a:cmdline))
elseif char == "\<C-w>" elseif char == "\<C-w>"
@ -87,10 +87,12 @@ endfunction
function! s:module.on_char(cmdline) function! s:module.on_char(cmdline)
if a:cmdline.is_input("\<C-r>") if a:cmdline.is_input("\<C-r>")
call a:cmdline.tap_keyinput(self.prefix_key) call a:cmdline.tap_keyinput(self.prefix_key)
call a:cmdline.disable_keymapping()
call a:cmdline.setpos(a:cmdline.getpos()-1) call a:cmdline.setpos(a:cmdline.getpos()-1)
else else
if exists("self.prefix_key") if exists("self.prefix_key")
call a:cmdline.untap_keyinput(self.prefix_key) call a:cmdline.untap_keyinput(self.prefix_key)
call a:cmdline.enable_keymapping()
unlet! self.prefix_key unlet! self.prefix_key
endif endif
endif endif

View File

@ -9,7 +9,8 @@ let s:module = {
function! s:module.on_char_pre(cmdline) function! s:module.on_char_pre(cmdline)
if a:cmdline.is_input("<Over>(paste)") if a:cmdline.is_input("<Over>(paste)")
call a:cmdline.insert(@*) let register = v:register == "" ? '"' : v:register
call a:cmdline.insert(tr(getreg("*"), "\n", "\r"))
call a:cmdline.setchar('') call a:cmdline.setchar('')
endif endif
endfunction endfunction

View File

@ -1,5 +1,5 @@
easymotion easymotion
39d8e9c fb554d1
Over.Commandline.Base Over.Commandline.Base
Over.Commandline.Modules.Cancel Over.Commandline.Modules.Cancel