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