<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE language SYSTEM "language.dtd">
<!-- Author: Shane Wright <me@shanewright.co.uk> -->
<!-- PostgreSQL SQL, syntax definition based on sql.xml by Yury Lebedev -->
<language name="SQL-PostgreSQL" version="1.03" kateversion="2.1" section="Other" extensions="*.sql;*.SQL" mimetype="text/x-sql" casesensitive="0">
  <highlighting>
    <list name="keywords">
      <item> ABORT </item>
      <item> ACCESS </item>
      <item> ACTION </item>
      <item> ADA </item>
      <item> ADMIN </item>
      <item> AFTER </item>
      <item> AGGREGATE </item>
      <item> ALIAS </item>
      <item> ALL </item>
      <item> ALLOCATE </item>
      <item> ALTER </item>
      <item> ANALYSE </item>
      <item> ANALYZE </item>
      <item> ANY </item>
      <item> ARE </item>
      <item> AS </item>
      <item> ASC </item>
      <item> ASENSITIVE </item>
      <item> ASSERTION </item>
      <item> ASSIGNMENT </item>
      <item> ASYMMETRIC </item>
      <item> AT </item>
      <item> ATOMIC </item>
      <item> AUTHORIZATION </item>
      <item> BACKWARD </item>
      <item> BEFORE </item>
      <item> BEGIN </item>
      <item> BETWEEN </item>
      <item> BINARY </item>
      <item> BOTH </item>
      <item> BREADTH </item>
      <item> BY </item>
      <item> C </item>
      <item> CACHE </item>
      <item> CALL </item>
      <item> CALLED </item>
      <item> CARDINALITY </item>
      <item> CASCADE </item>
      <item> CASCADED </item>
      <item> CASE </item>
      <item> CAST </item>
      <item> CATALOG </item>
      <item> CATALOG_NAME </item>
      <item> CHAIN </item>
      <item> CHAR_LENGTH </item>
      <item> CHARACTER_LENGTH </item>
      <item> CHARACTER_SET_CATALOG </item>
      <item> CHARACTER_SET_NAME </item>
      <item> CHARACTER_SET_SCHEMA </item>
      <item> CHARACTERISTICS </item>
      <item> CHECK </item>
      <item> CHECKED </item>
      <item> CHECKPOINT </item>
      <item> CLASS </item>
      <item> CLASS_ORIGIN </item>
      <item> CLOB </item>
      <item> CLOSE </item>
      <item> CLUSTER </item>
      <item> COALESCE </item>
      <item> COBOL </item>
      <item> COLLATE </item>
      <item> COLLATION </item>
      <item> COLLATION_CATALOG </item>
      <item> COLLATION_NAME </item>
      <item> COLLATION_SCHEMA </item>
      <item> COLUMN </item>
      <item> COLUMN_NAME </item>
      <item> COMMAND_FUNCTION </item>
      <item> COMMAND_FUNCTION_CODE </item>
      <item> COMMENT </item>
      <item> COMMIT </item>
      <item> COMMITTED </item>
      <item> COMPLETION </item>
      <item> CONDITION_NUMBER </item>
      <item> CONNECT </item>
      <item> CONNECTION </item>
      <item> CONNECTION_NAME </item>
      <item> CONSTRAINT </item>
      <item> CONSTRAINT_CATALOG </item>
      <item> CONSTRAINT_NAME </item>
      <item> CONSTRAINT_SCHEMA </item>
      <item> CONSTRAINTS </item>
      <item> CONSTRUCTOR </item>
      <item> CONTAINS </item>
      <item> CONTINUE </item>
      <item> CONVERT </item>
      <item> COPY </item>
      <item> CORRESPONDING </item>
      <item> COUNT </item>
      <item> CREATE </item>
      <item> CREATEDB </item>
      <item> CREATEUSER </item>
      <item> CROSS </item>
      <item> CUBE </item>
      <item> CURRENT </item>
      <item> CURRENT_DATE </item>
      <item> CURRENT_PATH </item>
      <item> CURRENT_ROLE </item>
      <item> CURRENT_TIME </item>
      <item> CURRENT_TIMESTAMP </item>
      <item> CURRENT_USER </item>
      <item> CURSOR </item>
      <item> CURSOR_NAME </item>
      <item> CYCLE </item>
      <item> DATA </item>
      <item> DATABASE </item>
      <item> DATE </item>
      <item> DATETIME_INTERVAL_CODE </item>
      <item> DATETIME_INTERVAL_PRECISION </item>
      <item> DAY </item>
      <item> DEALLOCATE </item>
      <item> DEC </item>
      <item> DECIMAL </item>
      <item> DECLARE </item>
      <item> DEFAULT </item>
      <item> DEFERRABLE </item>
      <item> DEFERRED </item>
      <item> DEFINED </item>
      <item> DEFINER </item>
      <item> DELETE </item>
      <item> DELIMITERS </item>
      <item> DEPTH </item>
      <item> DEREF </item>
      <item> DESC </item>
      <item> DESCRIBE </item>
      <item> DESCRIPTOR </item>
      <item> DESTROY </item>
      <item> DESTRUCTOR </item>
      <item> DETERMINISTIC </item>
      <item> DIAGNOSTICS </item>
      <item> DICTIONARY </item>
      <item> DISCONNECT </item>
      <item> DISPATCH </item>
      <item> DISTINCT </item>
      <item> DO </item>
      <item> DOMAIN </item>
      <item> DOUBLE </item>
      <item> DROP </item>
      <item> DYNAMIC </item>
      <item> DYNAMIC_FUNCTION </item>
      <item> DYNAMIC_FUNCTION_CODE </item>
      <item> EACH </item>
      <item> ELSE </item>
      <item> ENCODING </item>
      <item> ENCRYPTED </item>
      <item> END </item>
      <item> END-EXEC </item>
      <item> EQUALS </item>
      <item> ESCAPE </item>
      <item> EVERY </item>
      <item> EXCEPT </item>
      <item> EXCEPTION </item>
      <item> EXCLUSIVE </item>
      <item> EXEC </item>
      <item> EXECUTE </item>
      <item> EXISTING </item>
      <item> EXISTS </item>
      <item> EXPLAIN </item>
      <item> EXTERNAL </item>
      <item> FETCH </item>
      <item> FINAL </item>
      <item> FIRST </item>
      <item> FOR </item>
      <item> FORCE </item>
      <item> FOREIGN </item>
      <item> FORTRAN </item>
      <item> FORWARD </item>
      <item> FOUND </item>
      <item> FREE </item>
      <item> FREEZE </item>
      <item> FROM </item>
      <item> FULL </item>
      <item> FUNCTION </item>
      <item> G </item>
      <item> GENERAL </item>
      <item> GENERATED </item>
      <item> GET </item>
      <item> GLOBAL </item>
      <item> GO </item>
      <item> GOTO </item>
      <item> GRANT </item>
      <item> GRANTED </item>
      <item> GROUP </item>
      <item> GROUPING </item>
      <item> HANDLER </item>
      <item> HAVING </item>
      <item> HIERARCHY </item>
      <item> HOLD </item>
      <item> HOST </item>
      <item> HOUR </item>
      <item> IDENTITY </item>
      <item> IGNORE </item>
      <item> ILIKE </item>
      <item> IMMEDIATE </item>
      <item> IMPLEMENTATION </item>
      <item> IN </item>
      <item> INCREMENT </item>
      <item> INDEX </item>
      <item> INDICATOR </item>
      <item> INFIX </item>
      <item> INHERITS </item>
      <item> INITIALIZE </item>
      <item> INITIALLY </item>
      <item> INNER </item>
      <item> INOUT </item>
      <item> INPUT </item>
      <item> INSENSITIVE </item>
      <item> INSERT </item>
      <item> INSTANCE </item>
      <item> INSTANTIABLE </item>
      <item> INSTEAD </item>
      <item> INTERSECT </item>
      <item> INTERVAL </item>
      <item> INTO </item>
      <item> INVOKER </item>
      <item> IS </item>
      <item> ISNULL </item>
      <item> ISOLATION </item>
      <item> ITERATE </item>
      <item> JOIN </item>
      <item> K </item>
      <item> KEY </item>
      <item> KEY_MEMBER </item>
      <item> KEY_TYPE </item>
      <item> LANCOMPILER </item>
      <item> LANGUAGE </item>
      <item> LARGE </item>
      <item> LAST </item>
      <item> LATERAL </item>
      <item> LEADING </item>
      <item> LEFT </item>
      <item> LENGTH </item>
      <item> LESS </item>
      <item> LEVEL </item>
      <item> LIKE </item>
      <item> LIMIT </item>
      <item> LISTEN </item>
      <item> LOAD </item>
      <item> LOCAL </item>
      <item> LOCALTIME </item>
      <item> LOCALTIMESTAMP </item>
      <item> LOCATION </item>
      <item> LOCATOR </item>
      <item> LOCK </item>
      <item> LOWER </item>
      <item> M </item>
      <item> MAP </item>
      <item> MATCH </item>
      <item> MAX </item>
      <item> MAXVALUE </item>
      <item> MESSAGE_LENGTH </item>
      <item> MESSAGE_OCTET_LENGTH </item>
      <item> MESSAGE_TEXT </item>
      <item> METHOD </item>
      <item> MIN </item>
      <item> MINUTE </item>
      <item> MINVALUE </item>
      <item> MOD </item>
      <item> MODE </item>
      <item> MODIFIES </item>
      <item> MODIFY </item>
      <item> MODULE </item>
      <item> MONTH </item>
      <item> MORE </item>
      <item> MOVE </item>
      <item> MUMPS </item>
      <item> NAME </item>
      <item> NAMES </item>
      <item> NATIONAL </item>
      <item> NATURAL </item>
      <item> NEW </item>
      <item> NEXT </item>
      <item> NO </item>
      <item> NOCREATEDB </item>
      <item> NOCREATEUSER </item>
      <item> NONE </item>
      <item> NOT </item>
      <item> NOTHING </item>
      <item> NOTIFY </item>
      <item> NOTNULL </item>
      <item> NULL </item>
      <item> NULLABLE </item>
      <item> NULLIF </item>
      <item> NUMBER </item>
      <item> NUMERIC </item>
      <item> OBJECT </item>
      <item> OCTET_LENGTH </item>
      <item> OF </item>
      <item> OFF </item>
      <item> OFFSET </item>
      <item> OIDS </item>
      <item> OLD </item>
      <item> ON </item>
      <item> ONLY </item>
      <item> OPEN </item>
      <item> OPERATION </item>
      <item> OPERATOR </item>
      <item> OPTION </item>
      <item> OPTIONS </item>
      <item> ORDER </item>
      <item> ORDINALITY </item>
      <item> OUT </item>
      <item> OUTER </item>
      <item> OUTPUT </item>
      <item> OVERLAPS </item>
      <item> OVERLAY </item>
      <item> OVERRIDING </item>
      <item> OWNER </item>
      <item> PAD </item>
      <item> PARAMETER </item>
      <item> PARAMETER_MODE </item>
      <item> PARAMETER_NAME </item>
      <item> PARAMETER_ORDINAL_POSITION </item>
      <item> PARAMETER_SPECIFIC_CATALOG </item>
      <item> PARAMETER_SPECIFIC_NAME </item>
      <item> PARAMETER_SPECIFIC_SCHEMA </item>
      <item> PARAMETERS </item>
      <item> PARTIAL </item>
      <item> PASCAL </item>
      <item> PASSWORD </item>
      <item> PATH </item>
      <item> PENDANT </item>
      <item> PLI </item>
      <item> POSITION </item>
      <item> POSTFIX </item>
      <item> PRECISION </item>
      <item> PREFIX </item>
      <item> PREORDER </item>
      <item> PREPARE </item>
      <item> PRESERVE </item>
      <item> PRIMARY </item>
      <item> PRIOR </item>
      <item> PRIVILEGES </item>
      <item> PROCEDURAL </item>
      <item> PROCEDURE </item>
      <item> PUBLIC </item>
      <item> READ </item>
      <item> READS </item>
      <item> REAL </item>
      <item> RECURSIVE </item>
      <item> REF </item>
      <item> REFERENCES </item>
      <item> REFERENCING </item>
      <item> REINDEX </item>
      <item> RELATIVE </item>
      <item> RENAME </item>
      <item> REPEATABLE </item>
      <item> REPLACE </item>
      <item> RESET </item>
      <item> RESTRICT </item>
      <item> RESULT </item>
      <item> RETURN </item>
      <item> RETURNED_LENGTH </item>
      <item> RETURNED_OCTET_LENGTH </item>
      <item> RETURNED_SQLSTATE </item>
      <item> RETURNS </item>
      <item> REVOKE </item>
      <item> RIGHT </item>
      <item> ROLE </item>
      <item> ROLLBACK </item>
      <item> ROLLUP </item>
      <item> ROUTINE </item>
      <item> ROUTINE_CATALOG </item>
      <item> ROUTINE_NAME </item>
      <item> ROUTINE_SCHEMA </item>
      <item> ROW </item>
      <item> ROW_COUNT </item>
      <item> ROWS </item>
      <item> RULE </item>
      <item> SAVEPOINT </item>
      <item> SCALE </item>
      <item> SCHEMA </item>
      <item> SCHEMA_NAME </item>
      <item> SCOPE </item>
      <item> SCROLL </item>
      <item> SEARCH </item>
      <item> SECOND </item>
      <item> SECTION </item>
      <item> SECURITY </item>
      <item> SELECT </item>
      <item> SELF </item>
      <item> SENSITIVE </item>
      <item> SEQUENCE </item>
      <item> SERIALIZABLE </item>
      <item> SERVER_NAME </item>
      <item> SESSION </item>
      <item> SESSION_USER </item>
      <item> SET </item>
      <item> SETOF </item>
      <item> SETS </item>
      <item> SHARE </item>
      <item> SHOW </item>
      <item> SIMILAR </item>
      <item> SIMPLE </item>
      <item> SIZE </item>
      <item> SOME </item>
      <item> SOURCE </item>
      <item> SPACE </item>
      <item> SPECIFIC </item>
      <item> SPECIFIC_NAME </item>
      <item> SPECIFICTYPE </item>
      <item> SQL </item>
      <item> SQLCODE </item>
      <item> SQLERROR </item>
      <item> SQLEXCEPTION </item>
      <item> SQLSTATE </item>
      <item> SQLWARNING </item>
      <item> START </item>
      <item> STATE </item>
      <item> STATEMENT </item>
      <item> STATIC </item>
      <item> STATISTICS </item>
      <item> STDIN </item>
      <item> STDOUT </item>
      <item> STRUCTURE </item>
      <item> STYLE </item>
      <item> SUBCLASS_ORIGIN </item>
      <item> SUBLIST </item>
      <item> SUBSTRING </item>
      <item> SUM </item>
      <item> SYMMETRIC </item>
      <item> SYSID </item>
      <item> SYSTEM </item>
      <item> SYSTEM_USER </item>
      <item> TABLE </item>
      <item> TABLE_NAME </item>
      <item> TEMP </item>
      <item> TEMPLATE </item>
      <item> TEMPORARY </item>
      <item> TERMINATE </item>
      <item> THAN </item>
      <item> THEN </item>
      <item> TIMEZONE_HOUR </item>
      <item> TIMEZONE_MINUTE </item>
      <item> TO </item>
      <item> TOAST </item>
      <item> TRAILING </item>
      <item> TRANSACTION </item>
      <item> TRANSACTION_ACTIVE </item>
      <item> TRANSACTIONS_COMMITTED </item>
      <item> TRANSACTIONS_ROLLED_BACK </item>
      <item> TRANSFORM </item>
      <item> TRANSFORMS </item>
      <item> TRANSLATE </item>
      <item> TRANSLATION </item>
      <item> TREAT </item>
      <item> TRIGGER </item>
      <item> TRIGGER_CATALOG </item>
      <item> TRIGGER_NAME </item>
      <item> TRIGGER_SCHEMA </item>
      <item> TRIM </item>
      <item> TRUNCATE </item>
      <item> TRUSTED </item>
      <item> TYPE </item>
      <item> UNCOMMITTED </item>
      <item> UNDER </item>
      <item> UNENCRYPTED </item>
      <item> UNION </item>
      <item> UNIQUE </item>
      <item> UNKNOWN </item>
      <item> UNLISTEN </item>
      <item> UNNAMED </item>
      <item> UNNEST </item>
      <item> UNTIL </item>
      <item> UPDATE </item>
      <item> UPPER </item>
      <item> USAGE </item>
      <item> USER </item>
      <item> USER_DEFINED_TYPE_CATALOG </item>
      <item> USER_DEFINED_TYPE_NAME </item>
      <item> USER_DEFINED_TYPE_SCHEMA </item>
      <item> USING </item>
      <item> VACUUM </item>
      <item> VALID </item>
      <item> VALUE </item>
      <item> VALUES </item>
      <item> VARIABLE </item>
      <item> VARYING </item>
      <item> VERBOSE </item>
      <item> VERSION </item>
      <item> VIEW </item>
      <item> WHEN </item>
      <item> WHENEVER </item>
      <item> WHERE </item>
      <item> WITH </item>
      <item> WITHOUT </item>
      <item> WORK </item>
      <item> WRITE </item>
      <item> YEAR </item>
      <item> ZONE </item>
      <item> FALSE </item>
      <item> TRUE </item>
    </list>
  <list name="operators">
      <item> + </item>
      <item> - </item>
      <item> * </item>
      <item> / </item>
      <item> || </item>
      <item> |/ </item>
      <item> ||/ </item>
      <item> ! </item>
      <item> !! </item>
      <item> @ </item>
      <item> &amp; </item>
      <item> | </item>
      <item> # </item>
      <item> &lt;&lt; </item>
      <item> &gt;&gt; </item>
      <item> % </item>
      <item> ^ </item>
      <item> = </item>
      <item> != </item>
      <item> &lt;&gt; </item>
      <item> &lt; </item>
      <item> &lt;= </item>
      <item> &gt; </item>
      <item> &gt;= </item>
      <item> ~ </item>
      <item> ~* </item>
      <item> !~ </item>
      <item> !~* </item>
      <item> ^= </item>
      <item> := </item>
      <item> =&gt; </item>
      <item> ** </item>
      <item> .. </item>
      <item> AND </item>
      <item> OR </item>
      <item> NOT </item>
      <!-- geometric -->
      <item> ## </item>
      <item> &amp;&amp; </item>
      <item> &amp;&lt; </item>
      <item> &amp;&gt; </item>
      <item> &lt;-&gt; </item>
      <item> &lt;^ </item>
      <item> &gt;^ </item>
      <item> ?# </item>
      <item> ?- </item>
      <item> ?-| </item>
      <item> @-@ </item>
      <item> ?| </item>
      <item> ?|| </item>
      <item> @@ </item>
      <item> ~= </item>
      <!-- network address type -->
      <item> &lt;&lt;= </item>
      <item> &gt;&gt;= </item>
   </list>
     <list name="functions">
      <!-- math -->
      <item> ABS </item>
      <item> CBRT </item>
      <item> CEIL </item>
      <item> DEGREES </item>
      <item> EXP </item>
      <item> FLOOR </item>
      <item> LN </item>
      <item> LOG </item>
      <item> MOD </item>
      <item> PI </item>
      <item> POW </item>
      <item> RADIANS </item>
      <item> RANDOM </item>
      <item> ROUND </item>
      <item> SIGN </item>
      <item> SQRT </item>
      <item> TRUNC </item>
      <!-- trig -->
      <item> ACOS </item>
      <item> ASIN </item>
      <item> ATAN </item>
      <item> ATAN2 </item>
      <item> COS </item>
      <item> COT </item>
      <item> SIN </item>
      <item> TAN </item>
      <!-- string -->
      <item> BIT_LENGTH </item>
      <item> CHAR_LENGTH </item>
      <item> CHARACTER_LENGTH </item>
      <item> LOWER </item>
      <item> OCTET_LENGTH </item>
      <item> POSITION </item>
      <item> SUBSTRING </item>
      <item> TRIM </item>
      <item> UPPER </item>
      <!-- other string -->
      <item> ASCII </item>
      <item> BTRIM </item>
      <item> CHR </item>
      <item> CONVERT </item>
      <item> INITCAP </item>
      <item> LENGTH </item>
      <item> LPAD </item>
      <item> LTRIM </item>
      <item> PG_CLIENT_ENCODING </item>
      <item> REPEAT </item>
      <item> RPAD </item>
      <item> RTRIM </item>
      <item> STRPOS </item>
      <item> SUBSTR </item>
      <item> TO_ASCII </item>
      <item> TRANSLATE </item>
      <item> ENCODE </item>
      <item> DECODE </item>
      <!-- data type formatting -->
      <item> TO_CHAR </item>
      <item> TO_DATE </item>
      <item> TO_TIMESTAMP </item>
      <item> TO_NUMBER </item>
      <!-- date/time -->
      <item> AGE </item>
      <item> DATE_PART </item>
      <item> DATE_TRUNC </item>
      <item> EXTRACT </item>
      <item> ISFINITE </item>
      <item> NOW </item>
      <item> TIMEOFDAY </item>
      <item> TIMESTAMP </item>
      <item> EXTRACT </item>
      <!-- geometric -->
      <item> AREA </item>
      <item> BOX </item>
      <item> CENTER </item>
      <item> DIAMETER </item>
      <item> HEIGHT </item>
      <item> ISCLOSED </item>
      <item> ISOPEN </item>
      <item> PCLOSE </item>
      <item> NPOINT </item>
      <item> POPEN </item>
      <item> RADIUS </item>
      <item> WIDTH </item>
      <!-- geometric type conversion -->
      <item> BOX </item>
      <item> CIRCLE </item>
      <item> LSEG </item>
      <item> PATH </item>
      <item> POINT </item>
      <item> POLYGON </item>
      <!-- network address type, TEXT is omitted as its more commonly a data type -->
      <item> BROADCAST </item>
      <item> HOST </item>
      <item> MASKLEN </item>
      <item> SET_MASKLEN </item>
      <item> NETMASK </item>
      <item> NETWORK </item>
      <item> ABBREV </item>
      <!-- sequence manipulation -->
      <item> NEXTVAL </item>
      <item> CURRVAL </item>
      <item> SETVAL </item>
      <!-- conditional expressions -->
      <item> COALESCE </item>
      <item> NULLIF </item>
      <!-- misc -->
      <item> HAS_TABLE_PRIVILEGE </item>
      <item> PG_GET_VIEWDEF </item>
      <item> PG_GET_RULEDEF </item>
      <item> PG_GET_INDEXDEF </item>
      <item> PG_GET_USERBYID </item>
      <item> OBJ_DESCRIPTION </item>
      <item> COL_DESCRIPTION </item>
      <!-- aggregate -->
      <item> AVG </item>
      <item> COUNT </item>
      <item> MAX </item>
      <item> MIN </item>
      <item> STDDEV </item>
      <item> SUM </item>
      <item> VARIANCE </item>
    </list>
    <list name="types">
      <item> LZTEXT </item>
      <item> BIGINT </item>
      <item> INT2 </item>
      <item> INT8 </item>
      <item> BIGSERIAL </item>
      <item> SERIAL8 </item>
      <item> BIT </item>
      <item> BIT VARYING </item>
      <item> VARBIT </item>
      <item> BOOLEAN </item>
      <item> BOOL </item>
      <item> BOX </item>
      <item> BYTEA </item>
      <item> CHARACTER </item>
      <item> CHAR </item>
      <item> CHARACTER VARYING </item>
      <item> VARCHAR </item>
      <item> CIDR </item>
      <item> CIRCLE </item>
      <item> DATE </item>
      <item> DOUBLE PRECISION </item>
      <item> FLOAT8 </item>
      <item> INET </item>
      <item> INTEGER </item>
      <item> INT </item>
      <item> INT4 </item>
      <item> INTERVAL </item>
      <item> LINE </item>
      <item> LSEG </item>
      <item> MACADDR </item>
      <item> MONEY </item>
      <item> NUMERIC </item>
      <item> DECIMAL </item>
      <item> OID </item>
      <item> PATH </item>
      <item> POINT </item>
      <item> POLYGON </item>
      <item> REAL </item>
      <item> SMALLINT </item>
      <item> SERIAL </item>
      <item> TEXT </item>
      <item> TIME </item>
      <item> TIMETZ </item>
      <item> TIMESTAMP </item>
      <item> TIMESTAMPTZ </item>
    </list>
    <contexts>
      <context name="Normal" attribute="Normal Text" lineEndContext="#stay">
        <keyword attribute="Keyword" context="#stay" String="keywords"/>
        <keyword attribute="Operator" context="#stay" String="operators"/>
        <keyword attribute="Function" context="#stay" String="functions"/>
        <keyword attribute="Data Type" context="#stay" String="types"/>
        <RegExpr attribute="Data Type" context="#stay" String="%[Bb][Uu][Ll][Kk]_[Ee][Xx][Cc][Ee][Pp][Tt][Ii][Oo][Nn][Ss]\b"/>
        <RegExpr attribute="Data Type" context="#stay" String="%[Bb][Uu][Ll][Kk]_[Rr][Oo][Ww][Cc][Oo][Uu][Nn][Tt]\b"/>
        <RegExpr attribute="Data Type" context="#stay" String="%[Ff][Oo][Uu][Nn][Dd]\b"/>
        <RegExpr attribute="Data Type" context="#stay" String="%[Ii][Ss][Oo][Pp][Ee][Nn]\b"/>
        <RegExpr attribute="Data Type" context="#stay" String="%[Nn][Oo][Tt][Ff][Oo][Uu][Nn][Dd]\b"/>
        <RegExpr attribute="Data Type" context="#stay" String="%[Rr][Oo][Ww][Cc][Oo][Uu][Nn][Tt]\b"/>
        <RegExpr attribute="Data Type" context="#stay" String="%[Rr][Oo][Ww][Tt][Yy][Pp][Ee]\b"/>
        <RegExpr attribute="Data Type" context="#stay" String="%[Tt][Yy][Pp][Ee]\b"/>
        <Float attribute="Float" context="#stay"/>
        <Int attribute="Decimal" context="#stay"/>
        <DetectChar attribute="String" context="String" char="'"/>
        <DetectChar attribute="Comment" context="SingleLineComment" char="#"/>
        <Detect2Chars attribute="Comment" context="SingleLineComment" char="-" char1="-"/>
        <Detect2Chars attribute="Comment" context="MultiLineComment" char="/" char1="*" beginRegion="Comment"/>
        <RegExpr attribute="Comment" context="SingleLineComment" String="^[Rr][Ee][Mm]\b"/>
        <DetectChar attribute="Comment" context="Identifier" char="&quot;"/>
        <AnyChar attribute="Symbol" context="#stay" String=":&#38;"/>
        <RegExpr attribute="Symbol" context="#stay" String="^/$"/>
        <RegExpr attribute="Preprocessor" context="Preprocessor" String="^@@?[^@ \t\r\n]"/>
      </context>
      <context name="String" attribute="String" lineEndContext="#stay">
        <LineContinue attribute="String" context="#pop"/>
        <HlCStringChar attribute="String Char" context="#stay"/>
        <DetectChar attribute="Symbol" context="#stay" char="&#38;"/>
        <DetectChar attribute="String" context="#pop" char="'"/>
      </context>
      <context name="SingleLineComment" attribute="Comment" lineEndContext="#pop"/>
      <context name="MultiLineComment" attribute="Comment" lineEndContext="#stay">
        <LineContinue attribute="Comment" context="#pop"/>
        <Detect2Chars attribute="Comment" context="#pop" char="*" char1="/" endRegion="Comment"/>
      </context>
      <context name="Identifier" attribute="Identifier" lineEndContext="#pop">
        <DetectChar attribute="Identifier" context="#pop" char="&quot;"/>
      </context>
      <context name="Preprocessor" attribute="Preprocessor" lineEndContext="#pop"/>
    </contexts>
    <itemDatas>
      <itemData name="Normal Text" defStyleNum="dsNormal"/>
      <itemData name="Keyword" defStyleNum="dsKeyword"/>
      <itemData name="Operator" defStyleNum="dsNormal"/>
      <itemData name="Function" defStyleNum="dsKeyword"/>
      <itemData name="Data Type" defStyleNum="dsDataType"/>
      <itemData name="Decimal"  defStyleNum="dsDecVal"/>
      <itemData name="Float"  defStyleNum="dsFloat"/>
      <itemData name="String" defStyleNum="dsString"/>
      <itemData name="String Char" defStyleNum="dsChar"/>
      <itemData name="Comment" defStyleNum="dsComment"/>
      <itemData name="Identifier" defStyleNum="dsOthers"/>
      <itemData name="Symbol"  defStyleNum="dsChar"/>
      <itemData name="Preprocessor" defStyleNum="dsOthers"/>
    </itemDatas>
  </highlighting>
  <general>
    <comments>
      <comment name="singleLine" start="--"/>
      <comment name="multiLine" start="/*" end="*/"/>
    </comments>
    <keywords casesensitive="0"/>
  </general>
</language>
