diff options
| author | Mehmet Samet Duman <yongdohyun@projecttick.org> | 2026-04-04 12:41:27 +0300 |
|---|---|---|
| committer | Mehmet Samet Duman <yongdohyun@projecttick.org> | 2026-04-04 12:41:27 +0300 |
| commit | 4f2d36194b4f299aa7509d815c07121039ea833b (patch) | |
| tree | f3ded014bad3a4c76ff6a22b8726ebaab68c3d13 /mnv/runtime/ftplugin/mnv.mnv | |
| parent | 5b578e70c314723a3cde5c9bfc2be0bf1dadc93b (diff) | |
| download | Project-Tick-4f2d36194b4f299aa7509d815c07121039ea833b.tar.gz Project-Tick-4f2d36194b4f299aa7509d815c07121039ea833b.zip | |
NOISSUE change uvim folder name to mnv
Signed-off-by: Mehmet Samet Duman <yongdohyun@projecttick.org>
Diffstat (limited to 'mnv/runtime/ftplugin/mnv.mnv')
| -rw-r--r-- | mnv/runtime/ftplugin/mnv.mnv | 224 |
1 files changed, 224 insertions, 0 deletions
diff --git a/mnv/runtime/ftplugin/mnv.mnv b/mnv/runtime/ftplugin/mnv.mnv new file mode 100644 index 0000000000..9daf7a20ab --- /dev/null +++ b/mnv/runtime/ftplugin/mnv.mnv @@ -0,0 +1,224 @@ +" MNV filetype plugin +" Language: MNV +" Maintainer: Doug Kearns <dougkearns@gmail.com> +" Former Maintainer: Bram Moolenaar <Bram@mnv.org> +" Contributors: Riley Bruins <ribru17@gmail.com> ('commentstring') +" @Konfekt +" @tpope (s:Help()) +" @lacygoill +" Last Change: 2025 Aug 07 +" 2025 Aug 06 by MNV Project (add gf maps #17881) +" 2025 Aug 08 by MNV Project (add MNV script complete function #17871) +" 2025 Aug 12 by MNV Project (improve mnvgoto script #17970)) +" 2025 Aug 16 by MNV Project set com depending on MNV9 or legacy script +" 2026 Jan 26 by MNV Project set path to common MNV directories #19219 +" 2026 Feb 03 by MNV Project update s:Help to improve detecting functions #19320 + +" 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&mnv + +if !exists('*MNVFtpluginUndo') + func MNVFtpluginUndo() + setl fo< isk< com< tw< commentstring< include< define< keywordprg< omnifunc< path< + sil! delc -buffer MNVKeywordPrg + 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 MNVFtpluginUndo()" + +" 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 + + " keyword is not necessarily under the cursor, see :help K + let line = getline('.') + let i = match(line, '\V' .. escape(topic, '\'), col('.') - len(topic)) + let pre = strpart(line, 0, i) + let post = strpart(line, i + len(topic)) + + " local/global option vars + if topic =~# '[lg]' && pre ==# '&' && post =~# ':\k\+' + let topic = matchstr(post, '\k\+') + endif + + if get(g:, 'syntax_on', 0) + let syn = synIDattr(synID(line('.'), col('.'), 1), 'name') + if syn ==# 'mnvFuncName' + return topic .. '()' + elseif syn ==# 'mnvOption' || syn ==# 'mnvOptionVarName' + return "'" .. topic .. "'" + elseif syn ==# 'mnvUserCmdAttrKey' + return ':command-' .. topic + elseif syn ==# 'mnvCommand' + return ':' .. topic + endif + endif + + if stridx(post, '(') == 0 + return topic .. '()' + elseif pre =~# '^\s*:\=$' || 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\+') + elseif pre =~# '&\%([lg]:\)\=$' + return "'" .. topic .. "'" + else + return topic + endif + endfunction +endif +command! -buffer -nargs=1 MNVKeywordPrg :exe 'help' s:Help(<q-args>) +setlocal keywordprg=:MNVKeywordPrg + +" Comments starts with # in MNV9 script. We have to guess which one to use. +if "\n" .. getline(1, 32)->join("\n") =~# '\n\s*mnv9\%[script]\>' + setlocal commentstring=#\ %s + " Set 'comments' to format dashed lists in comments, for MNV9 script. + setlocal com=sO:#\ -,mO:#\ \ ,eO:##,:#\\\ ,:# +else + setlocal commentstring=\"%s + " Set 'comments' to format dashed lists in comments, for legacy MNV script. + setlocal com=sO:\"\ -,mO:\"\ \ ,eO:\"\",:\"\\\ ,:\" +endif + +" 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("mnv9script") + " set omnifunc completion + setlocal omnifunc=mnvcomplete#Complete +endif + +" Format comments to be up to 78 characters long +if &tw == 0 + setlocal tw=78 +endif + +" set 'path' to common MNV directories +setlocal path-=/usr/include +setlocal path+=pack/**,runtime/**,autoload/**,colors/**,compiler/**,ftplugin/**,indent/**,keymap/**,macros/**,plugin/**,syntax/**,after/** + +if !exists("no_plugin_maps") && !exists("no_mnv_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, :colorscheme 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 `~/.mnv/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, MNV finds the current file, and simply reloads the + " buffer. + " }}} + " We use the `F` variants, instead of the `f` ones, because they're smarter. + " See $MNVRUNTIME/autoload/mnvgoto.mnv + nnoremap <silent><buffer> gf :<C-U>call mnvgoto#Find('gF')<CR> + nnoremap <silent><buffer> <C-W>f :<C-U>call mnvgoto#Find("\<lt>C-W>F")<CR> + nnoremap <silent><buffer> <C-W>gf :<C-U>call mnvgoto#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 (mnvVar). + let b:match_skip = 'synIDattr(synID(line("."), col("."), 1), "name") + \ =~? "comment\\|string\\|mnvSynReg\\|mnvSet\\|mnvLetHereDoc\\|mnvVar"' +endif + +let &cpo = s:cpo_save +unlet s:cpo_save + +" removed this, because 'cpoptions' is a global option. +" setlocal cpo+=M " makes \%( match \) +" +" mnv: sw=2 et |
