| " Vim filetype plugin |
| " Language: Vim |
| " Maintainer: Doug Kearns <dougkearns@gmail.com> |
| " Last Change: 2025 Mar 05 |
| " Former Maintainer: Bram Moolenaar <Bram@vim.org> |
| " Contributors: Riley Bruins <ribru17@gmail.com> ('commentstring'), |
| " @Konfekt |
| " @tpope (s:Help()) |
| |
| " 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 s:cpo_save = &cpo |
| set cpo&vim |
| |
| if !exists('*VimFtpluginUndo') |
| func VimFtpluginUndo() |
| setl fo< isk< com< tw< commentstring< include< define< keywordprg< |
| sil! delc -buffer VimKeywordPrg |
| if exists('b:did_add_maps') |
| silent! nunmap <buffer> [[ |
| silent! xunmap <buffer> [[ |
| silent! nunmap <buffer> ]] |
| silent! xunmap <buffer> ]] |
| silent! nunmap <buffer> [] |
| silent! xunmap <buffer> [] |
| silent! nunmap <buffer> ][ |
| silent! xunmap <buffer> ][ |
| silent! nunmap <buffer> ]" |
| silent! xunmap <buffer> ]" |
| silent! nunmap <buffer> [" |
| silent! xunmap <buffer> [" |
| endif |
| unlet! b:match_ignorecase b:match_words b:match_skip b:did_add_maps |
| endfunc |
| endif |
| |
| let b:undo_ftplugin = "call VimFtpluginUndo()" |
| |
| " Set 'formatoptions' to break comment lines but not other lines, |
| " and insert the comment leader when hitting <CR> or using "o". |
| setlocal fo-=t fo+=croql |
| |
| " To allow tag lookup via CTRL-] for autoload functions, '#' must be a |
| " keyword character. E.g., for netrw#Nread(). |
| setlocal isk+=# |
| |
| " Use :help to lookup the keyword under the cursor with K. |
| " Distinguish between commands, options and functions. |
| if !exists("*" .. expand("<SID>") .. "Help") |
| function s:Help(topic) abort |
| let topic = a:topic |
| |
| if get(g:, 'syntax_on', 0) |
| let syn = synIDattr(synID(line('.'), col('.'), 1), 'name') |
| if syn ==# 'vimFuncName' |
| return topic.'()' |
| elseif syn ==# 'vimOption' |
| return "'".topic."'" |
| elseif syn ==# 'vimUserAttrbKey' |
| return ':command-'.topic |
| elseif syn =~# 'vimCommand' |
| return ':'.topic |
| endif |
| endif |
| |
| let col = col('.') - 1 |
| while col && getline('.')[col] =~# '\k' |
| let col -= 1 |
| endwhile |
| let pre = col == 0 ? '' : getline('.')[0 : col] |
| |
| let col = col('.') - 1 |
| while col && getline('.')[col] =~# '\k' |
| let col += 1 |
| endwhile |
| let post = getline('.')[col : -1] |
| |
| if pre =~# '^\s*:\=$' |
| return ':'.topic |
| elseif pre =~# '\<v:$' |
| return 'v:'.topic |
| elseif pre =~# '<$' |
| return '<'.topic.'>' |
| elseif pre =~# '\\$' |
| return '/\'.topic |
| elseif topic ==# 'v' && post =~# ':\w\+' |
| return 'v'.matchstr(post, ':\w\+') |
| else |
| return topic |
| endif |
| endfunction |
| endif |
| command! -buffer -nargs=1 VimKeywordPrg :exe 'help' s:Help(<q-args>) |
| setlocal keywordprg=:VimKeywordPrg |
| |
| " Comments starts with # in Vim9 script. We have to guess which one to use. |
| if "\n" .. getline(1, 32)->join("\n") =~# '\n\s*vim9\%[script]\>' |
| setlocal commentstring=#\ %s |
| else |
| setlocal commentstring=\"%s |
| endif |
| |
| " Set 'comments' to format dashed lists in comments, both in Vim9 and legacy |
| " script. |
| setlocal com=sO:#\ -,mO:#\ \ ,eO:##,:#\\\ ,:#,sO:\"\ -,mO:\"\ \ ,eO:\"\",:\"\\\ ,:\" |
| |
| " set 'include' to recognize import commands |
| setlocal include=\\v^\\s*import\\s*(autoload)? |
| |
| " set 'define' to recognize export commands |
| setlocal define=\\v^\\s*export\\s*(def\|const\|var\|final) |
| |
| " Format comments to be up to 78 characters long |
| if &tw == 0 |
| setlocal tw=78 |
| endif |
| |
| if !exists("no_plugin_maps") && !exists("no_vim_maps") |
| let b:did_add_maps = 1 |
| |
| " Move around functions. |
| nnoremap <silent><buffer> [[ m':call search('^\s*\(fu\%[nction]\\|\(export\s\+\)\?def\)\>', "bW")<CR> |
| xnoremap <silent><buffer> [[ m':<C-U>exe "normal! gv"<Bar>call search('^\s*\(fu\%[nction]\\|\(export\s\+\)\?def\)\>', "bW")<CR> |
| nnoremap <silent><buffer> ]] m':call search('^\s*\(fu\%[nction]\\|\(export\s\+\)\?def\)\>', "W")<CR> |
| xnoremap <silent><buffer> ]] m':<C-U>exe "normal! gv"<Bar>call search('^\s*\(fu\%[nction]\\|\(export\s\+\)\?def\)\>', "W")<CR> |
| nnoremap <silent><buffer> [] m':call search('^\s*end\(f\%[unction]\\|\(export\s\+\)\?def\)\>', "bW")<CR> |
| xnoremap <silent><buffer> [] m':<C-U>exe "normal! gv"<Bar>call search('^\s*end\(f\%[unction]\\|\(export\s\+\)\?def\)\>', "bW")<CR> |
| nnoremap <silent><buffer> ][ m':call search('^\s*end\(f\%[unction]\\|\(export\s\+\)\?def\)\>', "W")<CR> |
| xnoremap <silent><buffer> ][ m':<C-U>exe "normal! gv"<Bar>call search('^\s*end\(f\%[unction]\\|\(export\s\+\)\?def\)\>', "W")<CR> |
| |
| " Move around comments |
| nnoremap <silent><buffer> ]" :call search('\%(^\s*".*\n\)\@<!\%(^\s*"\)', "W")<CR> |
| xnoremap <silent><buffer> ]" :<C-U>exe "normal! gv"<Bar>call search('\%(^\s*".*\n\)\@<!\%(^\s*"\)', "W")<CR> |
| nnoremap <silent><buffer> [" :call search('\%(^\s*".*\n\)\%(^\s*"\)\@!', "bW")<CR> |
| xnoremap <silent><buffer> [" :<C-U>exe "normal! gv"<Bar>call search('\%(^\s*".*\n\)\%(^\s*"\)\@!', "bW")<CR> |
| endif |
| |
| " Let the matchit plugin know what items can be matched. |
| if exists("loaded_matchit") |
| let b:match_ignorecase = 0 |
| " "func" can also be used as a type: |
| " var Ref: func |
| " or to list functions: |
| " func name |
| " require a parenthesis following, then there can be an "endfunc". |
| let b:match_words = |
| \ '\<\%(fu\%[nction]\|def\)!\=\s\+\S\+\s*(:\%(\%(^\||\)\s*\)\@<=\<retu\%[rn]\>:\%(\%(^\||\)\s*\)\@<=\<\%(endf\%[unction]\|enddef\)\>,' .. |
| \ '\<\%(wh\%[ile]\|for\)\>:\%(\%(^\||\)\s*\)\@<=\<brea\%[k]\>:\%(\%(^\||\)\s*\)\@<=\<con\%[tinue]\>:\%(\%(^\||\)\s*\)\@<=\<end\%(w\%[hile]\|fo\%[r]\)\>,' .. |
| \ '\<if\>:\%(\%(^\||\)\s*\)\@<=\<el\%[seif]\>:\%(\%(^\||\)\s*\)\@<=\<en\%[dif]\>,' .. |
| \ '{:},' .. |
| \ '\<try\>:\%(\%(^\||\)\s*\)\@<=\<cat\%[ch]\>:\%(\%(^\||\)\s*\)\@<=\<fina\%[lly]\>:\%(\%(^\||\)\s*\)\@<=\<endt\%[ry]\>,' .. |
| \ '\<aug\%[roup]\s\+\%(END\>\)\@!\S:\<aug\%[roup]\s\+END\>,' .. |
| \ '\<class\>:\<endclass\>,' .. |
| \ '\<interface\>:\<endinterface\>,' .. |
| \ '\<enum\>:\<endenum\>' |
| |
| " Ignore syntax region commands and settings, any 'en*' would clobber |
| " if-endif. |
| " - set spl=de,en |
| " - au! FileType javascript syntax region foldBraces start=/{/ end=/}/ … |
| " Also ignore here-doc and dictionary keys (vimVar). |
| let b:match_skip = 'synIDattr(synID(line("."), col("."), 1), "name") |
| \ =~? "comment\\|string\\|vimSynReg\\|vimSet\\|vimLetHereDoc\\|vimVar"' |
| endif |
| |
| let &cpo = s:cpo_save |
| unlet s:cpo_save |
| |
| " removed this, because 'cpoptions' is a global option. |
| " setlocal cpo+=M " makes \%( match \) |
| " |
| " vim: sw=2 et |