1. <lexer>
    
  2.   <config>
    
  3.     <name>VHDL</name>
    
  4.     <alias>vhdl</alias>
    
  5.     <filename>*.vhdl</filename>
    
  6.     <filename>*.vhd</filename>
    
  7.     <mime_type>text/x-vhdl</mime_type>
    
  8.     <case_insensitive>true</case_insensitive>
    
  9.   </config>
    
  10.   <rules>
    
  11.     <state name="root">
    
  12.       <rule pattern="\n">
    
  13.         <token type="Text"/>
    
  14.       </rule>
    
  15.       <rule pattern="\s+">
    
  16.         <token type="Text"/>
    
  17.       </rule>
    
  18.       <rule pattern="\\\n">
    
  19.         <token type="Text"/>
    
  20.       </rule>
    
  21.       <rule pattern="--.*?$">
    
  22.         <token type="CommentSingle"/>
    
  23.       </rule>
    
  24.       <rule pattern="&#39;(U|X|0|1|Z|W|L|H|-)&#39;">
    
  25.         <token type="LiteralStringChar"/>
    
  26.       </rule>
    
  27.       <rule pattern="[~!%^&amp;*+=|?:&lt;&gt;/-]">
    
  28.         <token type="Operator"/>
    
  29.       </rule>
    
  30.       <rule pattern="&#39;[a-z_]\w*">
    
  31.         <token type="NameAttribute"/>
    
  32.       </rule>
    
  33.       <rule pattern="[()\[\],.;\&#39;]">
    
  34.         <token type="Punctuation"/>
    
  35.       </rule>
    
  36.       <rule pattern="&#34;[^\n\\&#34;]*&#34;">
    
  37.         <token type="LiteralString"/>
    
  38.       </rule>
    
  39.       <rule pattern="(library)(\s+)([a-z_]\w*)">
    
  40.         <bygroups>
    
  41.           <token type="Keyword"/>
    
  42.           <token type="Text"/>
    
  43.           <token type="NameNamespace"/>
    
  44.         </bygroups>
    
  45.       </rule>
    
  46.       <rule pattern="(use)(\s+)(entity)">
    
  47.         <bygroups>
    
  48.           <token type="Keyword"/>
    
  49.           <token type="Text"/>
    
  50.           <token type="Keyword"/>
    
  51.         </bygroups>
    
  52.       </rule>
    
  53.       <rule pattern="(use)(\s+)([a-z_][\w.]*\.)(all)">
    
  54.         <bygroups>
    
  55.           <token type="Keyword"/>
    
  56.           <token type="Text"/>
    
  57.           <token type="NameNamespace"/>
    
  58.           <token type="Keyword"/>
    
  59.         </bygroups>
    
  60.       </rule>
    
  61.       <rule pattern="(use)(\s+)([a-z_][\w.]*)">
    
  62.         <bygroups>
    
  63.           <token type="Keyword"/>
    
  64.           <token type="Text"/>
    
  65.           <token type="NameNamespace"/>
    
  66.         </bygroups>
    
  67.       </rule>
    
  68.       <rule pattern="(std|ieee)(\.[a-z_]\w*)">
    
  69.         <bygroups>
    
  70.           <token type="NameNamespace"/>
    
  71.           <token type="NameNamespace"/>
    
  72.         </bygroups>
    
  73.       </rule>
    
  74.       <rule pattern="(ieee|work|std)\b">
    
  75.         <token type="NameNamespace"/>
    
  76.       </rule>
    
  77.       <rule pattern="(entity|component)(\s+)([a-z_]\w*)">
    
  78.         <bygroups>
    
  79.           <token type="Keyword"/>
    
  80.           <token type="Text"/>
    
  81.           <token type="NameClass"/>
    
  82.         </bygroups>
    
  83.       </rule>
    
  84.       <rule pattern="(architecture|configuration)(\s+)([a-z_]\w*)(\s+)(of)(\s+)([a-z_]\w*)(\s+)(is)">
    
  85.         <bygroups>
    
  86.           <token type="Keyword"/>
    
  87.           <token type="Text"/>
    
  88.           <token type="NameClass"/>
    
  89.           <token type="Text"/>
    
  90.           <token type="Keyword"/>
    
  91.           <token type="Text"/>
    
  92.           <token type="NameClass"/>
    
  93.           <token type="Text"/>
    
  94.           <token type="Keyword"/>
    
  95.         </bygroups>
    
  96.       </rule>
    
  97.       <rule pattern="([a-z_]\w*)(:)(\s+)(process|for)">
    
  98.         <bygroups>
    
  99.           <token type="NameClass"/>
    
  100.           <token type="Operator"/>
    
  101.           <token type="Text"/>
    
  102.           <token type="Keyword"/>
    
  103.         </bygroups>
    
  104.       </rule>
    
  105.       <rule pattern="(end)(\s+)">
    
  106.         <bygroups>
    
  107.           <token type="Keyword"/>
    
  108.           <token type="Text"/>
    
  109.         </bygroups>
    
  110.         <push state="endblock"/>
    
  111.       </rule>
    
  112.       <rule>
    
  113.         <include state="types"/>
    
  114.       </rule>
    
  115.       <rule>
    
  116.         <include state="keywords"/>
    
  117.       </rule>
    
  118.       <rule>
    
  119.         <include state="numbers"/>
    
  120.       </rule>
    
  121.       <rule pattern="[a-z_]\w*">
    
  122.         <token type="Name"/>
    
  123.       </rule>
    
  124.     </state>
    
  125.     <state name="endblock">
    
  126.       <rule>
    
  127.         <include state="keywords"/>
    
  128.       </rule>
    
  129.       <rule pattern="[a-z_]\w*">
    
  130.         <token type="NameClass"/>
    
  131.       </rule>
    
  132.       <rule pattern="(\s+)">
    
  133.         <token type="Text"/>
    
  134.       </rule>
    
  135.       <rule pattern=";">
    
  136.         <token type="Punctuation"/>
    
  137.         <pop depth="1"/>
    
  138.       </rule>
    
  139.     </state>
    
  140.     <state name="types">
    
  141.       <rule pattern="(std_ulogic_vector|file_open_status|std_logic_vector|severity_level|file_open_kind|delay_length|std_ulogic|bit_vector|character|std_logic|positive|unsigned|boolean|natural|integer|signed|string|time|bit)\b">
    
  142.         <token type="KeywordType"/>
    
  143.       </rule>
    
  144.     </state>
    
  145.     <state name="keywords">
    
  146.       <rule pattern="(configuration|architecture|disconnect|attribute|transport|postponed|procedure|component|function|variable|severity|constant|generate|register|inertial|package|library|guarded|linkage|generic|subtype|process|literal|record|entity|others|shared|signal|downto|access|assert|return|reject|buffer|impure|select|elsif|inout|until|label|range|group|units|begin|array|alias|after|block|while|null|next|file|when|wait|open|nand|exit|then|case|port|type|loop|else|pure|with|xnor|body|not|rem|bus|rol|ror|xor|abs|end|and|sla|sll|sra|srl|all|out|nor|mod|map|for|new|use|or|on|of|in|if|is|to)\b">
    
  147.         <token type="Keyword"/>
    
  148.       </rule>
    
  149.     </state>
    
  150.     <state name="numbers">
    
  151.       <rule pattern="\d{1,2}#[0-9a-f_]+#?">
    
  152.         <token type="LiteralNumberInteger"/>
    
  153.       </rule>
    
  154.       <rule pattern="\d+">
    
  155.         <token type="LiteralNumberInteger"/>
    
  156.       </rule>
    
  157.       <rule pattern="(\d+\.\d*|\.\d+|\d+)E[+-]?\d+">
    
  158.         <token type="LiteralNumberFloat"/>
    
  159.       </rule>
    
  160.       <rule pattern="X&#34;[0-9a-f_]+&#34;">
    
  161.         <token type="LiteralNumberHex"/>
    
  162.       </rule>
    
  163.       <rule pattern="O&#34;[0-7_]+&#34;">
    
  164.         <token type="LiteralNumberOct"/>
    
  165.       </rule>
    
  166.       <rule pattern="B&#34;[01_]+&#34;">
    
  167.         <token type="LiteralNumberBin"/>
    
  168.       </rule>
    
  169.     </state>
    
  170.   </rules>
    
  171. </lexer>