mirror of
https://github.com/vim/vim.git
synced 2025-08-25 19:53:53 -04:00
closes: #17871 Signed-off-by: Maxim Kim <habamax@gmail.com> Signed-off-by: Christian Brabandt <cb@256bit.org>
213 lines
7.7 KiB
VimL
213 lines
7.7 KiB
VimL
" Vim filetype plugin
|
|
" Language: Vim
|
|
" Maintainer: Doug Kearns <dougkearns@gmail.com>
|
|
" Former Maintainer: Bram Moolenaar <Bram@vim.org>
|
|
" Contributors: Riley Bruins <ribru17@gmail.com> ('commentstring'),
|
|
" @Konfekt
|
|
" @tpope (s:Help())
|
|
" @lacygoill
|
|
" Last Change: 2025 Mar 05
|
|
" 2025 Aug 06 by Vim Project (add gf maps #17881)
|
|
" 2025 Aug 08 by Vim Project (add vimscript complete function #17871)
|
|
|
|
" 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< omnifunc<
|
|
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> ["
|
|
silent! nunmap <buffer> gf
|
|
silent! nunmap <buffer> <C-W>f
|
|
silent! nunmap <buffer> <C-W>gf
|
|
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)
|
|
|
|
if has("vim9script")
|
|
" set omnifunc completion
|
|
setlocal omnifunc=vimcomplete#Complete
|
|
endif
|
|
|
|
" 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>
|
|
|
|
" Purpose: Handle `:import` and `:packadd` lines in a smarter way. {{{
|
|
"
|
|
" `:import` is followed by a filename or filepath. Find it.
|
|
"
|
|
" `:packadd` is followed by the name of a package, which we might have
|
|
" configured in scripts under `~/.vim/plugin`. Find it.
|
|
"
|
|
" ---
|
|
"
|
|
" We can't handle the `:import` lines simply by setting `'includeexpr'`, because
|
|
" the option would be ignored if:
|
|
"
|
|
" - the name of the imported script is the same as the current one
|
|
" - `'path'` includes the `.` item
|
|
"
|
|
" Indeed, in that case, Vim finds the current file, and simply reloads the
|
|
" buffer.
|
|
" }}}
|
|
" We use the `F` variants, instead of the `f` ones, because they're smarter.
|
|
nnoremap <silent><buffer> gf :<C-U>call vim#Find('gF')<CR>
|
|
nnoremap <silent><buffer> <C-W>f :<C-U>call vim#Find("\<lt>C-W>F")<CR>
|
|
nnoremap <silent><buffer> <C-W>gf :<C-U>call vim#Find("\<lt>C-W>gF")<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
|