@canopycanopycanopy/b-ber-markdown-renderer 3.0.0 → 3.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/highlightjs/highlight.js +50 -201
- package/dist/highlightjs/index.js +1 -1
- package/dist/highlightjs/languages/1c.js +91 -46
- package/dist/highlightjs/languages/accesslog.js +10 -5
- package/dist/highlightjs/languages/ada.js +26 -12
- package/dist/highlightjs/languages/angelscript.js +12 -5
- package/dist/highlightjs/languages/applescript.js +1 -4
- package/dist/highlightjs/languages/arcade.js +1 -4
- package/dist/highlightjs/languages/armasm.js +35 -16
- package/dist/highlightjs/languages/asciidoc.js +42 -21
- package/dist/highlightjs/languages/autohotkey.js +2 -2
- package/dist/highlightjs/languages/autoit.js +82 -82
- package/dist/highlightjs/languages/avrasm.js +7 -9
- package/dist/highlightjs/languages/bash.js +9 -5
- package/dist/highlightjs/languages/bnf.js +6 -3
- package/dist/highlightjs/languages/cal.js +0 -3
- package/dist/highlightjs/languages/capnproto.js +0 -2
- package/dist/highlightjs/languages/ceylon.js +4 -7
- package/dist/highlightjs/languages/clojure.js +2 -1
- package/dist/highlightjs/languages/cmake.js +10 -5
- package/dist/highlightjs/languages/coffeescript.js +10 -10
- package/dist/highlightjs/languages/cos.js +6 -2
- package/dist/highlightjs/languages/cpp.js +4 -4
- package/dist/highlightjs/languages/crystal.js +0 -4
- package/dist/highlightjs/languages/cs.js +4 -2
- package/dist/highlightjs/languages/d.js +34 -29
- package/dist/highlightjs/languages/dart.js +4 -3
- package/dist/highlightjs/languages/delphi.js +0 -3
- package/dist/highlightjs/languages/dns.js +4 -2
- package/dist/highlightjs/languages/dos.js +2 -1
- package/dist/highlightjs/languages/ebnf.js +2 -1
- package/dist/highlightjs/languages/elm.js +7 -2
- package/dist/highlightjs/languages/erlang.js +9 -6
- package/dist/highlightjs/languages/excel.js +2 -5
- package/dist/highlightjs/languages/gams.js +6 -3
- package/dist/highlightjs/languages/gauss.js +2 -6
- package/dist/highlightjs/languages/gcode.js +0 -3
- package/dist/highlightjs/languages/glsl.js +10 -5
- package/dist/highlightjs/languages/go.js +0 -1
- package/dist/highlightjs/languages/groovy.js +4 -2
- package/dist/highlightjs/languages/haml.js +4 -2
- package/dist/highlightjs/languages/haskell.js +9 -3
- package/dist/highlightjs/languages/hy.js +2 -1
- package/dist/highlightjs/languages/inform7.js +8 -4
- package/dist/highlightjs/languages/irpf90.js +4 -2
- package/dist/highlightjs/languages/isbl.js +292 -148
- package/dist/highlightjs/languages/java.js +8 -4
- package/dist/highlightjs/languages/javascript.js +3 -6
- package/dist/highlightjs/languages/json.js +0 -2
- package/dist/highlightjs/languages/julia.js +12 -5
- package/dist/highlightjs/languages/kotlin.js +15 -8
- package/dist/highlightjs/languages/lasso.js +0 -3
- package/dist/highlightjs/languages/less.js +20 -17
- package/dist/highlightjs/languages/livecodeserver.js +0 -3
- package/dist/highlightjs/languages/livescript.js +8 -9
- package/dist/highlightjs/languages/llvm.js +4 -2
- package/dist/highlightjs/languages/lua.js +6 -6
- package/dist/highlightjs/languages/makefile.js +0 -5
- package/dist/highlightjs/languages/markdown.js +18 -9
- package/dist/highlightjs/languages/mercury.js +4 -2
- package/dist/highlightjs/languages/mipsasm.js +37 -18
- package/dist/highlightjs/languages/mojolicious.js +4 -2
- package/dist/highlightjs/languages/moonscript.js +5 -8
- package/dist/highlightjs/languages/nginx.js +12 -6
- package/dist/highlightjs/languages/ocaml.js +3 -8
- package/dist/highlightjs/languages/openscad.js +39 -39
- package/dist/highlightjs/languages/perl.js +3 -3
- package/dist/highlightjs/languages/pgsql.js +128 -72
- package/dist/highlightjs/languages/php.js +0 -1
- package/dist/highlightjs/languages/pony.js +1 -0
- package/dist/highlightjs/languages/powershell.js +5 -8
- package/dist/highlightjs/languages/processing.js +2 -1
- package/dist/highlightjs/languages/prolog.js +1 -3
- package/dist/highlightjs/languages/properties.js +8 -5
- package/dist/highlightjs/languages/protobuf.js +0 -1
- package/dist/highlightjs/languages/puppet.js +4 -8
- package/dist/highlightjs/languages/purebasic.js +9 -5
- package/dist/highlightjs/languages/python.js +0 -1
- package/dist/highlightjs/languages/qml.js +15 -11
- package/dist/highlightjs/languages/reasonml.js +0 -6
- package/dist/highlightjs/languages/roboconf.js +8 -4
- package/dist/highlightjs/languages/routeros.js +36 -18
- package/dist/highlightjs/languages/ruby.js +0 -4
- package/dist/highlightjs/languages/ruleslanguage.js +2 -1
- package/dist/highlightjs/languages/rust.js +8 -4
- package/dist/highlightjs/languages/sas.js +4 -2
- package/dist/highlightjs/languages/scala.js +2 -1
- package/dist/highlightjs/languages/scheme.js +0 -3
- package/dist/highlightjs/languages/scilab.js +2 -4
- package/dist/highlightjs/languages/sml.js +2 -6
- package/dist/highlightjs/languages/sqf.js +8 -5
- package/dist/highlightjs/languages/stan.js +2 -1
- package/dist/highlightjs/languages/stylus.js +45 -24
- package/dist/highlightjs/languages/swift.js +4 -3
- package/dist/highlightjs/languages/tap.js +8 -4
- package/dist/highlightjs/languages/thrift.js +0 -1
- package/dist/highlightjs/languages/tp.js +1 -3
- package/dist/highlightjs/languages/twig.js +0 -3
- package/dist/highlightjs/languages/typescript.js +0 -3
- package/dist/highlightjs/languages/vala.js +12 -6
- package/dist/highlightjs/languages/vbnet.js +12 -27
- package/dist/highlightjs/languages/verilog.js +1 -2
- package/dist/highlightjs/languages/vhdl.js +8 -5
- package/dist/highlightjs/languages/vim.js +6 -3
- package/dist/highlightjs/languages/x86asm.js +52 -26
- package/dist/highlightjs/languages/xml.js +2 -2
- package/dist/highlightjs/languages/xquery.js +12 -7
- package/dist/highlightjs/languages/yaml.js +3 -1
- package/dist/highlightjs/languages/zephir.js +0 -1
- package/dist/index.js +9 -36
- package/package.json +17 -17
|
@@ -1,72 +1,106 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
4
|
var _map = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/map"));
|
|
6
|
-
|
|
7
5
|
var _trim = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/trim"));
|
|
8
|
-
|
|
9
6
|
module.exports = function (hljs) {
|
|
10
7
|
var _context, _context2;
|
|
11
|
-
|
|
12
8
|
var COMMENT_MODE = hljs.COMMENT('--', '$');
|
|
13
9
|
var UNQUOTED_IDENT = '[a-zA-Z_][a-zA-Z_0-9$]*';
|
|
14
10
|
var DOLLAR_STRING = '\\$([a-zA-Z_]?|[a-zA-Z_][a-zA-Z_0-9]*)\\$';
|
|
15
11
|
var LABEL = '<<\\s*' + UNQUOTED_IDENT + '\\s*>>';
|
|
16
|
-
var SQL_KW =
|
|
12
|
+
var SQL_KW =
|
|
13
|
+
// https://www.postgresql.org/docs/11/static/sql-keywords-appendix.html
|
|
17
14
|
// https://www.postgresql.org/docs/11/static/sql-commands.html
|
|
18
15
|
// SQL commands (starting words)
|
|
19
|
-
'ABORT ALTER ANALYZE BEGIN CALL CHECKPOINT|10 CLOSE CLUSTER COMMENT COMMIT COPY CREATE DEALLOCATE DECLARE ' + 'DELETE DISCARD DO DROP END EXECUTE EXPLAIN FETCH GRANT IMPORT INSERT LISTEN LOAD LOCK MOVE NOTIFY ' + 'PREPARE REASSIGN|10 REFRESH REINDEX RELEASE RESET REVOKE ROLLBACK SAVEPOINT SECURITY SELECT SET SHOW ' + 'START TRUNCATE UNLISTEN|10 UPDATE VACUUM|10 VALUES ' +
|
|
20
|
-
|
|
21
|
-
'
|
|
22
|
-
|
|
23
|
-
'
|
|
24
|
-
|
|
25
|
-
'
|
|
16
|
+
'ABORT ALTER ANALYZE BEGIN CALL CHECKPOINT|10 CLOSE CLUSTER COMMENT COMMIT COPY CREATE DEALLOCATE DECLARE ' + 'DELETE DISCARD DO DROP END EXECUTE EXPLAIN FETCH GRANT IMPORT INSERT LISTEN LOAD LOCK MOVE NOTIFY ' + 'PREPARE REASSIGN|10 REFRESH REINDEX RELEASE RESET REVOKE ROLLBACK SAVEPOINT SECURITY SELECT SET SHOW ' + 'START TRUNCATE UNLISTEN|10 UPDATE VACUUM|10 VALUES ' +
|
|
17
|
+
// SQL commands (others)
|
|
18
|
+
'AGGREGATE COLLATION CONVERSION|10 DATABASE DEFAULT PRIVILEGES DOMAIN TRIGGER EXTENSION FOREIGN ' + 'WRAPPER|10 TABLE FUNCTION GROUP LANGUAGE LARGE OBJECT MATERIALIZED VIEW OPERATOR CLASS ' + 'FAMILY POLICY PUBLICATION|10 ROLE RULE SCHEMA SEQUENCE SERVER STATISTICS SUBSCRIPTION SYSTEM ' + 'TABLESPACE CONFIGURATION DICTIONARY PARSER TEMPLATE TYPE USER MAPPING PREPARED ACCESS ' + 'METHOD CAST AS TRANSFORM TRANSACTION OWNED TO INTO SESSION AUTHORIZATION ' + 'INDEX PROCEDURE ASSERTION ' +
|
|
19
|
+
// additional reserved key words
|
|
20
|
+
'ALL ANALYSE AND ANY ARRAY ASC ASYMMETRIC|10 BOTH CASE CHECK ' + 'COLLATE COLUMN CONCURRENTLY|10 CONSTRAINT CROSS ' + 'DEFERRABLE RANGE ' + 'DESC DISTINCT ELSE EXCEPT FOR FREEZE|10 FROM FULL HAVING ' + 'ILIKE IN INITIALLY INNER INTERSECT IS ISNULL JOIN LATERAL LEADING LIKE LIMIT ' + 'NATURAL NOT NOTNULL NULL OFFSET ON ONLY OR ORDER OUTER OVERLAPS PLACING PRIMARY ' + 'REFERENCES RETURNING SIMILAR SOME SYMMETRIC TABLESAMPLE THEN ' + 'TRAILING UNION UNIQUE USING VARIADIC|10 VERBOSE WHEN WHERE WINDOW WITH ' +
|
|
21
|
+
// some of non-reserved (which are used in clauses or as PL/pgSQL keyword)
|
|
22
|
+
'BY RETURNS INOUT OUT SETOF|10 IF STRICT CURRENT CONTINUE OWNER LOCATION OVER PARTITION WITHIN ' + 'BETWEEN ESCAPE EXTERNAL INVOKER DEFINER WORK RENAME VERSION CONNECTION CONNECT ' + 'TABLES TEMP TEMPORARY FUNCTIONS SEQUENCES TYPES SCHEMAS OPTION CASCADE RESTRICT ADD ADMIN ' + 'EXISTS VALID VALIDATE ENABLE DISABLE REPLICA|10 ALWAYS PASSING COLUMNS PATH ' + 'REF VALUE OVERRIDING IMMUTABLE STABLE VOLATILE BEFORE AFTER EACH ROW PROCEDURAL ' + 'ROUTINE NO HANDLER VALIDATOR OPTIONS STORAGE OIDS|10 WITHOUT INHERIT DEPENDS CALLED ' + 'INPUT LEAKPROOF|10 COST ROWS NOWAIT SEARCH UNTIL ENCRYPTED|10 PASSWORD CONFLICT|10 ' + 'INSTEAD INHERITS CHARACTERISTICS WRITE CURSOR ALSO STATEMENT SHARE EXCLUSIVE INLINE ' + 'ISOLATION REPEATABLE READ COMMITTED SERIALIZABLE UNCOMMITTED LOCAL GLOBAL SQL PROCEDURES ' + 'RECURSIVE SNAPSHOT ROLLUP CUBE TRUSTED|10 INCLUDE FOLLOWING PRECEDING UNBOUNDED RANGE GROUPS ' + 'UNENCRYPTED|10 SYSID FORMAT DELIMITER HEADER QUOTE ENCODING FILTER OFF ' +
|
|
23
|
+
// some parameters of VACUUM/ANALYZE/EXPLAIN
|
|
24
|
+
'FORCE_QUOTE FORCE_NOT_NULL FORCE_NULL COSTS BUFFERS TIMING SUMMARY DISABLE_PAGE_SKIPPING ' +
|
|
25
|
+
//
|
|
26
|
+
'RESTART CYCLE GENERATED IDENTITY DEFERRED IMMEDIATE LEVEL LOGGED UNLOGGED ' + 'OF NOTHING NONE EXCLUDE ATTRIBUTE ' +
|
|
27
|
+
// from GRANT (not keywords actually)
|
|
28
|
+
'USAGE ROUTINES ' +
|
|
29
|
+
// actually literals, but look better this way (due to IS TRUE, IS FALSE, ISNULL etc)
|
|
26
30
|
'TRUE FALSE NAN INFINITY ';
|
|
27
|
-
var ROLE_ATTRS =
|
|
31
|
+
var ROLE_ATTRS =
|
|
32
|
+
// only those not in keywrods already
|
|
28
33
|
'SUPERUSER NOSUPERUSER CREATEDB NOCREATEDB CREATEROLE NOCREATEROLE INHERIT NOINHERIT ' + 'LOGIN NOLOGIN REPLICATION NOREPLICATION BYPASSRLS NOBYPASSRLS ';
|
|
29
34
|
var PLPGSQL_KW = 'ALIAS BEGIN CONSTANT DECLARE END EXCEPTION RETURN PERFORM|10 RAISE GET DIAGNOSTICS ' + 'STACKED|10 FOREACH LOOP ELSIF EXIT WHILE REVERSE SLICE DEBUG LOG INFO NOTICE WARNING ASSERT ' + 'OPEN ';
|
|
30
|
-
var TYPES =
|
|
31
|
-
|
|
32
|
-
'
|
|
33
|
-
|
|
35
|
+
var TYPES =
|
|
36
|
+
// https://www.postgresql.org/docs/11/static/datatype.html
|
|
37
|
+
'BIGINT INT8 BIGSERIAL SERIAL8 BIT VARYING VARBIT BOOLEAN BOOL BOX BYTEA CHARACTER CHAR VARCHAR ' + 'CIDR CIRCLE DATE DOUBLE PRECISION FLOAT8 FLOAT INET INTEGER INT INT4 INTERVAL JSON JSONB LINE LSEG|10 ' + 'MACADDR MACADDR8 MONEY NUMERIC DEC DECIMAL PATH POINT POLYGON REAL FLOAT4 SMALLINT INT2 ' + 'SMALLSERIAL|10 SERIAL2|10 SERIAL|10 SERIAL4|10 TEXT TIME ZONE TIMETZ|10 TIMESTAMP TIMESTAMPTZ|10 TSQUERY|10 TSVECTOR|10 ' + 'TXID_SNAPSHOT|10 UUID XML NATIONAL NCHAR ' + 'INT4RANGE|10 INT8RANGE|10 NUMRANGE|10 TSRANGE|10 TSTZRANGE|10 DATERANGE|10 ' +
|
|
38
|
+
// pseudotypes
|
|
39
|
+
'ANYELEMENT ANYARRAY ANYNONARRAY ANYENUM ANYRANGE CSTRING INTERNAL ' + 'RECORD PG_DDL_COMMAND VOID UNKNOWN OPAQUE REFCURSOR ' +
|
|
40
|
+
// spec. type
|
|
41
|
+
'NAME ' +
|
|
42
|
+
// OID-types
|
|
34
43
|
'OID REGPROC|10 REGPROCEDURE|10 REGOPER|10 REGOPERATOR|10 REGCLASS|10 REGTYPE|10 REGROLE|10 ' + 'REGNAMESPACE|10 REGCONFIG|10 REGDICTIONARY|10 '; // +
|
|
35
44
|
// some types from standard extensions
|
|
36
|
-
|
|
37
45
|
'HSTORE|10 LO LTREE|10 ';
|
|
38
46
|
var TYPES_RE = (0, _map.default)(_context = (0, _trim.default)(TYPES).call(TYPES).split(' ')).call(_context, function (val) {
|
|
39
47
|
return val.split('|')[0];
|
|
40
48
|
}).join('|');
|
|
41
49
|
var SQL_BI = 'CURRENT_TIME CURRENT_TIMESTAMP CURRENT_USER CURRENT_CATALOG|10 CURRENT_DATE LOCALTIME LOCALTIMESTAMP ' + 'CURRENT_ROLE|10 CURRENT_SCHEMA|10 SESSION_USER PUBLIC ';
|
|
42
|
-
var PLPGSQL_BI = 'FOUND NEW OLD TG_NAME|10 TG_WHEN|10 TG_LEVEL|10 TG_OP|10 TG_RELID|10 TG_RELNAME|10 ' + 'TG_TABLE_NAME|10 TG_TABLE_SCHEMA|10 TG_NARGS|10 TG_ARGV|10 TG_EVENT|10 TG_TAG|10 ' +
|
|
50
|
+
var PLPGSQL_BI = 'FOUND NEW OLD TG_NAME|10 TG_WHEN|10 TG_LEVEL|10 TG_OP|10 TG_RELID|10 TG_RELNAME|10 ' + 'TG_TABLE_NAME|10 TG_TABLE_SCHEMA|10 TG_NARGS|10 TG_ARGV|10 TG_EVENT|10 TG_TAG|10 ' +
|
|
51
|
+
// get diagnostics
|
|
43
52
|
'ROW_COUNT RESULT_OID|10 PG_CONTEXT|10 RETURNED_SQLSTATE COLUMN_NAME CONSTRAINT_NAME ' + 'PG_DATATYPE_NAME|10 MESSAGE_TEXT TABLE_NAME SCHEMA_NAME PG_EXCEPTION_DETAIL|10 ' + 'PG_EXCEPTION_HINT|10 PG_EXCEPTION_CONTEXT|10 ';
|
|
44
|
-
var PLPGSQL_EXCEPTIONS =
|
|
53
|
+
var PLPGSQL_EXCEPTIONS =
|
|
54
|
+
// exceptions https://www.postgresql.org/docs/current/static/errcodes-appendix.html
|
|
45
55
|
'SQLSTATE SQLERRM|10 ' + 'SUCCESSFUL_COMPLETION WARNING DYNAMIC_RESULT_SETS_RETURNED IMPLICIT_ZERO_BIT_PADDING ' + 'NULL_VALUE_ELIMINATED_IN_SET_FUNCTION PRIVILEGE_NOT_GRANTED PRIVILEGE_NOT_REVOKED ' + 'STRING_DATA_RIGHT_TRUNCATION DEPRECATED_FEATURE NO_DATA NO_ADDITIONAL_DYNAMIC_RESULT_SETS_RETURNED ' + 'SQL_STATEMENT_NOT_YET_COMPLETE CONNECTION_EXCEPTION CONNECTION_DOES_NOT_EXIST CONNECTION_FAILURE ' + 'SQLCLIENT_UNABLE_TO_ESTABLISH_SQLCONNECTION SQLSERVER_REJECTED_ESTABLISHMENT_OF_SQLCONNECTION ' + 'TRANSACTION_RESOLUTION_UNKNOWN PROTOCOL_VIOLATION TRIGGERED_ACTION_EXCEPTION FEATURE_NOT_SUPPORTED ' + 'INVALID_TRANSACTION_INITIATION LOCATOR_EXCEPTION INVALID_LOCATOR_SPECIFICATION INVALID_GRANTOR ' + 'INVALID_GRANT_OPERATION INVALID_ROLE_SPECIFICATION DIAGNOSTICS_EXCEPTION ' + 'STACKED_DIAGNOSTICS_ACCESSED_WITHOUT_ACTIVE_HANDLER CASE_NOT_FOUND CARDINALITY_VIOLATION ' + 'DATA_EXCEPTION ARRAY_SUBSCRIPT_ERROR CHARACTER_NOT_IN_REPERTOIRE DATETIME_FIELD_OVERFLOW ' + 'DIVISION_BY_ZERO ERROR_IN_ASSIGNMENT ESCAPE_CHARACTER_CONFLICT INDICATOR_OVERFLOW ' + 'INTERVAL_FIELD_OVERFLOW INVALID_ARGUMENT_FOR_LOGARITHM INVALID_ARGUMENT_FOR_NTILE_FUNCTION ' + 'INVALID_ARGUMENT_FOR_NTH_VALUE_FUNCTION INVALID_ARGUMENT_FOR_POWER_FUNCTION ' + 'INVALID_ARGUMENT_FOR_WIDTH_BUCKET_FUNCTION INVALID_CHARACTER_VALUE_FOR_CAST ' + 'INVALID_DATETIME_FORMAT INVALID_ESCAPE_CHARACTER INVALID_ESCAPE_OCTET INVALID_ESCAPE_SEQUENCE ' + 'NONSTANDARD_USE_OF_ESCAPE_CHARACTER INVALID_INDICATOR_PARAMETER_VALUE INVALID_PARAMETER_VALUE ' + 'INVALID_REGULAR_EXPRESSION INVALID_ROW_COUNT_IN_LIMIT_CLAUSE ' + 'INVALID_ROW_COUNT_IN_RESULT_OFFSET_CLAUSE INVALID_TABLESAMPLE_ARGUMENT INVALID_TABLESAMPLE_REPEAT ' + 'INVALID_TIME_ZONE_DISPLACEMENT_VALUE INVALID_USE_OF_ESCAPE_CHARACTER MOST_SPECIFIC_TYPE_MISMATCH ' + 'NULL_VALUE_NOT_ALLOWED NULL_VALUE_NO_INDICATOR_PARAMETER NUMERIC_VALUE_OUT_OF_RANGE ' + 'SEQUENCE_GENERATOR_LIMIT_EXCEEDED STRING_DATA_LENGTH_MISMATCH STRING_DATA_RIGHT_TRUNCATION ' + 'SUBSTRING_ERROR TRIM_ERROR UNTERMINATED_C_STRING ZERO_LENGTH_CHARACTER_STRING ' + 'FLOATING_POINT_EXCEPTION INVALID_TEXT_REPRESENTATION INVALID_BINARY_REPRESENTATION ' + 'BAD_COPY_FILE_FORMAT UNTRANSLATABLE_CHARACTER NOT_AN_XML_DOCUMENT INVALID_XML_DOCUMENT ' + 'INVALID_XML_CONTENT INVALID_XML_COMMENT INVALID_XML_PROCESSING_INSTRUCTION ' + 'INTEGRITY_CONSTRAINT_VIOLATION RESTRICT_VIOLATION NOT_NULL_VIOLATION FOREIGN_KEY_VIOLATION ' + 'UNIQUE_VIOLATION CHECK_VIOLATION EXCLUSION_VIOLATION INVALID_CURSOR_STATE ' + 'INVALID_TRANSACTION_STATE ACTIVE_SQL_TRANSACTION BRANCH_TRANSACTION_ALREADY_ACTIVE ' + 'HELD_CURSOR_REQUIRES_SAME_ISOLATION_LEVEL INAPPROPRIATE_ACCESS_MODE_FOR_BRANCH_TRANSACTION ' + 'INAPPROPRIATE_ISOLATION_LEVEL_FOR_BRANCH_TRANSACTION ' + 'NO_ACTIVE_SQL_TRANSACTION_FOR_BRANCH_TRANSACTION READ_ONLY_SQL_TRANSACTION ' + 'SCHEMA_AND_DATA_STATEMENT_MIXING_NOT_SUPPORTED NO_ACTIVE_SQL_TRANSACTION ' + 'IN_FAILED_SQL_TRANSACTION IDLE_IN_TRANSACTION_SESSION_TIMEOUT INVALID_SQL_STATEMENT_NAME ' + 'TRIGGERED_DATA_CHANGE_VIOLATION INVALID_AUTHORIZATION_SPECIFICATION INVALID_PASSWORD ' + 'DEPENDENT_PRIVILEGE_DESCRIPTORS_STILL_EXIST DEPENDENT_OBJECTS_STILL_EXIST ' + 'INVALID_TRANSACTION_TERMINATION SQL_ROUTINE_EXCEPTION FUNCTION_EXECUTED_NO_RETURN_STATEMENT ' + 'MODIFYING_SQL_DATA_NOT_PERMITTED PROHIBITED_SQL_STATEMENT_ATTEMPTED ' + 'READING_SQL_DATA_NOT_PERMITTED INVALID_CURSOR_NAME EXTERNAL_ROUTINE_EXCEPTION ' + 'CONTAINING_SQL_NOT_PERMITTED MODIFYING_SQL_DATA_NOT_PERMITTED ' + 'PROHIBITED_SQL_STATEMENT_ATTEMPTED READING_SQL_DATA_NOT_PERMITTED ' + 'EXTERNAL_ROUTINE_INVOCATION_EXCEPTION INVALID_SQLSTATE_RETURNED NULL_VALUE_NOT_ALLOWED ' + 'TRIGGER_PROTOCOL_VIOLATED SRF_PROTOCOL_VIOLATED EVENT_TRIGGER_PROTOCOL_VIOLATED ' + 'SAVEPOINT_EXCEPTION INVALID_SAVEPOINT_SPECIFICATION INVALID_CATALOG_NAME ' + 'INVALID_SCHEMA_NAME TRANSACTION_ROLLBACK TRANSACTION_INTEGRITY_CONSTRAINT_VIOLATION ' + 'SERIALIZATION_FAILURE STATEMENT_COMPLETION_UNKNOWN DEADLOCK_DETECTED ' + 'SYNTAX_ERROR_OR_ACCESS_RULE_VIOLATION SYNTAX_ERROR INSUFFICIENT_PRIVILEGE CANNOT_COERCE ' + 'GROUPING_ERROR WINDOWING_ERROR INVALID_RECURSION INVALID_FOREIGN_KEY INVALID_NAME ' + 'NAME_TOO_LONG RESERVED_NAME DATATYPE_MISMATCH INDETERMINATE_DATATYPE COLLATION_MISMATCH ' + 'INDETERMINATE_COLLATION WRONG_OBJECT_TYPE GENERATED_ALWAYS UNDEFINED_COLUMN ' + 'UNDEFINED_FUNCTION UNDEFINED_TABLE UNDEFINED_PARAMETER UNDEFINED_OBJECT ' + 'DUPLICATE_COLUMN DUPLICATE_CURSOR DUPLICATE_DATABASE DUPLICATE_FUNCTION ' + 'DUPLICATE_PREPARED_STATEMENT DUPLICATE_SCHEMA DUPLICATE_TABLE DUPLICATE_ALIAS ' + 'DUPLICATE_OBJECT AMBIGUOUS_COLUMN AMBIGUOUS_FUNCTION AMBIGUOUS_PARAMETER AMBIGUOUS_ALIAS ' + 'INVALID_COLUMN_REFERENCE INVALID_COLUMN_DEFINITION INVALID_CURSOR_DEFINITION ' + 'INVALID_DATABASE_DEFINITION INVALID_FUNCTION_DEFINITION ' + 'INVALID_PREPARED_STATEMENT_DEFINITION INVALID_SCHEMA_DEFINITION INVALID_TABLE_DEFINITION ' + 'INVALID_OBJECT_DEFINITION WITH_CHECK_OPTION_VIOLATION INSUFFICIENT_RESOURCES DISK_FULL ' + 'OUT_OF_MEMORY TOO_MANY_CONNECTIONS CONFIGURATION_LIMIT_EXCEEDED PROGRAM_LIMIT_EXCEEDED ' + 'STATEMENT_TOO_COMPLEX TOO_MANY_COLUMNS TOO_MANY_ARGUMENTS OBJECT_NOT_IN_PREREQUISITE_STATE ' + 'OBJECT_IN_USE CANT_CHANGE_RUNTIME_PARAM LOCK_NOT_AVAILABLE OPERATOR_INTERVENTION ' + 'QUERY_CANCELED ADMIN_SHUTDOWN CRASH_SHUTDOWN CANNOT_CONNECT_NOW DATABASE_DROPPED ' + 'SYSTEM_ERROR IO_ERROR UNDEFINED_FILE DUPLICATE_FILE SNAPSHOT_TOO_OLD CONFIG_FILE_ERROR ' + 'LOCK_FILE_EXISTS FDW_ERROR FDW_COLUMN_NAME_NOT_FOUND FDW_DYNAMIC_PARAMETER_VALUE_NEEDED ' + 'FDW_FUNCTION_SEQUENCE_ERROR FDW_INCONSISTENT_DESCRIPTOR_INFORMATION ' + 'FDW_INVALID_ATTRIBUTE_VALUE FDW_INVALID_COLUMN_NAME FDW_INVALID_COLUMN_NUMBER ' + 'FDW_INVALID_DATA_TYPE FDW_INVALID_DATA_TYPE_DESCRIPTORS ' + 'FDW_INVALID_DESCRIPTOR_FIELD_IDENTIFIER FDW_INVALID_HANDLE FDW_INVALID_OPTION_INDEX ' + 'FDW_INVALID_OPTION_NAME FDW_INVALID_STRING_LENGTH_OR_BUFFER_LENGTH ' + 'FDW_INVALID_STRING_FORMAT FDW_INVALID_USE_OF_NULL_POINTER FDW_TOO_MANY_HANDLES ' + 'FDW_OUT_OF_MEMORY FDW_NO_SCHEMAS FDW_OPTION_NAME_NOT_FOUND FDW_REPLY_HANDLE ' + 'FDW_SCHEMA_NOT_FOUND FDW_TABLE_NOT_FOUND FDW_UNABLE_TO_CREATE_EXECUTION ' + 'FDW_UNABLE_TO_CREATE_REPLY FDW_UNABLE_TO_ESTABLISH_CONNECTION PLPGSQL_ERROR ' + 'RAISE_EXCEPTION NO_DATA_FOUND TOO_MANY_ROWS ASSERT_FAILURE INTERNAL_ERROR DATA_CORRUPTED ' + 'INDEX_CORRUPTED ';
|
|
46
|
-
var FUNCTIONS =
|
|
47
|
-
|
|
48
|
-
'
|
|
49
|
-
|
|
50
|
-
'
|
|
51
|
-
|
|
52
|
-
'
|
|
53
|
-
|
|
54
|
-
'
|
|
55
|
-
|
|
56
|
-
'
|
|
57
|
-
|
|
58
|
-
'
|
|
59
|
-
|
|
60
|
-
'
|
|
61
|
-
|
|
62
|
-
'
|
|
63
|
-
|
|
64
|
-
'
|
|
65
|
-
|
|
66
|
-
'
|
|
67
|
-
|
|
68
|
-
'
|
|
69
|
-
|
|
56
|
+
var FUNCTIONS =
|
|
57
|
+
// https://www.postgresql.org/docs/11/static/functions-aggregate.html
|
|
58
|
+
'ARRAY_AGG AVG BIT_AND BIT_OR BOOL_AND BOOL_OR COUNT EVERY JSON_AGG JSONB_AGG JSON_OBJECT_AGG ' + 'JSONB_OBJECT_AGG MAX MIN MODE STRING_AGG SUM XMLAGG ' + 'CORR COVAR_POP COVAR_SAMP REGR_AVGX REGR_AVGY REGR_COUNT REGR_INTERCEPT REGR_R2 REGR_SLOPE ' + 'REGR_SXX REGR_SXY REGR_SYY STDDEV STDDEV_POP STDDEV_SAMP VARIANCE VAR_POP VAR_SAMP ' + 'PERCENTILE_CONT PERCENTILE_DISC ' +
|
|
59
|
+
// https://www.postgresql.org/docs/11/static/functions-window.html
|
|
60
|
+
'ROW_NUMBER RANK DENSE_RANK PERCENT_RANK CUME_DIST NTILE LAG LEAD FIRST_VALUE LAST_VALUE NTH_VALUE ' +
|
|
61
|
+
// https://www.postgresql.org/docs/11/static/functions-comparison.html
|
|
62
|
+
'NUM_NONNULLS NUM_NULLS ' +
|
|
63
|
+
// https://www.postgresql.org/docs/11/static/functions-math.html
|
|
64
|
+
'ABS CBRT CEIL CEILING DEGREES DIV EXP FLOOR LN LOG MOD PI POWER RADIANS ROUND SCALE SIGN SQRT ' + 'TRUNC WIDTH_BUCKET ' + 'RANDOM SETSEED ' + 'ACOS ACOSD ASIN ASIND ATAN ATAND ATAN2 ATAN2D COS COSD COT COTD SIN SIND TAN TAND ' +
|
|
65
|
+
// https://www.postgresql.org/docs/11/static/functions-string.html
|
|
66
|
+
'BIT_LENGTH CHAR_LENGTH CHARACTER_LENGTH LOWER OCTET_LENGTH OVERLAY POSITION SUBSTRING TREAT TRIM UPPER ' + 'ASCII BTRIM CHR CONCAT CONCAT_WS CONVERT CONVERT_FROM CONVERT_TO DECODE ENCODE INITCAP' + 'LEFT LENGTH LPAD LTRIM MD5 PARSE_IDENT PG_CLIENT_ENCODING QUOTE_IDENT|10 QUOTE_LITERAL|10 ' + 'QUOTE_NULLABLE|10 REGEXP_MATCH REGEXP_MATCHES REGEXP_REPLACE REGEXP_SPLIT_TO_ARRAY ' + 'REGEXP_SPLIT_TO_TABLE REPEAT REPLACE REVERSE RIGHT RPAD RTRIM SPLIT_PART STRPOS SUBSTR ' + 'TO_ASCII TO_HEX TRANSLATE ' +
|
|
67
|
+
// https://www.postgresql.org/docs/11/static/functions-binarystring.html
|
|
68
|
+
'OCTET_LENGTH GET_BIT GET_BYTE SET_BIT SET_BYTE ' +
|
|
69
|
+
// https://www.postgresql.org/docs/11/static/functions-formatting.html
|
|
70
|
+
'TO_CHAR TO_DATE TO_NUMBER TO_TIMESTAMP ' +
|
|
71
|
+
// https://www.postgresql.org/docs/11/static/functions-datetime.html
|
|
72
|
+
'AGE CLOCK_TIMESTAMP|10 DATE_PART DATE_TRUNC ISFINITE JUSTIFY_DAYS JUSTIFY_HOURS JUSTIFY_INTERVAL ' + 'MAKE_DATE MAKE_INTERVAL|10 MAKE_TIME MAKE_TIMESTAMP|10 MAKE_TIMESTAMPTZ|10 NOW STATEMENT_TIMESTAMP|10 ' + 'TIMEOFDAY TRANSACTION_TIMESTAMP|10 ' +
|
|
73
|
+
// https://www.postgresql.org/docs/11/static/functions-enum.html
|
|
74
|
+
'ENUM_FIRST ENUM_LAST ENUM_RANGE ' +
|
|
75
|
+
// https://www.postgresql.org/docs/11/static/functions-geometry.html
|
|
76
|
+
'AREA CENTER DIAMETER HEIGHT ISCLOSED ISOPEN NPOINTS PCLOSE POPEN RADIUS WIDTH ' + 'BOX BOUND_BOX CIRCLE LINE LSEG PATH POLYGON ' +
|
|
77
|
+
// https://www.postgresql.org/docs/11/static/functions-net.html
|
|
78
|
+
'ABBREV BROADCAST HOST HOSTMASK MASKLEN NETMASK NETWORK SET_MASKLEN TEXT INET_SAME_FAMILY' + 'INET_MERGE MACADDR8_SET7BIT ' +
|
|
79
|
+
// https://www.postgresql.org/docs/11/static/functions-textsearch.html
|
|
80
|
+
'ARRAY_TO_TSVECTOR GET_CURRENT_TS_CONFIG NUMNODE PLAINTO_TSQUERY PHRASETO_TSQUERY WEBSEARCH_TO_TSQUERY ' + 'QUERYTREE SETWEIGHT STRIP TO_TSQUERY TO_TSVECTOR JSON_TO_TSVECTOR JSONB_TO_TSVECTOR TS_DELETE ' + 'TS_FILTER TS_HEADLINE TS_RANK TS_RANK_CD TS_REWRITE TSQUERY_PHRASE TSVECTOR_TO_ARRAY ' + 'TSVECTOR_UPDATE_TRIGGER TSVECTOR_UPDATE_TRIGGER_COLUMN ' +
|
|
81
|
+
// https://www.postgresql.org/docs/11/static/functions-xml.html
|
|
82
|
+
'XMLCOMMENT XMLCONCAT XMLELEMENT XMLFOREST XMLPI XMLROOT ' + 'XMLEXISTS XML_IS_WELL_FORMED XML_IS_WELL_FORMED_DOCUMENT XML_IS_WELL_FORMED_CONTENT ' + 'XPATH XPATH_EXISTS XMLTABLE XMLNAMESPACES ' + 'TABLE_TO_XML TABLE_TO_XMLSCHEMA TABLE_TO_XML_AND_XMLSCHEMA ' + 'QUERY_TO_XML QUERY_TO_XMLSCHEMA QUERY_TO_XML_AND_XMLSCHEMA ' + 'CURSOR_TO_XML CURSOR_TO_XMLSCHEMA ' + 'SCHEMA_TO_XML SCHEMA_TO_XMLSCHEMA SCHEMA_TO_XML_AND_XMLSCHEMA ' + 'DATABASE_TO_XML DATABASE_TO_XMLSCHEMA DATABASE_TO_XML_AND_XMLSCHEMA ' + 'XMLATTRIBUTES ' +
|
|
83
|
+
// https://www.postgresql.org/docs/11/static/functions-json.html
|
|
84
|
+
'TO_JSON TO_JSONB ARRAY_TO_JSON ROW_TO_JSON JSON_BUILD_ARRAY JSONB_BUILD_ARRAY JSON_BUILD_OBJECT ' + 'JSONB_BUILD_OBJECT JSON_OBJECT JSONB_OBJECT JSON_ARRAY_LENGTH JSONB_ARRAY_LENGTH JSON_EACH ' + 'JSONB_EACH JSON_EACH_TEXT JSONB_EACH_TEXT JSON_EXTRACT_PATH JSONB_EXTRACT_PATH ' + 'JSON_OBJECT_KEYS JSONB_OBJECT_KEYS JSON_POPULATE_RECORD JSONB_POPULATE_RECORD JSON_POPULATE_RECORDSET ' + 'JSONB_POPULATE_RECORDSET JSON_ARRAY_ELEMENTS JSONB_ARRAY_ELEMENTS JSON_ARRAY_ELEMENTS_TEXT ' + 'JSONB_ARRAY_ELEMENTS_TEXT JSON_TYPEOF JSONB_TYPEOF JSON_TO_RECORD JSONB_TO_RECORD JSON_TO_RECORDSET ' + 'JSONB_TO_RECORDSET JSON_STRIP_NULLS JSONB_STRIP_NULLS JSONB_SET JSONB_INSERT JSONB_PRETTY ' +
|
|
85
|
+
// https://www.postgresql.org/docs/11/static/functions-sequence.html
|
|
86
|
+
'CURRVAL LASTVAL NEXTVAL SETVAL ' +
|
|
87
|
+
// https://www.postgresql.org/docs/11/static/functions-conditional.html
|
|
88
|
+
'COALESCE NULLIF GREATEST LEAST ' +
|
|
89
|
+
// https://www.postgresql.org/docs/11/static/functions-array.html
|
|
90
|
+
'ARRAY_APPEND ARRAY_CAT ARRAY_NDIMS ARRAY_DIMS ARRAY_FILL ARRAY_LENGTH ARRAY_LOWER ARRAY_POSITION ' + 'ARRAY_POSITIONS ARRAY_PREPEND ARRAY_REMOVE ARRAY_REPLACE ARRAY_TO_STRING ARRAY_UPPER CARDINALITY ' + 'STRING_TO_ARRAY UNNEST ' +
|
|
91
|
+
// https://www.postgresql.org/docs/11/static/functions-range.html
|
|
92
|
+
'ISEMPTY LOWER_INC UPPER_INC LOWER_INF UPPER_INF RANGE_MERGE ' +
|
|
93
|
+
// https://www.postgresql.org/docs/11/static/functions-srf.html
|
|
94
|
+
'GENERATE_SERIES GENERATE_SUBSCRIPTS ' +
|
|
95
|
+
// https://www.postgresql.org/docs/11/static/functions-info.html
|
|
96
|
+
'CURRENT_DATABASE CURRENT_QUERY CURRENT_SCHEMA|10 CURRENT_SCHEMAS|10 INET_CLIENT_ADDR INET_CLIENT_PORT ' + 'INET_SERVER_ADDR INET_SERVER_PORT ROW_SECURITY_ACTIVE FORMAT_TYPE ' + 'TO_REGCLASS TO_REGPROC TO_REGPROCEDURE TO_REGOPER TO_REGOPERATOR TO_REGTYPE TO_REGNAMESPACE TO_REGROLE ' + 'COL_DESCRIPTION OBJ_DESCRIPTION SHOBJ_DESCRIPTION ' + 'TXID_CURRENT TXID_CURRENT_IF_ASSIGNED TXID_CURRENT_SNAPSHOT TXID_SNAPSHOT_XIP TXID_SNAPSHOT_XMAX ' + 'TXID_SNAPSHOT_XMIN TXID_VISIBLE_IN_SNAPSHOT TXID_STATUS ' +
|
|
97
|
+
// https://www.postgresql.org/docs/11/static/functions-admin.html
|
|
98
|
+
'CURRENT_SETTING SET_CONFIG BRIN_SUMMARIZE_NEW_VALUES BRIN_SUMMARIZE_RANGE BRIN_DESUMMARIZE_RANGE ' + 'GIN_CLEAN_PENDING_LIST ' +
|
|
99
|
+
// https://www.postgresql.org/docs/11/static/functions-trigger.html
|
|
100
|
+
'SUPPRESS_REDUNDANT_UPDATES_TRIGGER ' +
|
|
101
|
+
// ihttps://www.postgresql.org/docs/devel/static/lo-funcs.html
|
|
102
|
+
'LO_FROM_BYTEA LO_PUT LO_GET LO_CREAT LO_CREATE LO_UNLINK LO_IMPORT LO_EXPORT LOREAD LOWRITE ' +
|
|
103
|
+
//
|
|
70
104
|
'GROUPING CAST ';
|
|
71
105
|
var FUNCTIONS_RE = (0, _map.default)(_context2 = (0, _trim.default)(FUNCTIONS).call(FUNCTIONS).split(' ')).call(_context2, function (val) {
|
|
72
106
|
return val.split('|')[0];
|
|
@@ -81,7 +115,8 @@ module.exports = function (hljs) {
|
|
|
81
115
|
// Forbid some cunstructs from other languages to improve autodetect. In fact
|
|
82
116
|
// "[a-z]:" is legal (as part of array slice), but improbabal.
|
|
83
117
|
illegal: /:==|\W\s*\(\*|(^|\s)\$[a-z]|{{|[a-z]:\s*$|\.\.\.|TO:|DO:/,
|
|
84
|
-
contains: [
|
|
118
|
+
contains: [
|
|
119
|
+
// special handling of some words, which are reserved only in some contexts
|
|
85
120
|
{
|
|
86
121
|
className: 'keyword',
|
|
87
122
|
variants: [{
|
|
@@ -169,27 +204,33 @@ module.exports = function (hljs) {
|
|
|
169
204
|
}, {
|
|
170
205
|
begin: /\bAS\s+(ASSIGNMENT|IMPLICIT|PERMISSIVE|RESTRICTIVE|ENUM|RANGE)\b/
|
|
171
206
|
}]
|
|
172
|
-
},
|
|
207
|
+
},
|
|
208
|
+
// functions named as keywords, followed by '('
|
|
173
209
|
{
|
|
174
|
-
begin: /\b(FORMAT|FAMILY|VERSION)\s*\(/
|
|
175
|
-
|
|
176
|
-
},
|
|
210
|
+
begin: /\b(FORMAT|FAMILY|VERSION)\s*\(/
|
|
211
|
+
//keywords: { built_in: 'FORMAT FAMILY VERSION' }
|
|
212
|
+
},
|
|
213
|
+
// INCLUDE ( ... ) in index_parameters in CREATE TABLE
|
|
177
214
|
{
|
|
178
215
|
begin: /\bINCLUDE\s*\(/,
|
|
179
216
|
keywords: 'INCLUDE'
|
|
180
|
-
},
|
|
217
|
+
},
|
|
218
|
+
// not highlight RANGE if not in frame_clause (not 100% correct, but seems satisfactory)
|
|
181
219
|
{
|
|
182
220
|
begin: /\bRANGE(?!\s*(BETWEEN|UNBOUNDED|CURRENT|[-0-9]+))/
|
|
183
|
-
},
|
|
221
|
+
},
|
|
222
|
+
// disable highlighting in commands CREATE AGGREGATE/COLLATION/DATABASE/OPERTOR/TEXT SEARCH .../TYPE
|
|
184
223
|
// and in PL/pgSQL RAISE ... USING
|
|
185
224
|
{
|
|
186
225
|
begin: /\b(VERSION|OWNER|TEMPLATE|TABLESPACE|CONNECTION\s+LIMIT|PROCEDURE|RESTRICT|JOIN|PARSER|COPY|START|END|COLLATION|INPUT|ANALYZE|STORAGE|LIKE|DEFAULT|DELIMITER|ENCODING|COLUMN|CONSTRAINT|TABLE|SCHEMA)\s*=/
|
|
187
|
-
},
|
|
226
|
+
},
|
|
227
|
+
// PG_smth; HAS_some_PRIVILEGE
|
|
188
228
|
{
|
|
189
229
|
//className: 'built_in',
|
|
190
230
|
begin: /\b(PG_\w+?|HAS_[A-Z_]+_PRIVILEGE)\b/,
|
|
191
231
|
relevance: 10
|
|
192
|
-
},
|
|
232
|
+
},
|
|
233
|
+
// extract
|
|
193
234
|
{
|
|
194
235
|
begin: /\bEXTRACT\s*\(/,
|
|
195
236
|
end: /\bFROM\b/,
|
|
@@ -198,21 +239,24 @@ module.exports = function (hljs) {
|
|
|
198
239
|
//built_in: 'EXTRACT',
|
|
199
240
|
type: 'CENTURY DAY DECADE DOW DOY EPOCH HOUR ISODOW ISOYEAR MICROSECONDS ' + 'MILLENNIUM MILLISECONDS MINUTE MONTH QUARTER SECOND TIMEZONE TIMEZONE_HOUR ' + 'TIMEZONE_MINUTE WEEK YEAR'
|
|
200
241
|
}
|
|
201
|
-
},
|
|
242
|
+
},
|
|
243
|
+
// xmlelement, xmlpi - special NAME
|
|
202
244
|
{
|
|
203
245
|
begin: /\b(XMLELEMENT|XMLPI)\s*\(\s*NAME/,
|
|
204
246
|
keywords: {
|
|
205
247
|
//built_in: 'XMLELEMENT XMLPI',
|
|
206
248
|
keyword: 'NAME'
|
|
207
249
|
}
|
|
208
|
-
},
|
|
250
|
+
},
|
|
251
|
+
// xmlparse, xmlserialize
|
|
209
252
|
{
|
|
210
253
|
begin: /\b(XMLPARSE|XMLSERIALIZE)\s*\(\s*(DOCUMENT|CONTENT)/,
|
|
211
254
|
keywords: {
|
|
212
255
|
//built_in: 'XMLPARSE XMLSERIALIZE',
|
|
213
256
|
keyword: 'DOCUMENT CONTENT'
|
|
214
257
|
}
|
|
215
|
-
},
|
|
258
|
+
},
|
|
259
|
+
// Sequences. We actually skip everything between CACHE|INCREMENT|MAXVALUE|MINVALUE and
|
|
216
260
|
// nearest following numeric constant. Without with trick we find a lot of "keywords"
|
|
217
261
|
// in 'avrasm' autodetection test...
|
|
218
262
|
{
|
|
@@ -220,29 +264,33 @@ module.exports = function (hljs) {
|
|
|
220
264
|
end: hljs.C_NUMBER_RE,
|
|
221
265
|
returnEnd: true,
|
|
222
266
|
keywords: 'BY CACHE INCREMENT MAXVALUE MINVALUE'
|
|
223
|
-
},
|
|
267
|
+
},
|
|
268
|
+
// WITH|WITHOUT TIME ZONE as part of datatype
|
|
224
269
|
{
|
|
225
270
|
className: 'type',
|
|
226
271
|
begin: /\b(WITH|WITHOUT)\s+TIME\s+ZONE\b/
|
|
227
|
-
},
|
|
272
|
+
},
|
|
273
|
+
// INTERVAL optional fields
|
|
228
274
|
{
|
|
229
275
|
className: 'type',
|
|
230
276
|
begin: /\bINTERVAL\s+(YEAR|MONTH|DAY|HOUR|MINUTE|SECOND)(\s+TO\s+(MONTH|HOUR|MINUTE|SECOND))?\b/
|
|
231
|
-
},
|
|
277
|
+
},
|
|
278
|
+
// Pseudo-types which allowed only as return type
|
|
232
279
|
{
|
|
233
280
|
begin: /\bRETURNS\s+(LANGUAGE_HANDLER|TRIGGER|EVENT_TRIGGER|FDW_HANDLER|INDEX_AM_HANDLER|TSM_HANDLER)\b/,
|
|
234
281
|
keywords: {
|
|
235
282
|
keyword: 'RETURNS',
|
|
236
283
|
type: 'LANGUAGE_HANDLER TRIGGER EVENT_TRIGGER FDW_HANDLER INDEX_AM_HANDLER TSM_HANDLER'
|
|
237
284
|
}
|
|
238
|
-
},
|
|
285
|
+
},
|
|
286
|
+
// Known functions - only when followed by '('
|
|
239
287
|
{
|
|
240
|
-
begin: '\\b(' + FUNCTIONS_RE + ')\\s*\\('
|
|
241
|
-
|
|
242
|
-
},
|
|
288
|
+
begin: '\\b(' + FUNCTIONS_RE + ')\\s*\\('
|
|
289
|
+
//keywords: { built_in: FUNCTIONS }
|
|
290
|
+
},
|
|
291
|
+
// Types
|
|
243
292
|
{
|
|
244
293
|
begin: '\\.(' + TYPES_RE + ')\\b' // prevent highlight as type, say, 'oid' in 'pgclass.oid'
|
|
245
|
-
|
|
246
294
|
}, {
|
|
247
295
|
begin: '\\b(' + TYPES_RE + ')\\s+PATH\\b',
|
|
248
296
|
// in XMLTABLE
|
|
@@ -254,7 +302,8 @@ module.exports = function (hljs) {
|
|
|
254
302
|
}, {
|
|
255
303
|
className: 'type',
|
|
256
304
|
begin: '\\b(' + TYPES_RE + ')\\b'
|
|
257
|
-
},
|
|
305
|
+
},
|
|
306
|
+
// Strings, see https://www.postgresql.org/docs/11/static/sql-syntax-lexical.html#SQL-SYNTAX-CONSTANTS
|
|
258
307
|
{
|
|
259
308
|
className: 'string',
|
|
260
309
|
begin: '\'',
|
|
@@ -279,32 +328,39 @@ module.exports = function (hljs) {
|
|
|
279
328
|
subLanguage: ['pgsql', 'perl', 'python', 'tcl', 'r', 'lua', 'java', 'php', 'ruby', 'bash', 'scheme', 'xml', 'json'],
|
|
280
329
|
endsWithParent: true
|
|
281
330
|
}]
|
|
282
|
-
},
|
|
331
|
+
},
|
|
332
|
+
// identifiers in quotes
|
|
283
333
|
{
|
|
284
334
|
begin: '"',
|
|
285
335
|
end: '"',
|
|
286
336
|
contains: [{
|
|
287
337
|
begin: '""'
|
|
288
338
|
}]
|
|
289
|
-
},
|
|
290
|
-
|
|
291
|
-
hljs.
|
|
339
|
+
},
|
|
340
|
+
// numbers
|
|
341
|
+
hljs.C_NUMBER_MODE,
|
|
342
|
+
// comments
|
|
343
|
+
hljs.C_BLOCK_COMMENT_MODE, COMMENT_MODE,
|
|
344
|
+
// PL/pgSQL staff
|
|
292
345
|
// %ROWTYPE, %TYPE, $n
|
|
293
346
|
{
|
|
294
347
|
className: 'meta',
|
|
295
348
|
variants: [{
|
|
296
349
|
begin: '%(ROW)?TYPE',
|
|
297
350
|
relevance: 10
|
|
298
|
-
},
|
|
351
|
+
},
|
|
352
|
+
// %TYPE, %ROWTYPE
|
|
299
353
|
{
|
|
300
354
|
begin: '\\$\\d+'
|
|
301
|
-
},
|
|
355
|
+
},
|
|
356
|
+
// $n
|
|
302
357
|
{
|
|
303
358
|
begin: '^#\\w',
|
|
304
359
|
end: '$'
|
|
305
360
|
} // #compiler option
|
|
306
361
|
]
|
|
307
|
-
},
|
|
362
|
+
},
|
|
363
|
+
// <<labeles>>
|
|
308
364
|
{
|
|
309
365
|
className: 'symbol',
|
|
310
366
|
begin: LABEL,
|
|
@@ -42,24 +42,21 @@ module.exports = function (hljs) {
|
|
|
42
42
|
};
|
|
43
43
|
var PS_HELPTAGS = {
|
|
44
44
|
className: "doctag",
|
|
45
|
-
variants: [
|
|
46
|
-
|
|
45
|
+
variants: [/* no paramater help tags */
|
|
46
|
+
|
|
47
47
|
{
|
|
48
48
|
begin: /\.(synopsis|description|example|inputs|outputs|notes|link|component|role|functionality)/
|
|
49
|
-
},
|
|
50
|
-
/* one parameter help tags */
|
|
49
|
+
}, /* one parameter help tags */
|
|
51
50
|
{
|
|
52
51
|
begin: /\.(parameter|forwardhelptargetname|forwardhelpcategory|remotehelprunspace|externalhelp)\s+\S+/
|
|
53
52
|
}]
|
|
54
53
|
};
|
|
55
54
|
var PS_COMMENT = hljs.inherit(hljs.COMMENT(null, null), {
|
|
56
|
-
variants: [
|
|
57
|
-
/* single-line comment */
|
|
55
|
+
variants: [/* single-line comment */
|
|
58
56
|
{
|
|
59
57
|
begin: /#/,
|
|
60
58
|
end: /$/
|
|
61
|
-
},
|
|
62
|
-
/* multi-line comment */
|
|
59
|
+
}, /* multi-line comment */
|
|
63
60
|
{
|
|
64
61
|
begin: /<#/,
|
|
65
62
|
end: /#>/
|
|
@@ -3,7 +3,8 @@
|
|
|
3
3
|
module.exports = function (hljs) {
|
|
4
4
|
return {
|
|
5
5
|
keywords: {
|
|
6
|
-
keyword: 'BufferedReader PVector PFont PImage PGraphics HashMap boolean byte char color ' + 'double float int long String Array FloatDict FloatList IntDict IntList JSONArray JSONObject ' + 'Object StringDict StringList Table TableRow XML ' +
|
|
6
|
+
keyword: 'BufferedReader PVector PFont PImage PGraphics HashMap boolean byte char color ' + 'double float int long String Array FloatDict FloatList IntDict IntList JSONArray JSONObject ' + 'Object StringDict StringList Table TableRow XML ' +
|
|
7
|
+
// Java keywords
|
|
7
8
|
'false synchronized int abstract float private char boolean static null if const ' + 'for true while long throw strictfp finally protected import native final return void ' + 'enum else break transient new catch instanceof byte super volatile case assert short ' + 'package default double public try this switch continue throws protected public private',
|
|
8
9
|
literal: 'P2D P3D HALF_PI PI QUARTER_PI TAU TWO_PI',
|
|
9
10
|
title: 'setup draw',
|
|
@@ -1,9 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
4
|
var _concat = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/concat"));
|
|
6
|
-
|
|
7
5
|
module.exports = function (hljs) {
|
|
8
6
|
var ATOM = {
|
|
9
7
|
begin: /[a-z][A-Za-z0-9_]*/,
|
|
@@ -47,8 +45,8 @@ module.exports = function (hljs) {
|
|
|
47
45
|
var SPACE_CODE = {
|
|
48
46
|
className: 'string',
|
|
49
47
|
begin: /0\'\\s/ // 0'\s
|
|
50
|
-
|
|
51
48
|
};
|
|
49
|
+
|
|
52
50
|
var PRED_OP = {
|
|
53
51
|
// relevance booster
|
|
54
52
|
begin: /:-/
|
|
@@ -3,8 +3,8 @@
|
|
|
3
3
|
module.exports = function (hljs) {
|
|
4
4
|
// whitespaces: space, tab, formfeed
|
|
5
5
|
var WS0 = '[ \\t\\f]*';
|
|
6
|
-
var WS1 = '[ \\t\\f]+';
|
|
7
|
-
|
|
6
|
+
var WS1 = '[ \\t\\f]+';
|
|
7
|
+
// delimiter
|
|
8
8
|
var DELIM = '(' + WS0 + '[:=]' + WS0 + '|' + WS1 + ')';
|
|
9
9
|
var KEY_ALPHANUM = '([^\\\\\\W:= \\t\\f\\n]|\\\\.)+';
|
|
10
10
|
var KEY_OTHER = '([^\\\\:= \\t\\f\\n]|\\\\.)+';
|
|
@@ -25,7 +25,8 @@ module.exports = function (hljs) {
|
|
|
25
25
|
return {
|
|
26
26
|
case_insensitive: true,
|
|
27
27
|
illegal: /\S/,
|
|
28
|
-
contains: [hljs.COMMENT('^\\s*[!#]', '$'),
|
|
28
|
+
contains: [hljs.COMMENT('^\\s*[!#]', '$'),
|
|
29
|
+
// key: everything until whitespace or = or : (taking into account backslashes)
|
|
29
30
|
// case of a "normal" key
|
|
30
31
|
{
|
|
31
32
|
begin: KEY_ALPHANUM + DELIM,
|
|
@@ -37,7 +38,8 @@ module.exports = function (hljs) {
|
|
|
37
38
|
relevance: 0
|
|
38
39
|
}],
|
|
39
40
|
starts: DELIM_AND_VALUE
|
|
40
|
-
},
|
|
41
|
+
},
|
|
42
|
+
// case of key containing non-alphanumeric chars => relevance = 0
|
|
41
43
|
{
|
|
42
44
|
begin: KEY_OTHER + DELIM,
|
|
43
45
|
returnBegin: true,
|
|
@@ -49,7 +51,8 @@ module.exports = function (hljs) {
|
|
|
49
51
|
relevance: 0
|
|
50
52
|
}],
|
|
51
53
|
starts: DELIM_AND_VALUE
|
|
52
|
-
},
|
|
54
|
+
},
|
|
55
|
+
// case of an empty key
|
|
53
56
|
{
|
|
54
57
|
className: 'attr',
|
|
55
58
|
relevance: 0,
|
|
@@ -2,16 +2,12 @@
|
|
|
2
2
|
|
|
3
3
|
module.exports = function (hljs) {
|
|
4
4
|
var PUPPET_KEYWORDS = {
|
|
5
|
-
keyword:
|
|
6
|
-
/* language keywords */
|
|
5
|
+
keyword: /* language keywords */
|
|
7
6
|
'and case default else elsif false if in import enherits node or true undef unless main settings $string ',
|
|
8
|
-
literal:
|
|
9
|
-
/*
|
|
10
|
-
'alias audit before loglevel noop require subscribe tag ' +
|
|
11
|
-
/* normal attributes */
|
|
7
|
+
literal: /* metaparameters */
|
|
8
|
+
'alias audit before loglevel noop require subscribe tag ' + /* normal attributes */
|
|
12
9
|
'owner ensure group mode name|0 changes context force incl lens load_path onlyif provider returns root show_diff type_check ' + 'en_address ip_address realname command environment hour monute month monthday special target weekday ' + 'creates cwd ogoutput refresh refreshonly tries try_sleep umask backup checksum content ctime force ignore ' + 'links mtime purge recurse recurselimit replace selinux_ignore_defaults selrange selrole seltype seluser source ' + 'souirce_permissions sourceselect validate_cmd validate_replacement allowdupe attribute_membership auth_membership forcelocal gid ' + 'ia_load_module members system host_aliases ip allowed_trunk_vlans description device_url duplex encapsulation etherchannel ' + 'native_vlan speed principals allow_root auth_class auth_type authenticate_user k_of_n mechanisms rule session_owner shared options ' + 'device fstype enable hasrestart directory present absent link atboot blockdevice device dump pass remounts poller_tag use ' + 'message withpath adminfile allow_virtual allowcdrom category configfiles flavor install_options instance package_settings platform ' + 'responsefile status uninstall_options vendor unless_system_user unless_uid binary control flags hasstatus manifest pattern restart running ' + 'start stop allowdupe auths expiry gid groups home iterations key_membership keys managehome membership password password_max_age ' + 'password_min_age profile_membership profiles project purge_ssh_keys role_membership roles salt shell uid baseurl cost descr enabled ' + 'enablegroups exclude failovermethod gpgcheck gpgkey http_caching include includepkgs keepalive metadata_expire metalink mirrorlist ' + 'priority protect proxy proxy_password proxy_username repo_gpgcheck s3_enabled skip_if_unavailable sslcacert sslclientcert sslclientkey ' + 'sslverify mounted',
|
|
13
|
-
built_in:
|
|
14
|
-
/* core facts */
|
|
10
|
+
built_in: /* core facts */
|
|
15
11
|
'architecture augeasversion blockdevices boardmanufacturer boardproductname boardserialnumber cfkey dhcp_servers ' + 'domain ec2_ ec2_userdata facterversion filesystems ldom fqdn gid hardwareisa hardwaremodel hostname id|0 interfaces ' + 'ipaddress ipaddress_ ipaddress6 ipaddress6_ iphostnumber is_virtual kernel kernelmajversion kernelrelease kernelversion ' + 'kernelrelease kernelversion lsbdistcodename lsbdistdescription lsbdistid lsbdistrelease lsbmajdistrelease lsbminordistrelease ' + 'lsbrelease macaddress macaddress_ macosx_buildversion macosx_productname macosx_productversion macosx_productverson_major ' + 'macosx_productversion_minor manufacturer memoryfree memorysize netmask metmask_ network_ operatingsystem operatingsystemmajrelease ' + 'operatingsystemrelease osfamily partitions path physicalprocessorcount processor processorcount productname ps puppetversion ' + 'rubysitedir rubyversion selinux selinux_config_mode selinux_config_policy selinux_current_mode selinux_current_mode selinux_enforced ' + 'selinux_policyversion serialnumber sp_ sshdsakey sshecdsakey sshrsakey swapencrypted swapfree swapsize timezone type uniqueid uptime ' + 'uptime_days uptime_hours uptime_seconds uuid virtual vlans xendomains zfs_version zonenae zones zpool_version'
|
|
16
12
|
};
|
|
17
13
|
var COMMENT = hljs.COMMENT('#', '$');
|
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
module.exports =
|
|
3
|
+
module.exports =
|
|
4
|
+
// Base deafult colors in PB IDE: background: #FFFFDF; foreground: #000000;
|
|
5
|
+
|
|
4
6
|
function (hljs) {
|
|
5
7
|
var STRINGS = {
|
|
6
8
|
// PB IDE color: #0080FF (Azure Radiance)
|
|
@@ -17,10 +19,12 @@ function (hljs) {
|
|
|
17
19
|
};
|
|
18
20
|
return {
|
|
19
21
|
aliases: ['pb', 'pbi'],
|
|
20
|
-
keywords:
|
|
22
|
+
keywords:
|
|
23
|
+
// PB IDE color: #006666 (Blue Stone) + Bold
|
|
21
24
|
// The following keywords list was taken and adapted from GuShH's PureBasic language file for GeSHi...
|
|
22
25
|
'And As Break CallDebugger Case CompilerCase CompilerDefault CompilerElse CompilerEndIf CompilerEndSelect ' + 'CompilerError CompilerIf CompilerSelect Continue Data DataSection EndDataSection Debug DebugLevel ' + 'Default Define Dim DisableASM DisableDebugger DisableExplicit Else ElseIf EnableASM ' + 'EnableDebugger EnableExplicit End EndEnumeration EndIf EndImport EndInterface EndMacro EndProcedure ' + 'EndSelect EndStructure EndStructureUnion EndWith Enumeration Extends FakeReturn For Next ForEach ' + 'ForEver Global Gosub Goto If Import ImportC IncludeBinary IncludeFile IncludePath Interface Macro ' + 'NewList Not Or ProcedureReturn Protected Prototype ' + 'PrototypeC Read ReDim Repeat Until Restore Return Select Shared Static Step Structure StructureUnion ' + 'Swap To Wend While With XIncludeFile XOr ' + 'Procedure ProcedureC ProcedureCDLL ProcedureDLL Declare DeclareC DeclareCDLL DeclareDLL',
|
|
23
|
-
contains: [
|
|
26
|
+
contains: [
|
|
27
|
+
// COMMENTS | PB IDE color: #00AAAA (Persian Green)
|
|
24
28
|
hljs.COMMENT(';', '$', {
|
|
25
29
|
relevance: 0
|
|
26
30
|
}), {
|
|
@@ -38,8 +42,8 @@ function (hljs) {
|
|
|
38
42
|
}, {
|
|
39
43
|
// PROCEDURE RETURN TYPE SETTING | PB IDE color: #000000 (Black)
|
|
40
44
|
className: 'type',
|
|
41
|
-
begin: '\\.\\w*'
|
|
42
|
-
|
|
45
|
+
begin: '\\.\\w*'
|
|
46
|
+
// end: ' ',
|
|
43
47
|
}, hljs.UNDERSCORE_TITLE_MODE // PROCEDURE NAME | PB IDE color: #006666 (Blue Stone)
|
|
44
48
|
]
|
|
45
49
|
}, STRINGS, CONSTANTS]
|