xref: /vim-8.2.3635/runtime/ftplugin/vhdl.vim (revision f1568eca)
1f740b29aSBram Moolenaar" VHDL filetype plugin
2748bf037SBram Moolenaar" Language:    VHDL
3*f1568ecaSBram Moolenaar" Maintainer:  R.Shankar <shankar.pec?gmail.com>
4f740b29aSBram Moolenaar" Modified By: Gerald Lai <laigera+vim?gmail.com>
5*f1568ecaSBram Moolenaar" Last Change: 2011 Dec 11
6748bf037SBram Moolenaar
7748bf037SBram Moolenaar" Only do this when not done yet for this buffer
8748bf037SBram Moolenaarif exists("b:did_ftplugin")
9748bf037SBram Moolenaar  finish
10748bf037SBram Moolenaarendif
11748bf037SBram Moolenaar
12748bf037SBram Moolenaar" Don't load another plugin for this buffer
13748bf037SBram Moolenaarlet b:did_ftplugin = 1
14748bf037SBram Moolenaar
15*f1568ecaSBram Moolenaarlet s:cpo_save = &cpo
16*f1568ecaSBram Moolenaarset cpo&vim
17*f1568ecaSBram Moolenaar
18748bf037SBram Moolenaar" Set 'formatoptions' to break comment lines but not other lines,
19748bf037SBram Moolenaar" and insert the comment leader when hitting <CR> or using "o".
20748bf037SBram Moolenaar"setlocal fo-=t fo+=croqlm1
21748bf037SBram Moolenaar
22748bf037SBram Moolenaar" Set 'comments' to format dashed lists in comments.
23748bf037SBram Moolenaar"setlocal comments=sO:*\ -,mO:*\ \ ,exO:*/,s1:/*,mb:*,ex:*/,://
24748bf037SBram Moolenaar
25748bf037SBram Moolenaar" Format comments to be up to 78 characters long
26f740b29aSBram Moolenaar"setlocal tw=75
27748bf037SBram Moolenaar
28748bf037SBram Moolenaar" Win32 can filter files in the browse dialog
29748bf037SBram Moolenaar"if has("gui_win32") && !exists("b:browsefilter")
30748bf037SBram Moolenaar"  let b:browsefilter = "Verilog Source Files (*.v)\t*.v\n" .
31748bf037SBram Moolenaar"   \ "All Files (*.*)\t*.*\n"
32748bf037SBram Moolenaar"endif
33748bf037SBram Moolenaar
34748bf037SBram Moolenaar" Let the matchit plugin know what items can be matched.
35748bf037SBram Moolenaarif ! exists("b:match_words")  &&  exists("loaded_matchit")
36748bf037SBram Moolenaar  let b:match_ignorecase=1
37748bf037SBram Moolenaar  let s:notend = '\%(\<end\s\+\)\@<!'
38748bf037SBram Moolenaar  let b:match_words =
39f740b29aSBram Moolenaar    \ s:notend.'\<if\>:\<elsif\>:\<else\>:\<end\s\+if\>,'.
40f740b29aSBram Moolenaar    \ s:notend.'\<case\>:\<when\>:\<end\s\+case\>,'.
41f740b29aSBram Moolenaar    \ s:notend.'\<loop\>:\<end\s\+loop\>,'.
42f740b29aSBram Moolenaar    \ s:notend.'\<for\>:\<end\s\+for\>,'.
43f740b29aSBram Moolenaar    \ s:notend.'\<generate\>:\<end\s\+generate\>,'.
44f740b29aSBram Moolenaar    \ s:notend.'\<record\>:\<end\s\+record\>,'.
45f740b29aSBram Moolenaar    \ s:notend.'\<units\>:\<end\s\+units\>,'.
46f740b29aSBram Moolenaar    \ s:notend.'\<process\>:\<end\s\+process\>,'.
47f740b29aSBram Moolenaar    \ s:notend.'\<block\>:\<end\s\+block\>,'.
48f740b29aSBram Moolenaar    \ s:notend.'\<function\>:\<end\s\+function\>,'.
49f740b29aSBram Moolenaar    \ s:notend.'\<entity\>:\<end\s\+entity\>,'.
50f740b29aSBram Moolenaar    \ s:notend.'\<component\>:\<end\s\+component\>,'.
51f740b29aSBram Moolenaar    \ s:notend.'\<architecture\>:\<end\s\+architecture\>,'.
52f740b29aSBram Moolenaar    \ s:notend.'\<package\>:\<end\s\+package\>,'.
53f740b29aSBram Moolenaar    \ s:notend.'\<procedure\>:\<end\s\+procedure\>,'.
54f740b29aSBram Moolenaar    \ s:notend.'\<configuration\>:\<end\s\+configuration\>'
55748bf037SBram Moolenaarendif
56f740b29aSBram Moolenaar
57f740b29aSBram Moolenaar" count repeat
58f740b29aSBram Moolenaarfunction! <SID>CountWrapper(cmd)
59f740b29aSBram Moolenaar  let i = v:count1
60f740b29aSBram Moolenaar  if a:cmd[0] == ":"
61f740b29aSBram Moolenaar    while i > 0
62f740b29aSBram Moolenaar      execute a:cmd
63f740b29aSBram Moolenaar      let i = i - 1
64f740b29aSBram Moolenaar    endwhile
65f740b29aSBram Moolenaar  else
66f740b29aSBram Moolenaar    execute "normal! gv\<Esc>"
67f740b29aSBram Moolenaar    execute "normal ".i.a:cmd
68f740b29aSBram Moolenaar    let curcol = col(".")
69f740b29aSBram Moolenaar    let curline = line(".")
70f740b29aSBram Moolenaar    normal! gv
71f740b29aSBram Moolenaar    call cursor(curline, curcol)
72f740b29aSBram Moolenaar  endif
73f740b29aSBram Moolenaarendfunction
74f740b29aSBram Moolenaar
75f740b29aSBram Moolenaar" explore motion
76f740b29aSBram Moolenaar" keywords: "architecture", "block", "configuration", "component", "entity", "function", "package", "procedure", "process", "record", "units"
77f740b29aSBram Moolenaarlet b:vhdl_explore = '\%(architecture\|block\|configuration\|component\|entity\|function\|package\|procedure\|process\|record\|units\)'
78f740b29aSBram Moolenaarnoremap  <buffer><silent>[[ :<C-u>cal <SID>CountWrapper(':cal search("\\%(--.*\\)\\@<!\\%(\\<end\\s\\+\\)\\@<!\\<".b:vhdl_explore."\\>\\c\\<Bar>\\%^","bW")')<CR>
79f740b29aSBram Moolenaarnoremap  <buffer><silent>]] :<C-u>cal <SID>CountWrapper(':cal search("\\%(--.*\\)\\@<!\\%(\\<end\\s\\+\\)\\@<!\\<".b:vhdl_explore."\\>\\c\\<Bar>\\%$","W")')<CR>
80f740b29aSBram Moolenaarnoremap  <buffer><silent>[] :<C-u>cal <SID>CountWrapper(':cal search("\\%(--.*\\)\\@<!\\<end\\s\\+".b:vhdl_explore."\\>\\c\\<Bar>\\%^","bW")')<CR>
81f740b29aSBram Moolenaarnoremap  <buffer><silent>][ :<C-u>cal <SID>CountWrapper(':cal search("\\%(--.*\\)\\@<!\\<end\\s\\+".b:vhdl_explore."\\>\\c\\<Bar>\\%$","W")')<CR>
82f740b29aSBram Moolenaarvnoremap <buffer><silent>[[ :<C-u>cal <SID>CountWrapper('[[')<CR>
83f740b29aSBram Moolenaarvnoremap <buffer><silent>]] :<C-u>cal <SID>CountWrapper(']]')<CR>
84f740b29aSBram Moolenaarvnoremap <buffer><silent>[] :<C-u>cal <SID>CountWrapper('[]')<CR>
85f740b29aSBram Moolenaarvnoremap <buffer><silent>][ :<C-u>cal <SID>CountWrapper('][')<CR>
86*f1568ecaSBram Moolenaar
87*f1568ecaSBram Moolenaarlet &cpo = s:cpo_save
88*f1568ecaSBram Moolenaarunlet s:cpo_save
89