" Vim filetype plugin " Language: Vim " Maintainer: Doug Kearns " Last Change: 2025 Mar 05 " Former Maintainer: Bram Moolenaar " Contributors: Riley Bruins ('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 [[ silent! xunmap [[ silent! nunmap ]] silent! xunmap ]] silent! nunmap [] silent! xunmap [] silent! nunmap ][ silent! xunmap ][ silent! nunmap ]" silent! xunmap ]" silent! nunmap [" silent! xunmap [" 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 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("") .. "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 =~# '\' 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() 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 [[ m':call search('^\s*\(fu\%[nction]\\|\(export\s\+\)\?def\)\>', "bW") xnoremap [[ m':exe "normal! gv"call search('^\s*\(fu\%[nction]\\|\(export\s\+\)\?def\)\>', "bW") nnoremap ]] m':call search('^\s*\(fu\%[nction]\\|\(export\s\+\)\?def\)\>', "W") xnoremap ]] m':exe "normal! gv"call search('^\s*\(fu\%[nction]\\|\(export\s\+\)\?def\)\>', "W") nnoremap [] m':call search('^\s*end\(f\%[unction]\\|\(export\s\+\)\?def\)\>', "bW") xnoremap [] m':exe "normal! gv"call search('^\s*end\(f\%[unction]\\|\(export\s\+\)\?def\)\>', "bW") nnoremap ][ m':call search('^\s*end\(f\%[unction]\\|\(export\s\+\)\?def\)\>', "W") xnoremap ][ m':exe "normal! gv"call search('^\s*end\(f\%[unction]\\|\(export\s\+\)\?def\)\>', "W") " Move around comments nnoremap ]" :call search('\%(^\s*".*\n\)\@ xnoremap ]" :exe "normal! gv"call search('\%(^\s*".*\n\)\@ nnoremap [" :call search('\%(^\s*".*\n\)\%(^\s*"\)\@!', "bW") xnoremap [" :exe "normal! gv"call search('\%(^\s*".*\n\)\%(^\s*"\)\@!', "bW") 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*\)\@<=\:\%(\%(^\||\)\s*\)\@<=\<\%(endf\%[unction]\|enddef\)\>,' .. \ '\<\%(wh\%[ile]\|for\)\>:\%(\%(^\||\)\s*\)\@<=\:\%(\%(^\||\)\s*\)\@<=\:\%(\%(^\||\)\s*\)\@<=\,' .. \ '\:\%(\%(^\||\)\s*\)\@<=\:\%(\%(^\||\)\s*\)\@<=\,' .. \ '{:},' .. \ '\:\%(\%(^\||\)\s*\)\@<=\:\%(\%(^\||\)\s*\)\@<=\:\%(\%(^\||\)\s*\)\@<=\,' .. \ '\\)\@!\S:\,' .. \ '\:\,' .. \ '\:\,' .. \ '\:\' " 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