diff options
Diffstat (limited to 'ftplugin')
| -rw-r--r-- | ftplugin/context.vim | 106 | ||||
| -rw-r--r-- | ftplugin/docker-compose.vim | 2 | ||||
| -rw-r--r-- | ftplugin/dockerfile.vim | 20 | ||||
| -rw-r--r-- | ftplugin/man.vim | 254 | 
4 files changed, 381 insertions, 1 deletions
| diff --git a/ftplugin/context.vim b/ftplugin/context.vim new file mode 100644 index 00000000..2e68ecfc --- /dev/null +++ b/ftplugin/context.vim @@ -0,0 +1,106 @@ +if !exists('g:polyglot_disabled') || index(g:polyglot_disabled, 'context') == -1 + +" Vim filetype plugin file +" Language:           ConTeXt typesetting engine +" Maintainer:         Nicola Vitacolonna <nvitacolonna@gmail.com> +" Former Maintainers: Nikolai Weibull <now@bitwi.se> +" Latest Revision:    2016 Oct 30 + +if exists("b:did_ftplugin") +  finish +endif +let b:did_ftplugin = 1 + +let s:cpo_save = &cpo +set cpo&vim + +if !exists('current_compiler') +  compiler context +endif + +let b:undo_ftplugin = "setl com< cms< def< inc< sua< fo< ofu<" +      \ . "| unlet! b:match_ignorecase b:match_words b:match_skip" + +setlocal comments=b:%D,b:%C,b:%M,:% commentstring=%\ %s formatoptions+=tjcroql2 +if get(b:, 'context_metapost', get(g:, 'context_metapost', 1)) +  setlocal omnifunc=contextcomplete#Complete +  let g:omni_syntax_group_include_context = 'mf\w\+,mp\w\+' +  let g:omni_syntax_group_exclude_context = 'mfTodoComment' +endif + +let &l:define='\\\%([egx]\|char\|mathchar\|count\|dimen\|muskip\|skip\|toks\)\=' +        \ .     'def\|\\font\|\\\%(future\)\=let' +        \ . '\|\\new\%(count\|dimen\|skip\|muskip\|box\|toks\|read\|write' +        \ .     '\|fam\|insert\|if\)' + +let &l:include = '^\s*\\\%(input\|component\|product\|project\|environment\)' + +setlocal suffixesadd=.tex + +if exists("loaded_matchit") +  let b:match_ignorecase = 0 +  let b:match_skip = 'r:\\\@<!\%(\\\\\)*%' +  let b:match_words = '(:),\[:],{:},\\(:\\),\\\[:\\],' . +        \ '\\start\(\a\+\):\\stop\1' +endif + +let s:context_regex = { +      \ 'beginsection' : '\\\%(start\)\=\%(\%(sub\)*section\|\%(sub\)*subject\|chapter\|part\|component\|product\|title\)\>', +      \ 'endsection'   : '\\\%(stop\)\=\%(\%(sub\)*section\|\%(sub\)*subject\|chapter\|part\|component\|product\|title\)\>', +      \ 'beginblock'   : '\\\%(start\|setup\|define\)', +      \ 'endblock'     : '\\\%(stop\|setup\|define\)' +      \ } + +function! s:move_around(count, what, flags, visual) +  if a:visual +    exe "normal! gv" +  endif +  call search(s:context_regex[a:what], a:flags.'s') " 's' sets previous context mark +  call map(range(2, a:count), 'search(s:context_regex[a:what], a:flags)') +endfunction + +" Move around macros. +nnoremap <silent><buffer> [[ :<C-U>call <SID>move_around(v:count1, "beginsection", "bW", v:false) <CR> +vnoremap <silent><buffer> [[ :<C-U>call <SID>move_around(v:count1, "beginsection", "bW", v:true)  <CR> +nnoremap <silent><buffer> ]] :<C-U>call <SID>move_around(v:count1, "beginsection", "W",  v:false) <CR> +vnoremap <silent><buffer> ]] :<C-U>call <SID>move_around(v:count1, "beginsection", "W",  v:true)  <CR> +nnoremap <silent><buffer> [] :<C-U>call <SID>move_around(v:count1, "endsection",   "bW", v:false) <CR> +vnoremap <silent><buffer> [] :<C-U>call <SID>move_around(v:count1, "endsection",   "bW", v:true)  <CR> +nnoremap <silent><buffer> ][ :<C-U>call <SID>move_around(v:count1, "endsection",   "W",  v:false) <CR> +vnoremap <silent><buffer> ][ :<C-U>call <SID>move_around(v:count1, "endsection",   "W",  v:true)  <CR> +nnoremap <silent><buffer> [{ :<C-U>call <SID>move_around(v:count1, "beginblock",   "bW", v:false) <CR> +vnoremap <silent><buffer> [{ :<C-U>call <SID>move_around(v:count1, "beginblock",   "bW", v:true)  <CR> +nnoremap <silent><buffer> ]} :<C-U>call <SID>move_around(v:count1, "endblock",     "W",  v:false) <CR> +vnoremap <silent><buffer> ]} :<C-U>call <SID>move_around(v:count1, "endblock",     "W",  v:true)  <CR> + +" Other useful mappings +if get(g:, 'context_mappings', 1) +  let s:tp_regex = '?^$\|^\s*\\\(item\|start\|stop\|blank\|\%(sub\)*section\|chapter\|\%(sub\)*subject\|title\|part\)' + +  fun! s:tp() +    call cursor(search(s:tp_regex, 'bcW') + 1, 1) +    normal! V +    call cursor(search(s:tp_regex, 'W') - 1, 1) +  endf + +  " Reflow paragraphs with commands like gqtp ("gq TeX paragraph") +  onoremap <silent><buffer> tp :<c-u>call <sid>tp()<cr> +  " Select TeX paragraph +  vnoremap <silent><buffer> tp <esc>:<c-u>call <sid>tp()<cr> + +  " $...$ text object +  onoremap <silent><buffer> i$ :<c-u>normal! T$vt$<cr> +  onoremap <silent><buffer> a$ :<c-u>normal! F$vf$<cr> +  vnoremap <buffer> i$ T$ot$ +  vnoremap <buffer> a$ F$of$ +endif + +" Commands for asynchronous typesetting +command! -buffer -nargs=? -complete=file ConTeXt          call context#typeset(<q-args>) +command!         -nargs=0                ConTeXtJobStatus call context#job_status() +command!         -nargs=0                ConTeXtStopJobs  call context#stop_jobs() + +let &cpo = s:cpo_save +unlet s:cpo_save + +endif diff --git a/ftplugin/docker-compose.vim b/ftplugin/docker-compose.vim index 82896b05..e80041e2 100644 --- a/ftplugin/docker-compose.vim +++ b/ftplugin/docker-compose.vim @@ -1,4 +1,4 @@ -if !exists('g:polyglot_disabled') || index(g:polyglot_disabled, 'dockerfile') == -1 +if !exists('g:polyglot_disabled') || index(g:polyglot_disabled, 'docker-compose') == -1  " Define comment string  setlocal commentstring=#\ %s diff --git a/ftplugin/dockerfile.vim b/ftplugin/dockerfile.vim new file mode 100644 index 00000000..3780119a --- /dev/null +++ b/ftplugin/dockerfile.vim @@ -0,0 +1,20 @@ +if !exists('g:polyglot_disabled') || index(g:polyglot_disabled, 'dockerfile') == -1 + +" Vim filetype plugin +" Language:	Dockerfile +" Maintainer:   Honza Pokorny <http://honza.ca> +" Last Change:	2014 Aug 29 + +" Only do this when not done yet for this buffer +if exists("b:did_ftplugin") +  finish +endif + +" Don't load another plugin for this buffer +let b:did_ftplugin = 1 + +let b:undo_ftplugin = "setl commentstring<" + +setlocal commentstring=#\ %s + +endif diff --git a/ftplugin/man.vim b/ftplugin/man.vim new file mode 100644 index 00000000..300129c2 --- /dev/null +++ b/ftplugin/man.vim @@ -0,0 +1,254 @@ +if !exists('g:polyglot_disabled') || index(g:polyglot_disabled, 'man') == -1 + +" Vim filetype plugin file +" Language:	man +" Maintainer:	Jason Franklin <vim@justemail.net> +" Maintainer:	SungHyun Nam <goweol@gmail.com> +" Last Change: 	2020 Jun 01 + +" To make the ":Man" command available before editing a manual page, source +" this script from your startup vimrc file. + +" If 'filetype' isn't "man", we must have been called to only define ":Man". +if &filetype == "man" + +  " Only do this when not done yet for this buffer +  if exists("b:did_ftplugin") +    finish +  endif +  let b:did_ftplugin = 1 +endif + +let s:cpo_save = &cpo +set cpo-=C + +if &filetype == "man" +  " allow dot and dash in manual page name. +  setlocal iskeyword+=\.,- +  let b:undo_ftplugin = "setlocal iskeyword<" + +  " Add mappings, unless the user didn't want this. +  if !exists("no_plugin_maps") && !exists("no_man_maps") +    if !hasmapto('<Plug>ManBS') +      nmap <buffer> <LocalLeader>h <Plug>ManBS +      let b:undo_ftplugin = b:undo_ftplugin +	    \ . '|silent! nunmap <buffer> <LocalLeader>h' +    endif +    nnoremap <buffer> <Plug>ManBS :%s/.\b//g<CR>:setl nomod<CR>'' + +    nnoremap <buffer> <silent> <c-]> :call <SID>PreGetPage(v:count)<CR> +    nnoremap <buffer> <silent> <c-t> :call <SID>PopPage()<CR> +    nnoremap <buffer> <silent> q :q<CR> + +    " Add undo commands for the maps +    let b:undo_ftplugin = b:undo_ftplugin +	  \ . '|silent! nunmap <buffer> <Plug>ManBS' +	  \ . '|silent! nunmap <buffer> <c-]>' +	  \ . '|silent! nunmap <buffer> <c-t>' +	  \ . '|silent! nunmap <buffer> q' +  endif + +  if exists('g:ft_man_folding_enable') && (g:ft_man_folding_enable == 1) +    setlocal foldmethod=indent foldnestmax=1 foldenable +    let b:undo_ftplugin = b:undo_ftplugin +	  \ . '|silent! setl fdm< fdn< fen<' +  endif + +endif + +if exists(":Man") != 2 +  com -nargs=+ -complete=shellcmd Man call s:GetPage(<q-mods>, <f-args>) +  nmap <Leader>K :call <SID>PreGetPage(0)<CR> +  nmap <Plug>ManPreGetPage :call <SID>PreGetPage(0)<CR> +endif + +" Define functions only once. +if !exists("s:man_tag_depth") + +let s:man_tag_depth = 0 + +let s:man_sect_arg = "" +let s:man_find_arg = "-w" +try +  if !has("win32") && $OSTYPE !~ 'cygwin\|linux' && system('uname -s') =~ "SunOS" && system('uname -r') =~ "^5" +    let s:man_sect_arg = "-s" +    let s:man_find_arg = "-l" +  endif +catch /E145:/ +  " Ignore the error in restricted mode +endtry + +func <SID>PreGetPage(cnt) +  if a:cnt == 0 +    let old_isk = &iskeyword +    if &ft == 'man' +      setl iskeyword+=(,) +    endif +    let str = expand("<cword>") +    let &l:iskeyword = old_isk +    let page = substitute(str, '(*\(\k\+\).*', '\1', '') +    let sect = substitute(str, '\(\k\+\)(\([^()]*\)).*', '\2', '') +    if match(sect, '^[0-9 ]\+$') == -1 +      let sect = "" +    endif +    if sect == page +      let sect = "" +    endif +  else +    let sect = a:cnt +    let page = expand("<cword>") +  endif +  call s:GetPage('', sect, page) +endfunc + +func <SID>GetCmdArg(sect, page) +  if a:sect == '' +    return a:page +  endif +  return s:man_sect_arg.' '.a:sect.' '.a:page +endfunc + +func <SID>FindPage(sect, page) +  let where = system("man ".s:man_find_arg.' '.s:GetCmdArg(a:sect, a:page)) +  if where !~ "^/" +    if matchstr(where, " [^ ]*$") !~ "^ /" +      return 0 +    endif +  endif +  return 1 +endfunc + +func <SID>GetPage(cmdmods, ...) +  if a:0 >= 2 +    let sect = a:1 +    let page = a:2 +  elseif a:0 >= 1 +    let sect = "" +    let page = a:1 +  else +    return +  endif + +  " To support:	    nmap K :Man <cword> +  if page == '<cword>' +    let page = expand('<cword>') +  endif + +  if !exists('g:ft_man_no_sect_fallback') || (g:ft_man_no_sect_fallback == 0) +    if sect != "" && s:FindPage(sect, page) == 0 +      let sect = "" +    endif +  endif +  if s:FindPage(sect, page) == 0 +    let msg = 'man.vim: no manual entry for "' . page . '"' +    if !empty(sect) +      let msg .= ' in section ' . sect +    endif +    echomsg msg +    return +  endif +  exec "let s:man_tag_buf_".s:man_tag_depth." = ".bufnr("%") +  exec "let s:man_tag_lin_".s:man_tag_depth." = ".line(".") +  exec "let s:man_tag_col_".s:man_tag_depth." = ".col(".") +  let s:man_tag_depth = s:man_tag_depth + 1 + +  let open_cmd = 'edit' + +  " Use an existing "man" window if it exists, otherwise open a new one. +  if &filetype != "man" +    let thiswin = winnr() +    exe "norm! \<C-W>b" +    if winnr() > 1 +      exe "norm! " . thiswin . "\<C-W>w" +      while 1 +	if &filetype == "man" +	  break +	endif +	exe "norm! \<C-W>w" +	if thiswin == winnr() +	  break +	endif +      endwhile +    endif +    if &filetype != "man" +      if exists("g:ft_man_open_mode") +        if g:ft_man_open_mode == 'vert' +	  let open_cmd = 'vsplit' +        elseif g:ft_man_open_mode == 'tab' +	  let open_cmd = 'tabedit' +        else +	  let open_cmd = 'split' +        endif +      else +	let open_cmd = a:cmdmods . ' split' +      endif +    endif +  endif + +  silent execute open_cmd . " $HOME/" . page . '.' . sect . '~' + +  " Avoid warning for editing the dummy file twice +  setl buftype=nofile noswapfile + +  setl fdc=0 ma nofen nonu nornu +  %delete _ +  let unsetwidth = 0 +  if empty($MANWIDTH) +    let $MANWIDTH = winwidth(0) +    let unsetwidth = 1 +  endif + +  " Ensure Vim is not recursively invoked (man-db does this) when doing ctrl-[ +  " on a man page reference by unsetting MANPAGER. +  " Some versions of env(1) do not support the '-u' option, and in such case +  " we set MANPAGER=cat. +  if !exists('s:env_has_u') +    call system('env -u x true') +    let s:env_has_u = (v:shell_error == 0) +  endif +  let env_cmd = s:env_has_u ? 'env -u MANPAGER' : 'env MANPAGER=cat' +  let env_cmd .= ' GROFF_NO_SGR=1' +  let man_cmd = env_cmd . ' man ' . s:GetCmdArg(sect, page) . ' | col -b' +  silent exec "r !" . man_cmd + +  if unsetwidth +    let $MANWIDTH = '' +  endif +  " Remove blank lines from top and bottom. +  while line('$') > 1 && getline(1) =~ '^\s*$' +    1delete _ +  endwhile +  while line('$') > 1 && getline('$') =~ '^\s*$' +    $delete _ +  endwhile +  1 +  setl ft=man nomod +  setl bufhidden=hide +  setl nobuflisted +  setl noma +endfunc + +func <SID>PopPage() +  if s:man_tag_depth > 0 +    let s:man_tag_depth = s:man_tag_depth - 1 +    exec "let s:man_tag_buf=s:man_tag_buf_".s:man_tag_depth +    exec "let s:man_tag_lin=s:man_tag_lin_".s:man_tag_depth +    exec "let s:man_tag_col=s:man_tag_col_".s:man_tag_depth +    exec s:man_tag_buf."b" +    exec s:man_tag_lin +    exec "norm! ".s:man_tag_col."|" +    exec "unlet s:man_tag_buf_".s:man_tag_depth +    exec "unlet s:man_tag_lin_".s:man_tag_depth +    exec "unlet s:man_tag_col_".s:man_tag_depth +    unlet s:man_tag_buf s:man_tag_lin s:man_tag_col +  endif +endfunc + +endif + +let &cpo = s:cpo_save +unlet s:cpo_save + +" vim: set sw=2 ts=8 noet: + +endif | 
