Revised completion
This commit is contained in:
parent
b63d763cc9
commit
bb999c6e34
1 changed files with 76 additions and 38 deletions
114
c4ctrl.vim
114
c4ctrl.vim
|
@ -4,13 +4,15 @@
|
||||||
" Maintainer: Shy
|
" Maintainer: Shy
|
||||||
" License: This file is placed in the public domain.
|
" License: This file is placed in the public domain.
|
||||||
"
|
"
|
||||||
" Usage: C4ctrl [get] [open $preset] [set [w][p][f]] [text] [write]
|
" Usage: C4ctrl [get | open PRESET | set [w] [p] [f] [-magic MODE] |
|
||||||
|
" text | write]
|
||||||
|
|
||||||
if exists("g:loaded_c4ctrl")
|
if exists("g:loaded_c4ctrl")
|
||||||
finish
|
finish
|
||||||
endif
|
endif
|
||||||
let g:loaded_c4ctrl = 1
|
let g:loaded_c4ctrl = 1
|
||||||
|
|
||||||
|
let s:Name = "C4ctrl"
|
||||||
|
|
||||||
function s:FindConfigDir()
|
function s:FindConfigDir()
|
||||||
" Run only once
|
" Run only once
|
||||||
|
@ -49,8 +51,6 @@ function C4ctrl(cmd, ...)
|
||||||
" Read current status into new buffer
|
" Read current status into new buffer
|
||||||
if getbufinfo("%")[0].changed
|
if getbufinfo("%")[0].changed
|
||||||
vnew
|
vnew
|
||||||
else
|
|
||||||
enew
|
|
||||||
endif
|
endif
|
||||||
set filetype=conf
|
set filetype=conf
|
||||||
silent execute "0 read !" s:c4ctrl "-o -"
|
silent execute "0 read !" s:c4ctrl "-o -"
|
||||||
|
@ -74,8 +74,6 @@ function C4ctrl(cmd, ...)
|
||||||
|
|
||||||
if getbufinfo("%")[0].changed
|
if getbufinfo("%")[0].changed
|
||||||
vnew
|
vnew
|
||||||
else
|
|
||||||
enew
|
|
||||||
endif
|
endif
|
||||||
execute "edit" fnameescape(s:fn)
|
execute "edit" fnameescape(s:fn)
|
||||||
|
|
||||||
|
@ -88,21 +86,26 @@ function C4ctrl(cmd, ...)
|
||||||
let s:cmd = s:cmd . " -w - -p - -f -"
|
let s:cmd = s:cmd . " -w - -p - -f -"
|
||||||
endif
|
endif
|
||||||
|
|
||||||
for s:arg in a:000
|
for s:i in range(a:0)
|
||||||
" Ignore options which are longer than 1 char
|
let s:arg = a:000[s:i]
|
||||||
if strchars(s:arg) != 1
|
if strchars(s:arg) == 1
|
||||||
continue
|
if stridx("wpf", s:arg) != -1
|
||||||
|
let s:cmd = printf("%s -%s -", s:cmd, s:arg)
|
||||||
|
endif
|
||||||
|
elseif stridx("-magic", s:arg) == 0
|
||||||
|
try
|
||||||
|
let s:cmd = printf("%s --magic %s", s:cmd, a:000[s:i+1])
|
||||||
|
catch /^Vim\%((\a\+)\)\=:E684/
|
||||||
|
" Catching list index out of range
|
||||||
|
echoerr "Option -magic expects one argument!"
|
||||||
|
continue
|
||||||
|
endtry
|
||||||
endif
|
endif
|
||||||
" Ignore unknown chars
|
|
||||||
if stridx("wpf", s:arg) == -1
|
|
||||||
continue
|
|
||||||
endif
|
|
||||||
let s:cmd = printf("%s -%s -", s:cmd, s:arg)
|
|
||||||
endfor
|
endfor
|
||||||
|
|
||||||
silent let s:ret = system(s:cmd, bufnr("%"))
|
silent let s:ret = system(s:cmd, bufnr("%"))
|
||||||
|
|
||||||
unlet! s:arg s:cmd s:txt
|
unlet! s:arg s:i s:cmd s:txt
|
||||||
|
|
||||||
elseif stridx("text", a:cmd) == 0
|
elseif stridx("text", a:cmd) == 0
|
||||||
" Send line under the cursor to the Kitchenlight
|
" Send line under the cursor to the Kitchenlight
|
||||||
|
@ -127,7 +130,7 @@ function C4ctrl(cmd, ...)
|
||||||
let s:fn = s:cfgdir . a:1
|
let s:fn = s:cfgdir . a:1
|
||||||
|
|
||||||
if strridx(a:cmd, "!") + 1 == len(a:cmd)
|
if strridx(a:cmd, "!") + 1 == len(a:cmd)
|
||||||
" Force if a ! was appended to the command
|
" Force if a '!' was appended to the command
|
||||||
execute "saveas!" fnameescape(s:fn)
|
execute "saveas!" fnameescape(s:fn)
|
||||||
else
|
else
|
||||||
execute "saveas" fnameescape(s:fn)
|
execute "saveas" fnameescape(s:fn)
|
||||||
|
@ -151,30 +154,65 @@ endfunction
|
||||||
|
|
||||||
" Custom command line completion
|
" Custom command line completion
|
||||||
function s:C4ctrlCompletion(ArgLead, CmdLine, CursorPos)
|
function s:C4ctrlCompletion(ArgLead, CmdLine, CursorPos)
|
||||||
if stridx(a:CmdLine, "open") != -1
|
" A list of current cmd line arguments excluding leading commands like
|
||||||
let s:cfgdir = s:FindConfigDir()
|
" :vertical etc.
|
||||||
if s:cfgdir == ""
|
let s:relCmdLine = split(a:CmdLine)
|
||||||
return ""
|
let s:relCmdLine = s:relCmdLine[index(s:relCmdLine, s:Name):]
|
||||||
endif
|
|
||||||
return join(map(glob(s:cfgdir."*", 0, 1), "fnamemodify(v:val, ':t')"), "\n")
|
|
||||||
elseif stridx(a:CmdLine, "get") != -1
|
|
||||||
return ""
|
|
||||||
elseif stridx(a:CmdLine, "set") != -1
|
|
||||||
return "w\np\nf"
|
|
||||||
elseif stridx(a:CmdLine, "text") != -1
|
|
||||||
return ""
|
|
||||||
elseif stridx(a:CmdLine, "write") != -1
|
|
||||||
let s:cfgdir = s:FindConfigDir()
|
|
||||||
if s:cfgdir == ""
|
|
||||||
return ""
|
|
||||||
endif
|
|
||||||
return join(map(glob(s:cfgdir."*", 0, 1), "fnamemodify(v:val, ':t')"), "\n")
|
|
||||||
endif
|
|
||||||
|
|
||||||
return "get\nopen\nset\ntext\nwrite"
|
if stridx("open", get(s:relCmdLine, 1)) == 0
|
||||||
|
if a:ArgLead != ""
|
||||||
|
return "open"
|
||||||
|
elseif len(s:relCmdLine) > 2 " Do not return more than one name
|
||||||
|
return ""
|
||||||
|
endif
|
||||||
|
let s:cfgdir = s:FindConfigDir()
|
||||||
|
if s:cfgdir == ""
|
||||||
|
return ""
|
||||||
|
endif
|
||||||
|
return join(map(glob(s:cfgdir."*", 0, 1), "fnamemodify(v:val, ':t')"), "\n")
|
||||||
|
|
||||||
|
elseif stridx("get", get(s:relCmdLine, 1)) == 0
|
||||||
|
if a:ArgLead != ""
|
||||||
|
return "get"
|
||||||
|
endif
|
||||||
|
return ""
|
||||||
|
|
||||||
|
elseif stridx("set", get(s:relCmdLine, 1)) == 0
|
||||||
|
if a:ArgLead != ""
|
||||||
|
return "set"
|
||||||
|
endif
|
||||||
|
if stridx("-magic", get(s:relCmdLine, -1)) == 0
|
||||||
|
return "none\nemp\nfade\nflash\nwave"
|
||||||
|
endif
|
||||||
|
return "w\np\nf\n-magic"
|
||||||
|
|
||||||
|
elseif stridx("text", get(s:relCmdLine, 1)) == 0
|
||||||
|
if a:ArgLead != ""
|
||||||
|
return "text"
|
||||||
|
endif
|
||||||
|
return ""
|
||||||
|
|
||||||
|
elseif stridx("write", get(s:relCmdLine, 1)) == 0
|
||||||
|
if a:ArgLead != ""
|
||||||
|
return "write"
|
||||||
|
elseif len(s:relCmdLine) > 2 " Do not return more than one name
|
||||||
|
return ""
|
||||||
|
endif
|
||||||
|
let s:cfgdir = s:FindConfigDir()
|
||||||
|
if s:cfgdir == ""
|
||||||
|
return ""
|
||||||
|
endif
|
||||||
|
return join(map(glob(s:cfgdir."*", 0, 1), "fnamemodify(v:val, ':t')"), "\n")
|
||||||
|
|
||||||
|
elseif get(s:relCmdLine, -1) == s:Name
|
||||||
|
unlet s:relCmdLine
|
||||||
|
return "get\nopen\nset\ntext\nwrite"
|
||||||
|
else
|
||||||
|
return ""
|
||||||
|
endif
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
if !exists(":C4ctrl")
|
if !exists(":".s:Name)
|
||||||
command -nargs=+ -complete=custom,s:C4ctrlCompletion C4ctrl call C4ctrl(<f-args>)
|
execute "command -nargs=+ -complete=custom,s:C4ctrlCompletion" s:Name "call C4ctrl(<f-args>)"
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue