1. <lexer>
    
  2.   <config>
    
  3.     <name>MySQL</name>
    
  4.     <alias>mysql</alias>
    
  5.     <alias>mariadb</alias>
    
  6.     <filename>*.sql</filename>
    
  7.     <mime_type>text/x-mysql</mime_type>
    
  8.     <mime_type>text/x-mariadb</mime_type>
    
  9.     <case_insensitive>true</case_insensitive>
    
  10.     <not_multiline>true</not_multiline>
    
  11.   </config>
    
  12.   <rules>
    
  13.     <state name="string">
    
  14.       <rule pattern="[^&#39;]+">
    
  15.         <token type="LiteralStringSingle"/>
    
  16.       </rule>
    
  17.       <rule pattern="&#39;&#39;">
    
  18.         <token type="LiteralStringSingle"/>
    
  19.       </rule>
    
  20.       <rule pattern="&#39;">
    
  21.         <token type="LiteralStringSingle"/>
    
  22.         <pop depth="1"/>
    
  23.       </rule>
    
  24.     </state>
    
  25.     <state name="double-string">
    
  26.       <rule pattern="[^&#34;]+">
    
  27.         <token type="LiteralStringDouble"/>
    
  28.       </rule>
    
  29.       <rule pattern="&#34;&#34;">
    
  30.         <token type="LiteralStringDouble"/>
    
  31.       </rule>
    
  32.       <rule pattern="&#34;">
    
  33.         <token type="LiteralStringDouble"/>
    
  34.         <pop depth="1"/>
    
  35.       </rule>
    
  36.     </state>
    
  37.     <state name="root">
    
  38.       <rule pattern="\s+">
    
  39.         <token type="TextWhitespace"/>
    
  40.       </rule>
    
  41.       <rule pattern="(#|--\s+).*\n?">
    
  42.         <token type="CommentSingle"/>
    
  43.       </rule>
    
  44.       <rule pattern="/\*">
    
  45.         <token type="CommentMultiline"/>
    
  46.         <push state="multiline-comments"/>
    
  47.       </rule>
    
  48.       <rule pattern="[0-9]+">
    
  49.         <token type="LiteralNumberInteger"/>
    
  50.       </rule>
    
  51.       <rule pattern="[0-9]*\.[0-9]+(e[+-][0-9]+)">
    
  52.         <token type="LiteralNumberFloat"/>
    
  53.       </rule>
    
  54.       <rule pattern="((?:_[a-z0-9]+)?)(&#39;)">
    
  55.         <bygroups>
    
  56.           <token type="LiteralStringAffix"/>
    
  57.           <token type="LiteralStringSingle"/>
    
  58.         </bygroups>
    
  59.         <push state="string"/>
    
  60.       </rule>
    
  61.       <rule pattern="((?:_[a-z0-9]+)?)(&#34;)">
    
  62.         <bygroups>
    
  63.           <token type="LiteralStringAffix"/>
    
  64.           <token type="LiteralStringDouble"/>
    
  65.         </bygroups>
    
  66.         <push state="double-string"/>
    
  67.       </rule>
    
  68.       <rule pattern="[+*/&lt;&gt;=~!@#%^&amp;|`?-]">
    
  69.         <token type="Operator"/>
    
  70.       </rule>
    
  71.       <rule pattern="\b(tinyint|smallint|mediumint|int|integer|bigint|date|datetime|time|bit|bool|tinytext|mediumtext|longtext|text|tinyblob|mediumblob|longblob|blob|float|double|double\s+precision|real|numeric|dec|decimal|timestamp|year|char|varchar|varbinary|varcharacter|enum|set)(\b\s*)(\()?">
    
  72.         <bygroups>
    
  73.           <token type="KeywordType"/>
    
  74.           <token type="TextWhitespace"/>
    
  75.           <token type="Punctuation"/>
    
  76.         </bygroups>
    
  77.       </rule>
    
  78.       <rule pattern="\b(add|all|alter|analyze|and|as|asc|asensitive|before|between|bigint|binary|blob|both|by|call|cascade|case|change|char|character|check|collate|column|condition|constraint|continue|convert|create|cross|current_date|current_time|current_timestamp|current_user|cursor|database|databases|day_hour|day_microsecond|day_minute|day_second|dec|decimal|declare|default|delayed|delete|desc|describe|deterministic|distinct|distinctrow|div|double|drop|dual|each|else|elseif|enclosed|escaped|exists|exit|explain|fetch|flush|float|float4|float8|for|force|foreign|from|fulltext|grant|group|having|high_priority|hour_microsecond|hour_minute|hour_second|identified|if|ignore|in|index|infile|inner|inout|insensitive|insert|int|int1|int2|int3|int4|int8|integer|interval|into|is|iterate|join|key|keys|kill|leading|leave|left|like|limit|lines|load|localtime|localtimestamp|lock|long|loop|low_priority|match|minute_microsecond|minute_second|mod|modifies|natural|no_write_to_binlog|not|numeric|on|optimize|option|optionally|or|order|out|outer|outfile|precision|primary|privileges|procedure|purge|raid0|read|reads|real|references|regexp|release|rename|repeat|replace|require|restrict|return|revoke|right|rlike|schema|schemas|second_microsecond|select|sensitive|separator|set|show|smallint|soname|spatial|specific|sql|sql_big_result|sql_calc_found_rows|sql_small_result|sqlexception|sqlstate|sqlwarning|ssl|starting|straight_join|table|terminated|then|to|trailing|trigger|undo|union|unique|unlock|unsigned|update|usage|use|user|using|utc_date|utc_time|utc_timestamp|values|varying|when|where|while|with|write|x509|xor|year_month|zerofill)\b">
    
  79.         <token type="Keyword"/>
    
  80.       </rule>
    
  81.       <rule pattern="\b(auto_increment|engine|charset|tables)\b">
    
  82.         <token type="KeywordPseudo"/>
    
  83.       </rule>
    
  84.       <rule pattern="(true|false|null)">
    
  85.         <token type="NameConstant"/>
    
  86.       </rule>
    
  87.       <rule pattern="([a-z_]\w*)(\s*)(\()">
    
  88.         <bygroups>
    
  89.           <token type="NameFunction"/>
    
  90.           <token type="TextWhitespace"/>
    
  91.           <token type="Punctuation"/>
    
  92.         </bygroups>
    
  93.       </rule>
    
  94.       <rule pattern="[a-z_]\w*">
    
  95.         <token type="Name"/>
    
  96.       </rule>
    
  97.       <rule pattern="@[a-z0-9]*[._]*[a-z0-9]*">
    
  98.         <token type="NameVariable"/>
    
  99.       </rule>
    
  100.       <rule pattern="[;:()\[\],.]">
    
  101.         <token type="Punctuation"/>
    
  102.       </rule>
    
  103.     </state>
    
  104.     <state name="multiline-comments">
    
  105.       <rule pattern="/\*">
    
  106.         <token type="CommentMultiline"/>
    
  107.         <push state="multiline-comments"/>
    
  108.       </rule>
    
  109.       <rule pattern="\*/">
    
  110.         <token type="CommentMultiline"/>
    
  111.         <pop depth="1"/>
    
  112.       </rule>
    
  113.       <rule pattern="[^/*]+">
    
  114.         <token type="CommentMultiline"/>
    
  115.       </rule>
    
  116.       <rule pattern="[/*]">
    
  117.         <token type="CommentMultiline"/>
    
  118.       </rule>
    
  119.     </state>
    
  120.   </rules>
    
  121. </lexer>