1 | (function webpackUniversalModuleDefinition(root, factory) {
|
2 | if(typeof exports === 'object' && typeof module === 'object')
|
3 | module.exports = factory();
|
4 | else if(typeof define === 'function' && define.amd)
|
5 | define([], factory);
|
6 | else if(typeof exports === 'object')
|
7 | exports["sqlFormatter"] = factory();
|
8 | else
|
9 | root["sqlFormatter"] = factory();
|
10 | })(self, () => {
|
11 | return /******/ (() => { // webpackBootstrap
|
12 | /******/ "use strict";
|
13 | /******/ var __webpack_modules__ = ({
|
14 |
|
15 | /***/ "./src/core/AliasAs.ts":
|
16 | /*!*****************************!*\
|
17 | !*** ./src/core/AliasAs.ts ***!
|
18 | \*****************************/
|
19 | /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
20 |
|
21 | __webpack_require__.r(__webpack_exports__);
|
22 | /* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
23 | /* harmony export */ "default": () => (/* binding */ AliasAs)
|
24 | /* harmony export */ });
|
25 | /* harmony import */ var _token__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./token */ "./src/core/token.ts");
|
26 | function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
27 |
|
28 | function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
29 |
|
30 | function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
31 |
|
32 |
|
33 | /** Decides addition and removal of AS tokens */
|
34 |
|
35 | var AliasAs = /*#__PURE__*/function () {
|
36 | function AliasAs(aliasAs, formatter) {
|
37 | _classCallCheck(this, AliasAs);
|
38 |
|
39 | this.aliasAs = aliasAs;
|
40 | this.formatter = formatter;
|
41 | }
|
42 | /** True when AS keyword should be added *before* current token */
|
43 |
|
44 |
|
45 | _createClass(AliasAs, [{
|
46 | key: "shouldAddBefore",
|
47 | value: function shouldAddBefore(token) {
|
48 | return this.isMissingTableAlias(token) || this.isMissingSelectColumnAlias(token);
|
49 | } // if table alias is missing and should be added
|
50 |
|
51 | }, {
|
52 | key: "isMissingTableAlias",
|
53 | value: function isMissingTableAlias(token) {
|
54 | return this.aliasAs === 'always' && token.type === _token__WEBPACK_IMPORTED_MODULE_0__.TokenType.WORD && this.lookBehind().value === ')';
|
55 | } // if select column alias is missing and should be added
|
56 |
|
57 | }, {
|
58 | key: "isMissingSelectColumnAlias",
|
59 | value: function isMissingSelectColumnAlias(token) {
|
60 | var prevToken = this.lookBehind();
|
61 | var nextToken = this.lookAhead();
|
62 | return (this.aliasAs === 'always' || this.aliasAs === 'select') && this.formatter.isWithinSelect() && token.type === _token__WEBPACK_IMPORTED_MODULE_0__.TokenType.WORD && (_token__WEBPACK_IMPORTED_MODULE_0__.isToken.END(prevToken) || (prevToken.type === _token__WEBPACK_IMPORTED_MODULE_0__.TokenType.WORD || prevToken.type === _token__WEBPACK_IMPORTED_MODULE_0__.TokenType.NUMBER) && (nextToken.value === ',' || (0,_token__WEBPACK_IMPORTED_MODULE_0__.isCommand)(nextToken)));
|
63 | }
|
64 | /** True when AS keyword should be added *after* current token */
|
65 |
|
66 | }, {
|
67 | key: "shouldAddAfter",
|
68 | value: function shouldAddAfter() {
|
69 | return this.isEdgeCaseCTE() || this.isEdgeCaseCreateTable() || this.isMissingTypeCastAs();
|
70 | } // checks for CAST(«expression» [AS] type)
|
71 |
|
72 | }, {
|
73 | key: "isMissingTypeCastAs",
|
74 | value: function isMissingTypeCastAs() {
|
75 | return this.aliasAs === 'never' && this.formatter.isWithinSelect() && _token__WEBPACK_IMPORTED_MODULE_0__.isToken.CAST(this.formatter.getPreviousReservedToken()) && _token__WEBPACK_IMPORTED_MODULE_0__.isToken.AS(this.lookAhead()) && (this.lookAhead(2).type === _token__WEBPACK_IMPORTED_MODULE_0__.TokenType.WORD || this.lookAhead(2).type === _token__WEBPACK_IMPORTED_MODULE_0__.TokenType.RESERVED_KEYWORD) && this.lookAhead(3).value === ')';
|
76 | } // checks for WITH `table` [AS] (
|
77 |
|
78 | }, {
|
79 | key: "isEdgeCaseCTE",
|
80 | value: function isEdgeCaseCTE() {
|
81 | var nextToken = this.lookAhead();
|
82 | return this.aliasAs === 'never' && _token__WEBPACK_IMPORTED_MODULE_0__.isToken.WITH(this.lookBehind()) && (nextToken.value === '(' || _token__WEBPACK_IMPORTED_MODULE_0__.isToken.AS(nextToken) && this.lookAhead(2).value === '(');
|
83 | } // checks for CREATE TABLE `table` [AS] WITH (
|
84 |
|
85 | }, {
|
86 | key: "isEdgeCaseCreateTable",
|
87 | value: function isEdgeCaseCreateTable() {
|
88 | var prevToken = this.lookBehind();
|
89 | var nextToken = this.lookAhead();
|
90 | return this.aliasAs === 'never' && (_token__WEBPACK_IMPORTED_MODULE_0__.isToken.TABLE(prevToken) || prevToken.value.endsWith('TABLE')) && (_token__WEBPACK_IMPORTED_MODULE_0__.isToken.WITH(nextToken) || _token__WEBPACK_IMPORTED_MODULE_0__.isToken.AS(nextToken) && _token__WEBPACK_IMPORTED_MODULE_0__.isToken.WITH(this.lookAhead(2)));
|
91 | }
|
92 | /* True when the current AS token should be discarded */
|
93 |
|
94 | }, {
|
95 | key: "shouldRemove",
|
96 | value: function shouldRemove() {
|
97 | return this.aliasAs === 'never' || this.aliasAs === 'select' && this.isRemovableNonSelectAs();
|
98 | }
|
99 | }, {
|
100 | key: "isRemovableNonSelectAs",
|
101 | value: function isRemovableNonSelectAs() {
|
102 | return this.lookBehind().value === ')' && // ) [AS] alias but not SELECT (a) [AS] alpha
|
103 | !this.formatter.isWithinSelect() && this.lookAhead().value !== '(' // skip WITH foo [AS] ( ...
|
104 | ;
|
105 | }
|
106 | }, {
|
107 | key: "lookBehind",
|
108 | value: function lookBehind(n) {
|
109 | return this.formatter.tokenLookBehind(n);
|
110 | }
|
111 | }, {
|
112 | key: "lookAhead",
|
113 | value: function lookAhead(n) {
|
114 | return this.formatter.tokenLookAhead(n);
|
115 | }
|
116 | }]);
|
117 |
|
118 | return AliasAs;
|
119 | }();
|
120 |
|
121 |
|
122 |
|
123 | /***/ }),
|
124 |
|
125 | /***/ "./src/core/AsTokenFactory.ts":
|
126 | /*!************************************!*\
|
127 | !*** ./src/core/AsTokenFactory.ts ***!
|
128 | \************************************/
|
129 | /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
130 |
|
131 | __webpack_require__.r(__webpack_exports__);
|
132 | /* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
133 | /* harmony export */ "default": () => (/* binding */ AsTokenFactory)
|
134 | /* harmony export */ });
|
135 | /* harmony import */ var _token__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./token */ "./src/core/token.ts");
|
136 | function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
137 |
|
138 | function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
139 |
|
140 | function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
141 |
|
142 |
|
143 |
|
144 | var AsTokenFactory = /*#__PURE__*/function () {
|
145 | function AsTokenFactory(keywordCase) {
|
146 | var tokens = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
|
147 |
|
148 | _classCallCheck(this, AsTokenFactory);
|
149 |
|
150 | this.keywordCase = keywordCase;
|
151 | this.detectedCase = this.autoDetectCase(tokens);
|
152 | }
|
153 |
|
154 | _createClass(AsTokenFactory, [{
|
155 | key: "autoDetectCase",
|
156 | value: function autoDetectCase(tokens) {
|
157 | var asTokens = tokens.filter(_token__WEBPACK_IMPORTED_MODULE_0__.isToken.AS);
|
158 | var upperAsTokens = asTokens.filter(function (_ref) {
|
159 | var value = _ref.value;
|
160 | return value === 'AS';
|
161 | });
|
162 | return upperAsTokens.length > asTokens.length / 2 ? 'upper' : 'lower';
|
163 | }
|
164 | /** Returns AS token with either upper- or lowercase text */
|
165 |
|
166 | }, {
|
167 | key: "token",
|
168 | value: function token() {
|
169 | return {
|
170 | type: _token__WEBPACK_IMPORTED_MODULE_0__.TokenType.RESERVED_KEYWORD,
|
171 | value: this.asTokenValue()
|
172 | };
|
173 | }
|
174 | }, {
|
175 | key: "asTokenValue",
|
176 | value: function asTokenValue() {
|
177 | var keywordCase = this.keywordCase === 'preserve' ? this.detectedCase : this.keywordCase;
|
178 | return keywordCase === 'upper' ? 'AS' : 'as';
|
179 | }
|
180 | }]);
|
181 |
|
182 | return AsTokenFactory;
|
183 | }();
|
184 |
|
185 |
|
186 |
|
187 | /***/ }),
|
188 |
|
189 | /***/ "./src/core/Formatter.ts":
|
190 | /*!*******************************!*\
|
191 | !*** ./src/core/Formatter.ts ***!
|
192 | \*******************************/
|
193 | /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
194 |
|
195 | __webpack_require__.r(__webpack_exports__);
|
196 | /* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
197 | /* harmony export */ "default": () => (/* binding */ Formatter)
|
198 | /* harmony export */ });
|
199 | /* harmony import */ var _Indentation__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./Indentation */ "./src/core/Indentation.ts");
|
200 | /* harmony import */ var _InlineBlock__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./InlineBlock */ "./src/core/InlineBlock.ts");
|
201 | /* harmony import */ var _Params__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./Params */ "./src/core/Params.ts");
|
202 | /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../utils */ "./src/utils.ts");
|
203 | /* harmony import */ var _token__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./token */ "./src/core/token.ts");
|
204 | /* harmony import */ var _formatCommaPositions__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./formatCommaPositions */ "./src/core/formatCommaPositions.ts");
|
205 | /* harmony import */ var _formatAliasPositions__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./formatAliasPositions */ "./src/core/formatAliasPositions.ts");
|
206 | /* harmony import */ var _tabularStyle__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./tabularStyle */ "./src/core/tabularStyle.ts");
|
207 | /* harmony import */ var _AliasAs__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./AliasAs */ "./src/core/AliasAs.ts");
|
208 | /* harmony import */ var _AsTokenFactory__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./AsTokenFactory */ "./src/core/AsTokenFactory.ts");
|
209 | function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; }
|
210 |
|
211 | function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
212 |
|
213 | function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
214 |
|
215 | function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
216 |
|
217 | function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
218 |
|
219 | function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
220 |
|
221 |
|
222 |
|
223 |
|
224 |
|
225 |
|
226 |
|
227 |
|
228 |
|
229 |
|
230 |
|
231 | /** Main formatter class that produces a final output string from list of tokens */
|
232 |
|
233 | var Formatter = /*#__PURE__*/function () {
|
234 | function Formatter(cfg) {
|
235 | _classCallCheck(this, Formatter);
|
236 |
|
237 | this.currentNewline = true;
|
238 | this.previousReservedToken = _token__WEBPACK_IMPORTED_MODULE_4__.EOF_TOKEN;
|
239 | this.previousCommandToken = _token__WEBPACK_IMPORTED_MODULE_4__.EOF_TOKEN;
|
240 | this.tokens = [];
|
241 | this.index = -1;
|
242 | this.cfg = cfg;
|
243 | this.indentation = new _Indentation__WEBPACK_IMPORTED_MODULE_0__["default"](this.indentString());
|
244 | this.inlineBlock = new _InlineBlock__WEBPACK_IMPORTED_MODULE_1__["default"](this.cfg.expressionWidth);
|
245 | this.aliasAs = new _AliasAs__WEBPACK_IMPORTED_MODULE_8__["default"](this.cfg.aliasAs, this);
|
246 | this.params = new _Params__WEBPACK_IMPORTED_MODULE_2__["default"](this.cfg.params);
|
247 | this.asTokenFactory = new _AsTokenFactory__WEBPACK_IMPORTED_MODULE_9__["default"](this.cfg.keywordCase);
|
248 | }
|
249 |
|
250 | _createClass(Formatter, [{
|
251 | key: "indentString",
|
252 | value: function indentString() {
|
253 | if (this.isTabularStyle()) {
|
254 | return ' '.repeat(10);
|
255 | }
|
256 |
|
257 | if (this.cfg.useTabs) {
|
258 | return '\t';
|
259 | }
|
260 |
|
261 | return ' '.repeat(this.cfg.tabWidth);
|
262 | }
|
263 | /**
|
264 | * SQL Tokenizer for this formatter, provided by subclasses.
|
265 | */
|
266 |
|
267 | }, {
|
268 | key: "tokenizer",
|
269 | value: function tokenizer() {
|
270 | throw new Error('tokenizer() not implemented by subclass');
|
271 | }
|
272 | /**
|
273 | * Reprocess and modify a token based on parsed context.
|
274 | * Subclasses can override this to modify tokens during formatting.
|
275 | * @param {Token} token - The token to modify
|
276 | * @return {Token} new token or the original
|
277 | */
|
278 |
|
279 | }, {
|
280 | key: "tokenOverride",
|
281 | value: function tokenOverride(token) {
|
282 | return token;
|
283 | }
|
284 | /**
|
285 | * Formats an SQL query.
|
286 | * @param {string} query - The SQL query string to be formatted
|
287 | * @return {string} The formatter query
|
288 | */
|
289 |
|
290 | }, {
|
291 | key: "format",
|
292 | value: function format(query) {
|
293 | this.tokens = this.tokenizer().tokenize(query);
|
294 | this.asTokenFactory = new _AsTokenFactory__WEBPACK_IMPORTED_MODULE_9__["default"](this.cfg.keywordCase, this.tokens);
|
295 | var formattedQuery = this.getFormattedQueryFromTokens();
|
296 | var finalQuery = this.postFormat(formattedQuery);
|
297 | return finalQuery.replace(/^\n*/, '').trimEnd();
|
298 | }
|
299 | /**
|
300 | * Does post-processing on the formatted query.
|
301 | */
|
302 |
|
303 | }, {
|
304 | key: "postFormat",
|
305 | value: function postFormat(query) {
|
306 | if (this.cfg.tabulateAlias) {
|
307 | query = (0,_formatAliasPositions__WEBPACK_IMPORTED_MODULE_6__["default"])(query);
|
308 | }
|
309 |
|
310 | if (this.cfg.commaPosition === 'before' || this.cfg.commaPosition === 'tabular') {
|
311 | query = (0,_formatCommaPositions__WEBPACK_IMPORTED_MODULE_5__["default"])(query, this.cfg.commaPosition, this.indentString());
|
312 | }
|
313 |
|
314 | return query;
|
315 | }
|
316 | /**
|
317 | * Performs main construction of query from token list, delegates to other methods for formatting based on token criteria
|
318 | */
|
319 |
|
320 | }, {
|
321 | key: "getFormattedQueryFromTokens",
|
322 | value: function getFormattedQueryFromTokens() {
|
323 | var formattedQuery = '';
|
324 |
|
325 | for (this.index = 0; this.index < this.tokens.length; this.index++) {
|
326 | var token = this.tokenOverride(this.tokens[this.index]); // if token is a Reserved Keyword, Command, Binary Command, Dependent Clause, Logical Operator
|
327 |
|
328 | if ((0,_token__WEBPACK_IMPORTED_MODULE_4__.isReserved)(token)) {
|
329 | this.previousReservedToken = token;
|
330 |
|
331 | if (token.type !== _token__WEBPACK_IMPORTED_MODULE_4__.TokenType.RESERVED_KEYWORD && token.type !== _token__WEBPACK_IMPORTED_MODULE_4__.TokenType.RESERVED_JOIN_CONDITION) {
|
332 | // convert Reserved Command or Logical Operator to tabular format if needed
|
333 | token = (0,_tabularStyle__WEBPACK_IMPORTED_MODULE_7__.toTabularToken)(token, this.cfg.indentStyle);
|
334 | }
|
335 |
|
336 | if (token.type === _token__WEBPACK_IMPORTED_MODULE_4__.TokenType.RESERVED_COMMAND) {
|
337 | this.previousCommandToken = token;
|
338 | }
|
339 | }
|
340 |
|
341 | if (token.type === _token__WEBPACK_IMPORTED_MODULE_4__.TokenType.LINE_COMMENT) {
|
342 | formattedQuery = this.formatLineComment(token, formattedQuery);
|
343 | } else if (token.type === _token__WEBPACK_IMPORTED_MODULE_4__.TokenType.BLOCK_COMMENT) {
|
344 | formattedQuery = this.formatBlockComment(token, formattedQuery);
|
345 | } else if (token.type === _token__WEBPACK_IMPORTED_MODULE_4__.TokenType.RESERVED_COMMAND) {
|
346 | this.currentNewline = this.checkNewline(token);
|
347 | formattedQuery = this.formatCommand(token, formattedQuery);
|
348 | } else if (token.type === _token__WEBPACK_IMPORTED_MODULE_4__.TokenType.RESERVED_BINARY_COMMAND) {
|
349 | formattedQuery = this.formatBinaryCommand(token, formattedQuery);
|
350 | } else if (token.type === _token__WEBPACK_IMPORTED_MODULE_4__.TokenType.RESERVED_DEPENDENT_CLAUSE) {
|
351 | formattedQuery = this.formatDependentClause(token, formattedQuery);
|
352 | } else if (token.type === _token__WEBPACK_IMPORTED_MODULE_4__.TokenType.RESERVED_JOIN_CONDITION) {
|
353 | formattedQuery = this.formatJoinCondition(token, formattedQuery);
|
354 | } else if (token.type === _token__WEBPACK_IMPORTED_MODULE_4__.TokenType.RESERVED_LOGICAL_OPERATOR) {
|
355 | formattedQuery = this.formatLogicalOperator(token, formattedQuery);
|
356 | } else if (token.type === _token__WEBPACK_IMPORTED_MODULE_4__.TokenType.RESERVED_KEYWORD) {
|
357 | formattedQuery = this.formatKeyword(token, formattedQuery);
|
358 | } else if (token.type === _token__WEBPACK_IMPORTED_MODULE_4__.TokenType.BLOCK_START) {
|
359 | formattedQuery = this.formatBlockStart(token, formattedQuery);
|
360 | } else if (token.type === _token__WEBPACK_IMPORTED_MODULE_4__.TokenType.BLOCK_END) {
|
361 | formattedQuery = this.formatBlockEnd(token, formattedQuery);
|
362 | } else if (token.type === _token__WEBPACK_IMPORTED_MODULE_4__.TokenType.PLACEHOLDER) {
|
363 | formattedQuery = this.formatPlaceholder(token, formattedQuery);
|
364 | } else if (token.type === _token__WEBPACK_IMPORTED_MODULE_4__.TokenType.OPERATOR) {
|
365 | formattedQuery = this.formatOperator(token, formattedQuery);
|
366 | } else {
|
367 | formattedQuery = this.formatWord(token, formattedQuery);
|
368 | }
|
369 | }
|
370 |
|
371 | return (0,_tabularStyle__WEBPACK_IMPORTED_MODULE_7__.replaceTabularPlaceholders)(formattedQuery);
|
372 | }
|
373 | /**
|
374 | * Formats word tokens + any potential AS tokens for aliases
|
375 | */
|
376 |
|
377 | }, {
|
378 | key: "formatWord",
|
379 | value: function formatWord(token, query) {
|
380 | var finalQuery = query;
|
381 |
|
382 | if (this.aliasAs.shouldAddBefore(token)) {
|
383 | finalQuery = this.formatWithSpaces(this.asTokenFactory.token(), finalQuery);
|
384 | }
|
385 |
|
386 | finalQuery = this.formatWithSpaces(token, finalQuery);
|
387 |
|
388 | if (this.aliasAs.shouldAddAfter()) {
|
389 | finalQuery = this.formatWithSpaces(this.asTokenFactory.token(), finalQuery);
|
390 | }
|
391 |
|
392 | return finalQuery;
|
393 | }
|
394 | /**
|
395 | * Checks if a newline should currently be inserted
|
396 | */
|
397 |
|
398 | }, {
|
399 | key: "checkNewline",
|
400 | value: function checkNewline(token) {
|
401 | var nextTokens = this.tokensUntilNextCommandOrQueryEnd(); // auto break if SELECT includes CASE statements
|
402 |
|
403 | if (this.isWithinSelect() && nextTokens.some(_token__WEBPACK_IMPORTED_MODULE_4__.isToken.CASE)) {
|
404 | return true;
|
405 | }
|
406 |
|
407 | switch (this.cfg.multilineLists) {
|
408 | case 'always':
|
409 | return true;
|
410 |
|
411 | case 'avoid':
|
412 | return false;
|
413 |
|
414 | case 'expressionWidth':
|
415 | return this.inlineWidth(token, nextTokens) > this.cfg.expressionWidth;
|
416 |
|
417 | default:
|
418 | // multilineLists mode is a number
|
419 | return this.countClauses(nextTokens) > this.cfg.multilineLists || this.inlineWidth(token, nextTokens) > this.cfg.expressionWidth;
|
420 | }
|
421 | }
|
422 | }, {
|
423 | key: "inlineWidth",
|
424 | value: function inlineWidth(token, tokens) {
|
425 | var tokensString = tokens.map(function (_ref) {
|
426 | var value = _ref.value;
|
427 | return value === ',' ? value + ' ' : value;
|
428 | }).join('');
|
429 | return "".concat(token.whitespaceBefore).concat(token.value, " ").concat(tokensString).length;
|
430 | }
|
431 | /**
|
432 | * Counts comma-separated clauses (doesn't count commas inside blocks)
|
433 | * Note: There's always at least one clause.
|
434 | */
|
435 |
|
436 | }, {
|
437 | key: "countClauses",
|
438 | value: function countClauses(tokens) {
|
439 | var count = 1;
|
440 | var openBlocks = 0;
|
441 |
|
442 | var _iterator = _createForOfIteratorHelper(tokens),
|
443 | _step;
|
444 |
|
445 | try {
|
446 | for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
447 | var _step$value = _step.value,
|
448 | type = _step$value.type,
|
449 | value = _step$value.value;
|
450 |
|
451 | if (value === ',' && openBlocks === 0) {
|
452 | count++;
|
453 | }
|
454 |
|
455 | if (type === _token__WEBPACK_IMPORTED_MODULE_4__.TokenType.BLOCK_START) {
|
456 | openBlocks++;
|
457 | }
|
458 |
|
459 | if (type === _token__WEBPACK_IMPORTED_MODULE_4__.TokenType.BLOCK_END) {
|
460 | openBlocks--;
|
461 | }
|
462 | }
|
463 | } catch (err) {
|
464 | _iterator.e(err);
|
465 | } finally {
|
466 | _iterator.f();
|
467 | }
|
468 |
|
469 | return count;
|
470 | }
|
471 | /** get all tokens between current token and next Reserved Command or query end */
|
472 |
|
473 | }, {
|
474 | key: "tokensUntilNextCommandOrQueryEnd",
|
475 | value: function tokensUntilNextCommandOrQueryEnd() {
|
476 | var tail = this.tokens.slice(this.index + 1);
|
477 | return tail.slice(0, tail.length ? tail.findIndex(function (token) {
|
478 | return (0,_token__WEBPACK_IMPORTED_MODULE_4__.isCommand)(token) || token.value === ';';
|
479 | }) : undefined);
|
480 | }
|
481 | /** Formats a line comment onto query */
|
482 |
|
483 | }, {
|
484 | key: "formatLineComment",
|
485 | value: function formatLineComment(token, query) {
|
486 | return this.addNewline(query + this.show(token));
|
487 | }
|
488 | /** Formats a block comment onto query */
|
489 |
|
490 | }, {
|
491 | key: "formatBlockComment",
|
492 | value: function formatBlockComment(token, query) {
|
493 | return this.addNewline(this.addNewline(query) + this.indentComment(token.value));
|
494 | }
|
495 | /** Aligns comment to current indentation level */
|
496 |
|
497 | }, {
|
498 | key: "indentComment",
|
499 | value: function indentComment(comment) {
|
500 | return comment.replace(/\n[\t ]*/g, '\n' + this.indentation.getIndent() + ' ');
|
501 | }
|
502 | /**
|
503 | * Formats a Reserved Command onto query, increasing indentation level where necessary
|
504 | */
|
505 |
|
506 | }, {
|
507 | key: "formatCommand",
|
508 | value: function formatCommand(token, query) {
|
509 | this.indentation.decreaseTopLevel();
|
510 | query = this.addNewline(query); // indent tabular formats, except when preceding a (
|
511 |
|
512 | if (this.isTabularStyle()) {
|
513 | if (this.tokenLookAhead().value !== '(') {
|
514 | this.indentation.increaseTopLevel();
|
515 | }
|
516 | } else {
|
517 | this.indentation.increaseTopLevel();
|
518 | }
|
519 |
|
520 | query += this.equalizeWhitespace(this.show(token)); // print token onto query
|
521 |
|
522 | if (this.currentNewline && !this.isTabularStyle()) {
|
523 | query = this.addNewline(query);
|
524 | } else {
|
525 | query += ' ';
|
526 | }
|
527 |
|
528 | return query;
|
529 | }
|
530 | /**
|
531 | * Formats a Reserved Binary Command onto query, joining neighbouring tokens
|
532 | */
|
533 |
|
534 | }, {
|
535 | key: "formatBinaryCommand",
|
536 | value: function formatBinaryCommand(token, query) {
|
537 | var isJoin = /JOIN/i.test(token.value); // check if token contains JOIN
|
538 |
|
539 | if (!isJoin || this.isTabularStyle()) {
|
540 | // decrease for boolean set operators or in tabular mode
|
541 | this.indentation.decreaseTopLevel();
|
542 | }
|
543 |
|
544 | query = this.addNewline(query) + this.equalizeWhitespace(this.show(token));
|
545 | return isJoin ? query + ' ' : this.addNewline(query);
|
546 | }
|
547 | /**
|
548 | * Formats a Reserved Keyword onto query, skipping AS if disabled
|
549 | */
|
550 |
|
551 | }, {
|
552 | key: "formatKeyword",
|
553 | value: function formatKeyword(token, query) {
|
554 | if (_token__WEBPACK_IMPORTED_MODULE_4__.isToken.AS(token) && this.aliasAs.shouldRemove()) {
|
555 | return query;
|
556 | }
|
557 |
|
558 | return this.formatWithSpaces(token, query);
|
559 | }
|
560 | /**
|
561 | * Formats a Reserved Dependent Clause token onto query, supporting the keyword that precedes it
|
562 | */
|
563 |
|
564 | }, {
|
565 | key: "formatDependentClause",
|
566 | value: function formatDependentClause(token, query) {
|
567 | return this.addNewline(query) + this.equalizeWhitespace(this.show(token)) + ' ';
|
568 | } // Formats ON and USING keywords
|
569 |
|
570 | }, {
|
571 | key: "formatJoinCondition",
|
572 | value: function formatJoinCondition(token, query) {
|
573 | return query + this.equalizeWhitespace(this.show(token)) + ' ';
|
574 | }
|
575 | /**
|
576 | * Formats an Operator onto query, following rules for specific characters
|
577 | */
|
578 |
|
579 | }, {
|
580 | key: "formatOperator",
|
581 | value: function formatOperator(token, query) {
|
582 | // special operator
|
583 | if (token.value === ',') {
|
584 | return this.formatComma(token, query);
|
585 | } else if (token.value === ';') {
|
586 | return this.formatQuerySeparator(token, query);
|
587 | } else if (['$', '['].includes(token.value)) {
|
588 | return this.formatWithSpaces(token, query, 'before');
|
589 | } else if ([':', ']'].includes(token.value)) {
|
590 | return this.formatWithSpaces(token, query, 'after');
|
591 | } else if (['.', '{', '}', '`'].includes(token.value)) {
|
592 | return this.formatWithoutSpaces(token, query);
|
593 | } // regular operator
|
594 |
|
595 |
|
596 | if (this.cfg.denseOperators && this.tokenLookBehind().type !== _token__WEBPACK_IMPORTED_MODULE_4__.TokenType.RESERVED_COMMAND) {
|
597 | // do not trim whitespace if SELECT *
|
598 | return this.formatWithoutSpaces(token, query);
|
599 | }
|
600 |
|
601 | return this.formatWithSpaces(token, query);
|
602 | }
|
603 | /**
|
604 | * Formats a Logical Operator onto query, joining boolean conditions
|
605 | */
|
606 |
|
607 | }, {
|
608 | key: "formatLogicalOperator",
|
609 | value: function formatLogicalOperator(token, query) {
|
610 | // ignore AND when BETWEEN x [AND] y
|
611 | if (_token__WEBPACK_IMPORTED_MODULE_4__.isToken.AND(token) && _token__WEBPACK_IMPORTED_MODULE_4__.isToken.BETWEEN(this.tokenLookBehind(2))) {
|
612 | return this.formatWithSpaces(token, query);
|
613 | }
|
614 |
|
615 | if (this.isTabularStyle()) {
|
616 | this.indentation.decreaseTopLevel();
|
617 | }
|
618 |
|
619 | if (this.cfg.logicalOperatorNewline === 'before') {
|
620 | return (this.currentNewline ? this.addNewline(query) : query) + this.equalizeWhitespace(this.show(token)) + ' ';
|
621 | } else {
|
622 | query += this.show(token);
|
623 | return this.currentNewline ? this.addNewline(query) : query;
|
624 | }
|
625 | }
|
626 | /** Replace any sequence of whitespace characters with single space */
|
627 |
|
628 | }, {
|
629 | key: "equalizeWhitespace",
|
630 | value: function equalizeWhitespace(string) {
|
631 | return string.replace(/[\t-\r \xA0\u1680\u2000-\u200A\u2028\u2029\u202F\u205F\u3000\uFEFF]+/g, ' ');
|
632 | }
|
633 | /**
|
634 | * Formats a Block Start token (left paren/bracket/brace, CASE) onto query, beginning an Inline Block or increasing indentation where necessary
|
635 | */
|
636 |
|
637 | }, {
|
638 | key: "formatBlockStart",
|
639 | value: function formatBlockStart(token, query) {
|
640 | var _a;
|
641 |
|
642 | if (_token__WEBPACK_IMPORTED_MODULE_4__.isToken.CASE(token)) {
|
643 | query = this.formatWithSpaces(token, query);
|
644 | } else {
|
645 | // Take out the preceding space unless there was whitespace there in the original query
|
646 | // or another opening parens or line comment
|
647 | var preserveWhitespaceFor = [_token__WEBPACK_IMPORTED_MODULE_4__.TokenType.BLOCK_START, _token__WEBPACK_IMPORTED_MODULE_4__.TokenType.LINE_COMMENT, _token__WEBPACK_IMPORTED_MODULE_4__.TokenType.OPERATOR];
|
648 |
|
649 | if (((_a = token.whitespaceBefore) === null || _a === void 0 ? void 0 : _a.length) === 0 && !preserveWhitespaceFor.includes(this.tokenLookBehind().type)) {
|
650 | query = (0,_utils__WEBPACK_IMPORTED_MODULE_3__.trimSpacesEnd)(query);
|
651 | } else if (!this.cfg.newlineBeforeOpenParen) {
|
652 | query = query.trimEnd() + ' ';
|
653 | }
|
654 |
|
655 | query += this.show(token);
|
656 | this.inlineBlock.beginIfPossible(this.tokens, this.index);
|
657 | }
|
658 |
|
659 | if (!this.inlineBlock.isActive()) {
|
660 | this.indentation.increaseBlockLevel();
|
661 |
|
662 | if (!_token__WEBPACK_IMPORTED_MODULE_4__.isToken.CASE(token) || this.cfg.multilineLists === 'always') {
|
663 | query = this.addNewline(query);
|
664 | }
|
665 | }
|
666 |
|
667 | return query;
|
668 | }
|
669 | /**
|
670 | * Formats a Block End token (right paren/bracket/brace, END) onto query, closing an Inline Block or decreasing indentation where necessary
|
671 | */
|
672 |
|
673 | }, {
|
674 | key: "formatBlockEnd",
|
675 | value: function formatBlockEnd(token, query) {
|
676 | if (this.inlineBlock.isActive()) {
|
677 | this.inlineBlock.end();
|
678 |
|
679 | if (_token__WEBPACK_IMPORTED_MODULE_4__.isToken.END(token)) {
|
680 | return this.formatWithSpaces(token, query); // add space before END when closing inline block
|
681 | }
|
682 |
|
683 | return this.formatWithSpaces(token, query, 'after'); // do not add space before )
|
684 | } else {
|
685 | this.indentation.decreaseBlockLevel();
|
686 |
|
687 | if (this.isTabularStyle()) {
|
688 | // +1 extra indentation step for the closing paren
|
689 | query = this.addNewline(query) + this.indentation.getSingleIndent();
|
690 | } else if (this.cfg.newlineBeforeCloseParen) {
|
691 | query = this.addNewline(query);
|
692 | } else {
|
693 | query = query.trimEnd() + ' ';
|
694 | }
|
695 |
|
696 | return this.formatWithSpaces(token, query);
|
697 | }
|
698 | }
|
699 | /**
|
700 | * Formats a Placeholder item onto query, to be replaced with the value of the placeholder
|
701 | */
|
702 |
|
703 | }, {
|
704 | key: "formatPlaceholder",
|
705 | value: function formatPlaceholder(token, query) {
|
706 | return query + this.params.get(token) + ' ';
|
707 | }
|
708 | /**
|
709 | * Formats a comma Operator onto query, ending line unless in an Inline Block
|
710 | */
|
711 |
|
712 | }, {
|
713 | key: "formatComma",
|
714 | value: function formatComma(token, query) {
|
715 | query = (0,_utils__WEBPACK_IMPORTED_MODULE_3__.trimSpacesEnd)(query) + this.show(token) + ' ';
|
716 |
|
717 | if (this.inlineBlock.isActive()) {
|
718 | return query;
|
719 | } else if (_token__WEBPACK_IMPORTED_MODULE_4__.isToken.LIMIT(this.getPreviousReservedToken())) {
|
720 | return query;
|
721 | } else if (this.currentNewline) {
|
722 | return this.addNewline(query);
|
723 | } else {
|
724 | return query;
|
725 | }
|
726 | }
|
727 | /** Simple append of token onto query */
|
728 |
|
729 | }, {
|
730 | key: "formatWithoutSpaces",
|
731 | value: function formatWithoutSpaces(token, query) {
|
732 | return (0,_utils__WEBPACK_IMPORTED_MODULE_3__.trimSpacesEnd)(query) + this.show(token);
|
733 | }
|
734 | /**
|
735 | * Add token onto query with spaces - either before, after, or both
|
736 | */
|
737 |
|
738 | }, {
|
739 | key: "formatWithSpaces",
|
740 | value: function formatWithSpaces(token, query) {
|
741 | var addSpace = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'both';
|
742 | var before = addSpace === 'after' ? (0,_utils__WEBPACK_IMPORTED_MODULE_3__.trimSpacesEnd)(query) : query;
|
743 | var after = addSpace === 'before' ? '' : ' ';
|
744 | return before + this.show(token) + after;
|
745 | }
|
746 | }, {
|
747 | key: "formatQuerySeparator",
|
748 | value: function formatQuerySeparator(token, query) {
|
749 | this.indentation.resetIndentation();
|
750 | return [(0,_utils__WEBPACK_IMPORTED_MODULE_3__.trimSpacesEnd)(query), this.cfg.newlineBeforeSemicolon ? '\n' : '', this.show(token), '\n'.repeat(this.cfg.linesBetweenQueries + 1)].join('');
|
751 | }
|
752 | /** Converts token to string, uppercasing if enabled */
|
753 |
|
754 | }, {
|
755 | key: "show",
|
756 | value: function show(token) {
|
757 | if ((0,_token__WEBPACK_IMPORTED_MODULE_4__.isReserved)(token) || token.type === _token__WEBPACK_IMPORTED_MODULE_4__.TokenType.BLOCK_START || token.type === _token__WEBPACK_IMPORTED_MODULE_4__.TokenType.BLOCK_END) {
|
758 | switch (this.cfg.keywordCase) {
|
759 | case 'preserve':
|
760 | return token.value;
|
761 |
|
762 | case 'upper':
|
763 | return token.value.toUpperCase();
|
764 |
|
765 | case 'lower':
|
766 | return token.value.toLowerCase();
|
767 | }
|
768 | } else {
|
769 | return token.value;
|
770 | }
|
771 | }
|
772 | /** Inserts a newline onto the query */
|
773 |
|
774 | }, {
|
775 | key: "addNewline",
|
776 | value: function addNewline(query) {
|
777 | query = (0,_utils__WEBPACK_IMPORTED_MODULE_3__.trimSpacesEnd)(query);
|
778 |
|
779 | if (!query.endsWith('\n')) {
|
780 | query += '\n';
|
781 | }
|
782 |
|
783 | return query + this.indentation.getIndent();
|
784 | }
|
785 | }, {
|
786 | key: "isTabularStyle",
|
787 | value: function isTabularStyle() {
|
788 | return this.cfg.indentStyle === 'tabularLeft' || this.cfg.indentStyle === 'tabularRight';
|
789 | }
|
790 | /** Returns the latest encountered reserved keyword token */
|
791 |
|
792 | }, {
|
793 | key: "getPreviousReservedToken",
|
794 | value: function getPreviousReservedToken() {
|
795 | return this.previousReservedToken;
|
796 | }
|
797 | /** True when currently within SELECT command */
|
798 |
|
799 | }, {
|
800 | key: "isWithinSelect",
|
801 | value: function isWithinSelect() {
|
802 | return _token__WEBPACK_IMPORTED_MODULE_4__.isToken.SELECT(this.previousCommandToken);
|
803 | }
|
804 | /** Fetches nth previous token from the token stream */
|
805 |
|
806 | }, {
|
807 | key: "tokenLookBehind",
|
808 | value: function tokenLookBehind() {
|
809 | var n = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 1;
|
810 | return this.tokens[this.index - n] || _token__WEBPACK_IMPORTED_MODULE_4__.EOF_TOKEN;
|
811 | }
|
812 | /** Fetches nth next token from the token stream */
|
813 |
|
814 | }, {
|
815 | key: "tokenLookAhead",
|
816 | value: function tokenLookAhead() {
|
817 | var n = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 1;
|
818 | return this.tokens[this.index + n] || _token__WEBPACK_IMPORTED_MODULE_4__.EOF_TOKEN;
|
819 | }
|
820 | }]);
|
821 |
|
822 | return Formatter;
|
823 | }();
|
824 |
|
825 |
|
826 |
|
827 | /***/ }),
|
828 |
|
829 | /***/ "./src/core/Indentation.ts":
|
830 | /*!*********************************!*\
|
831 | !*** ./src/core/Indentation.ts ***!
|
832 | \*********************************/
|
833 | /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
834 |
|
835 | __webpack_require__.r(__webpack_exports__);
|
836 | /* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
837 | /* harmony export */ "default": () => (/* binding */ Indentation)
|
838 | /* harmony export */ });
|
839 | /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../utils */ "./src/utils.ts");
|
840 | function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
841 |
|
842 | function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
843 |
|
844 | function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
845 |
|
846 |
|
847 | var INDENT_TYPE_TOP_LEVEL = 'top-level';
|
848 | var INDENT_TYPE_BLOCK_LEVEL = 'block-level';
|
849 | /**
|
850 | * Manages indentation levels.
|
851 | *
|
852 | * There are two types of indentation levels:
|
853 | *
|
854 | * - BLOCK_LEVEL : increased by open-parenthesis
|
855 | * - TOP_LEVEL : increased by RESERVED_COMMAND words
|
856 | */
|
857 |
|
858 | var Indentation = /*#__PURE__*/function () {
|
859 | /**
|
860 | * @param {string} indent A string to indent with
|
861 | */
|
862 | function Indentation(indent) {
|
863 | _classCallCheck(this, Indentation);
|
864 |
|
865 | this.indent = indent;
|
866 | this.indentTypes = [];
|
867 | }
|
868 | /**
|
869 | * Returns indentation string for single indentation step.
|
870 | */
|
871 |
|
872 |
|
873 | _createClass(Indentation, [{
|
874 | key: "getSingleIndent",
|
875 | value: function getSingleIndent() {
|
876 | return this.indent;
|
877 | }
|
878 | /**
|
879 | * Returns current indentation string.
|
880 | * @return {string} indentation string based on indentTypes
|
881 | */
|
882 |
|
883 | }, {
|
884 | key: "getIndent",
|
885 | value: function getIndent() {
|
886 | return this.indent.repeat(this.indentTypes.length);
|
887 | }
|
888 | /**
|
889 | * Increases indentation by one top-level indent.
|
890 | */
|
891 |
|
892 | }, {
|
893 | key: "increaseTopLevel",
|
894 | value: function increaseTopLevel() {
|
895 | this.indentTypes.push(INDENT_TYPE_TOP_LEVEL);
|
896 | }
|
897 | /**
|
898 | * Increases indentation by one block-level indent.
|
899 | */
|
900 |
|
901 | }, {
|
902 | key: "increaseBlockLevel",
|
903 | value: function increaseBlockLevel() {
|
904 | this.indentTypes.push(INDENT_TYPE_BLOCK_LEVEL);
|
905 | }
|
906 | /**
|
907 | * Decreases indentation by one top-level indent.
|
908 | * Does nothing when the previous indent is not top-level.
|
909 | */
|
910 |
|
911 | }, {
|
912 | key: "decreaseTopLevel",
|
913 | value: function decreaseTopLevel() {
|
914 | if (this.indentTypes.length > 0 && (0,_utils__WEBPACK_IMPORTED_MODULE_0__.last)(this.indentTypes) === INDENT_TYPE_TOP_LEVEL) {
|
915 | this.indentTypes.pop();
|
916 | }
|
917 | }
|
918 | /**
|
919 | * Decreases indentation by one block-level indent.
|
920 | * If there are top-level indents within the block-level indent,
|
921 | * throws away these as well.
|
922 | */
|
923 |
|
924 | }, {
|
925 | key: "decreaseBlockLevel",
|
926 | value: function decreaseBlockLevel() {
|
927 | while (this.indentTypes.length > 0) {
|
928 | var type = this.indentTypes.pop();
|
929 |
|
930 | if (type !== INDENT_TYPE_TOP_LEVEL) {
|
931 | break;
|
932 | }
|
933 | }
|
934 | }
|
935 | /** Clears all indentation */
|
936 |
|
937 | }, {
|
938 | key: "resetIndentation",
|
939 | value: function resetIndentation() {
|
940 | this.indentTypes = [];
|
941 | }
|
942 | }]);
|
943 |
|
944 | return Indentation;
|
945 | }();
|
946 |
|
947 |
|
948 |
|
949 | /***/ }),
|
950 |
|
951 | /***/ "./src/core/InlineBlock.ts":
|
952 | /*!*********************************!*\
|
953 | !*** ./src/core/InlineBlock.ts ***!
|
954 | \*********************************/
|
955 | /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
956 |
|
957 | __webpack_require__.r(__webpack_exports__);
|
958 | /* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
959 | /* harmony export */ "default": () => (/* binding */ InlineBlock)
|
960 | /* harmony export */ });
|
961 | /* harmony import */ var _token__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./token */ "./src/core/token.ts");
|
962 | function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
963 |
|
964 | function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
965 |
|
966 | function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
967 |
|
968 |
|
969 | /**
|
970 | * Bookkeeper for inline blocks.
|
971 | *
|
972 | * Inline blocks are parenthesised expressions that are shorter than INLINE_MAX_LENGTH.
|
973 | * These blocks are formatted on a single line, unlike longer parenthesised
|
974 | * expressions where open-parenthesis causes newline and increase of indentation.
|
975 | */
|
976 |
|
977 | var InlineBlock = /*#__PURE__*/function () {
|
978 | function InlineBlock(expressionWidth) {
|
979 | _classCallCheck(this, InlineBlock);
|
980 |
|
981 | this.level = 0;
|
982 | this.expressionWidth = expressionWidth;
|
983 | }
|
984 | /**
|
985 | * Begins inline block when lookahead through upcoming tokens determines
|
986 | * that the block would be smaller than INLINE_MAX_LENGTH.
|
987 | * @param {Token[]} tokens Array of all tokens
|
988 | * @param {Number} index Current token position
|
989 | */
|
990 |
|
991 |
|
992 | _createClass(InlineBlock, [{
|
993 | key: "beginIfPossible",
|
994 | value: function beginIfPossible(tokens, index) {
|
995 | if (this.level === 0 && this.isInlineBlock(tokens, index)) {
|
996 | this.level = 1;
|
997 | } else if (this.level > 0) {
|
998 | this.level++;
|
999 | } else {
|
1000 | this.level = 0;
|
1001 | }
|
1002 | }
|
1003 | /**
|
1004 | * Finishes current inline block.
|
1005 | * There might be several nested ones.
|
1006 | */
|
1007 |
|
1008 | }, {
|
1009 | key: "end",
|
1010 | value: function end() {
|
1011 | this.level--;
|
1012 | }
|
1013 | /**
|
1014 | * True when inside an inline block
|
1015 | */
|
1016 |
|
1017 | }, {
|
1018 | key: "isActive",
|
1019 | value: function isActive() {
|
1020 | return this.level > 0;
|
1021 | }
|
1022 | /**
|
1023 | * Check if this should be an inline parentheses block
|
1024 | * Examples are "NOW()", "COUNT(*)", "int(10)", key(`somecolumn`), DECIMAL(7,2)
|
1025 | */
|
1026 |
|
1027 | }, {
|
1028 | key: "isInlineBlock",
|
1029 | value: function isInlineBlock(tokens, index) {
|
1030 | var length = 0;
|
1031 | var level = 0;
|
1032 |
|
1033 | for (var i = index; i < tokens.length; i++) {
|
1034 | var token = tokens[i];
|
1035 | length += token.value.length;
|
1036 |
|
1037 | if (this.isForbiddenToken(token)) {
|
1038 | return false;
|
1039 | } // Overran max length
|
1040 |
|
1041 |
|
1042 | if (length > this.expressionWidth) {
|
1043 | return false;
|
1044 | }
|
1045 |
|
1046 | if (token.type === _token__WEBPACK_IMPORTED_MODULE_0__.TokenType.BLOCK_START) {
|
1047 | level++;
|
1048 | } else if (token.type === _token__WEBPACK_IMPORTED_MODULE_0__.TokenType.BLOCK_END) {
|
1049 | level--;
|
1050 |
|
1051 | if (level === 0) {
|
1052 | return true;
|
1053 | }
|
1054 | }
|
1055 | }
|
1056 |
|
1057 | return false;
|
1058 | } // Reserved words that cause newlines, comments and semicolons
|
1059 | // are not allowed inside inline parentheses block
|
1060 |
|
1061 | }, {
|
1062 | key: "isForbiddenToken",
|
1063 | value: function isForbiddenToken(_ref) {
|
1064 | var type = _ref.type,
|
1065 | value = _ref.value;
|
1066 | return type === _token__WEBPACK_IMPORTED_MODULE_0__.TokenType.RESERVED_COMMAND || type === _token__WEBPACK_IMPORTED_MODULE_0__.TokenType.RESERVED_LOGICAL_OPERATOR || // type === TokenType.LINE_COMMENT ||
|
1067 | type === _token__WEBPACK_IMPORTED_MODULE_0__.TokenType.BLOCK_COMMENT || value === ';' || _token__WEBPACK_IMPORTED_MODULE_0__.isToken.CASE({
|
1068 | type: type,
|
1069 | value: value
|
1070 | }) // CASE cannot have inline blocks
|
1071 | ;
|
1072 | }
|
1073 | }]);
|
1074 |
|
1075 | return InlineBlock;
|
1076 | }();
|
1077 |
|
1078 |
|
1079 |
|
1080 | /***/ }),
|
1081 |
|
1082 | /***/ "./src/core/Params.ts":
|
1083 | /*!****************************!*\
|
1084 | !*** ./src/core/Params.ts ***!
|
1085 | \****************************/
|
1086 | /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
1087 |
|
1088 | __webpack_require__.r(__webpack_exports__);
|
1089 | /* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
1090 | /* harmony export */ "default": () => (/* binding */ Params)
|
1091 | /* harmony export */ });
|
1092 | function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
1093 |
|
1094 | function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
1095 |
|
1096 | function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
1097 |
|
1098 | /**
|
1099 | * Handles placeholder replacement with given params.
|
1100 | */
|
1101 | var Params = /*#__PURE__*/function () {
|
1102 | function Params(params) {
|
1103 | _classCallCheck(this, Params);
|
1104 |
|
1105 | this.params = params;
|
1106 | this.index = 0;
|
1107 | }
|
1108 | /**
|
1109 | * Returns param value that matches given placeholder with param key.
|
1110 | * @param {Token} token
|
1111 | * @return {string} param or token.value when params are missing
|
1112 | */
|
1113 |
|
1114 |
|
1115 | _createClass(Params, [{
|
1116 | key: "get",
|
1117 | value: function get(_ref) {
|
1118 | var key = _ref.key,
|
1119 | value = _ref.value;
|
1120 |
|
1121 | if (!this.params) {
|
1122 | return value;
|
1123 | }
|
1124 |
|
1125 | if (key) {
|
1126 | return this.params[key];
|
1127 | }
|
1128 |
|
1129 | return this.params[this.index++];
|
1130 | }
|
1131 | }]);
|
1132 |
|
1133 | return Params;
|
1134 | }();
|
1135 |
|
1136 |
|
1137 |
|
1138 | /***/ }),
|
1139 |
|
1140 | /***/ "./src/core/Tokenizer.ts":
|
1141 | /*!*******************************!*\
|
1142 | !*** ./src/core/Tokenizer.ts ***!
|
1143 | \*******************************/
|
1144 | /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
1145 |
|
1146 | __webpack_require__.r(__webpack_exports__);
|
1147 | /* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
1148 | /* harmony export */ "WHITESPACE_REGEX": () => (/* binding */ WHITESPACE_REGEX),
|
1149 | /* harmony export */ "default": () => (/* binding */ Tokenizer)
|
1150 | /* harmony export */ });
|
1151 | /* harmony import */ var _regexFactory__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./regexFactory */ "./src/core/regexFactory.ts");
|
1152 | /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils */ "./src/utils.ts");
|
1153 | /* harmony import */ var _token__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./token */ "./src/core/token.ts");
|
1154 | function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
1155 |
|
1156 | function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
|
1157 |
|
1158 | function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
1159 |
|
1160 | function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
1161 |
|
1162 | function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
|
1163 |
|
1164 | function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
|
1165 |
|
1166 | function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
1167 |
|
1168 | function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
1169 |
|
1170 | function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
1171 |
|
1172 | function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
1173 |
|
1174 |
|
1175 |
|
1176 | // convert to partial type import in TS 4.5
|
1177 |
|
1178 | var WHITESPACE_REGEX = /^([\t-\r \xA0\u1680\u2000-\u200A\u2028\u2029\u202F\u205F\u3000\uFEFF]+)/;
|
1179 | var NULL_REGEX = /(?!)/; // zero-width negative lookahead, matches nothing
|
1180 |
|
1181 | /** Converts SQL language string into a token stream */
|
1182 |
|
1183 | var Tokenizer = /*#__PURE__*/function () {
|
1184 | /**
|
1185 | * @param {TokenizerOptions} cfg
|
1186 | * @param {string[]} cfg.reservedKeywords - Reserved words in SQL
|
1187 | * @param {string[]} cfg.reservedDependentClauses - Words that following a specific Statement and must have data attached
|
1188 | * @param {string[]} cfg.reservedLogicalOperators - Words that are set to newline
|
1189 | * @param {string[]} cfg.reservedCommands - Words that are set to new line separately
|
1190 | * @param {string[]} cfg.reservedBinaryCommands - Words that are top level but have no indentation
|
1191 | * @param {string[]} cfg.reservedJoinConditions - ON and USING
|
1192 | * @param {string[]} cfg.stringTypes - string types to enable - "", '', ``, [], N''
|
1193 | * @param {string[]} cfg.blockStart - Opening parentheses to enable, like (, [
|
1194 | * @param {string[]} cfg.blockEnd - Closing parentheses to enable, like ), ]
|
1195 | * @param {string[]} cfg.indexedPlaceholderTypes - Prefixes for indexed placeholders, like ?
|
1196 | * @param {string[]} cfg.namedPlaceholderTypes - Prefixes for named placeholders, like @ and :
|
1197 | * @param {string[]} cfg.lineCommentTypes - Line comments to enable, like # and --
|
1198 | * @param {string[]} cfg.specialWordChars - Special chars that can be found inside of words, like @ and #
|
1199 | * @param {string[]} cfg.operators - Additional operators to recognize
|
1200 | */
|
1201 | function Tokenizer(cfg) {
|
1202 | var _this = this,
|
1203 | _this$REGEX_MAP;
|
1204 |
|
1205 | _classCallCheck(this, Tokenizer);
|
1206 |
|
1207 | var _a, _b, _c, _d;
|
1208 | /** Curried function of `getTokenOnFirstMatch` that allows token type to be passed first */
|
1209 |
|
1210 |
|
1211 | this.matchToken = function (tokenType) {
|
1212 | return function (input) {
|
1213 | return _this.getTokenOnFirstMatch({
|
1214 | input: input,
|
1215 | type: tokenType,
|
1216 | regex: _this.REGEX_MAP[tokenType]
|
1217 | });
|
1218 | };
|
1219 | };
|
1220 |
|
1221 | var specialWordCharsAll = Object.values((_a = cfg.specialWordChars) !== null && _a !== void 0 ? _a : {}).join('');
|
1222 | this.REGEX_MAP = (_this$REGEX_MAP = {}, _defineProperty(_this$REGEX_MAP, _token__WEBPACK_IMPORTED_MODULE_2__.TokenType.WORD, _regexFactory__WEBPACK_IMPORTED_MODULE_0__.createWordRegex(cfg.specialWordChars)), _defineProperty(_this$REGEX_MAP, _token__WEBPACK_IMPORTED_MODULE_2__.TokenType.STRING, _regexFactory__WEBPACK_IMPORTED_MODULE_0__.createStringRegex(cfg.stringTypes)), _defineProperty(_this$REGEX_MAP, _token__WEBPACK_IMPORTED_MODULE_2__.TokenType.RESERVED_KEYWORD, _regexFactory__WEBPACK_IMPORTED_MODULE_0__.createReservedWordRegex(cfg.reservedKeywords, specialWordCharsAll)), _defineProperty(_this$REGEX_MAP, _token__WEBPACK_IMPORTED_MODULE_2__.TokenType.RESERVED_DEPENDENT_CLAUSE, _regexFactory__WEBPACK_IMPORTED_MODULE_0__.createReservedWordRegex((_b = cfg.reservedDependentClauses) !== null && _b !== void 0 ? _b : [], specialWordCharsAll)), _defineProperty(_this$REGEX_MAP, _token__WEBPACK_IMPORTED_MODULE_2__.TokenType.RESERVED_LOGICAL_OPERATOR, _regexFactory__WEBPACK_IMPORTED_MODULE_0__.createReservedWordRegex(cfg.reservedLogicalOperators, specialWordCharsAll)), _defineProperty(_this$REGEX_MAP, _token__WEBPACK_IMPORTED_MODULE_2__.TokenType.RESERVED_COMMAND, _regexFactory__WEBPACK_IMPORTED_MODULE_0__.createReservedWordRegex(cfg.reservedCommands, specialWordCharsAll)), _defineProperty(_this$REGEX_MAP, _token__WEBPACK_IMPORTED_MODULE_2__.TokenType.RESERVED_BINARY_COMMAND, _regexFactory__WEBPACK_IMPORTED_MODULE_0__.createReservedWordRegex(cfg.reservedBinaryCommands, specialWordCharsAll)), _defineProperty(_this$REGEX_MAP, _token__WEBPACK_IMPORTED_MODULE_2__.TokenType.RESERVED_JOIN_CONDITION, _regexFactory__WEBPACK_IMPORTED_MODULE_0__.createReservedWordRegex(cfg.reservedJoinConditions, specialWordCharsAll)), _defineProperty(_this$REGEX_MAP, _token__WEBPACK_IMPORTED_MODULE_2__.TokenType.OPERATOR, _regexFactory__WEBPACK_IMPORTED_MODULE_0__.createOperatorRegex('+-/*%&|^><=.,;[]{}`:$', ['<>', '<=', '>=', '!='].concat(_toConsumableArray((_c = cfg.operators) !== null && _c !== void 0 ? _c : [])))), _defineProperty(_this$REGEX_MAP, _token__WEBPACK_IMPORTED_MODULE_2__.TokenType.BLOCK_START, _regexFactory__WEBPACK_IMPORTED_MODULE_0__.createParenRegex(cfg.blockStart)), _defineProperty(_this$REGEX_MAP, _token__WEBPACK_IMPORTED_MODULE_2__.TokenType.BLOCK_END, _regexFactory__WEBPACK_IMPORTED_MODULE_0__.createParenRegex(cfg.blockEnd)), _defineProperty(_this$REGEX_MAP, _token__WEBPACK_IMPORTED_MODULE_2__.TokenType.LINE_COMMENT, _regexFactory__WEBPACK_IMPORTED_MODULE_0__.createLineCommentRegex(cfg.lineCommentTypes)), _defineProperty(_this$REGEX_MAP, _token__WEBPACK_IMPORTED_MODULE_2__.TokenType.BLOCK_COMMENT, /^(\/\*(?:(?![])[\s\S])*?(?:\*\/|$))/), _defineProperty(_this$REGEX_MAP, _token__WEBPACK_IMPORTED_MODULE_2__.TokenType.NUMBER, /^(0x[0-9A-Fa-f]+|0b[01]+|(\x2D[\t-\r \xA0\u1680\u2000-\u200A\u2028\u2029\u202F\u205F\u3000\uFEFF]*)?[0-9]+(\.[0-9]*)?([Ee][\+\x2D]?[0-9]+(\.[0-9]+)?)?)/), _defineProperty(_this$REGEX_MAP, _token__WEBPACK_IMPORTED_MODULE_2__.TokenType.PLACEHOLDER, NULL_REGEX), _defineProperty(_this$REGEX_MAP, _token__WEBPACK_IMPORTED_MODULE_2__.TokenType.EOF, NULL_REGEX), _this$REGEX_MAP);
|
1223 | this.INDEXED_PLACEHOLDER_REGEX = _regexFactory__WEBPACK_IMPORTED_MODULE_0__.createPlaceholderRegex((_d = cfg.indexedPlaceholderTypes) !== null && _d !== void 0 ? _d : [], '[0-9]*');
|
1224 | this.IDENT_NAMED_PLACEHOLDER_REGEX = _regexFactory__WEBPACK_IMPORTED_MODULE_0__.createPlaceholderRegex(cfg.namedPlaceholderTypes, '[a-zA-Z0-9._$]+');
|
1225 | this.STRING_NAMED_PLACEHOLDER_REGEX = _regexFactory__WEBPACK_IMPORTED_MODULE_0__.createPlaceholderRegex(cfg.namedPlaceholderTypes, _regexFactory__WEBPACK_IMPORTED_MODULE_0__.createStringPattern(cfg.stringTypes));
|
1226 | }
|
1227 | /**
|
1228 | * Takes a SQL string and breaks it into tokens.
|
1229 | * Each token is an object with type and value.
|
1230 | *
|
1231 | * @param {string} input - The SQL string
|
1232 | * @returns {Token[]} output token stream
|
1233 | */
|
1234 |
|
1235 |
|
1236 | _createClass(Tokenizer, [{
|
1237 | key: "tokenize",
|
1238 | value: function tokenize(input) {
|
1239 | var tokens = [];
|
1240 | var token; // Keep processing the string until it is empty
|
1241 |
|
1242 | while (input.length) {
|
1243 | // grab any preceding whitespace
|
1244 | var whitespaceBefore = this.getWhitespace(input);
|
1245 | input = input.substring(whitespaceBefore.length);
|
1246 |
|
1247 | if (input.length) {
|
1248 | // Get the next token and the token type
|
1249 | token = this.getNextToken(input, token); // Advance the string
|
1250 |
|
1251 | input = input.substring(token.value.length);
|
1252 | tokens.push(Object.assign(Object.assign({}, token), {
|
1253 | whitespaceBefore: whitespaceBefore
|
1254 | }));
|
1255 | }
|
1256 | }
|
1257 |
|
1258 | return tokens;
|
1259 | }
|
1260 | /** Matches preceding whitespace if present */
|
1261 |
|
1262 | }, {
|
1263 | key: "getWhitespace",
|
1264 | value: function getWhitespace(input) {
|
1265 | var matches = input.match(WHITESPACE_REGEX);
|
1266 | return matches ? matches[1] : '';
|
1267 | }
|
1268 | /** Attempts to match next token from input string, tests RegExp patterns in decreasing priority */
|
1269 |
|
1270 | }, {
|
1271 | key: "getNextToken",
|
1272 | value: function getNextToken(input, previousToken) {
|
1273 | return this.matchToken(_token__WEBPACK_IMPORTED_MODULE_2__.TokenType.LINE_COMMENT)(input) || this.matchToken(_token__WEBPACK_IMPORTED_MODULE_2__.TokenType.BLOCK_COMMENT)(input) || this.matchToken(_token__WEBPACK_IMPORTED_MODULE_2__.TokenType.STRING)(input) || this.matchToken(_token__WEBPACK_IMPORTED_MODULE_2__.TokenType.BLOCK_START)(input) || this.matchToken(_token__WEBPACK_IMPORTED_MODULE_2__.TokenType.BLOCK_END)(input) || this.getPlaceholderToken(input) || this.matchToken(_token__WEBPACK_IMPORTED_MODULE_2__.TokenType.NUMBER)(input) || this.getReservedWordToken(input, previousToken) || this.matchToken(_token__WEBPACK_IMPORTED_MODULE_2__.TokenType.WORD)(input) || this.matchToken(_token__WEBPACK_IMPORTED_MODULE_2__.TokenType.OPERATOR)(input);
|
1274 | }
|
1275 | /**
|
1276 | * Attempts to match a placeholder token pattern
|
1277 | * @return {Token | undefined} - The placeholder token if found, otherwise undefined
|
1278 | */
|
1279 |
|
1280 | }, {
|
1281 | key: "getPlaceholderToken",
|
1282 | value: function getPlaceholderToken(input) {
|
1283 | var _this2 = this;
|
1284 |
|
1285 | var _a, _b, _c;
|
1286 |
|
1287 | var placeholderTokenRegexMap = [// pattern for placeholder with identifier name
|
1288 | {
|
1289 | regex: (_a = this.IDENT_NAMED_PLACEHOLDER_REGEX) !== null && _a !== void 0 ? _a : NULL_REGEX,
|
1290 | parseKey: function parseKey(v) {
|
1291 | return v.slice(1);
|
1292 | }
|
1293 | }, // pattern for placeholder with string name
|
1294 | {
|
1295 | regex: (_b = this.STRING_NAMED_PLACEHOLDER_REGEX) !== null && _b !== void 0 ? _b : NULL_REGEX,
|
1296 | parseKey: function parseKey(v) {
|
1297 | return _this2.getEscapedPlaceholderKey({
|
1298 | key: v.slice(2, -1),
|
1299 | quoteChar: v.slice(-1)
|
1300 | });
|
1301 | }
|
1302 | }, // pattern for placeholder with numeric index
|
1303 | {
|
1304 | regex: (_c = this.INDEXED_PLACEHOLDER_REGEX) !== null && _c !== void 0 ? _c : NULL_REGEX,
|
1305 | parseKey: function parseKey(v) {
|
1306 | return v.slice(1);
|
1307 | }
|
1308 | }];
|
1309 | return placeholderTokenRegexMap.reduce(function (acc, _ref) {
|
1310 | var regex = _ref.regex,
|
1311 | parseKey = _ref.parseKey;
|
1312 |
|
1313 | var token = _this2.getTokenOnFirstMatch({
|
1314 | input: input,
|
1315 | regex: regex,
|
1316 | type: _token__WEBPACK_IMPORTED_MODULE_2__.TokenType.PLACEHOLDER
|
1317 | });
|
1318 |
|
1319 | return token ? Object.assign(Object.assign({}, token), {
|
1320 | key: parseKey(token.value)
|
1321 | }) : acc;
|
1322 | }, undefined);
|
1323 | }
|
1324 | }, {
|
1325 | key: "getEscapedPlaceholderKey",
|
1326 | value: function getEscapedPlaceholderKey(_ref2) {
|
1327 | var key = _ref2.key,
|
1328 | quoteChar = _ref2.quoteChar;
|
1329 | return key.replace(new RegExp((0,_utils__WEBPACK_IMPORTED_MODULE_1__.escapeRegExp)('\\' + quoteChar), 'gu'), quoteChar);
|
1330 | }
|
1331 | /**
|
1332 | * Attempts to match a Reserved word token pattern, avoiding edge cases of Reserved words within string tokens
|
1333 | * @return {Token | undefined} - The Reserved word token if found, otherwise undefined
|
1334 | */
|
1335 |
|
1336 | }, {
|
1337 | key: "getReservedWordToken",
|
1338 | value: function getReservedWordToken(input, previousToken) {
|
1339 | var _this3 = this;
|
1340 |
|
1341 | // A reserved word cannot be preceded by a '.'
|
1342 | // this makes it so in "mytable.from", "from" is not considered a reserved word
|
1343 | if ((previousToken === null || previousToken === void 0 ? void 0 : previousToken.value) === '.') {
|
1344 | return undefined;
|
1345 | } // prioritised list of Reserved token types
|
1346 |
|
1347 |
|
1348 | var reservedTokenList = [_token__WEBPACK_IMPORTED_MODULE_2__.TokenType.RESERVED_COMMAND, _token__WEBPACK_IMPORTED_MODULE_2__.TokenType.RESERVED_BINARY_COMMAND, _token__WEBPACK_IMPORTED_MODULE_2__.TokenType.RESERVED_DEPENDENT_CLAUSE, _token__WEBPACK_IMPORTED_MODULE_2__.TokenType.RESERVED_LOGICAL_OPERATOR, _token__WEBPACK_IMPORTED_MODULE_2__.TokenType.RESERVED_KEYWORD, _token__WEBPACK_IMPORTED_MODULE_2__.TokenType.RESERVED_JOIN_CONDITION];
|
1349 | return reservedTokenList.reduce(function (matchedToken, tokenType) {
|
1350 | return matchedToken || _this3.matchToken(tokenType)(input);
|
1351 | }, undefined);
|
1352 | }
|
1353 | /**
|
1354 | * Attempts to match RegExp from head of input, returning undefined if not found
|
1355 | * @param {string} _.input - The string to match
|
1356 | * @param {TokenType} _.type - The type of token to match against
|
1357 | * @param {RegExp} _.regex - The regex to match
|
1358 | * @return {Token | undefined} - The matched token if found, otherwise undefined
|
1359 | */
|
1360 |
|
1361 | }, {
|
1362 | key: "getTokenOnFirstMatch",
|
1363 | value: function getTokenOnFirstMatch(_ref3) {
|
1364 | var input = _ref3.input,
|
1365 | type = _ref3.type,
|
1366 | regex = _ref3.regex;
|
1367 | var matches = input.match(regex);
|
1368 | return matches ? {
|
1369 | type: type,
|
1370 | value: matches[1]
|
1371 | } : undefined;
|
1372 | }
|
1373 | }]);
|
1374 |
|
1375 | return Tokenizer;
|
1376 | }();
|
1377 |
|
1378 |
|
1379 |
|
1380 | /***/ }),
|
1381 |
|
1382 | /***/ "./src/core/formatAliasPositions.ts":
|
1383 | /*!******************************************!*\
|
1384 | !*** ./src/core/formatAliasPositions.ts ***!
|
1385 | \******************************************/
|
1386 | /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
1387 |
|
1388 | __webpack_require__.r(__webpack_exports__);
|
1389 | /* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
1390 | /* harmony export */ "default": () => (/* binding */ formatAliasPositions)
|
1391 | /* harmony export */ });
|
1392 | /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../utils */ "./src/utils.ts");
|
1393 | function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
|
1394 |
|
1395 | function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
1396 |
|
1397 | function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
1398 |
|
1399 | function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
|
1400 |
|
1401 | function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
|
1402 |
|
1403 | function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
1404 |
|
1405 |
|
1406 | /**
|
1407 | * Handles select alias placement - tabulates if enabled
|
1408 | */
|
1409 |
|
1410 | function formatAliasPositions(query) {
|
1411 | var lines = query.split('\n');
|
1412 | var newQuery = [];
|
1413 |
|
1414 | for (var i = 0; i < lines.length; i++) {
|
1415 | // find SELECT rows with trailing comma, if no comma (only one row) - no-op
|
1416 | if (lines[i].match(/^\s*SELECT/i)) {
|
1417 | var _ret = function () {
|
1418 | var aliasLines = [];
|
1419 |
|
1420 | if (lines[i].match(/.*,$/)) {
|
1421 | aliasLines = [lines[i]]; // add select to aliasLines in case of tabular formats
|
1422 | } else {
|
1423 | newQuery.push(lines[i]); // add select to new query
|
1424 |
|
1425 | if (lines[i].match(/^\s*SELECT\s+.+(?!,$)/i)) {
|
1426 | return "continue";
|
1427 | }
|
1428 |
|
1429 | aliasLines.push(lines[++i]);
|
1430 | } // get all lines in SELECT clause
|
1431 |
|
1432 |
|
1433 | while (lines[i++].match(/.*,$/)) {
|
1434 | aliasLines.push(lines[i]);
|
1435 | } // break lines into alias with optional AS, and all preceding text
|
1436 |
|
1437 |
|
1438 | var splitLines = aliasLines.map(function (line) {
|
1439 | return {
|
1440 | line: line,
|
1441 | matches: line.match(/(^.*?\S) (AS )?(\S+,?$)/i)
|
1442 | };
|
1443 | }).map(function (_ref) {
|
1444 | var line = _ref.line,
|
1445 | matches = _ref.matches;
|
1446 |
|
1447 | if (!matches) {
|
1448 | return {
|
1449 | precedingText: line
|
1450 | };
|
1451 | }
|
1452 |
|
1453 | return {
|
1454 | precedingText: matches[1],
|
1455 | as: matches[2],
|
1456 | alias: matches[3]
|
1457 | };
|
1458 | }); // get longest of precedingText, trim trailing comma for non-alias columns
|
1459 |
|
1460 | var aliasMaxLength = (0,_utils__WEBPACK_IMPORTED_MODULE_0__.maxLength)(splitLines.map(function (_ref2) {
|
1461 | var precedingText = _ref2.precedingText;
|
1462 | return precedingText.replace(/\s*,\s*$/, '');
|
1463 | })); // re-construct line, aligning by inserting space before AS or alias
|
1464 |
|
1465 | aliasLines = splitLines.map(function (_ref3) {
|
1466 | var precedingText = _ref3.precedingText,
|
1467 | as = _ref3.as,
|
1468 | alias = _ref3.alias;
|
1469 | return precedingText + (alias ? ' '.repeat(aliasMaxLength - precedingText.length + 1) + (as !== null && as !== void 0 ? as : '') + alias : '');
|
1470 | });
|
1471 | newQuery = [].concat(_toConsumableArray(newQuery), _toConsumableArray(aliasLines));
|
1472 | }();
|
1473 |
|
1474 | if (_ret === "continue") continue;
|
1475 | }
|
1476 |
|
1477 | newQuery.push(lines[i]);
|
1478 | }
|
1479 |
|
1480 | return newQuery.join('\n');
|
1481 | }
|
1482 |
|
1483 | /***/ }),
|
1484 |
|
1485 | /***/ "./src/core/formatCommaPositions.ts":
|
1486 | /*!******************************************!*\
|
1487 | !*** ./src/core/formatCommaPositions.ts ***!
|
1488 | \******************************************/
|
1489 | /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
1490 |
|
1491 | __webpack_require__.r(__webpack_exports__);
|
1492 | /* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
1493 | /* harmony export */ "default": () => (/* binding */ formatCommaPositions)
|
1494 | /* harmony export */ });
|
1495 | /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../utils */ "./src/utils.ts");
|
1496 | /* harmony import */ var _Tokenizer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Tokenizer */ "./src/core/Tokenizer.ts");
|
1497 | function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
1498 |
|
1499 | function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
1500 |
|
1501 | function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
1502 |
|
1503 | function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
1504 |
|
1505 | function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
|
1506 |
|
1507 | function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
1508 |
|
1509 |
|
1510 |
|
1511 | /**
|
1512 | * Handles comma placement - either before, after or tabulated
|
1513 | */
|
1514 |
|
1515 | function formatCommaPositions(query, commaPosition, indent) {
|
1516 | return groupCommaDelimitedLines(query.split('\n')).flatMap(function (commaLines) {
|
1517 | if (commaLines.length === 1) {
|
1518 | return commaLines;
|
1519 | } else if (commaPosition === 'tabular') {
|
1520 | return formatTabular(commaLines);
|
1521 | } else if (commaPosition === 'before') {
|
1522 | return formatBefore(commaLines, indent);
|
1523 | } else {
|
1524 | throw new Error("Unexpected commaPosition: ".concat(commaPosition));
|
1525 | }
|
1526 | }).join('\n');
|
1527 | }
|
1528 | /**
|
1529 | * Given lines like this:
|
1530 | *
|
1531 | * [
|
1532 | * 'SELECT',
|
1533 | * ' foo,',
|
1534 | * ' bar,',
|
1535 | * ' baz',
|
1536 | * 'FROM'
|
1537 | * ]
|
1538 | *
|
1539 | * Returns groups like this:
|
1540 | *
|
1541 | * [
|
1542 | * ['SELECT'],
|
1543 | * [' foo,', ' bar,', ' baz'],
|
1544 | * ['FROM']
|
1545 | * ]
|
1546 | */
|
1547 |
|
1548 | function groupCommaDelimitedLines(lines) {
|
1549 | var groups = [];
|
1550 |
|
1551 | for (var i = 0; i < lines.length; i++) {
|
1552 | var group = [lines[i]]; // when line ends with comma,
|
1553 | // gather together all following lines that also end with comma,
|
1554 | // plus one (which doesn't end with comma)
|
1555 |
|
1556 | while (lines[i].match(/.*,$/)) {
|
1557 | i++;
|
1558 | group.push(lines[i]);
|
1559 | }
|
1560 |
|
1561 | groups.push(group);
|
1562 | }
|
1563 |
|
1564 | return groups;
|
1565 | } // makes all lines the same length by appending spaces before comma
|
1566 |
|
1567 |
|
1568 | function formatTabular(commaLines) {
|
1569 | var maxLineLength = (0,_utils__WEBPACK_IMPORTED_MODULE_0__.maxLength)(commaLines);
|
1570 | return trimTrailingCommas(commaLines).map(function (line, i) {
|
1571 | if (i === commaLines.length - 1) {
|
1572 | return line; // do not add comma for last item
|
1573 | }
|
1574 |
|
1575 | return line + ' '.repeat(maxLineLength - line.length - 1) + ',';
|
1576 | });
|
1577 | }
|
1578 |
|
1579 | function formatBefore(commaLines, indent) {
|
1580 | return trimTrailingCommas(commaLines).map(function (line, i) {
|
1581 | if (i === 0) {
|
1582 | return line; // do not add comma for first item
|
1583 | }
|
1584 |
|
1585 | var _ref = line.match(_Tokenizer__WEBPACK_IMPORTED_MODULE_1__.WHITESPACE_REGEX) || [''],
|
1586 | _ref2 = _slicedToArray(_ref, 1),
|
1587 | whitespace = _ref2[0];
|
1588 |
|
1589 | return removeLastIndent(whitespace, indent) + indent.replace(/ {2}$/, ', ') + // add comma to the end of last indent
|
1590 | line.trimStart();
|
1591 | });
|
1592 | }
|
1593 |
|
1594 | function removeLastIndent(whitespace, indent) {
|
1595 | return whitespace.replace(new RegExp(indent + '$'), '');
|
1596 | }
|
1597 |
|
1598 | function trimTrailingCommas(lines) {
|
1599 | return lines.map(function (line) {
|
1600 | return line.replace(/,$/, '');
|
1601 | });
|
1602 | }
|
1603 |
|
1604 | /***/ }),
|
1605 |
|
1606 | /***/ "./src/core/regexFactory.ts":
|
1607 | /*!**********************************!*\
|
1608 | !*** ./src/core/regexFactory.ts ***!
|
1609 | \**********************************/
|
1610 | /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
1611 |
|
1612 | __webpack_require__.r(__webpack_exports__);
|
1613 | /* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
1614 | /* harmony export */ "createLineCommentRegex": () => (/* binding */ createLineCommentRegex),
|
1615 | /* harmony export */ "createOperatorRegex": () => (/* binding */ createOperatorRegex),
|
1616 | /* harmony export */ "createParenRegex": () => (/* binding */ createParenRegex),
|
1617 | /* harmony export */ "createPlaceholderRegex": () => (/* binding */ createPlaceholderRegex),
|
1618 | /* harmony export */ "createReservedWordRegex": () => (/* binding */ createReservedWordRegex),
|
1619 | /* harmony export */ "createStringPattern": () => (/* binding */ createStringPattern),
|
1620 | /* harmony export */ "createStringRegex": () => (/* binding */ createStringRegex),
|
1621 | /* harmony export */ "createWordRegex": () => (/* binding */ createWordRegex)
|
1622 | /* harmony export */ });
|
1623 | /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../utils */ "./src/utils.ts");
|
1624 |
|
1625 | /**
|
1626 | * Builds a RegExp containing all operators for a SQL dialect
|
1627 | * @param {string} monadOperators - concatenated string of all 1-length operators
|
1628 | * @param {string[]} polyadOperators - list of strings of all >1-length operators
|
1629 | */
|
1630 |
|
1631 | var createOperatorRegex = function createOperatorRegex(monadOperators, polyadOperators) {
|
1632 | return new RegExp("^(".concat((0,_utils__WEBPACK_IMPORTED_MODULE_0__.sortByLengthDesc)(polyadOperators).map(_utils__WEBPACK_IMPORTED_MODULE_0__.escapeRegExp).join('|'), "|") + "[".concat(monadOperators.split('').map(_utils__WEBPACK_IMPORTED_MODULE_0__.escapeRegExp).join(''), "])"), 'u');
|
1633 | };
|
1634 | /**
|
1635 | * Builds a RegExp for valid line comments in a SQL dialect
|
1636 | * @param {string[]} lineCommentTypes - list of character strings that denote line comments
|
1637 | */
|
1638 |
|
1639 | var createLineCommentRegex = function createLineCommentRegex(lineCommentTypes) {
|
1640 | return new RegExp("^((?:".concat(lineCommentTypes.map(function (c) {
|
1641 | return (0,_utils__WEBPACK_IMPORTED_MODULE_0__.escapeRegExp)(c);
|
1642 | }).join('|'), ").*?)(?:\r\n|\r|\n|$)"), 'u');
|
1643 | };
|
1644 | /**
|
1645 | * Builds a RegExp for all Reserved Keywords in a SQL dialect
|
1646 | * @param {string[]} reservedKeywords - list of strings of all Reserved Keywords
|
1647 | * @param {string} specialWordChars - concatenated string of all special chars that can appear in valid identifiers (and not in Reserved Keywords)
|
1648 | */
|
1649 |
|
1650 | var createReservedWordRegex = function createReservedWordRegex(reservedKeywords) {
|
1651 | var specialWordChars = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';
|
1652 |
|
1653 | if (reservedKeywords.length === 0) {
|
1654 | return /^\b$/;
|
1655 | }
|
1656 |
|
1657 | var reservedKeywordsPattern = (0,_utils__WEBPACK_IMPORTED_MODULE_0__.sortByLengthDesc)(reservedKeywords).join('|').replace(/ /g, '\\s+');
|
1658 | return new RegExp("^(".concat(reservedKeywordsPattern, ")(?![").concat((0,_utils__WEBPACK_IMPORTED_MODULE_0__.escapeRegExp)(specialWordChars), "]+)\\b"), 'iu');
|
1659 | };
|
1660 | /**
|
1661 | * Builds a RegExp for valid identifiers in a SQL dialect
|
1662 | * @param {Object} specialChars
|
1663 | * @param {string} specialChars.any - concatenated string of chars that can appear anywhere in a valid identifier
|
1664 | * @param {string} specialChars.prefix - concatenated string of chars that only appear at the beginning of a valid identifier
|
1665 | * @param {string} specialChars.suffix - concatenated string of chars that only appear at the end of a valid identifier
|
1666 | */
|
1667 |
|
1668 | var createWordRegex = function createWordRegex() {
|
1669 | var specialChars = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
1670 |
|
1671 | var _a, _b, _c;
|
1672 |
|
1673 | var prefixLookBehind = "[".concat((0,_utils__WEBPACK_IMPORTED_MODULE_0__.escapeRegExp)((_a = specialChars.prefix) !== null && _a !== void 0 ? _a : ''), "]*");
|
1674 | var suffixLookAhead = "[".concat((0,_utils__WEBPACK_IMPORTED_MODULE_0__.escapeRegExp)((_b = specialChars.suffix) !== null && _b !== void 0 ? _b : ''), "]*");
|
1675 | var unicodeWordChar = '\\p{Alphabetic}\\p{Mark}\\p{Decimal_Number}\\p{Connector_Punctuation}\\p{Join_Control}';
|
1676 | var specialWordChars = "".concat((0,_utils__WEBPACK_IMPORTED_MODULE_0__.escapeRegExp)((_c = specialChars.any) !== null && _c !== void 0 ? _c : ''));
|
1677 | var arrayAccessor = '\\[\\d\\]';
|
1678 | var mapAccessor = "\\[['\"][".concat(unicodeWordChar, "]+['\"]\\]");
|
1679 | return new RegExp("^((".concat(prefixLookBehind, "([").concat(unicodeWordChar).concat(specialWordChars, "]+)").concat(suffixLookAhead, ")(").concat(arrayAccessor, "|").concat(mapAccessor, ")?)"), 'u');
|
1680 | }; // This enables the following string patterns:
|
1681 | // 1. backtick quoted string using `` to escape
|
1682 | // 2. square bracket quoted string (SQL Server) using ]] to escape
|
1683 | // 3. double quoted string using "" or \" to escape
|
1684 | // 4. single quoted string using '' or \' to escape
|
1685 | // 5. national character quoted string using N'' or N\' to escape
|
1686 | // 6. Unicode single-quoted string using \' to escape
|
1687 | // 7. Unicode double-quoted string using \" to escape
|
1688 | // 8. PostgreSQL dollar-quoted strings
|
1689 |
|
1690 | var patterns = {
|
1691 | '``': '((`[^`]*($|`))+)',
|
1692 | '{}': '((\\{[^\\}]*($|\\}))+)',
|
1693 | '[]': '((\\[[^\\]]*($|\\]))(\\][^\\]]*($|\\]))*)',
|
1694 | '""': '(("[^"\\\\]*(?:\\\\.[^"\\\\]*)*("|$))+)',
|
1695 | "''": "(('[^'\\\\]*(?:\\\\.[^'\\\\]*)*('|$))+)",
|
1696 | "N''": "((N'[^'\\\\]*(?:\\\\.[^'\\\\]*)*('|$))+)",
|
1697 | "x''": "(([xX]'[^'\\\\]*(?:\\\\.[^'\\\\]*)*('|$))+)",
|
1698 | "E''": "((E'[^'\\\\]*(?:\\\\.[^'\\\\]*)*('|$))+)",
|
1699 | "U&''": "((U&'[^'\\\\]*(?:\\\\.[^'\\\\]*)*('|$))+)",
|
1700 | 'U&""': '((U&"[^"\\\\]*(?:\\\\.[^"\\\\]*)*("|$))+)',
|
1701 | '$$': '((?<tag>\\$\\w*\\$)[\\s\\S]*?(?:\\k<tag>|$))'
|
1702 | };
|
1703 | /**
|
1704 | * Builds a string pattern for matching string patterns for all given string types
|
1705 | * @param {StringPatternType[]} stringTypes - list of strings that denote string patterns
|
1706 | */
|
1707 |
|
1708 | var createStringPattern = function createStringPattern(stringTypes) {
|
1709 | return stringTypes.map(function (t) {
|
1710 | return patterns[t];
|
1711 | }).join('|');
|
1712 | };
|
1713 | /**
|
1714 | * Builds a RegExp for matching string patterns using `createStringPattern`
|
1715 | * @param {StringPatternType[]} stringTypes - list of strings that denote string patterns
|
1716 | */
|
1717 |
|
1718 | var createStringRegex = function createStringRegex(stringTypes) {
|
1719 | return new RegExp('^(' + createStringPattern(stringTypes) + ')', 'u');
|
1720 | };
|
1721 | /** Escapes paren characters for RegExp patterns */
|
1722 |
|
1723 | var escapeParen = function escapeParen(paren) {
|
1724 | if (paren.length === 1) {
|
1725 | // A single punctuation character
|
1726 | return (0,_utils__WEBPACK_IMPORTED_MODULE_0__.escapeRegExp)(paren);
|
1727 | } else {
|
1728 | // longer word
|
1729 | return '\\b' + paren + '\\b';
|
1730 | }
|
1731 | };
|
1732 | /**
|
1733 | * Builds a RegExp for matching parenthesis patterns, escaping them with `escapeParen`
|
1734 | * @param {string[]} parens - list of strings that denote parenthesis patterns
|
1735 | */
|
1736 |
|
1737 |
|
1738 | var createParenRegex = function createParenRegex(parens) {
|
1739 | return new RegExp('^(' + parens.map(escapeParen).join('|') + ')', 'iu');
|
1740 | };
|
1741 | /**
|
1742 | * Builds a RegExp for placeholder patterns
|
1743 | * @param {string[]} types - list of strings that denote placeholder types
|
1744 | * @param {string} pattern - string that denotes placeholder pattern
|
1745 | */
|
1746 |
|
1747 | var createPlaceholderRegex = function createPlaceholderRegex(types, pattern) {
|
1748 | if ((0,_utils__WEBPACK_IMPORTED_MODULE_0__.isEmpty)(types)) {
|
1749 | return undefined;
|
1750 | }
|
1751 |
|
1752 | var typesRegex = types.map(_utils__WEBPACK_IMPORTED_MODULE_0__.escapeRegExp).join('|');
|
1753 | return new RegExp("^((?:".concat(typesRegex, ")(?:").concat(pattern, "))"), 'u');
|
1754 | };
|
1755 |
|
1756 | /***/ }),
|
1757 |
|
1758 | /***/ "./src/core/tabularStyle.ts":
|
1759 | /*!**********************************!*\
|
1760 | !*** ./src/core/tabularStyle.ts ***!
|
1761 | \**********************************/
|
1762 | /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
1763 |
|
1764 | __webpack_require__.r(__webpack_exports__);
|
1765 | /* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
1766 | /* harmony export */ "replaceTabularPlaceholders": () => (/* binding */ replaceTabularPlaceholders),
|
1767 | /* harmony export */ "toTabularToken": () => (/* binding */ toTabularToken)
|
1768 | /* harmony export */ });
|
1769 | /* harmony import */ var _token__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./token */ "./src/core/token.ts");
|
1770 | function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
|
1771 |
|
1772 | function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
1773 |
|
1774 | function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
|
1775 |
|
1776 | function _toArray(arr) { return _arrayWithHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableRest(); }
|
1777 |
|
1778 | function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
1779 |
|
1780 | function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
1781 |
|
1782 | function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
1783 |
|
1784 | function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
|
1785 |
|
1786 | function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
1787 |
|
1788 |
|
1789 | /**
|
1790 | * When tabular style enabled,
|
1791 | * produces a 10-char wide version of reserved token.
|
1792 | *
|
1793 | * It'll be padded by zero-width space characters
|
1794 | * instead of normal spaces, so that these spaces will survive
|
1795 | * trimming of spaces in other parts of formatter.
|
1796 | * They'll be converted to normal spaces in the end of
|
1797 | * all the normal formatting with the replaceTabularPlaceholders()
|
1798 | */
|
1799 |
|
1800 | function toTabularToken(token, indentStyle) {
|
1801 | if (indentStyle === 'standard') {
|
1802 | return token;
|
1803 | }
|
1804 |
|
1805 | var bufferItem = token.value; // store which part of keyword receives 10-space buffer
|
1806 |
|
1807 | var tail = []; // rest of keyword
|
1808 |
|
1809 | if (bufferItem.length >= 10 && bufferItem.includes(' ')) {
|
1810 | // split for long keywords like INNER JOIN or UNION DISTINCT
|
1811 | var _bufferItem$split = bufferItem.split(' ');
|
1812 |
|
1813 | var _bufferItem$split2 = _toArray(_bufferItem$split);
|
1814 |
|
1815 | bufferItem = _bufferItem$split2[0];
|
1816 | tail = _bufferItem$split2.slice(1);
|
1817 | }
|
1818 |
|
1819 | if (indentStyle === 'tabularLeft') {
|
1820 | bufferItem = bufferItem.padEnd(9, _token__WEBPACK_IMPORTED_MODULE_0__.ZWS);
|
1821 | } else {
|
1822 | bufferItem = bufferItem.padStart(9, _token__WEBPACK_IMPORTED_MODULE_0__.ZWS);
|
1823 | }
|
1824 |
|
1825 | return Object.assign(Object.assign({}, token), {
|
1826 | value: bufferItem + [''].concat(_toConsumableArray(tail)).join(' ')
|
1827 | });
|
1828 | }
|
1829 | /**
|
1830 | * Replaces zero-width-spaces added by the above function
|
1831 | */
|
1832 |
|
1833 | function replaceTabularPlaceholders(query) {
|
1834 | return query.replace(new RegExp(_token__WEBPACK_IMPORTED_MODULE_0__.ZWS, 'ugim'), ' ');
|
1835 | }
|
1836 |
|
1837 | /***/ }),
|
1838 |
|
1839 | /***/ "./src/core/token.ts":
|
1840 | /*!***************************!*\
|
1841 | !*** ./src/core/token.ts ***!
|
1842 | \***************************/
|
1843 | /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
1844 |
|
1845 | __webpack_require__.r(__webpack_exports__);
|
1846 | /* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
1847 | /* harmony export */ "EOF_TOKEN": () => (/* binding */ EOF_TOKEN),
|
1848 | /* harmony export */ "TokenType": () => (/* binding */ TokenType),
|
1849 | /* harmony export */ "ZWS": () => (/* binding */ ZWS),
|
1850 | /* harmony export */ "isCommand": () => (/* binding */ isCommand),
|
1851 | /* harmony export */ "isReserved": () => (/* binding */ isReserved),
|
1852 | /* harmony export */ "isToken": () => (/* binding */ isToken),
|
1853 | /* harmony export */ "testToken": () => (/* binding */ testToken)
|
1854 | /* harmony export */ });
|
1855 | /** Token type enum for all possible Token categories */
|
1856 | var TokenType;
|
1857 |
|
1858 | (function (TokenType) {
|
1859 | TokenType["WORD"] = "WORD";
|
1860 | TokenType["STRING"] = "STRING";
|
1861 | TokenType["RESERVED_KEYWORD"] = "RESERVED_KEYWORD";
|
1862 | TokenType["RESERVED_LOGICAL_OPERATOR"] = "RESERVED_LOGICAL_OPERATOR";
|
1863 | TokenType["RESERVED_DEPENDENT_CLAUSE"] = "RESERVED_DEPENDENT_CLAUSE";
|
1864 | TokenType["RESERVED_BINARY_COMMAND"] = "RESERVED_BINARY_COMMAND";
|
1865 | TokenType["RESERVED_COMMAND"] = "RESERVED_COMMAND";
|
1866 | TokenType["RESERVED_JOIN_CONDITION"] = "RESERVED_JOIN_CONDITION";
|
1867 | TokenType["OPERATOR"] = "OPERATOR";
|
1868 | TokenType["BLOCK_START"] = "BLOCK_START";
|
1869 | TokenType["BLOCK_END"] = "BLOCK_END";
|
1870 | TokenType["LINE_COMMENT"] = "LINE_COMMENT";
|
1871 | TokenType["BLOCK_COMMENT"] = "BLOCK_COMMENT";
|
1872 | TokenType["NUMBER"] = "NUMBER";
|
1873 | TokenType["PLACEHOLDER"] = "PLACEHOLDER";
|
1874 | TokenType["EOF"] = "EOF";
|
1875 | })(TokenType || (TokenType = {}));
|
1876 | /**
|
1877 | * For use as a "missing token"
|
1878 | * e.g. in lookAhead and lookBehind to avoid dealing with null values
|
1879 | */
|
1880 |
|
1881 |
|
1882 | var EOF_TOKEN = {
|
1883 | type: TokenType.EOF,
|
1884 | value: '«EOF»'
|
1885 | };
|
1886 | /** Special Unicode character to serve as a placeholder for tabular formats as \w whitespace is unavailable */
|
1887 |
|
1888 | var ZWS = ''; // uses zero-width space (​ / U+200B)
|
1889 |
|
1890 | var ZWS_REGEX = "\u200B";
|
1891 | var spaces = "[".concat(ZWS_REGEX, "\\s]");
|
1892 | /** Checks if two tokens are equivalent */
|
1893 |
|
1894 | var testToken = function testToken(compareToken) {
|
1895 | return function (token) {
|
1896 | return token.type === compareToken.type && new RegExp("^".concat(spaces, "*").concat(compareToken.value).concat(spaces, "*$"), 'iu').test(token.value);
|
1897 | };
|
1898 | };
|
1899 | /** Util object that allows for easy checking of Reserved Keywords */
|
1900 |
|
1901 | var isToken = {
|
1902 | AS: testToken({
|
1903 | value: 'AS',
|
1904 | type: TokenType.RESERVED_KEYWORD
|
1905 | }),
|
1906 | AND: testToken({
|
1907 | value: 'AND',
|
1908 | type: TokenType.RESERVED_LOGICAL_OPERATOR
|
1909 | }),
|
1910 | BETWEEN: testToken({
|
1911 | value: 'BETWEEN',
|
1912 | type: TokenType.RESERVED_KEYWORD
|
1913 | }),
|
1914 | CASE: testToken({
|
1915 | value: 'CASE',
|
1916 | type: TokenType.BLOCK_START
|
1917 | }),
|
1918 | CAST: testToken({
|
1919 | value: 'CAST',
|
1920 | type: TokenType.RESERVED_KEYWORD
|
1921 | }),
|
1922 | BY: testToken({
|
1923 | value: 'BY',
|
1924 | type: TokenType.RESERVED_KEYWORD
|
1925 | }),
|
1926 | END: testToken({
|
1927 | value: 'END',
|
1928 | type: TokenType.BLOCK_END
|
1929 | }),
|
1930 | FROM: testToken({
|
1931 | value: 'FROM',
|
1932 | type: TokenType.RESERVED_COMMAND
|
1933 | }),
|
1934 | LIMIT: testToken({
|
1935 | value: 'LIMIT',
|
1936 | type: TokenType.RESERVED_COMMAND
|
1937 | }),
|
1938 | SELECT: testToken({
|
1939 | value: 'SELECT',
|
1940 | type: TokenType.RESERVED_COMMAND
|
1941 | }),
|
1942 | SET: testToken({
|
1943 | value: 'SET',
|
1944 | type: TokenType.RESERVED_COMMAND
|
1945 | }),
|
1946 | TABLE: testToken({
|
1947 | value: 'TABLE',
|
1948 | type: TokenType.RESERVED_KEYWORD
|
1949 | }),
|
1950 | WINDOW: testToken({
|
1951 | value: 'WINDOW',
|
1952 | type: TokenType.RESERVED_COMMAND
|
1953 | }),
|
1954 | WITH: testToken({
|
1955 | value: 'WITH',
|
1956 | type: TokenType.RESERVED_COMMAND
|
1957 | })
|
1958 | };
|
1959 | /** Checks if token is a Reserved Command or Reserved Binary Command */
|
1960 |
|
1961 | var isCommand = function isCommand(token) {
|
1962 | return token.type === TokenType.RESERVED_COMMAND || token.type === TokenType.RESERVED_BINARY_COMMAND;
|
1963 | };
|
1964 | /** Checks if token is any Reserved Keyword or Command */
|
1965 |
|
1966 | var isReserved = function isReserved(token) {
|
1967 | return token.type === TokenType.RESERVED_KEYWORD || token.type === TokenType.RESERVED_LOGICAL_OPERATOR || token.type === TokenType.RESERVED_DEPENDENT_CLAUSE || token.type === TokenType.RESERVED_JOIN_CONDITION || token.type === TokenType.RESERVED_COMMAND || token.type === TokenType.RESERVED_BINARY_COMMAND;
|
1968 | };
|
1969 |
|
1970 | /***/ }),
|
1971 |
|
1972 | /***/ "./src/languages/bigquery.formatter.ts":
|
1973 | /*!*********************************************!*\
|
1974 | !*** ./src/languages/bigquery.formatter.ts ***!
|
1975 | \*********************************************/
|
1976 | /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
1977 |
|
1978 | __webpack_require__.r(__webpack_exports__);
|
1979 | /* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
1980 | /* harmony export */ "default": () => (/* binding */ BigQueryFormatter)
|
1981 | /* harmony export */ });
|
1982 | /* harmony import */ var _core_Formatter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../core/Formatter */ "./src/core/Formatter.ts");
|
1983 | /* harmony import */ var _core_Tokenizer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../core/Tokenizer */ "./src/core/Tokenizer.ts");
|
1984 | /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils */ "./src/utils.ts");
|
1985 | function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
1986 |
|
1987 | function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
|
1988 |
|
1989 | function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
1990 |
|
1991 | function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
1992 |
|
1993 | function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
|
1994 |
|
1995 | function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
|
1996 |
|
1997 | function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
1998 |
|
1999 | function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
2000 |
|
2001 | function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
2002 |
|
2003 | function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
2004 |
|
2005 | function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
|
2006 |
|
2007 | function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
|
2008 |
|
2009 | function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
2010 |
|
2011 | function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
|
2012 |
|
2013 | function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
|
2014 |
|
2015 | function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
2016 |
|
2017 | function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
|
2018 |
|
2019 |
|
2020 |
|
2021 |
|
2022 | /**
|
2023 | * Priority 5 (last)
|
2024 | * Full list of reserved functions
|
2025 | * distinct from Keywords due to interaction with parentheses
|
2026 | */
|
2027 |
|
2028 | var reservedFunctions = {
|
2029 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/aead_encryption_functions
|
2030 | aead: ['KEYS.NEW_KEYSET', 'KEYS.ADD_KEY_FROM_RAW_BYTES', 'AEAD.DECRYPT_BYTES', 'AEAD.DECRYPT_STRING', 'AEAD.ENCRYPT', 'KEYS.KEYSET_CHAIN', 'KEYS.KEYSET_FROM_JSON', 'KEYS.KEYSET_TO_JSON', 'KEYS.ROTATE_KEYSET', 'KEYS.KEYSET_LENGTH'],
|
2031 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/aggregate_analytic_functions
|
2032 | aggregateAnalytic: ['ANY_VALUE', 'ARRAY_AGG', 'AVG', 'CORR', 'COUNT', 'COUNTIF', 'COVAR_POP', 'COVAR_SAMP', 'MAX', 'MIN', 'ST_CLUSTERDBSCAN', 'STDDEV_POP', 'STDDEV_SAMP', 'STRING_AGG', 'SUM', 'VAR_POP', 'VAR_SAMP'],
|
2033 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/aggregate_functions
|
2034 | aggregate: ['ANY_VALUE', 'ARRAY_AGG', 'ARRAY_CONCAT_AGG', 'AVG', 'BIT_AND', 'BIT_OR', 'BIT_XOR', 'COUNT', 'COUNTIF', 'LOGICAL_AND', 'LOGICAL_OR', 'MAX', 'MIN', 'STRING_AGG', 'SUM'],
|
2035 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/approximate_aggregate_functions
|
2036 | approximateAggregate: ['APPROX_COUNT_DISTINCT', 'APPROX_QUANTILES', 'APPROX_TOP_COUNT', 'APPROX_TOP_SUM'],
|
2037 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/array_functions
|
2038 | array: ['ARRAY', 'ARRAY_CONCAT', 'ARRAY_LENGTH', 'ARRAY_TO_STRING', 'GENERATE_ARRAY', 'GENERATE_DATE_ARRAY', 'GENERATE_TIMESTAMP_ARRAY', 'ARRAY_REVERSE', 'OFFSET', 'SAFE_OFFSET', 'ORDINAL', 'SAFE_ORDINAL'],
|
2039 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/bit_functions
|
2040 | bitwise: ['BIT_COUNT'],
|
2041 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/conversion_functions
|
2042 | conversion: ['CASE', 'PARSE_BIGNUMERIC', 'PARSE_NUMERIC', 'SAFE_CAST'],
|
2043 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/date_functions
|
2044 | date: ['CURRENT_DATE', 'EXTRACT', 'DATE', 'DATE_ADD', 'DATE_SUB', 'DATE_DIFF', 'DATE_TRUNC', 'DATE_FROM_UNIX_DATE', 'FORMAT_DATE', 'LAST_DAY', 'PARSE_DATE', 'UNIX_DATE'],
|
2045 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/datetime_functions
|
2046 | datetime: ['CURRENT_DATETIME', 'DATETIME', 'EXTRACT', 'DATETIME_ADD', 'DATETIME_SUB', 'DATETIME_DIFF', 'DATETIME_TRUNC', 'FORMAT_DATETIME', 'LAST_DAY', 'PARSE_DATETIME'],
|
2047 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/debugging_functions
|
2048 | debugging: ['ERROR'],
|
2049 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/federated_query_functions
|
2050 | federatedQuery: ['EXTERNAL_QUERY'],
|
2051 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/geography_functions
|
2052 | geography: ['S2_CELLIDFROMPOINT', 'S2_COVERINGCELLIDS', 'ST_ANGLE', 'ST_AREA', 'ST_ASBINARY', 'ST_ASGEOJSON', 'ST_ASTEXT', 'ST_AZIMUTH', 'ST_BOUNDARY', 'ST_BOUNDINGBOX', 'ST_BUFFER', 'ST_BUFFERWITHTOLERANCE', 'ST_CENTROID', 'ST_CENTROID_AGG', 'ST_CLOSESTPOINT', 'ST_CLUSTERDBSCAN', 'ST_CONTAINS', 'ST_CONVEXHULL', 'ST_COVEREDBY', 'ST_COVERS', 'ST_DIFFERENCE', 'ST_DIMENSION', 'ST_DISJOINT', 'ST_DISTANCE', 'ST_DUMP', 'ST_DWITHIN', 'ST_ENDPOINT', 'ST_EQUALS', 'ST_EXTENT', 'ST_EXTERIORRING', 'ST_GEOGFROM', 'ST_GEOGFROMGEOJSON', 'ST_GEOGFROMTEXT', 'ST_GEOGFROMWKB', 'ST_GEOGPOINT', 'ST_GEOGPOINTFROMGEOHASH', 'ST_GEOHASH', 'ST_GEOMETRYTYPE', 'ST_INTERIORRINGS', 'ST_INTERSECTION', 'ST_INTERSECTS', 'ST_INTERSECTSBOX', 'ST_ISCOLLECTION', 'ST_ISEMPTY', 'ST_LENGTH', 'ST_MAKELINE', 'ST_MAKEPOLYGON', 'ST_MAKEPOLYGONORIENTED', 'ST_MAXDISTANCE', 'ST_NPOINTS', 'ST_NUMGEOMETRIES', 'ST_NUMPOINTS', 'ST_PERIMETER', 'ST_POINTN', 'ST_SIMPLIFY', 'ST_SNAPTOGRID', 'ST_STARTPOINT', 'ST_TOUCHES', 'ST_UNION', 'ST_UNION_AGG', 'ST_WITHIN', 'ST_X', 'ST_Y'],
|
2053 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/hash_functions
|
2054 | hash: ['FARM_FINGERPRINT', 'MD5', 'SHA1', 'SHA256', 'SHA512'],
|
2055 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/hll_functions
|
2056 | hll: ['HLL_COUNT.INIT', 'HLL_COUNT.MERGE', 'HLL_COUNT.MERGE_PARTIAL', 'HLL_COUNT.EXTRACT'],
|
2057 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/interval_functions
|
2058 | interval: ['MAKE_INTERVAL', 'EXTRACT', 'JUSTIFY_DAYS', 'JUSTIFY_HOURS', 'JUSTIFY_INTERVAL'],
|
2059 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/json_functions
|
2060 | json: ['JSON_EXTRACT', 'JSON_QUERY', 'JSON_EXTRACT_SCALAR', 'JSON_VALUE', 'JSON_EXTRACT_ARRAY', 'JSON_QUERY_ARRAY', 'JSON_EXTRACT_STRING_ARRAY', 'JSON_VALUE_ARRAY', 'TO_JSON_STRING'],
|
2061 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/mathematical_functions
|
2062 | math: ['ABS', 'SIGN', 'IS_INF', 'IS_NAN', 'IEEE_DIVIDE', 'RAND', 'SQRT', 'POW', 'POWER', 'EXP', 'LN', 'LOG', 'LOG10', 'GREATEST', 'LEAST', 'DIV', 'SAFE_DIVIDE', 'SAFE_MULTIPLY', 'SAFE_NEGATE', 'SAFE_ADD', 'SAFE_SUBTRACT', 'MOD', 'ROUND', 'TRUNC', 'CEIL', 'CEILING', 'FLOOR', 'COS', 'COSH', 'ACOS', 'ACOSH', 'SIN', 'SINH', 'ASIN', 'ASINH', 'TAN', 'TANH', 'ATAN', 'ATANH', 'ATAN2', 'RANGE_BUCKET'],
|
2063 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/navigation_functions
|
2064 | navigation: ['FIRST_VALUE', 'LAST_VALUE', 'NTH_VALUE', 'LEAD', 'LAG', 'PERCENTILE_CONT', 'PERCENTILE_DISC'],
|
2065 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/net_functions
|
2066 | net: ['NET.IP_FROM_STRING', 'NET.SAFE_IP_FROM_STRING', 'NET.IP_TO_STRING', 'NET.IP_NET_MASK', 'NET.IP_TRUNC', 'NET.IPV4_FROM_INT64', 'NET.IPV4_TO_INT64', 'NET.HOST', 'NET.PUBLIC_SUFFIX', 'NET.REG_DOMAIN'],
|
2067 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/numbering_functions
|
2068 | numbering: ['RANK', 'DENSE_RANK', 'PERCENT_RANK', 'CUME_DIST', 'NTILE', 'ROW_NUMBER'],
|
2069 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/security_functions
|
2070 | security: ['SESSION_USER'],
|
2071 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/statistical_aggregate_functions
|
2072 | statisticalAggregate: ['CORR', 'COVAR_POP', 'COVAR_SAMP', 'STDDEV_POP', 'STDDEV_SAMP', 'STDDEV', 'VAR_POP', 'VAR_SAMP', 'VARIANCE'],
|
2073 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/string_functions
|
2074 | string: ['ASCII', 'BYTE_LENGTH', 'CHAR_LENGTH', 'CHARACTER_LENGTH', 'CHR', 'CODE_POINTS_TO_BYTES', 'CODE_POINTS_TO_STRING', 'CONCAT', 'CONTAINS_SUBSTR', 'ENDS_WITH', 'FORMAT', 'FROM_BASE32', 'FROM_BASE64', 'FROM_HEX', 'INITCAP', 'INSTR', 'LEFT', 'LENGTH', 'LPAD', 'LOWER', 'LTRIM', 'NORMALIZE', 'NORMALIZE_AND_CASEFOLD', 'OCTET_LENGTH', 'REGEXP_CONTAINS', 'REGEXP_EXTRACT', 'REGEXP_EXTRACT_ALL', 'REGEXP_INSTR', 'REGEXP_REPLACE', 'REGEXP_SUBSTR', 'REPLACE', 'REPEAT', 'REVERSE', 'RIGHT', 'RPAD', 'RTRIM', 'SAFE_CONVERT_BYTES_TO_STRING', 'SOUNDEX', 'SPLIT', 'STARTS_WITH', 'STRPOS', 'SUBSTR', 'SUBSTRING', 'TO_BASE32', 'TO_BASE64', 'TO_CODE_POINTS', 'TO_HEX', 'TRANSLATE', 'TRIM', 'UNICODE', 'UPPER'],
|
2075 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/time_functions
|
2076 | time: ['CURRENT_TIME', 'TIME', 'EXTRACT', 'TIME_ADD', 'TIME_SUB', 'TIME_DIFF', 'TIME_TRUNC', 'FORMAT_TIME', 'PARSE_TIME'],
|
2077 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/timestamp_functions
|
2078 | timestamp: ['CURRENT_TIMESTAMP', 'EXTRACT', 'STRING', 'TIMESTAMP', 'TIMESTAMP_ADD', 'TIMESTAMP_SUB', 'TIMESTAMP_DIFF', 'TIMESTAMP_TRUNC', 'FORMAT_TIMESTAMP', 'PARSE_TIMESTAMP', 'TIMESTAMP_SECONDS', 'TIMESTAMP_MILLIS', 'TIMESTAMP_MICROS', 'UNIX_SECONDS', 'UNIX_MILLIS', 'UNIX_MICROS'],
|
2079 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/uuid_functions
|
2080 | uuid: ['GENERATE_UUID'],
|
2081 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/conditional_expressions
|
2082 | conditional: ['COALESCE', 'IF', 'IFNULL', 'NULLIF'],
|
2083 | // https://cloud.google.com/bigquery/docs/reference/legacy-sql
|
2084 | legacyAggregate: ['AVG', 'BIT_AND', 'BIT_OR', 'BIT_XOR', 'CORR', 'COUNT', 'COVAR_POP', 'COVAR_SAMP', 'EXACT_COUNT_DISTINCT', 'FIRST', 'GROUP_CONCAT', 'GROUP_CONCAT_UNQUOTED', 'LAST', 'MAX', 'MIN', 'NEST', 'NTH', 'QUANTILES', 'STDDEV', 'STDDEV_POP', 'STDDEV_SAMP', 'SUM', 'TOP', 'UNIQUE', 'VARIANCE', 'VAR_POP', 'VAR_SAMP'],
|
2085 | legacyBitwise: ['BIT_COUNT'],
|
2086 | legacyCasting: ['BOOLEAN', 'BYTES', 'CAST', 'FLOAT', 'HEX_STRING', 'INTEGER', 'STRING'],
|
2087 | legacyComparison: [// expr 'IN',
|
2088 | 'COALESCE', 'GREATEST', 'IFNULL', 'IS_INF', 'IS_NAN', 'IS_EXPLICITLY_DEFINED', 'LEAST', 'NVL'],
|
2089 | legacyDatetime: ['CURRENT_DATE', 'CURRENT_TIME', 'CURRENT_TIMESTAMP', 'DATE', 'DATE_ADD', 'DATEDIFF', 'DAY', 'DAYOFWEEK', 'DAYOFYEAR', 'FORMAT_UTC_USEC', 'HOUR', 'MINUTE', 'MONTH', 'MSEC_TO_TIMESTAMP', 'NOW', 'PARSE_UTC_USEC', 'QUARTER', 'SEC_TO_TIMESTAMP', 'SECOND', 'STRFTIME_UTC_USEC', 'TIME', 'TIMESTAMP', 'TIMESTAMP_TO_MSEC', 'TIMESTAMP_TO_SEC', 'TIMESTAMP_TO_USEC', 'USEC_TO_TIMESTAMP', 'UTC_USEC_TO_DAY', 'UTC_USEC_TO_HOUR', 'UTC_USEC_TO_MONTH', 'UTC_USEC_TO_WEEK', 'UTC_USEC_TO_YEAR', 'WEEK', 'YEAR'],
|
2090 | legacyIp: ['FORMAT_IP', 'PARSE_IP', 'FORMAT_PACKED_IP', 'PARSE_PACKED_IP'],
|
2091 | legacyJson: ['JSON_EXTRACT', 'JSON_EXTRACT_SCALAR'],
|
2092 | legacyMath: ['ABS', 'ACOS', 'ACOSH', 'ASIN', 'ASINH', 'ATAN', 'ATANH', 'ATAN2', 'CEIL', 'COS', 'COSH', 'DEGREES', 'EXP', 'FLOOR', 'LN', 'LOG', 'LOG2', 'LOG10', 'PI', 'POW', 'RADIANS', 'RAND', 'ROUND', 'SIN', 'SINH', 'SQRT', 'TAN', 'TANH'],
|
2093 | legacyRegex: ['REGEXP_MATCH', 'REGEXP_EXTRACT', 'REGEXP_REPLACE'],
|
2094 | legacyString: ['CONCAT', // expr CONTAINS 'str'
|
2095 | 'INSTR', 'LEFT', 'LENGTH', 'LOWER', 'LPAD', 'LTRIM', 'REPLACE', 'RIGHT', 'RPAD', 'RTRIM', 'SPLIT', 'SUBSTR', 'UPPER'],
|
2096 | legacyTableWildcard: ['TABLE_DATE_RANGE', 'TABLE_DATE_RANGE_STRICT', 'TABLE_QUERY'],
|
2097 | legacyUrl: ['HOST', 'DOMAIN', 'TLD'],
|
2098 | legacyWindow: ['AVG', 'COUNT', 'MAX', 'MIN', 'STDDEV', 'SUM', 'CUME_DIST', 'DENSE_RANK', 'FIRST_VALUE', 'LAG', 'LAST_VALUE', 'LEAD', 'NTH_VALUE', 'NTILE', 'PERCENT_RANK', 'PERCENTILE_CONT', 'PERCENTILE_DISC', 'RANK', 'RATIO_TO_REPORT', 'ROW_NUMBER'],
|
2099 | legacyMisc: ['CURRENT_USER', 'EVERY', 'FROM_BASE64', 'HASH', 'FARM_FINGERPRINT', 'IF', 'POSITION', 'SHA1', 'SOME', 'TO_BASE64'],
|
2100 | other: ['BQ.JOBS.CANCEL', 'BQ.REFRESH_MATERIALIZED_VIEW']
|
2101 | };
|
2102 | /**
|
2103 | * Priority 5 (last)
|
2104 | * Full list of reserved words
|
2105 | * any words that are in a higher priority are removed
|
2106 | */
|
2107 |
|
2108 | var reservedKeywords = {
|
2109 | keywords: ['ALL', // 'AND',
|
2110 | 'ANY', // 'ARRAY',
|
2111 | 'AS', 'ASC', 'ASSERT_ROWS_MODIFIED', 'AT', 'BETWEEN', 'BY', // 'CASE',
|
2112 | 'CAST', 'COLLATE', 'CONTAINS', // 'CREATE',
|
2113 | // 'CROSS',
|
2114 | 'CUBE', 'CURRENT', 'DEFAULT', 'DEFINE', 'DESC', 'DISTINCT', // 'ELSE',
|
2115 | // 'END',
|
2116 | 'ENUM', 'ESCAPE', // 'EXCEPT',
|
2117 | // 'EXCLUDE',
|
2118 | 'EXISTS', 'EXTRACT', 'FALSE', // 'FETCH',
|
2119 | 'FOLLOWING', 'FOR', // 'FROM',
|
2120 | 'FULL', // 'GROUP',
|
2121 | 'GROUPING', 'GROUPS', 'HASH', // 'HAVING',
|
2122 | 'IF', 'IGNORE', 'IN', // 'INNER',
|
2123 | // 'INTERSECT',
|
2124 | // 'INTERVAL',
|
2125 | 'INTO', 'IS', // 'JOIN',
|
2126 | // 'LATERAL',
|
2127 | // 'LEFT',
|
2128 | 'LIKE', // 'LIMIT',
|
2129 | 'LOOKUP', // 'MERGE',
|
2130 | // 'NATURAL',
|
2131 | 'NEW', 'NO', 'NOT', 'NULL', 'NULLS', 'OF', // 'ON',
|
2132 | // 'OR',
|
2133 | // 'ORDER',
|
2134 | // 'OUTER',
|
2135 | 'OVER', 'PARTITION', 'PRECEDING', 'PROTO', 'RANGE', 'RECURSIVE', 'RESPECT', // 'RIGHT',
|
2136 | 'ROLLUP', 'ROWS', // 'SELECT',
|
2137 | // 'SET',
|
2138 | 'SOME', // 'STRUCT',
|
2139 | 'TABLE', // 'TABLESAMPLE',
|
2140 | 'THEN', 'TO', 'TREAT', 'TRUE', 'UNBOUNDED', // 'UNION',
|
2141 | // 'UNNEST',
|
2142 | // 'USING',
|
2143 | // 'WHEN',
|
2144 | // 'WHERE',
|
2145 | // 'WINDOW',
|
2146 | // 'WITH',
|
2147 | 'WITHIN'],
|
2148 | datatypes: ['ARRAY', 'BOOL', 'BYTES', 'DATE', 'DATETIME', 'GEOGRAPHY', 'INTERVAL', 'INT64', 'INT', 'SMALLINT', 'INTEGER', 'BIGINT', 'TINYINT', 'BYTEINT', 'NUMERIC', 'DECIMAL', 'BIGNUMERIC', 'BIGDECIMAL', 'FLOAT64', 'STRING', 'STRUCT', 'TIME', 'TIMEZONE'],
|
2149 | // https://cloud.google.com/bigquery/docs/reference/standard-sql/conversion_functions#formatting_syntax
|
2150 | stringFormat: ['HEX', 'BASEX', 'BASE64M', 'ASCII', 'UTF-8', 'UTF8'],
|
2151 | misc: ['SAFE']
|
2152 | };
|
2153 | /**
|
2154 | * Priority 1 (first)
|
2155 | * keywords that begin a new statement
|
2156 | * will begin new indented block
|
2157 | */
|
2158 |
|
2159 | var reservedCommands = [// DQL, https://cloud.google.com/bigquery/docs/reference/standard-sql/query-syntax
|
2160 | 'SELECT', 'FROM', 'UNNEST', 'PIVOT', 'UNPIVOT', 'TABLESAMPLE SYSTEM', 'WHERE', 'GROUP BY', 'HAVING', 'ORDER BY', 'QUALIFY', 'WINDOW', 'LIMIT', 'OFFSET', 'WITH', 'OMIT RECORD IF', // DML, https://cloud.google.com/bigquery/docs/reference/standard-sql/dml-syntax
|
2161 | 'INSERT', 'INSERT INTO', 'VALUES', 'DELETE', // 'DELETE FROM',
|
2162 | 'TRUNCATE TABLE', 'UPDATE', 'MERGE', 'MERGE INTO', // 'USING',
|
2163 | // DDL, https://cloud.google.com/bigquery/docs/reference/standard-sql/data-definition-language
|
2164 | 'SET SCHEMA', 'CREATE SCHEMA', 'CREATE TABLE', 'CREATE TABLE LIKE', 'CREATE TABLE COPY', 'CREATE SNAPSHOT TABLE', 'CREATE TABLE CLONE', 'CREATE VIEW', 'CREATE MATERIALIZED VIEW', 'CREATE EXTERNAL TABLE', 'CREATE FUNCTION', 'CREATE TABLE FUNCTION', 'CREATE PROCEDURE', 'CREATE ROW ACCESS POLICY', 'ALTER SCHEMA SET OPTIONS', 'ALTER TABLE SET OPTIONS', 'ALTER TABLE ADD COLUMN', 'ALTER TABLE RENAME TO', 'ALTER TABLE DROP COLUMN', 'ALTER COLUMN SET OPTIONS', 'ALTER COLUMN DROP NOT NULL', 'ALTER COLUMN SET DATA TYPE', 'ALTER VIEW SET OPTIONS', 'ALTER MATERIALIZED VIEW SET OPTIONS', 'DROP SCHEMA', 'DROP TABLE', 'DROP SNAPSHOT TABLE', 'DROP EXTERNAL TABLE', 'DROP VIEW', 'DROP MATERIALIZED VIEW', 'DROP FUNCTION', 'DROP TABLE FUNCTION', 'DROP PROCEDURE', 'DROP ROW ACCESS POLICY', // DCL, https://cloud.google.com/bigquery/docs/reference/standard-sql/data-control-language
|
2165 | 'GRANT', 'REVOKE', 'CREATE CAPACITY', 'CREATE RESERVATION', 'CREATE ASSIGNMENT', 'DROP CAPACITY', 'DROP RESERVATION', 'DROP ASSIGNMENT', // Script, https://cloud.google.com/bigquery/docs/reference/standard-sql/scripting
|
2166 | 'DECLARE', 'SET', 'EXECUTE IMMEDIATE', 'LOOP', 'END LOOP', 'REPEAT', 'END REPEAT', 'WHILE', 'END WHILE', 'BREAK', 'LEAVE', 'CONTINUE', 'ITERATE', 'FOR', 'END FOR', 'BEGIN', 'BEGIN TRANSACTION', 'COMMIT TRANSACTION', 'ROLLBACK TRANSACTION', 'RAISE', 'RETURN', 'CALL', // Debug, https://cloud.google.com/bigquery/docs/reference/standard-sql/debugging-statements
|
2167 | 'ASSERT', // Other, https://cloud.google.com/bigquery/docs/reference/standard-sql/other-statements
|
2168 | 'EXPORT DATA'];
|
2169 | /**
|
2170 | * Priority 2
|
2171 | * commands that operate on two tables or subqueries
|
2172 | * two main categories: joins and boolean set operators
|
2173 | */
|
2174 |
|
2175 | var reservedBinaryCommands = [// set booleans
|
2176 | 'INTERSECT', 'INTERSECT ALL', 'INTERSECT DISTINCT', 'UNION', 'UNION ALL', 'UNION DISTINCT', 'EXCEPT', 'EXCEPT ALL', 'EXCEPT DISTINCT', // joins
|
2177 | 'JOIN', 'INNER JOIN', 'LEFT JOIN', 'LEFT OUTER JOIN', 'RIGHT JOIN', 'RIGHT OUTER JOIN', 'FULL JOIN', 'FULL OUTER JOIN', 'CROSS JOIN'];
|
2178 | /**
|
2179 | * Priority 3
|
2180 | * keywords that follow a previous Statement, must be attached to subsequent data
|
2181 | * can be fully inline or on newline with optional indent
|
2182 | */
|
2183 |
|
2184 | var reservedDependentClauses = ['WHEN', 'ELSE']; // https://cloud.google.com/bigquery/docs/reference/#standard-sql-reference
|
2185 |
|
2186 | var BigQueryFormatter = /*#__PURE__*/function (_Formatter) {
|
2187 | _inherits(BigQueryFormatter, _Formatter);
|
2188 |
|
2189 | var _super = _createSuper(BigQueryFormatter);
|
2190 |
|
2191 | function BigQueryFormatter() {
|
2192 | _classCallCheck(this, BigQueryFormatter);
|
2193 |
|
2194 | return _super.apply(this, arguments);
|
2195 | }
|
2196 |
|
2197 | _createClass(BigQueryFormatter, [{
|
2198 | key: "tokenizer",
|
2199 | value: // TODO: handle trailing comma in select clause
|
2200 | function tokenizer() {
|
2201 | return new _core_Tokenizer__WEBPACK_IMPORTED_MODULE_1__["default"]({
|
2202 | reservedCommands: BigQueryFormatter.reservedCommands,
|
2203 | reservedBinaryCommands: BigQueryFormatter.reservedBinaryCommands,
|
2204 | reservedDependentClauses: BigQueryFormatter.reservedDependentClauses,
|
2205 | reservedJoinConditions: BigQueryFormatter.reservedJoinConditions,
|
2206 | reservedLogicalOperators: BigQueryFormatter.reservedLogicalOperators,
|
2207 | reservedKeywords: BigQueryFormatter.fullReservedWords,
|
2208 | stringTypes: BigQueryFormatter.stringTypes,
|
2209 | blockStart: BigQueryFormatter.blockStart,
|
2210 | blockEnd: BigQueryFormatter.blockEnd,
|
2211 | indexedPlaceholderTypes: BigQueryFormatter.indexedPlaceholderTypes,
|
2212 | namedPlaceholderTypes: BigQueryFormatter.namedPlaceholderTypes,
|
2213 | lineCommentTypes: BigQueryFormatter.lineCommentTypes,
|
2214 | specialWordChars: BigQueryFormatter.specialWordChars,
|
2215 | operators: BigQueryFormatter.operators
|
2216 | });
|
2217 | }
|
2218 | }, {
|
2219 | key: "tokenOverride",
|
2220 | value: function tokenOverride(token) {
|
2221 | if ((/ARRAY/i.test(token.value) || /STRUCT/i.test(token.value)) && this.tokenLookAhead().value === '<') {
|
2222 | var level = 0;
|
2223 | var finalToken = token.value;
|
2224 |
|
2225 | do {
|
2226 | var nextToken = this.tokenLookAhead();
|
2227 |
|
2228 | if (nextToken.value === '>' || nextToken.value === '>>') {
|
2229 | level -= nextToken.value.length;
|
2230 | } else if (nextToken.value === '<') {
|
2231 | level++;
|
2232 | }
|
2233 |
|
2234 | finalToken += this.tokens.splice(this.index + 1, 1)[0].value;
|
2235 | } while (level > 0);
|
2236 |
|
2237 | return Object.assign(Object.assign({}, token), {
|
2238 | value: finalToken
|
2239 | });
|
2240 | }
|
2241 |
|
2242 | return token;
|
2243 | }
|
2244 | }]);
|
2245 |
|
2246 | return BigQueryFormatter;
|
2247 | }(_core_Formatter__WEBPACK_IMPORTED_MODULE_0__["default"]);
|
2248 |
|
2249 |
|
2250 | BigQueryFormatter.reservedCommands = reservedCommands;
|
2251 | BigQueryFormatter.reservedBinaryCommands = reservedBinaryCommands;
|
2252 | BigQueryFormatter.reservedDependentClauses = reservedDependentClauses;
|
2253 | BigQueryFormatter.reservedJoinConditions = ['ON', 'USING'];
|
2254 | BigQueryFormatter.reservedLogicalOperators = ['AND', 'OR'];
|
2255 | BigQueryFormatter.fullReservedWords = (0,_utils__WEBPACK_IMPORTED_MODULE_2__.dedupe)([].concat(_toConsumableArray(Object.values(reservedFunctions).reduce(function (acc, arr) {
|
2256 | return [].concat(_toConsumableArray(acc), _toConsumableArray(arr));
|
2257 | }, [])), _toConsumableArray(Object.values(reservedKeywords).reduce(function (acc, arr) {
|
2258 | return [].concat(_toConsumableArray(acc), _toConsumableArray(arr));
|
2259 | }, []))));
|
2260 | BigQueryFormatter.stringTypes = ['""', "''", '``']; // add: '''''', """""" ; prefixes: r, b
|
2261 |
|
2262 | BigQueryFormatter.blockStart = ['(', 'CASE'];
|
2263 | BigQueryFormatter.blockEnd = [')', 'END'];
|
2264 | BigQueryFormatter.indexedPlaceholderTypes = ['?'];
|
2265 | BigQueryFormatter.namedPlaceholderTypes = [];
|
2266 | BigQueryFormatter.lineCommentTypes = ['--', '#'];
|
2267 | BigQueryFormatter.specialWordChars = {
|
2268 | any: '_@$-'
|
2269 | };
|
2270 | BigQueryFormatter.operators = ['>>', '<<', '||'];
|
2271 |
|
2272 | /***/ }),
|
2273 |
|
2274 | /***/ "./src/languages/db2.formatter.ts":
|
2275 | /*!****************************************!*\
|
2276 | !*** ./src/languages/db2.formatter.ts ***!
|
2277 | \****************************************/
|
2278 | /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
2279 |
|
2280 | __webpack_require__.r(__webpack_exports__);
|
2281 | /* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
2282 | /* harmony export */ "default": () => (/* binding */ Db2Formatter)
|
2283 | /* harmony export */ });
|
2284 | /* harmony import */ var _core_Formatter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../core/Formatter */ "./src/core/Formatter.ts");
|
2285 | /* harmony import */ var _core_Tokenizer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../core/Tokenizer */ "./src/core/Tokenizer.ts");
|
2286 | /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils */ "./src/utils.ts");
|
2287 | function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
2288 |
|
2289 | function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
|
2290 |
|
2291 | function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
2292 |
|
2293 | function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
2294 |
|
2295 | function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
|
2296 |
|
2297 | function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
|
2298 |
|
2299 | function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
2300 |
|
2301 | function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
2302 |
|
2303 | function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
2304 |
|
2305 | function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
2306 |
|
2307 | function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
|
2308 |
|
2309 | function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
|
2310 |
|
2311 | function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
2312 |
|
2313 | function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
|
2314 |
|
2315 | function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
|
2316 |
|
2317 | function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
2318 |
|
2319 | function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
|
2320 |
|
2321 |
|
2322 |
|
2323 |
|
2324 | /**
|
2325 | * Priority 5 (last)
|
2326 | * Full list of reserved functions
|
2327 | * distinct from Keywords due to interaction with parentheses
|
2328 | */
|
2329 |
|
2330 | var reservedFunctions = {
|
2331 | // https://www.ibm.com/docs/en/db2-for-zos/11?topic=functions-aggregate
|
2332 | aggregate: ['ARRAY_AGG', 'AVG', 'CORR', 'CORRELATION', 'COUNT', 'COUNT_BIG', 'COVAR_POP', 'COVARIANCE', 'COVAR', 'COVAR_SAMP', 'COVARIANCE_SAMP', 'CUME_DIST', 'GROUPING', 'LISTAGG', 'MAX', 'MEDIAN', 'MIN', 'PERCENTILE_CONT', 'PERCENTILE_DISC', 'PERCENT_RANK', 'REGR_AVGX', 'REGR_AVGY', 'REGR_COUNT', 'REGR_INTERCEPT', 'REGR_ICPT', 'REGR_R2', 'REGR_SLOPE', 'REGR_SXX', 'REGR_SXY', 'REGR_SYY', 'STDDEV_POP', 'STDDEV', 'STDDEV_SAMP', 'SUM', 'VAR_POP', 'VARIANCE', 'VAR', 'VAR_SAMP', 'VARIANCE_SAMP', 'XMLAGG'],
|
2333 | // https://www.ibm.com/docs/en/db2-for-zos/11?topic=functions-scalar
|
2334 | scalar: ['ABS', 'ABSVAL', 'ACOS', 'ADD_DAYS', 'ADD_MONTHS', 'ARRAY_DELETE', 'ARRAY_FIRST', 'ARRAY_LAST', 'ARRAY_NEXT', 'ARRAY_PRIOR', 'ARRAY_TRIM', 'ASCII', 'ASCII_CHR', 'ASCII_STR', 'ASCIISTR', 'ASIN', 'ATAN', 'ATANH', 'ATAN2', 'BIGINT', 'BINARY', 'BITAND', 'BITANDNOT', 'BITOR', 'BITXOR', 'BITNOT', 'BLOB', 'BTRIM', 'CARDINALITY', 'CCSID_ENCODING', 'CEILING', 'CEIL', 'CHAR', 'CHAR9', 'CHARACTER_LENGTH', 'CHAR_LENGTH', 'CHR', 'CLOB', 'COALESCE', 'COLLATION_KEY', 'COMPARE_DECFLOAT', 'CONCAT', 'CONTAINS', 'COS', 'COSH', 'DATE', 'DAY', 'DAYOFMONTH', 'DAYOFWEEK', 'DAYOFWEEK_ISO', 'DAYOFYEAR', 'DAYS', 'DAYS_BETWEEN', 'DBCLOB', 'DECFLOAT', 'DECFLOAT_FORMAT', 'DECFLOAT_SORTKEY', 'DECIMAL', 'DEC', 'DECODE', 'DECRYPT_BINARY', 'DECRYPT_BIT', 'DECRYPT_CHAR', 'DECRYPT_DB', 'DECRYPT_DATAKEY_BIGINT', 'DECRYPT_DATAKEY_BIT', 'DECRYPT_DATAKEY_CLOB', 'DECRYPT_DATAKEY_DBCLOB', 'DECRYPT_DATAKEY_DECIMAL', 'DECRYPT_DATAKEY_INTEGER', 'DECRYPT_DATAKEY_VARCHAR', 'DECRYPT_DATAKEY_VARGRAPHIC', 'DEGREES', 'DIFFERENCE', 'DIGITS', 'DOUBLE_PRECISION', 'DOUBLE', 'DSN_XMLVALIDATE', 'EBCDIC_CHR', 'EBCDIC_STR', 'ENCRYPT_DATAKEY', 'ENCRYPT_TDES', 'EXP', 'EXTRACT', 'FLOAT', 'FLOOR', 'GENERATE_UNIQUE', 'GENERATE_UNIQUE_BINARY', 'GETHINT', 'GETVARIABLE', 'GRAPHIC', 'GREATEST', 'HASH', 'HASH_CRC32', 'HASH_MD5', 'HASH_SHA1', 'HASH_SHA256', 'HEX', 'HOUR', 'IDENTITY_VAL_LOCAL', 'IFNULL', 'INSERT', 'INSTR', 'INTEGER', 'INT', 'JULIAN_DAY', 'LAST_DAY', 'LCASE', 'LEAST', 'LEFT', 'LENGTH', 'LN', 'LOCATE', 'LOCATE_IN_STRING', 'LOG10', 'LOWER', 'LPAD', 'LTRIM', 'MAX', 'MAX_CARDINALITY', 'MICROSECOND', 'MIDNIGHT_SECONDS', 'MIN', 'MINUTE', 'MOD', 'MONTH', 'MONTHS_BETWEEN', 'MQREAD', 'MQREADCLOB', 'MQRECEIVE', 'MQRECEIVECLOB', 'MQSEND', 'MULTIPLY_ALT', 'NEXT_DAY', 'NEXT_MONTH', 'NORMALIZE_DECFLOAT', 'NORMALIZE_STRING', 'NULLIF', 'NVL', 'OVERLAY', 'PACK', 'POSITION', 'POSSTR', 'POWER', 'POW', 'QUANTIZE', 'QUARTER', 'RADIANS', 'RAISE_ERROR', 'RANDOM', 'RAND', 'REAL', 'REGEXP_COUNT', 'REGEXP_INSTR', 'REGEXP_LIKE', 'REGEXP_REPLACE', 'REGEXP_SUBSTR', 'REPEAT', 'REPLACE', 'RID', 'RIGHT', 'ROUND', 'ROUND_TIMESTAMP', 'ROWID', 'RPAD', 'RTRIM', 'SCORE', 'SECOND', 'SIGN', 'SIN', 'SINH', 'SMALLINT', 'SOUNDEX', 'SOAPHTTPC', 'SOAPHTTPV', 'SOAPHTTPNC', 'SOAPHTTPNV', 'SPACE', 'SQRT', 'STRIP', 'STRLEFT', 'STRPOS', 'STRRIGHT', 'SUBSTR', 'SUBSTRING', 'TAN', 'TANH', 'TIME', 'TIMESTAMP', 'TIMESTAMPADD', 'TIMESTAMPDIFF', 'TIMESTAMP_FORMAT', 'TIMESTAMP_ISO', 'TIMESTAMP_TZ', 'TO_CHAR', 'TO_CLOB', 'TO_DATE', 'TO_NUMBER', 'TOTALORDER', 'TO_TIMESTAMP', 'TRANSLATE', 'TRIM', 'TRIM_ARRAY', 'TRUNCATE', 'TRUNC', 'TRUNC_TIMESTAMP', 'UCASE', 'UNICODE', 'UNICODE_STR', 'UNISTR', 'UPPER', 'VALUE', 'VARBINARY', 'VARCHAR', 'VARCHAR9', 'VARCHAR_BIT_FORMAT', 'VARCHAR_FORMAT', 'VARGRAPHIC', 'VERIFY_GROUP_FOR_USER', 'VERIFY_ROLE_FOR_USER', 'VERIFY_TRUSTED_CONTEXT_ROLE_FOR_USER', 'WEEK', 'WEEK_ISO', 'WRAP', 'XMLATTRIBUTES', 'XMLCOMMENT', 'XMLCONCAT', 'XMLDOCUMENT', 'XMLELEMENT', 'XMLFOREST', 'XMLMODIFY', 'XMLNAMESPACES', 'XMLPARSE', 'XMLPI', 'XMLQUERY', 'XMLSERIALIZE', 'XMLTEXT', 'XMLXSROBJECTID', 'XSLTRANSFORM', 'YEAR'],
|
2335 | // https://www.ibm.com/docs/en/db2-for-zos/11?topic=functions-table
|
2336 | table: ['ADMIN_TASK_LIST', 'ADMIN_TASK_OUTPUT', 'ADMIN_TASK_STATUS', 'BLOCKING_THREADS', 'MQREADALL', 'MQREADALLCLOB', 'MQRECEIVEALL', 'MQRECEIVEALLCLOB', 'XMLTABLE'],
|
2337 | // https://www.ibm.com/docs/en/db2-for-zos/11?topic=functions-row
|
2338 | row: ['UNPACK'],
|
2339 | // https://www.ibm.com/docs/en/db2-for-zos/12?topic=expressions-olap-specification
|
2340 | olap: ['FIRST_VALUE', 'LAG', 'LAST_VALUE', 'LEAD', 'NTH_VALUE', 'NTILE', 'RATIO_TO_REPORT']
|
2341 | };
|
2342 | /**
|
2343 | * Priority 5 (last)
|
2344 | * Full list of reserved words
|
2345 | * any words that are in a higher priority are removed
|
2346 | */
|
2347 |
|
2348 | var reservedKeywords = {
|
2349 | // https://www.ibm.com/docs/en/db2-for-zos/11?topic=words-reserved#db2z_reservedwords__newresword
|
2350 | standard: ['ALL', 'ALLOCATE', 'ALLOW', 'ALTERAND', 'ANY', 'AS', 'ARRAY', 'ARRAY_EXISTS', 'ASENSITIVE', 'ASSOCIATE', 'ASUTIME', 'AT', 'AUDIT', 'AUX', 'AUXILIARY', 'BEFORE', 'BEGIN', 'BETWEEN', 'BUFFERPOOL', 'BY', 'CAPTURE', 'CASCADED', 'CASE', 'CAST', 'CCSID', 'CHARACTER', 'CHECK', 'CLONE', 'CLUSTER', 'COLLECTION', 'COLLID', 'COLUMN', 'CONDITION', 'CONNECTION', 'CONSTRAINT', 'CONTENT', 'CONTINUE', 'CREATE', 'CUBE', 'CURRENT', 'CURRENT_DATE', 'CURRENT_LC_CTYPE', 'CURRENT_PATH', 'CURRENT_SCHEMA', 'CURRENT_TIME', 'CURRENT_TIMESTAMP', 'CURRVAL', 'CURSOR', 'DATA', 'DATABASE', 'DBINFO', 'DECLARE', 'DEFAULT', 'DESCRIPTOR', 'DETERMINISTIC', 'DISABLE', 'DISALLOW', 'DISTINCT', 'DO', 'DOCUMENT', 'DSSIZE', 'DYNAMIC', 'EDITPROC', 'ENCODING', 'ENCRYPTION', 'ENDING', 'END-EXEC', 'ERASE', 'ESCAPE', 'EXCEPTION', 'EXISTS', 'EXIT', 'EXTERNAL', 'FENCED', 'FIELDPROC', 'FINAL', 'FIRST', 'FOR', 'FREE', 'FULL', 'FUNCTION', 'GENERATED', 'GET', 'GLOBAL', 'GOTO', 'GROUP', 'HANDLER', 'HOLD', 'HOURS', 'IF', 'IMMEDIATE', 'IN', 'INCLUSIVE', 'INDEX', 'INHERIT', 'INNER', 'INOUT', 'INSENSITIVE', 'INTO', 'IS', 'ISOBID', 'ITERATE', 'JAR', 'KEEP', 'KEY', 'LANGUAGE', 'LAST', 'LC_CTYPE', 'LEAVE', 'LIKE', 'LOCAL', 'LOCALE', 'LOCATOR', 'LOCATORS', 'LOCK', 'LOCKMAX', 'LOCKSIZE', 'LONG', 'LOOP', 'MAINTAINED', 'MATERIALIZED', 'MICROSECONDS', 'MINUTEMINUTES', 'MODIFIES', 'MONTHS', 'NEXT', 'NEXTVAL', 'NO', 'NONE', 'NOT', 'NULL', 'NULLS', 'NUMPARTS', 'OBID', 'OF', 'OLD', 'ON DELETE', 'ON UPDATE', 'OPTIMIZATION', 'OPTIMIZE', 'ORDER', 'ORGANIZATION', 'OUT', 'OUTER', 'PACKAGE', 'PARAMETER', 'PART', 'PADDED', 'PARTITION', 'PARTITIONED', 'PARTITIONING', 'PATH', 'PIECESIZE', 'PERIOD', 'PLAN', 'PRECISION', 'PREVVAL', 'PRIOR', 'PRIQTY', 'PRIVILEGES', 'PROCEDURE', 'PROGRAM', 'PSID', 'PUBLIC', 'QUERY', 'QUERYNO', 'READS', 'REFERENCES', 'RESIGNAL', 'RESTRICT', 'RESULT', 'RESULT_SET_LOCATOR', 'RETURN', 'RETURNS', 'ROLE', 'ROLLUP', 'ROUND_CEILING', 'ROUND_DOWN', 'ROUND_FLOOR', 'ROUND_HALF_DOWN', 'ROUND_HALF_EVEN', 'ROUND_HALF_UP', 'ROUND_UP', 'ROW', 'ROWSET', 'SCHEMA', 'SCRATCHPAD', 'SECONDS', 'SECQTY', 'SECURITY', 'SEQUENCE', 'SENSITIVE', 'SESSION_USER', 'SIMPLE', 'SOME', 'SOURCE', 'SPECIFIC', 'STANDARD', 'STATIC', 'STATEMENT', 'STAY', 'STOGROUP', 'STORES', 'STYLE', 'SUMMARY', 'SYNONYM', 'SYSDATE', 'SYSTEM', 'SYSTIMESTAMP', 'TABLE', 'TABLESPACE', 'THEN', 'TO', 'TRIGGER', 'TYPE', 'UNDO', 'UNIQUE', 'UNTIL', 'USER', 'VALIDPROC', 'VARIABLE', 'VARIANT', 'VCAT', 'VERSIONING', 'VIEW', 'VOLATILE', 'VOLUMES', 'WHILE', 'WLM', 'XMLEXISTS', 'XMLCAST', 'YEARS', 'ZONE'],
|
2351 | // https://www.ibm.com/docs/en/db2-for-zos/11?topic=utilities-db2-online
|
2352 | onlineUtilies: ['BACKUP SYSTEM', 'CATENFM', 'CATMAINT', 'CHECK DATA', 'CHECK INDEX', 'CHECK LOB', 'COPY', 'COPYTOCOPY', 'DIAGNOSE', 'EXEC SQL', 'LISTDEF', 'LOAD', 'MERGECOPY', 'MODIFY RECOVERY', 'MODIFY STATISTICS', 'OPTIONS', 'QUIESCE', 'REBUILD INDEX', 'RECOVER', 'REORG INDEX', 'REORG TABLESPACE', 'REPAIR', 'REPORT', 'RESTORE SYSTEM', 'RUNSTATS', 'STOSPACE', 'TEMPLATE', 'UNLOAD'],
|
2353 | // https://www.ibm.com/docs/en/db2-for-zos/11?topic=db2-commands
|
2354 | commands: ['ABEND', 'ACCESS DATABASE', 'ALTER BUFFERPOOL', 'ALTER GROUPBUFFERPOOL', 'ALTER UTILITY', 'ARCHIVE LOG', 'BIND PACKAGE', 'BIND PLAN', 'BIND QUERY', 'BIND SERVICE', 'BIND', 'REBIND', 'CANCEL THREAD', 'DCLGEN', 'DISPLAY ACCEL', 'DISPLAY ARCHIVE', 'DISPLAY BLOCKERS', 'DISPLAY BUFFERPOOL', 'DISPLAY DATABASE', 'DISPLAY DDF', 'DISPLAY FUNCTION SPECIFIC', 'DISPLAY GROUP', 'DISPLAY GROUPBUFFERPOOL', 'DISPLAY LOCATION', 'DISPLAY LOG', 'DISPLAY PROCEDURE', 'DISPLAY PROFILE', 'DISPLAY RLIMIT', 'DISPLAY RESTSVC', 'DISPLAY THREAD', 'DISPLAY TRACE', 'DISPLAY UTILITY', 'DSN', 'DSNH', 'END', 'FREE PACKAGE', 'FREE PLAN', 'FREE QUERY', 'FREE SERVICE', 'MODIFY admtproc,APPL=SHUTDOWN', 'MODIFY admtproc,APPL=TRACE', 'MODIFY DDF', 'MODIFY irlmproc,ABEND', 'MODIFY irlmproc,DIAG', 'MODIFY irlmproc,PURGE', 'MODIFY irlmproc,SET', 'MODIFY irlmproc,STATUS', 'MODIFY TRACE', 'REBIND PACKAGE', 'REBIND PLAN', 'REBIND TRIGGER PACKAGE', 'RECOVER BSDS', 'RECOVER INDOUBT', 'RECOVER POSTPONED', 'REFRESH DB2,EARLY', 'RESET GENERICLU', 'RESET INDOUBT', 'RUN', 'SET ARCHIVE', 'SET LOG', 'SET SYSPARM', 'SPUFI', 'START ACCEL', 'START admtproc', 'START CDDS', 'START DATABASE', 'START DB2', 'START DDF', 'START FUNCTION SPECIFIC', 'START irlmproc', 'START PROCEDURE', 'START PROFILE', 'START RLIMIT', 'START RESTSVC', 'START TRACE', 'STOP ACCEL', 'STOP admtproc', 'STOP CDDS', 'STOP DATABASE', 'STOP DB2', 'STOP DDF', 'STOP FUNCTION SPECIFIC', 'STOP irlmproc', 'STOP PROCEDURE', 'STOP PROFILE', 'STOP RLIMIT', 'STOP RESTSVC', 'STOP TRACE', 'TERM UTILITY', 'TRACE CT']
|
2355 | };
|
2356 | /**
|
2357 | * Priority 1 (first)
|
2358 | * keywords that begin a new statement
|
2359 | * will begin new indented block
|
2360 | */
|
2361 | // https://www.ibm.com/docs/en/db2-for-zos/11?topic=statements-list-supported
|
2362 |
|
2363 | var reservedCommands = ['ALLOCATE CURSOR', 'ALTER DATABASE', 'ALTER FUNCTION', 'ALTER INDEX', 'ALTER MASK', 'ALTER PERMISSION', 'ALTER PROCEDURE', 'ALTER SEQUENCE', 'ALTER STOGROUP', 'ALTER TABLE', 'ALTER TABLESPACE', 'ALTER TRIGGER', 'ALTER TRUSTED CONTEXT', 'ALTER VIEW', 'ASSOCIATE LOCATORS', 'BEGIN DECLARE SECTION', 'CALL', 'CLOSE', 'COMMENT', 'COMMIT', 'CONNECT', 'CREATE ALIAS', 'CREATE AUXILIARY TABLE', 'CREATE DATABASE', 'CREATE FUNCTION', 'CREATE GLOBAL TEMPORARY TABLE', 'CREATE INDEX', 'CREATE LOB TABLESPACE', 'CREATE MASK', 'CREATE PERMISSION', 'CREATE PROCEDURE', 'CREATE ROLE', 'CREATE SEQUENCE', 'CREATE STOGROUP', 'CREATE SYNONYM', 'CREATE TABLE', 'CREATE TABLESPACE', 'CREATE TRIGGER', 'CREATE TRUSTED CONTEXT', 'CREATE TYPE', 'CREATE VARIABLE', 'CREATE VIEW', 'DECLARE CURSOR', 'DECLARE GLOBAL TEMPORARY TABLE', 'DECLARE STATEMENT', 'DECLARE TABLE', 'DECLARE VARIABLE', 'DELETE', 'DESCRIBE CURSOR', 'DESCRIBE INPUT', 'DESCRIBE OUTPUT', 'DESCRIBE PROCEDURE', 'DESCRIBE TABLE', 'DROP', 'END DECLARE SECTION', 'EXCHANGE', 'EXECUTE', 'EXECUTE IMMEDIATE', 'EXPLAIN', 'FETCH', 'FREE LOCATOR', 'GET DIAGNOSTICS', 'GRANT', 'HOLD LOCATOR', 'INCLUDE', 'INSERT', 'LABEL', 'LOCK TABLE', 'MERGE', 'OPEN', 'PREPARE', 'REFRESH', 'RELEASE', 'RELEASE SAVEPOINT', 'RENAME', 'REVOKE', 'ROLLBACK', 'SAVEPOINT', 'SELECT', 'SELECT INTO', 'SET CONNECTION', 'SET', 'SET CURRENT ACCELERATOR', 'SET CURRENT APPLICATION COMPATIBILITY', 'SET CURRENT APPLICATION ENCODING SCHEME', 'SET CURRENT DEBUG MODE', 'SET CURRENT DECFLOAT ROUNDING MODE', 'SET CURRENT DEGREE', 'SET CURRENT EXPLAIN MODE', 'SET CURRENT GET_ACCEL_ARCHIVE', 'SET CURRENT LOCALE LC_CTYPE', 'SET CURRENT MAINTAINED TABLE TYPES FOR OPTIMIZATION', 'SET CURRENT OPTIMIZATION HINT', 'SET CURRENT PACKAGE PATH', 'SET CURRENT PACKAGESET', 'SET CURRENT PRECISION', 'SET CURRENT QUERY ACCELERATION', 'SET CURRENT QUERY ACCELERATION WAITFORDATA', 'SET CURRENT REFRESH AGE', 'SET CURRENT ROUTINE VERSION', 'SET CURRENT RULES', 'SET CURRENT SQLID', 'SET CURRENT TEMPORAL BUSINESS_TIME', 'SET CURRENT TEMPORAL SYSTEM_TIME', 'SET ENCRYPTION PASSWORD', 'SET PATH', 'SET SCHEMA', 'SET SESSION TIME ZONE', 'SIGNAL', 'TRUNCATE', 'UPDATE', 'VALUES', 'VALUES INTO', 'WHENEVER', // other
|
2364 | 'ADD', 'ALTER COLUMN', 'AFTER', 'DROP TABLE', 'FETCH FIRST', 'FROM', 'GROUP BY', 'GO', 'HAVING', 'INSERT INTO', 'LIMIT', 'OFFSET', 'ORDER BY', 'SELECT', 'SET CURRENT SCHEMA', 'WHERE', 'WITH'];
|
2365 | /**
|
2366 | * Priority 2
|
2367 | * commands that operate on two tables or subqueries
|
2368 | * two main categories: joins and boolean set operators
|
2369 | */
|
2370 |
|
2371 | var reservedBinaryCommands = [// set booleans
|
2372 | 'INTERSECT', 'INTERSECT ALL', 'INTERSECT DISTINCT', 'UNION', 'UNION ALL', 'UNION DISTINCT', 'EXCEPT', 'EXCEPT ALL', 'EXCEPT DISTINCT', // joins
|
2373 | 'JOIN', 'INNER JOIN', 'LEFT JOIN', 'LEFT OUTER JOIN', 'RIGHT JOIN', 'RIGHT OUTER JOIN', 'FULL JOIN', 'FULL OUTER JOIN', 'CROSS JOIN', 'NATURAL JOIN'];
|
2374 | /**
|
2375 | * Priority 3
|
2376 | * keywords that follow a previous Statement, must be attached to subsequent data
|
2377 | * can be fully inline or on newline with optional indent
|
2378 | */
|
2379 |
|
2380 | var reservedDependentClauses = ['WHEN', 'ELSE', 'ELSEIF']; // https://www.ibm.com/support/knowledgecenter/en/ssw_ibm_i_72/db2/rbafzintro.htm
|
2381 |
|
2382 | var Db2Formatter = /*#__PURE__*/function (_Formatter) {
|
2383 | _inherits(Db2Formatter, _Formatter);
|
2384 |
|
2385 | var _super = _createSuper(Db2Formatter);
|
2386 |
|
2387 | function Db2Formatter() {
|
2388 | _classCallCheck(this, Db2Formatter);
|
2389 |
|
2390 | return _super.apply(this, arguments);
|
2391 | }
|
2392 |
|
2393 | _createClass(Db2Formatter, [{
|
2394 | key: "tokenizer",
|
2395 | value: function tokenizer() {
|
2396 | return new _core_Tokenizer__WEBPACK_IMPORTED_MODULE_1__["default"]({
|
2397 | reservedCommands: Db2Formatter.reservedCommands,
|
2398 | reservedBinaryCommands: Db2Formatter.reservedBinaryCommands,
|
2399 | reservedDependentClauses: Db2Formatter.reservedDependentClauses,
|
2400 | reservedJoinConditions: Db2Formatter.reservedJoinConditions,
|
2401 | reservedLogicalOperators: Db2Formatter.reservedLogicalOperators,
|
2402 | reservedKeywords: Db2Formatter.fullReservedWords,
|
2403 | stringTypes: Db2Formatter.stringTypes,
|
2404 | blockStart: Db2Formatter.blockStart,
|
2405 | blockEnd: Db2Formatter.blockEnd,
|
2406 | indexedPlaceholderTypes: Db2Formatter.indexedPlaceholderTypes,
|
2407 | namedPlaceholderTypes: Db2Formatter.namedPlaceholderTypes,
|
2408 | lineCommentTypes: Db2Formatter.lineCommentTypes,
|
2409 | specialWordChars: Db2Formatter.specialWordChars,
|
2410 | operators: Db2Formatter.operators
|
2411 | });
|
2412 | }
|
2413 | }]);
|
2414 |
|
2415 | return Db2Formatter;
|
2416 | }(_core_Formatter__WEBPACK_IMPORTED_MODULE_0__["default"]);
|
2417 |
|
2418 |
|
2419 | Db2Formatter.reservedCommands = reservedCommands;
|
2420 | Db2Formatter.reservedBinaryCommands = reservedBinaryCommands;
|
2421 | Db2Formatter.reservedDependentClauses = reservedDependentClauses;
|
2422 | Db2Formatter.reservedJoinConditions = ['ON', 'USING'];
|
2423 | Db2Formatter.reservedLogicalOperators = ['AND', 'OR'];
|
2424 | Db2Formatter.fullReservedWords = (0,_utils__WEBPACK_IMPORTED_MODULE_2__.dedupe)([].concat(_toConsumableArray(Object.values(reservedFunctions).reduce(function (acc, arr) {
|
2425 | return [].concat(_toConsumableArray(acc), _toConsumableArray(arr));
|
2426 | }, [])), _toConsumableArray(Object.values(reservedKeywords).reduce(function (acc, arr) {
|
2427 | return [].concat(_toConsumableArray(acc), _toConsumableArray(arr));
|
2428 | }, []))));
|
2429 | Db2Formatter.stringTypes = ["\"\"", "''", '``', '[]', "x''"];
|
2430 | Db2Formatter.blockStart = ['('];
|
2431 | Db2Formatter.blockEnd = [')'];
|
2432 | Db2Formatter.indexedPlaceholderTypes = ['?'];
|
2433 | Db2Formatter.namedPlaceholderTypes = [':'];
|
2434 | Db2Formatter.lineCommentTypes = ['--'];
|
2435 | Db2Formatter.specialWordChars = {
|
2436 | any: '#@'
|
2437 | };
|
2438 | Db2Formatter.operators = ['**', '!>', '!<', '||'];
|
2439 |
|
2440 | /***/ }),
|
2441 |
|
2442 | /***/ "./src/languages/hive.formatter.ts":
|
2443 | /*!*****************************************!*\
|
2444 | !*** ./src/languages/hive.formatter.ts ***!
|
2445 | \*****************************************/
|
2446 | /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
2447 |
|
2448 | __webpack_require__.r(__webpack_exports__);
|
2449 | /* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
2450 | /* harmony export */ "default": () => (/* binding */ HiveFormatter)
|
2451 | /* harmony export */ });
|
2452 | /* harmony import */ var _core_Formatter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../core/Formatter */ "./src/core/Formatter.ts");
|
2453 | /* harmony import */ var _core_Tokenizer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../core/Tokenizer */ "./src/core/Tokenizer.ts");
|
2454 | /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils */ "./src/utils.ts");
|
2455 | function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
2456 |
|
2457 | function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
|
2458 |
|
2459 | function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
2460 |
|
2461 | function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
2462 |
|
2463 | function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
|
2464 |
|
2465 | function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
|
2466 |
|
2467 | function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
2468 |
|
2469 | function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
2470 |
|
2471 | function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
2472 |
|
2473 | function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
2474 |
|
2475 | function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
|
2476 |
|
2477 | function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
|
2478 |
|
2479 | function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
2480 |
|
2481 | function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
|
2482 |
|
2483 | function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
|
2484 |
|
2485 | function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
2486 |
|
2487 | function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
|
2488 |
|
2489 |
|
2490 |
|
2491 |
|
2492 | /**
|
2493 | * Priority 5 (last)
|
2494 | * Full list of reserved functions
|
2495 | * distinct from Keywords due to interaction with parentheses
|
2496 | */
|
2497 | // https://cwiki.apache.org/confluence/display/Hive/LanguageManual+UDF
|
2498 |
|
2499 | var reservedFunctions = {
|
2500 | math: ['ABS', 'ACOS', 'ASIN', 'ATAN', 'BIN', 'BROUND', 'CBRT', 'CEIL', 'CEILING', 'CONV', 'COS', 'DEGREES', // 'E',
|
2501 | 'EXP', 'FACTORIAL', 'FLOOR', 'GREATEST', 'HEX', 'LEAST', 'LN', 'LOG', 'LOG10', 'LOG2', 'NEGATIVE', 'PI', 'PMOD', 'POSITIVE', 'POW', 'POWER', 'RADIANS', 'RAND', 'ROUND', 'SHIFTLEFT', 'SHIFTRIGHT', 'SHIFTRIGHTUNSIGNED', 'SIGN', 'SIN', 'SQRT', 'TAN', 'UNHEX', 'WIDTH_BUCKET'],
|
2502 | array: ['ARRAY_CONTAINS', 'MAP_KEYS', 'MAP_VALUES', 'SIZE', 'SORT_ARRAY'],
|
2503 | conversion: ['BINARY', 'CAST'],
|
2504 | date: ['ADD_MONTHS', 'DATE', 'DATE_ADD', 'DATE_FORMAT', 'DATE_SUB', 'DATEDIFF', 'DAY', 'DAYNAME', 'DAYOFMONTH', 'DAYOFYEAR', 'EXTRACT', 'FROM_UNIXTIME', 'FROM_UTC_TIMESTAMP', 'HOUR', 'LAST_DAY', 'MINUTE', 'MONTH', 'MONTHS_BETWEEN', 'NEXT_DAY', 'QUARTER', 'SECOND', 'TIMESTAMP', 'TO_DATE', 'TO_UTC_TIMESTAMP', 'TRUNC', 'UNIX_TIMESTAMP', 'WEEKOFYEAR', 'YEAR'],
|
2505 | conditional: ['ASSERT_TRUE', 'COALESCE', 'IF', 'ISNOTNULL', 'ISNULL', 'NULLIF', 'NVL'],
|
2506 | string: ['ASCII', 'BASE64', 'CHARACTER_LENGTH', 'CHR', 'CONCAT', 'CONCAT_WS', 'CONTEXT_NGRAMS', 'DECODE', 'ELT', 'ENCODE', 'FIELD', 'FIND_IN_SET', 'FORMAT_NUMBER', 'GET_JSON_OBJECT', 'IN_FILE', 'INITCAP', 'INSTR', 'LCASE', 'LENGTH', 'LEVENSHTEIN', 'LOCATE', 'LOWER', 'LPAD', 'LTRIM', 'NGRAMS', 'OCTET_LENGTH', 'PARSE_URL', 'PRINTF', 'QUOTE', 'REGEXP_EXTRACT', 'REGEXP_REPLACE', 'REPEAT', 'REVERSE', 'RPAD', 'RTRIM', 'SENTENCES', 'SOUNDEX', 'SPACE', 'SPLIT', 'STR_TO_MAP', 'SUBSTR', 'SUBSTRING', 'TRANSLATE', 'TRIM', 'UCASE', 'UNBASE64', 'UPPER'],
|
2507 | masking: ['MASK', 'MASK_FIRST_N', 'MASK_HASH', 'MASK_LAST_N', 'MASK_SHOW_FIRST_N', 'MASK_SHOW_LAST_N'],
|
2508 | misc: ['AES_DECRYPT', 'AES_ENCRYPT', 'CRC32', 'CURRENT_DATABASE', 'CURRENT_USER', 'HASH', 'JAVA_METHOD', 'LOGGED_IN_USER', 'MD5', 'REFLECT', 'SHA', 'SHA1', 'SHA2', 'SURROGATE_KEY', 'VERSION'],
|
2509 | aggregate: ['AVG', 'COLLECT_LIST', 'COLLECT_SET', 'CORR', 'COUNT', 'COVAR_POP', 'COVAR_SAMP', 'HISTOGRAM_NUMERIC', 'MAX', 'MIN', 'NTILE', 'PERCENTILE', 'PERCENTILE_APPROX', 'REGR_AVGX', 'REGR_AVGY', 'REGR_COUNT', 'REGR_INTERCEPT', 'REGR_R2', 'REGR_SLOPE', 'REGR_SXX', 'REGR_SXY', 'REGR_SYY', 'STDDEV_POP', 'STDDEV_SAMP', 'SUM', 'VAR_POP', 'VAR_SAMP', 'VARIANCE'],
|
2510 | table: ['EXPLODE', 'INLINE', 'JSON_TUPLE', 'PARSE_URL_TUPLE', 'POSEXPLODE', 'STACK']
|
2511 | };
|
2512 | /**
|
2513 | * Priority 5 (last)
|
2514 | * Full list of reserved words
|
2515 | * any words that are in a higher priority are removed
|
2516 | */
|
2517 | // https://cwiki.apache.org/confluence/display/hive/languagemanual+ddl
|
2518 |
|
2519 | var reservedKeywords = {
|
2520 | // Non-reserved keywords have proscribed meanings in. HiveQL, but can still be used as table or column names
|
2521 | nonReserved: ['ADD', 'ADMIN', 'AFTER', 'ANALYZE', 'ARCHIVE', 'ASC', 'BEFORE', 'BUCKET', 'BUCKETS', 'CASCADE', 'CHANGE', 'CLUSTER', 'CLUSTERED', 'CLUSTERSTATUS', 'COLLECTION', 'COLUMNS', 'COMMENT', 'COMPACT', 'COMPACTIONS', 'COMPUTE', 'CONCATENATE', 'CONTINUE', 'DATA', 'DATABASES', 'DATETIME', 'DAY', 'DBPROPERTIES', 'DEFERRED', 'DEFINED', 'DELIMITED', 'DEPENDENCY', 'DESC', 'DIRECTORIES', 'DIRECTORY', 'DISABLE', 'DISTRIBUTE', 'ELEM_TYPE', 'ENABLE', 'ESCAPED', 'EXCLUSIVE', 'EXPLAIN', 'EXPORT', 'FIELDS', 'FILE', 'FILEFORMAT', 'FIRST', 'FORMAT', 'FORMATTED', 'FUNCTIONS', 'HOLD_DDLTIME', 'HOUR', 'IDXPROPERTIES', 'IGNORE', 'INDEX', 'INDEXES', 'INPATH', 'INPUTDRIVER', 'INPUTFORMAT', 'ITEMS', 'JAR', 'KEYS', 'KEY_TYPE', 'LIMIT', 'LINES', 'LOAD', 'LOCATION', 'LOCK', 'LOCKS', 'LOGICAL', 'LONG', 'MAPJOIN', 'MATERIALIZED', 'METADATA', 'MINUS', 'MINUTE', 'MONTH', 'MSCK', 'NOSCAN', 'NO_DROP', 'OFFLINE', 'OPTION', 'OUTPUTDRIVER', 'OUTPUTFORMAT', 'OVERWRITE', 'OWNER', 'PARTITIONED', 'PARTITIONS', 'PLUS', 'PRETTY', 'PRINCIPALS', 'PROTECTION', 'PURGE', 'READ', 'READONLY', 'REBUILD', 'RECORDREADER', 'RECORDWRITER', 'RELOAD', 'RENAME', 'REPAIR', 'REPLACE', 'REPLICATION', 'RESTRICT', 'REWRITE', 'ROLE', 'ROLES', 'SCHEMA', 'SCHEMAS', 'SECOND', 'SEMI', 'SERDE', 'SERDEPROPERTIES', 'SERVER', 'SETS', 'SHARED', 'SHOW', 'SHOW_DATABASE', 'SKEWED', 'SORT', 'SORTED', 'SSL', 'STATISTICS', 'STORED', 'STREAMTABLE', 'STRING', 'STRUCT', 'TABLES', 'TBLPROPERTIES', 'TEMPORARY', 'TERMINATED', 'TINYINT', 'TOUCH', 'TRANSACTIONS', 'UNARCHIVE', 'UNDO', 'UNIONTYPE', 'UNLOCK', 'UNSET', 'UNSIGNED', 'URI', // 'USE',
|
2522 | 'UTC', 'UTCTIMESTAMP', 'VALUE_TYPE', 'VIEW', 'WHILE', 'YEAR', 'AUTOCOMMIT', 'ISOLATION', 'LEVEL', 'OFFSET', 'SNAPSHOT', 'TRANSACTION', 'WORK', 'WRITE', 'ABORT', 'KEY', 'LAST', 'NORELY', 'NOVALIDATE', 'NULLS', 'RELY', 'VALIDATE', 'DETAIL', 'DOW', 'EXPRESSION', 'OPERATOR', 'QUARTER', 'SUMMARY', 'VECTORIZATION', 'WEEK', 'YEARS', 'MONTHS', 'WEEKS', 'DAYS', 'HOURS', 'MINUTES', 'SECONDS', 'TIMESTAMPTZ', 'ZONE'],
|
2523 | reserved: [// reserved
|
2524 | 'ALL', // 'ALTER',
|
2525 | // 'AND',
|
2526 | 'ARRAY', 'AS', 'AUTHORIZATION', 'BETWEEN', 'BIGINT', 'BINARY', 'BOOLEAN', 'BOTH', 'BY', // 'CASE',
|
2527 | 'CAST', 'CHAR', 'COLUMN', 'CONF', // 'CREATE',
|
2528 | 'CROSS', 'CUBE', 'CURRENT', 'CURRENT_DATE', 'CURRENT_TIMESTAMP', 'CURSOR', 'DATABASE', 'DATE', 'DECIMAL', 'DELETE', // 'DESCRIBE',
|
2529 | 'DISTINCT', 'DOUBLE', // 'DROP',
|
2530 | // 'ELSE',
|
2531 | // 'END',
|
2532 | 'EXCHANGE', 'EXISTS', 'EXTENDED', 'EXTERNAL', 'FALSE', // 'FETCH',
|
2533 | 'FLOAT', 'FOLLOWING', 'FOR', // 'FROM',
|
2534 | 'FULL', 'FUNCTION', 'GRANT', // 'GROUP',
|
2535 | 'GROUPING', // 'HAVING',
|
2536 | 'IF', 'IMPORT', 'IN', 'INNER', // 'INSERT',
|
2537 | 'INT', // 'INTERSECT',
|
2538 | 'INTERVAL', 'INTO', 'IS', // 'JOIN',
|
2539 | 'LATERAL', 'LEFT', 'LESS', 'LIKE', 'LOCAL', 'MACRO', 'MAP', 'MORE', 'NONE', 'NOT', 'NULL', 'OF', // 'ON',
|
2540 | // 'OR',
|
2541 | 'ORDER', 'OUT', 'OUTER', 'OVER', 'PARTIALSCAN', 'PARTITION', 'PERCENT', 'PRECEDING', 'PRESERVE', 'PROCEDURE', 'RANGE', 'READS', 'REDUCE', 'REVOKE', 'RIGHT', 'ROLLUP', 'ROW', 'ROWS', // 'SELECT',
|
2542 | 'SET', 'SMALLINT', 'TABLE', 'TABLESAMPLE', 'THEN', 'TIMESTAMP', 'TO', 'TRANSFORM', 'TRIGGER', 'TRUE', // 'TRUNCATE',
|
2543 | 'UNBOUNDED', // 'UNION',
|
2544 | 'UNIQUEJOIN', // 'UPDATE',
|
2545 | 'USER', 'UTC_TMESTAMP', // 'VALUES',
|
2546 | 'VARCHAR', // 'WHEN',
|
2547 | // 'WHERE',
|
2548 | 'WINDOW', // 'WITH',
|
2549 | 'COMMIT', 'ONLY', 'REGEXP', 'RLIKE', 'ROLLBACK', 'START', 'CACHE', 'CONSTRAINT', 'FOREIGN', 'PRIMARY', 'REFERENCES', 'DAYOFWEEK', 'EXTRACT', 'FLOOR', 'INTEGER', 'PRECISION', 'VIEWS', 'TIME', 'NUMERIC', 'SYNC'],
|
2550 | fileTypes: ['TEXTFILE', 'SEQUENCEFILE', 'ORC', 'CSV', 'TSV', 'PARQUET', 'AVRO', 'RCFILE', 'JSONFILE', 'INPUTFORMAT', 'OUTPUTFORMAT']
|
2551 | };
|
2552 | /**
|
2553 | * Priority 1 (first)
|
2554 | * keywords that begin a new statement
|
2555 | * will begin new indented block
|
2556 | */
|
2557 |
|
2558 | var reservedCommands = [// commands
|
2559 | 'ALTER', 'ALTER COLUMN', 'ALTER TABLE', 'CREATE', 'CREATE TABLE', 'USE', 'DESCRIBE', 'DROP', 'DROP TABLE', 'FETCH', 'FROM', 'GROUP BY', 'HAVING', 'INSERT', 'INSERT INTO', 'LIMIT', 'OFFSET', 'ORDER BY', 'SELECT', 'SET', 'SET SCHEMA', 'SHOW', 'SORT BY', 'TRUNCATE', 'UPDATE', 'VALUES', 'WHERE', 'WITH', // newline keywords
|
2560 | 'STORED AS', 'STORED BY', 'ROW FORMAT'];
|
2561 | /**
|
2562 | * Priority 2
|
2563 | * commands that operate on two tables or subqueries
|
2564 | * two main categories: joins and boolean set operators
|
2565 | */
|
2566 |
|
2567 | var reservedBinaryCommands = [// set booleans
|
2568 | 'INTERSECT', 'INTERSECT ALL', 'INTERSECT DISTINCT', 'UNION', 'UNION ALL', 'UNION DISTINCT', // joins
|
2569 | 'JOIN', 'INNER JOIN', 'LEFT JOIN', 'LEFT OUTER JOIN', 'RIGHT JOIN', 'RIGHT OUTER JOIN', 'FULL JOIN', 'FULL OUTER JOIN', 'CROSS JOIN'];
|
2570 | /**
|
2571 | * Priority 3
|
2572 | * keywords that follow a previous 'Statement', must be attached to subsequent data
|
2573 | * can be fully inline or on newline with optional indent
|
2574 | */
|
2575 |
|
2576 | var reservedDependentClauses = ['WHEN', 'ELSE']; // https://cwiki.apache.org/confluence/display/Hive/LanguageManual
|
2577 |
|
2578 | var HiveFormatter = /*#__PURE__*/function (_Formatter) {
|
2579 | _inherits(HiveFormatter, _Formatter);
|
2580 |
|
2581 | var _super = _createSuper(HiveFormatter);
|
2582 |
|
2583 | function HiveFormatter() {
|
2584 | _classCallCheck(this, HiveFormatter);
|
2585 |
|
2586 | return _super.apply(this, arguments);
|
2587 | }
|
2588 |
|
2589 | _createClass(HiveFormatter, [{
|
2590 | key: "tokenizer",
|
2591 | value: function tokenizer() {
|
2592 | return new _core_Tokenizer__WEBPACK_IMPORTED_MODULE_1__["default"]({
|
2593 | reservedCommands: HiveFormatter.reservedCommands,
|
2594 | reservedBinaryCommands: HiveFormatter.reservedBinaryCommands,
|
2595 | reservedDependentClauses: HiveFormatter.reservedDependentClauses,
|
2596 | reservedJoinConditions: HiveFormatter.reservedJoinConditions,
|
2597 | reservedLogicalOperators: HiveFormatter.reservedLogicalOperators,
|
2598 | reservedKeywords: HiveFormatter.fullReservedWords,
|
2599 | stringTypes: HiveFormatter.stringTypes,
|
2600 | blockStart: HiveFormatter.blockStart,
|
2601 | blockEnd: HiveFormatter.blockEnd,
|
2602 | indexedPlaceholderTypes: HiveFormatter.indexedPlaceholderTypes,
|
2603 | namedPlaceholderTypes: HiveFormatter.namedPlaceholderTypes,
|
2604 | lineCommentTypes: HiveFormatter.lineCommentTypes,
|
2605 | specialWordChars: HiveFormatter.specialWordChars,
|
2606 | operators: HiveFormatter.operators
|
2607 | });
|
2608 | }
|
2609 | }]);
|
2610 |
|
2611 | return HiveFormatter;
|
2612 | }(_core_Formatter__WEBPACK_IMPORTED_MODULE_0__["default"]);
|
2613 |
|
2614 |
|
2615 | HiveFormatter.reservedCommands = reservedCommands;
|
2616 | HiveFormatter.reservedBinaryCommands = reservedBinaryCommands;
|
2617 | HiveFormatter.reservedDependentClauses = reservedDependentClauses;
|
2618 | HiveFormatter.reservedJoinConditions = ['ON', 'USING'];
|
2619 | HiveFormatter.reservedLogicalOperators = ['AND', 'OR'];
|
2620 | HiveFormatter.fullReservedWords = (0,_utils__WEBPACK_IMPORTED_MODULE_2__.dedupe)([].concat(_toConsumableArray(Object.values(reservedFunctions).reduce(function (acc, arr) {
|
2621 | return [].concat(_toConsumableArray(acc), _toConsumableArray(arr));
|
2622 | }, [])), _toConsumableArray(Object.values(reservedKeywords).reduce(function (acc, arr) {
|
2623 | return [].concat(_toConsumableArray(acc), _toConsumableArray(arr));
|
2624 | }, []))));
|
2625 | HiveFormatter.stringTypes = ['""', "''", '``'];
|
2626 | HiveFormatter.blockStart = ['(', 'CASE'];
|
2627 | HiveFormatter.blockEnd = [')', 'END'];
|
2628 | HiveFormatter.indexedPlaceholderTypes = ['?'];
|
2629 | HiveFormatter.namedPlaceholderTypes = [];
|
2630 | HiveFormatter.lineCommentTypes = ['--'];
|
2631 | HiveFormatter.specialWordChars = {};
|
2632 | HiveFormatter.operators = ['<=>', '==', '||'];
|
2633 |
|
2634 | /***/ }),
|
2635 |
|
2636 | /***/ "./src/languages/mariadb.formatter.ts":
|
2637 | /*!********************************************!*\
|
2638 | !*** ./src/languages/mariadb.formatter.ts ***!
|
2639 | \********************************************/
|
2640 | /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
2641 |
|
2642 | __webpack_require__.r(__webpack_exports__);
|
2643 | /* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
2644 | /* harmony export */ "default": () => (/* binding */ MariaDbFormatter)
|
2645 | /* harmony export */ });
|
2646 | /* harmony import */ var _core_Formatter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../core/Formatter */ "./src/core/Formatter.ts");
|
2647 | /* harmony import */ var _core_Tokenizer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../core/Tokenizer */ "./src/core/Tokenizer.ts");
|
2648 | /* harmony import */ var _core_token__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../core/token */ "./src/core/token.ts");
|
2649 | /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../utils */ "./src/utils.ts");
|
2650 | function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
2651 |
|
2652 | function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
2653 |
|
2654 | function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
2655 |
|
2656 | function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
2657 |
|
2658 | function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
|
2659 |
|
2660 | function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
|
2661 |
|
2662 | function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
2663 |
|
2664 | function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
|
2665 |
|
2666 | function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
|
2667 |
|
2668 | function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
2669 |
|
2670 | function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
|
2671 |
|
2672 |
|
2673 |
|
2674 |
|
2675 |
|
2676 | /**
|
2677 | * Priority 5 (last)
|
2678 | * Full list of reserved functions
|
2679 | * distinct from Keywords due to interaction with parentheses
|
2680 | */
|
2681 | // https://mariadb.com/kb/en/information-schema-sql_functions-table/
|
2682 |
|
2683 | var reservedFunctions = ['ADDDATE', 'ADD_MONTHS', 'BIT_AND', 'BIT_OR', 'BIT_XOR', 'CAST', 'COUNT', 'CUME_DIST', 'CURDATE', 'CURTIME', 'DATE_ADD', 'DATE_SUB', 'DATE_FORMAT', 'DECODE', 'DENSE_RANK', 'EXTRACT', 'FIRST_VALUE', 'GROUP_CONCAT', 'JSON_ARRAYAGG', 'JSON_OBJECTAGG', 'LAG', 'LEAD', 'MAX', 'MEDIAN', 'MID', 'MIN', 'NOW', 'NTH_VALUE', 'NTILE', 'POSITION', 'PERCENT_RANK', 'PERCENTILE_CONT', 'PERCENTILE_DISC', 'RANK', 'ROW_NUMBER', 'SESSION_USER', 'STD', 'STDDEV', 'STDDEV_POP', 'STDDEV_SAMP', 'SUBDATE', 'SUBSTR', 'SUBSTRING', 'SUM', 'SYSTEM_USER', 'TRIM', 'TRIM_ORACLE', 'VARIANCE', 'VAR_POP', 'VAR_SAMP', 'ABS', 'ACOS', 'ADDTIME', 'AES_DECRYPT', 'AES_ENCRYPT', 'ASIN', 'ATAN', 'ATAN2', 'BENCHMARK', 'BIN', 'BINLOG_GTID_POS', 'BIT_COUNT', 'BIT_LENGTH', 'CEIL', 'CEILING', 'CHARACTER_LENGTH', 'CHAR_LENGTH', 'CHR', 'COERCIBILITY', 'COLUMN_CHECK', 'COLUMN_EXISTS', 'COLUMN_LIST', 'COLUMN_JSON', 'COMPRESS', 'CONCAT', 'CONCAT_OPERATOR_ORACLE', 'CONCAT_WS', 'CONNECTION_ID', 'CONV', 'CONVERT_TZ', 'COS', 'COT', 'CRC32', 'DATEDIFF', 'DAYNAME', 'DAYOFMONTH', 'DAYOFWEEK', 'DAYOFYEAR', 'DEGREES', 'DECODE_HISTOGRAM', 'DECODE_ORACLE', 'DES_DECRYPT', 'DES_ENCRYPT', 'ELT', 'ENCODE', 'ENCRYPT', 'EXP', 'EXPORT_SET', 'EXTRACTVALUE', 'FIELD', 'FIND_IN_SET', 'FLOOR', 'FORMAT', 'FOUND_ROWS', 'FROM_BASE64', 'FROM_DAYS', 'FROM_UNIXTIME', 'GET_LOCK', 'GREATEST', 'HEX', 'IFNULL', 'INSTR', 'ISNULL', 'IS_FREE_LOCK', 'IS_USED_LOCK', 'JSON_ARRAY', 'JSON_ARRAY_APPEND', 'JSON_ARRAY_INSERT', 'JSON_COMPACT', 'JSON_CONTAINS', 'JSON_CONTAINS_PATH', 'JSON_DEPTH', 'JSON_DETAILED', 'JSON_EXISTS', 'JSON_EXTRACT', 'JSON_INSERT', 'JSON_KEYS', 'JSON_LENGTH', 'JSON_LOOSE', 'JSON_MERGE', 'JSON_MERGE_PATCH', 'JSON_MERGE_PRESERVE', 'JSON_QUERY', 'JSON_QUOTE', 'JSON_OBJECT', 'JSON_REMOVE', 'JSON_REPLACE', 'JSON_SET', 'JSON_SEARCH', 'JSON_TYPE', 'JSON_UNQUOTE', 'JSON_VALID', 'JSON_VALUE', 'LAST_DAY', 'LAST_INSERT_ID', 'LCASE', 'LEAST', 'LENGTH', 'LENGTHB', 'LN', 'LOAD_FILE', 'LOCATE', 'LOG', 'LOG10', 'LOG2', 'LOWER', 'LPAD', 'LPAD_ORACLE', 'LTRIM', 'LTRIM_ORACLE', 'MAKEDATE', 'MAKETIME', 'MAKE_SET', 'MASTER_GTID_WAIT', 'MASTER_POS_WAIT', 'MD5', 'MONTHNAME', 'NAME_CONST', 'NVL', 'NVL2', 'NULLIF', 'OCT', 'OCTET_LENGTH', 'ORD', 'PERIOD_ADD', 'PERIOD_DIFF', 'PI', 'POW', 'POWER', 'QUOTE', 'REGEXP_INSTR', 'REGEXP_REPLACE', 'REGEXP_SUBSTR', 'RADIANS', 'RAND', 'RELEASE_ALL_LOCKS', 'RELEASE_LOCK', 'REPLACE_ORACLE', 'REVERSE', 'ROUND', 'RPAD', 'RPAD_ORACLE', 'RTRIM', 'RTRIM_ORACLE', 'SEC_TO_TIME', 'SHA', 'SHA1', 'SHA2', 'SIGN', 'SIN', 'SLEEP', 'SOUNDEX', 'SPACE', 'SQRT', 'STRCMP', 'STR_TO_DATE', 'SUBSTR_ORACLE', 'SUBSTRING_INDEX', 'SUBTIME', 'SYS_GUID', 'TAN', 'TIMEDIFF', 'TIME_FORMAT', 'TIME_TO_SEC', 'TO_BASE64', 'TO_CHAR', 'TO_DAYS', 'TO_SECONDS', 'UCASE', 'UNCOMPRESS', 'UNCOMPRESSED_LENGTH', 'UNHEX', 'UNIX_TIMESTAMP', 'UPDATEXML', 'UPPER', 'UUID', 'UUID_SHORT', 'VERSION', 'WEEKDAY', 'WEEKOFYEAR', 'WSREP_LAST_WRITTEN_GTID', 'WSREP_LAST_SEEN_GTID', 'WSREP_SYNC_WAIT_UPTO_GTID', 'YEARWEEK'];
|
2684 | /**
|
2685 | * Priority 5 (last)
|
2686 | * Full list of reserved words
|
2687 | * any words that are in a higher priority are removed
|
2688 | */
|
2689 | // https://mariadb.com/kb/en/information-schema-keywords-table/
|
2690 |
|
2691 | var reservedKeywords = ['ACCESSIBLE', 'ACCOUNT', 'ACTION', 'ADMIN', 'AFTER', 'AGAINST', 'AGGREGATE', 'ALL', 'ALGORITHM', 'ALTER', 'ALWAYS', 'ANY', 'AS', 'ASC', 'ASCII', 'ASENSITIVE', 'AT', 'ATOMIC', 'AUTHORS', 'AUTO_INCREMENT', 'AUTOEXTEND_SIZE', 'AUTO', 'AVG', 'AVG_ROW_LENGTH', 'BACKUP', 'BEFORE', 'BETWEEN', 'BIGINT', 'BINARY', 'BIT', 'BLOB', 'BLOCK', 'BODY', 'BOOL', 'BOOLEAN', 'BOTH', 'BTREE', 'BY', 'BYTE', 'CACHE', 'CASCADE', 'CASCADED', 'CATALOG_NAME', 'CHAIN', 'CHANGE', 'CHANGED', 'CHAR', 'CHARACTER', 'CHARACTER SET', 'CHARSET', 'CHECK', 'CHECKPOINT', 'CHECKSUM', 'CIPHER', 'CLASS_ORIGIN', 'CLIENT', 'CLOB', 'CLOSE', 'COALESCE', 'CODE', 'COLLATE', 'COLLATION', 'COLUMN', 'COLUMN_NAME', 'COLUMNS', 'COLUMN_ADD', 'COLUMN_CREATE', 'COLUMN_DELETE', 'COLUMN_GET', 'COMMENT', 'COMMITTED', 'COMPACT', 'COMPLETION', 'COMPRESSED', 'CONCURRENT', 'CONDITION', 'CONNECTION', 'CONSISTENT', 'CONSTRAINT', 'CONSTRAINT_CATALOG', 'CONSTRAINT_NAME', 'CONSTRAINT_SCHEMA', 'CONTAINS', 'CONTEXT', 'CONTINUE', 'CONTRIBUTORS', 'CONVERT', 'CPU', 'CREATE', 'CROSS', 'CUBE', 'CURRENT', 'CURRENT_DATE', 'CURRENT_POS', 'CURRENT_ROLE', 'CURRENT_TIME', 'CURRENT_TIMESTAMP', 'CURRENT_USER', 'CURSOR', 'CURSOR_NAME', 'CYCLE', 'DATA', 'DATABASE', 'DATABASES', 'DATAFILE', 'DATE', 'DATETIME', 'DAY', 'DAY_HOUR', 'DAY_MICROSECOND', 'DAY_MINUTE', 'DAY_SECOND', 'DEALLOCATE', 'DEC', 'DECIMAL', 'DECLARE', 'DEFAULT', 'DEFINER', 'DELAYED', 'DELAY_KEY_WRITE', 'DELETE_DOMAIN_ID', 'DES_KEY_FILE', 'DETERMINISTIC', 'DIAGNOSTICS', 'DIRECTORY', 'DISABLE', 'DISCARD', 'DISK', 'DISTINCT', 'DISTINCTROW', 'DIV', 'DOUBLE', 'DO_DOMAIN_IDS', 'DROP', 'DUAL', 'DUMPFILE', 'DUPLICATE', 'DYNAMIC', 'EACH', 'EMPTY', 'ENABLE', 'ENCLOSED', 'ENDS', 'ENGINE', 'ENGINES', 'ENUM', 'ERROR', 'ERRORS', 'ESCAPE', 'ESCAPED', 'EVENT', 'EVENTS', 'EVERY', 'EXAMINED', 'EXCHANGE', 'EXCLUDE', 'EXCEPTION', 'EXISTS', 'EXIT', 'EXPANSION', 'EXPIRE', 'EXPORT', 'EXTENDED', 'EXTENT_SIZE', 'FALSE', 'FAST', 'FAULTS', 'FEDERATED', 'FETCH', 'FIELDS', 'FILE', 'FIRST', 'FIXED', 'FLOAT', 'FLOAT4', 'FLOAT8', 'FOLLOWING', 'FOLLOWS', 'FOR', 'FORCE', 'FOREIGN', 'FOUND', 'FULL', 'FULLTEXT', 'FUNCTION', 'GENERAL', 'GENERATED', 'GET_FORMAT', 'GET', 'GLOBAL', 'GOTO', 'GRANTS', 'GROUP', 'HARD', 'HASH', 'HIGH_PRIORITY', 'HISTORY', 'HOST', 'HOSTS', 'HOUR', 'HOUR_MICROSECOND', 'HOUR_MINUTE', 'HOUR_SECOND', // 'ID',
|
2692 | 'IDENTIFIED', 'IF', 'IGNORE', 'IGNORED', 'IGNORE_DOMAIN_IDS', 'IGNORE_SERVER_IDS', 'IMMEDIATE', 'IMPORT', 'IN', 'INCREMENT', 'INDEX', 'INDEXES', 'INFILE', 'INITIAL_SIZE', 'INNER', 'INOUT', 'INSENSITIVE', 'INSERT_METHOD', 'INSTALL', 'INT', 'INT1', 'INT2', 'INT3', 'INT4', 'INT8', 'INTEGER', 'INTERVAL', 'INVISIBLE', 'INTO', 'IO', 'IO_THREAD', 'IPC', 'IS', 'ISOLATION', 'ISOPEN', 'ISSUER', 'ITERATE', 'INVOKER', 'JSON', 'JSON_TABLE', 'KEY', 'KEYS', 'KEY_BLOCK_SIZE', 'LANGUAGE', 'LAST', 'LAST_VALUE', 'LASTVAL', 'LEADING', 'LEAVE', 'LEAVES', 'LEFT', 'LESS', 'LEVEL', 'LIKE', 'LINEAR', 'LINES', 'LIST', 'LOAD', 'LOCAL', 'LOCALTIME', 'LOCALTIMESTAMP', 'LOCK', 'LOCKED', 'LOCKS', 'LOGFILE', 'LOGS', 'LONG', 'LONGBLOB', 'LONGTEXT', 'LOOP', 'LOW_PRIORITY', 'MASTER', 'MASTER_CONNECT_RETRY', 'MASTER_DELAY', 'MASTER_GTID_POS', 'MASTER_HOST', 'MASTER_LOG_FILE', 'MASTER_LOG_POS', 'MASTER_PASSWORD', 'MASTER_PORT', 'MASTER_SERVER_ID', 'MASTER_SSL', 'MASTER_SSL_CA', 'MASTER_SSL_CAPATH', 'MASTER_SSL_CERT', 'MASTER_SSL_CIPHER', 'MASTER_SSL_CRL', 'MASTER_SSL_CRLPATH', 'MASTER_SSL_KEY', 'MASTER_SSL_VERIFY_SERVER_CERT', 'MASTER_USER', 'MASTER_USE_GTID', 'MASTER_HEARTBEAT_PERIOD', 'MATCH', 'MAX_CONNECTIONS_PER_HOUR', 'MAX_QUERIES_PER_HOUR', 'MAX_ROWS', 'MAX_SIZE', 'MAX_STATEMENT_TIME', 'MAX_UPDATES_PER_HOUR', 'MAX_USER_CONNECTIONS', 'MAXVALUE', 'MEDIUM', 'MEDIUMBLOB', 'MEDIUMINT', 'MEDIUMTEXT', 'MEMORY', 'MERGE', 'MESSAGE_TEXT', 'MICROSECOND', 'MIDDLEINT', 'MIGRATE', 'MINUS', 'MINUTE', 'MINUTE_MICROSECOND', 'MINUTE_SECOND', 'MINVALUE', 'MIN_ROWS', 'MOD', 'MODE', 'MODIFIES', 'MODIFY', 'MONITOR', 'MONTH', 'MUTEX', 'MYSQL', 'MYSQL_ERRNO', 'NAME', 'NAMES', 'NATIONAL', 'NATURAL', 'NCHAR', 'NESTED', 'NEVER', 'NEW', 'NEXT', 'NEXTVAL', 'NO', 'NOMAXVALUE', 'NOMINVALUE', 'NOCACHE', 'NOCYCLE', 'NO_WAIT', 'NOWAIT', 'NODEGROUP', 'NONE', 'NOT', 'NOTFOUND', 'NO_WRITE_TO_BINLOG', 'NULL', 'NUMBER', 'NUMERIC', 'NVARCHAR', 'OF', 'OFFSET', 'OLD_PASSWORD', 'ON DELETE', 'ON UPDATE', 'ONE', 'ONLINE', 'ONLY', 'OPEN', 'OPTIMIZE', 'OPTIONS', 'OPTION', 'OPTIONALLY', 'ORDER', 'ORDINALITY', 'OTHERS', 'OUT', 'OUTER', 'OUTFILE', 'OVER', 'OVERLAPS', 'OWNER', 'PACKAGE', 'PACK_KEYS', 'PAGE', 'PAGE_CHECKSUM', 'PARSER', 'PARSE_VCOL_EXPR', 'PATH', 'PERIOD', 'PARTIAL', 'PARTITION', 'PARTITIONING', 'PARTITIONS', 'PASSWORD', 'PERSISTENT', 'PHASE', 'PLUGIN', 'PLUGINS', 'PORT', 'PORTION', 'PRECEDES', 'PRECEDING', 'PRECISION', 'PRESERVE', 'PREV', 'PREVIOUS', 'PRIMARY', 'PRIVILEGES', 'PROCEDURE', 'PROCESS', 'PROCESSLIST', 'PROFILE', 'PROFILES', 'PROXY', 'PURGE', 'QUARTER', 'QUERY', 'QUICK', 'RAISE', 'RANGE', 'RAW', 'READ', 'READ_ONLY', 'READ_WRITE', 'READS', 'REAL', 'REBUILD', 'RECOVER', 'RECURSIVE', 'REDO_BUFFER_SIZE', 'REDOFILE', 'REDUNDANT', 'REFERENCES', 'REGEXP', 'RELAY', 'RELAYLOG', 'RELAY_LOG_FILE', 'RELAY_LOG_POS', 'RELAY_THREAD', 'RELEASE', 'RELOAD', 'REMOVE', 'RENAME', 'REORGANIZE', 'REPAIR', 'REPEATABLE', 'REPLAY', 'REPLICA', 'REPLICAS', 'REPLICA_POS', 'REPLICATION', 'REPEAT', 'REQUIRE', 'RESET', 'RESTART', 'RESTORE', 'RESTRICT', 'RESUME', 'RETURNED_SQLSTATE', 'RETURN', 'RETURNS', 'REUSE', 'RIGHT', 'RLIKE', 'ROLE', 'ROLLUP', 'ROUTINE', 'ROW', 'ROWCOUNT', 'ROWNUM', 'ROWS', 'ROWTYPE', 'ROW_COUNT', 'ROW_FORMAT', 'RTREE', 'SCHEDULE', 'SCHEMA', 'SCHEMA_NAME', 'SCHEMAS', 'SECOND', 'SECOND_MICROSECOND', 'SECURITY', 'SENSITIVE', 'SEPARATOR', 'SEQUENCE', 'SERIAL', 'SERIALIZABLE', 'SESSION', 'SERVER', 'SETVAL', 'SHARE', 'SIGNED', 'SIMPLE', 'SKIP', 'SLAVE', 'SLAVES', 'SLAVE_POS', 'SLOW', 'SNAPSHOT', 'SMALLINT', 'SOCKET', 'SOFT', 'SOME', 'SONAME', 'SOUNDS', 'SOURCE', 'STAGE', 'STORED', 'SPATIAL', 'SPECIFIC', 'REF_SYSTEM_ID', 'SQL', 'SQLEXCEPTION', 'SQLSTATE', 'SQLWARNING', 'SQL_BIG_RESULT', 'SQL_BUFFER_RESULT', 'SQL_CACHE', 'SQL_CALC_FOUND_ROWS', 'SQL_NO_CACHE', 'SQL_SMALL_RESULT', 'SQL_THREAD', 'SQL_TSI_SECOND', 'SQL_TSI_MINUTE', 'SQL_TSI_HOUR', 'SQL_TSI_DAY', 'SQL_TSI_WEEK', 'SQL_TSI_MONTH', 'SQL_TSI_QUARTER', 'SQL_TSI_YEAR', 'SSL', 'START', 'STARTING', 'STARTS', 'STATEMENT', 'STATS_AUTO_RECALC', 'STATS_PERSISTENT', 'STATS_SAMPLE_PAGES', 'STATUS', 'STOP', 'STORAGE', 'STRING', 'SUBCLASS_ORIGIN', 'SUBJECT', 'SUBPARTITION', 'SUBPARTITIONS', 'SUPER', 'SUSPEND', 'SWAPS', 'SWITCHES', 'SYSDATE', 'SYSTEM', 'SYSTEM_TIME', 'TABLE', 'TABLE_NAME', 'TABLES', 'TABLESPACE', 'TABLE_CHECKSUM', 'TEMPORARY', 'TEMPTABLE', 'TERMINATED', 'TEXT', 'THAN', 'THEN', 'TIES', 'TIME', 'TIMESTAMP', 'TIMESTAMPADD', 'TIMESTAMPDIFF', 'TINYBLOB', 'TINYINT', 'TINYTEXT', 'TO', 'TRAILING', 'TRANSACTION', 'TRANSACTIONAL', 'THREADS', 'TRIGGER', 'TRIGGERS', 'TRUE', 'TYPE', 'TYPES', 'UNBOUNDED', 'UNCOMMITTED', 'UNDEFINED', 'UNDO_BUFFER_SIZE', 'UNDOFILE', 'UNDO', 'UNICODE', 'UNIQUE', 'UNKNOWN', 'UNLOCK', 'UNINSTALL', 'UNSIGNED', 'UNTIL', 'UPGRADE', 'USAGE', 'USER', 'USER_RESOURCES', 'USE_FRM', 'UTC_DATE', 'UTC_TIME', 'UTC_TIMESTAMP', 'VALUE', 'VARBINARY', 'VARCHAR', 'VARCHARACTER', 'VARCHAR2', 'VARIABLES', 'VARYING', 'VIA', 'VIEW', 'VIRTUAL', 'VISIBLE', 'VERSIONING', 'WAIT', 'WARNINGS', 'WEEK', 'WEIGHT_STRING', 'WHILE', 'WINDOW', 'WITHIN', 'WITHOUT', 'WORK', 'WRAPPER', 'WRITE', 'X509', 'XA', 'XML', 'YEAR', 'YEAR_MONTH', 'ZEROFILL'];
|
2693 | /**
|
2694 | * Priority 1 (first)
|
2695 | * keywords that begin a new statement
|
2696 | * will begin new indented block
|
2697 | */
|
2698 | // https://mariadb.com/docs/reference/mdb/sql-statements/
|
2699 |
|
2700 | var reservedCommands = ['ALTER DATABASE', 'ALTER DATABASE COMMENT', 'ALTER EVENT', 'ALTER FUNCTION', 'ALTER PROCEDURE', 'ALTER SCHEMA', 'ALTER SCHEMA COMMENT', 'ALTER SEQUENCE', 'ALTER SERVER', 'ALTER TABLE', 'ALTER USER', 'ALTER VIEW', 'ANALYZE', 'ANALYZE TABLE', 'BACKUP LOCK', 'BACKUP STAGE', 'BACKUP UNLOCK', 'BEGIN', 'BINLOG', 'CACHE INDEX', 'CALL', 'CHANGE MASTER TO', 'CHECK TABLE', 'CHECK VIEW', 'CHECKSUM TABLE', 'COMMIT', 'CREATE AGGREGATE FUNCTION', 'CREATE DATABASE', 'CREATE EVENT', 'CREATE FUNCTION', 'CREATE INDEX', 'CREATE PROCEDURE', 'CREATE ROLE', 'CREATE SEQUENCE', 'CREATE SERVER', 'CREATE SPATIAL INDEX', 'CREATE TABLE', 'CREATE TRIGGER', 'CREATE UNIQUE INDEX', 'CREATE USER', 'CREATE VIEW', 'DEALLOCATE PREPARE', 'DELETE', 'DESC', 'DESCRIBE', 'DO', 'DROP DATABASE', 'DROP EVENT', 'DROP FUNCTION', 'DROP INDEX', 'DROP PREPARE', 'DROP PROCEDURE', 'DROP ROLE', 'DROP SEQUENCE', 'DROP SERVER', 'DROP TABLE', 'DROP TRIGGER', 'DROP USER', 'DROP VIEW', 'EXECUTE', 'EXPLAIN', 'FLUSH', 'GET DIAGNOSTICS', 'GET DIAGNOSTICS CONDITION', 'GRANT', 'HANDLER', 'HELP', 'INSERT', 'INSTALL PLUGIN', 'INSTALL SONAME', 'KILL', 'LOAD DATA INFILE', 'LOAD INDEX INTO CACHE', 'LOAD XML INFILE', 'LOCK TABLE', 'OPTIMIZE TABLE', 'PREPARE', 'PURGE BINARY LOGS', 'PURGE MASTER LOGS', 'RELEASE SAVEPOINT', 'RENAME TABLE', 'RENAME USER', 'REPAIR TABLE', 'REPAIR VIEW', 'REPLACE', 'RESET MASTER', 'RESET QUERY CACHE', 'RESET REPLICA', 'RESET SLAVE', 'RESIGNAL', 'RETURNING', 'REVOKE', 'ROLLBACK', 'SAVEPOINT', 'SELECT', 'SET', 'SET CHARACTER SET', 'SET DEFAULT ROLE', 'SET GLOBAL TRANSACTION', 'SET NAMES', 'SET PASSWORD', 'SET ROLE', 'SET STATEMENT', 'SET TRANSACTION', 'SHOW', 'SHOW ALL REPLICAS STATUS', 'SHOW ALL SLAVES STATUS', 'SHOW AUTHORS', 'SHOW BINARY LOGS', 'SHOW BINLOG EVENTS', 'SHOW BINLOG STATUS', 'SHOW CHARACTER SET', 'SHOW CLIENT_STATISTICS', 'SHOW COLLATION', 'SHOW COLUMNS', 'SHOW CONTRIBUTORS', 'SHOW CREATE DATABASE', 'SHOW CREATE EVENT', 'SHOW CREATE FUNCTION', 'SHOW CREATE PACKAGE', 'SHOW CREATE PACKAGE BODY', 'SHOW CREATE PROCEDURE', 'SHOW CREATE SEQUENCE', 'SHOW CREATE TABLE', 'SHOW CREATE TRIGGER', 'SHOW CREATE USER', 'SHOW CREATE VIEW', 'SHOW DATABASES', 'SHOW ENGINE', 'SHOW ENGINE INNODB STATUS', 'SHOW ENGINES', 'SHOW ERRORS', 'SHOW EVENTS', 'SHOW EXPLAIN', 'SHOW FUNCTION CODE', 'SHOW FUNCTION STATUS', 'SHOW GRANTS', 'SHOW INDEX', 'SHOW INDEXES', 'SHOW INDEX_STATISTICS', 'SHOW KEYS', 'SHOW LOCALES', 'SHOW MASTER LOGS', 'SHOW MASTER STATUS', 'SHOW OPEN TABLES', 'SHOW PACKAGE BODY CODE', 'SHOW PACKAGE BODY STATUS', 'SHOW PACKAGE STATUS', 'SHOW PLUGINS', 'SHOW PLUGINS SONAME', 'SHOW PRIVILEGES', 'SHOW PROCEDURE CODE', 'SHOW PROCEDURE STATUS', 'SHOW PROCESSLIST', 'SHOW PROFILE', 'SHOW PROFILES', 'SHOW QUERY_RESPONSE_TIME', 'SHOW RELAYLOG EVENTS', 'SHOW REPLICA', 'SHOW REPLICA HOSTS', 'SHOW REPLICA STATUS', 'SHOW SCHEMAS', 'SHOW SLAVE', 'SHOW SLAVE HOSTS', 'SHOW SLAVE STATUS', 'SHOW STATUS', 'SHOW STORAGE ENGINES', 'SHOW TABLE STATUS', 'SHOW TABLES', 'SHOW TRIGGERS', 'SHOW USER_STATISTICS', 'SHOW VARIABLES', 'SHOW WARNINGS', 'SHOW WSREP_MEMBERSHIP', 'SHOW WSREP_STATUS', 'SHUTDOWN', 'SIGNAL', 'START ALL REPLICAS', 'START ALL SLAVES', 'START REPLICA', 'START SLAVE', 'START TRANSACTION', 'STOP ALL REPLICAS', 'STOP ALL SLAVES', 'STOP REPLICA', 'STOP SLAVE', 'TRUNCATE', 'TRUNCATE TABLE', 'UNINSTALL PLUGIN', 'UNINSTALL SONAME', 'UNLOCK TABLE', 'UPDATE', 'USE', 'WITH', 'XA BEGIN', 'XA COMMIT', 'XA END', 'XA PREPARE', 'XA RECOVER', 'XA ROLLBACK', 'XA START', // other
|
2701 | 'ADD', 'ALTER COLUMN', 'FROM', 'GROUP BY', 'HAVING', 'INSERT INTO', 'INSERT', 'LIMIT', 'OFFSET', 'ORDER BY', 'SELECT', 'VALUES', 'WHERE'];
|
2702 | /**
|
2703 | * Priority 2
|
2704 | * commands that operate on two tables or subqueries
|
2705 | * two main categories: joins and boolean set operators
|
2706 | */
|
2707 |
|
2708 | var reservedBinaryCommands = [// set booleans
|
2709 | 'INTERSECT', 'INTERSECT ALL', 'INTERSECT DISTINCT', 'UNION', 'UNION ALL', 'UNION DISTINCT', 'EXCEPT', 'EXCEPT ALL', 'EXCEPT DISTINCT', 'MINUS', 'MINUS ALL', 'MINUS DISTINCT', // joins
|
2710 | 'JOIN', 'INNER JOIN', 'LEFT JOIN', 'LEFT OUTER JOIN', 'RIGHT JOIN', 'RIGHT OUTER JOIN', 'CROSS JOIN', 'NATURAL JOIN', // non-standard joins
|
2711 | 'STRAIGHT_JOIN', 'NATURAL LEFT JOIN', 'NATURAL LEFT OUTER JOIN', 'NATURAL RIGHT JOIN', 'NATURAL RIGHT OUTER JOIN'];
|
2712 | /**
|
2713 | * Priority 3
|
2714 | * keywords that follow a previous Statement, must be attached to subsequent data
|
2715 | * can be fully inline or on newline with optional indent
|
2716 | */
|
2717 |
|
2718 | var reservedDependentClauses = ['WHEN', 'ELSE', 'ELSEIF', 'ELSIF']; // For reference: https://mariadb.com/kb/en/sql-statements-structure/
|
2719 |
|
2720 | var MariaDbFormatter = /*#__PURE__*/function (_Formatter) {
|
2721 | _inherits(MariaDbFormatter, _Formatter);
|
2722 |
|
2723 | var _super = _createSuper(MariaDbFormatter);
|
2724 |
|
2725 | function MariaDbFormatter() {
|
2726 | _classCallCheck(this, MariaDbFormatter);
|
2727 |
|
2728 | return _super.apply(this, arguments);
|
2729 | }
|
2730 |
|
2731 | _createClass(MariaDbFormatter, [{
|
2732 | key: "tokenizer",
|
2733 | value: function tokenizer() {
|
2734 | return new _core_Tokenizer__WEBPACK_IMPORTED_MODULE_1__["default"]({
|
2735 | reservedCommands: MariaDbFormatter.reservedCommands,
|
2736 | reservedBinaryCommands: MariaDbFormatter.reservedBinaryCommands,
|
2737 | reservedDependentClauses: MariaDbFormatter.reservedDependentClauses,
|
2738 | reservedJoinConditions: MariaDbFormatter.reservedJoinConditions,
|
2739 | reservedLogicalOperators: MariaDbFormatter.reservedLogicalOperators,
|
2740 | reservedKeywords: MariaDbFormatter.reservedKeywords,
|
2741 | stringTypes: MariaDbFormatter.stringTypes,
|
2742 | blockStart: MariaDbFormatter.blockStart,
|
2743 | blockEnd: MariaDbFormatter.blockEnd,
|
2744 | indexedPlaceholderTypes: MariaDbFormatter.indexedPlaceholderTypes,
|
2745 | namedPlaceholderTypes: MariaDbFormatter.namedPlaceholderTypes,
|
2746 | lineCommentTypes: MariaDbFormatter.lineCommentTypes,
|
2747 | specialWordChars: MariaDbFormatter.specialWordChars,
|
2748 | operators: MariaDbFormatter.operators
|
2749 | });
|
2750 | }
|
2751 | }, {
|
2752 | key: "tokenOverride",
|
2753 | value: function tokenOverride(token) {
|
2754 | // [SET] ( ...
|
2755 | if (_core_token__WEBPACK_IMPORTED_MODULE_2__.isToken.SET(token) && this.tokenLookAhead().value === '(') {
|
2756 | // This is SET datatype, not SET statement
|
2757 | return {
|
2758 | type: _core_token__WEBPACK_IMPORTED_MODULE_2__.TokenType.RESERVED_KEYWORD,
|
2759 | value: token.value
|
2760 | };
|
2761 | }
|
2762 |
|
2763 | return token;
|
2764 | }
|
2765 | }]);
|
2766 |
|
2767 | return MariaDbFormatter;
|
2768 | }(_core_Formatter__WEBPACK_IMPORTED_MODULE_0__["default"]);
|
2769 |
|
2770 |
|
2771 | MariaDbFormatter.reservedCommands = reservedCommands;
|
2772 | MariaDbFormatter.reservedBinaryCommands = reservedBinaryCommands;
|
2773 | MariaDbFormatter.reservedJoinConditions = ['ON', 'USING'];
|
2774 | MariaDbFormatter.reservedLogicalOperators = ['AND', 'OR', 'XOR'];
|
2775 | MariaDbFormatter.reservedDependentClauses = reservedDependentClauses;
|
2776 | MariaDbFormatter.reservedKeywords = (0,_utils__WEBPACK_IMPORTED_MODULE_3__.dedupe)([].concat(reservedKeywords, reservedFunctions));
|
2777 | MariaDbFormatter.stringTypes = ['``', "''", '""'];
|
2778 | MariaDbFormatter.blockStart = ['(', 'CASE'];
|
2779 | MariaDbFormatter.blockEnd = [')', 'END'];
|
2780 | MariaDbFormatter.indexedPlaceholderTypes = ['?'];
|
2781 | MariaDbFormatter.namedPlaceholderTypes = [];
|
2782 | MariaDbFormatter.lineCommentTypes = ['--', '#'];
|
2783 | MariaDbFormatter.specialWordChars = {
|
2784 | prefix: '@'
|
2785 | };
|
2786 | MariaDbFormatter.operators = [':=', '<<', '>>', '<=>', '&&', '||'];
|
2787 |
|
2788 | /***/ }),
|
2789 |
|
2790 | /***/ "./src/languages/mysql.formatter.ts":
|
2791 | /*!******************************************!*\
|
2792 | !*** ./src/languages/mysql.formatter.ts ***!
|
2793 | \******************************************/
|
2794 | /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
2795 |
|
2796 | __webpack_require__.r(__webpack_exports__);
|
2797 | /* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
2798 | /* harmony export */ "default": () => (/* binding */ MySqlFormatter)
|
2799 | /* harmony export */ });
|
2800 | /* harmony import */ var _core_Formatter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../core/Formatter */ "./src/core/Formatter.ts");
|
2801 | /* harmony import */ var _core_Tokenizer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../core/Tokenizer */ "./src/core/Tokenizer.ts");
|
2802 | /* harmony import */ var _core_token__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../core/token */ "./src/core/token.ts");
|
2803 | /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../utils */ "./src/utils.ts");
|
2804 | function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
2805 |
|
2806 | function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
2807 |
|
2808 | function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
2809 |
|
2810 | function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
2811 |
|
2812 | function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
|
2813 |
|
2814 | function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
|
2815 |
|
2816 | function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
2817 |
|
2818 | function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
|
2819 |
|
2820 | function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
|
2821 |
|
2822 | function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
2823 |
|
2824 | function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
|
2825 |
|
2826 |
|
2827 |
|
2828 |
|
2829 | // TODO: split this into object with function categories
|
2830 |
|
2831 | /**
|
2832 | * Priority 5 (last)
|
2833 | * Full list of reserved functions
|
2834 | * distinct from Keywords due to interaction with parentheses
|
2835 | */
|
2836 | // https://dev.mysql.com/doc/refman/8.0/en/built-in-function-reference.html
|
2837 |
|
2838 | var reservedFunctions = ['ABS', 'ACOS', 'ADDDATE', 'ADDTIME', 'AES_DECRYPT', 'AES_ENCRYPT', 'AND', 'ANY_VALUE', 'ASCII', 'ASIN', 'ATAN', 'ATAN2', 'AVG', 'BENCHMARK', 'BIN', 'BIN_TO_UUID', 'BINARY', 'BIT_AND', 'BIT_COUNT', 'BIT_LENGTH', 'BIT_OR', 'BIT_XOR', 'CAN_ACCESS_COLUMN', 'CAN_ACCESS_DATABASE', 'CAN_ACCESS_TABLE', 'CAN_ACCESS_USER', 'CAN_ACCESS_VIEW', 'CASE', 'CAST', 'CEIL', 'CEILING', 'CHAR', 'CHAR_LENGTH', 'CHARACTER_LENGTH', 'CHARSET', 'COALESCE', 'COERCIBILITY', 'COLLATION', 'COMPRESS', 'CONCAT', 'CONCAT_WS', 'CONNECTION_ID', 'CONV', 'CONVERT', 'CONVERT_TZ', 'COS', 'COT', 'COUNT', 'CRC32', 'CUME_DIST', 'CURDATE', 'CURRENT_DATE', 'CURRENT_ROLE', 'CURRENT_TIME', 'CURRENT_TIMESTAMP', 'CURRENT_USER', 'CURTIME', 'DATABASE', 'DATE', 'DATE_ADD', 'DATE_FORMAT', 'DATE_SUB', 'DATEDIFF', 'DAY', 'DAYNAME', 'DAYOFMONTH', 'DAYOFWEEK', 'DAYOFYEAR', 'DEFAULT', 'DEGREES', 'DENSE_RANK', 'DIV', 'ELT', 'EXP', 'EXPORT_SET', 'EXTRACT', 'ExtractValue', 'FIELD', 'FIND_IN_SET', 'FIRST_VALUE', 'FLOOR', 'FORMAT', 'FORMAT_BYTES', 'FORMAT_PICO_TIME', 'FOUND_ROWS', 'FROM_BASE64', 'FROM_DAYS', 'FROM_UNIXTIME', 'GeomCollection', 'GeometryCollection', 'GET_DD_COLUMN_PRIVILEGES', 'GET_DD_CREATE_OPTIONS', 'GET_DD_INDEX_SUB_PART_LENGTH', 'GET_FORMAT', 'GET_LOCK', 'GREATEST', 'GROUP_CONCAT', 'GROUPING', 'GTID_SUBSET', 'GTID_SUBTRACT', 'HEX', 'HOUR', 'ICU_VERSION', 'IF', 'IFNULL', 'IN', 'INET_ATON', 'INET_NTOA', 'INET6_ATON', 'INET6_NTOA', 'INSERT', 'INSTR', 'INTERNAL_AUTO_INCREMENT', 'INTERNAL_AVG_ROW_LENGTH', 'INTERNAL_CHECK_TIME', 'INTERNAL_CHECKSUM', 'INTERNAL_DATA_FREE', 'INTERNAL_DATA_LENGTH', 'INTERNAL_DD_CHAR_LENGTH', 'INTERNAL_GET_COMMENT_OR_ERROR', 'INTERNAL_GET_ENABLED_ROLE_JSON', 'INTERNAL_GET_HOSTNAME', 'INTERNAL_GET_USERNAME', 'INTERNAL_GET_VIEW_WARNING_OR_ERROR', 'INTERNAL_INDEX_COLUMN_CARDINALITY', 'INTERNAL_INDEX_LENGTH', 'INTERNAL_IS_ENABLED_ROLE', 'INTERNAL_IS_MANDATORY_ROLE', 'INTERNAL_KEYS_DISABLED', 'INTERNAL_MAX_DATA_LENGTH', 'INTERNAL_TABLE_ROWS', 'INTERNAL_UPDATE_TIME', 'INTERVAL', 'IS', 'IS_FREE_LOCK', 'IS_IPV4', 'IS_IPV4_COMPAT', 'IS_IPV4_MAPPED', 'IS_IPV6', 'IS NOT', 'IS NOT NULL', 'IS NULL', 'IS_USED_LOCK', 'IS_UUID', 'ISNULL', 'JSON_ARRAY', 'JSON_ARRAY_APPEND', 'JSON_ARRAY_INSERT', 'JSON_ARRAYAGG', 'JSON_CONTAINS', 'JSON_CONTAINS_PATH', 'JSON_DEPTH', 'JSON_EXTRACT', 'JSON_INSERT', 'JSON_KEYS', 'JSON_LENGTH', 'JSON_MERGE', 'JSON_MERGE_PATCH', 'JSON_MERGE_PRESERVE', 'JSON_OBJECT', 'JSON_OBJECTAGG', 'JSON_OVERLAPS', 'JSON_PRETTY', 'JSON_QUOTE', 'JSON_REMOVE', 'JSON_REPLACE', 'JSON_SCHEMA_VALID', 'JSON_SCHEMA_VALIDATION_REPORT', 'JSON_SEARCH', 'JSON_SET', 'JSON_STORAGE_FREE', 'JSON_STORAGE_SIZE', 'JSON_TABLE', 'JSON_TYPE', 'JSON_UNQUOTE', 'JSON_VALID', 'JSON_VALUE', 'LAG', 'LAST_DAY', 'LAST_INSERT_ID', 'LAST_VALUE', 'LCASE', 'LEAD', 'LEAST', 'LEFT', 'LENGTH', 'LIKE', 'LineString', 'LN', 'LOAD_FILE', 'LOCALTIME', 'LOCALTIMESTAMP', 'LOCATE', 'LOG', 'LOG10', 'LOG2', 'LOWER', 'LPAD', 'LTRIM', 'MAKE_SET', 'MAKEDATE', 'MAKETIME', 'MASTER_POS_WAIT', 'MATCH', 'MAX', 'MBRContains', 'MBRCoveredBy', 'MBRCovers', 'MBRDisjoint', 'MBREquals', 'MBRIntersects', 'MBROverlaps', 'MBRTouches', 'MBRWithin', 'MD5', 'MEMBER OF', 'MICROSECOND', 'MID', 'MIN', 'MINUTE', 'MOD', 'MONTH', 'MONTHNAME', 'MultiLineString', 'MultiPoint', 'MultiPolygon', 'NAME_CONST', 'NOT', 'NOT IN', 'NOT LIKE', 'NOT REGEXP', 'NOW', 'NTH_VALUE', 'NTILE', 'NULLIF', 'OCT', 'OCTET_LENGTH', 'OR', 'ORD', 'PERCENT_RANK', 'PERIOD_ADD', 'PERIOD_DIFF', 'PI', 'Point', 'Polygon', 'POSITION', 'POW', 'POWER', 'PS_CURRENT_THREAD_ID', 'PS_THREAD_ID', 'QUARTER', 'QUOTE', 'RADIANS', 'RAND', 'RANDOM_BYTES', 'RANK', 'REGEXP', 'REGEXP_INSTR', 'REGEXP_LIKE', 'REGEXP_REPLACE', 'REGEXP_SUBSTR', 'RELEASE_ALL_LOCKS', 'RELEASE_LOCK', 'REPEAT', 'REPLACE', 'REVERSE', 'RIGHT', 'RLIKE', 'ROLES_GRAPHML', 'ROUND', 'ROW_COUNT', 'ROW_NUMBER', 'RPAD', 'RTRIM', 'SCHEMA', 'SEC_TO_TIME', 'SECOND', 'SESSION_USER', 'SHA1', 'SHA2', 'SIGN', 'SIN', 'SLEEP', 'SOUNDEX', 'SOUNDS LIKE', 'SOURCE_POS_WAIT', 'SPACE', 'SQRT', 'ST_Area', 'ST_AsBinary', 'ST_AsGeoJSON', 'ST_AsText', 'ST_Buffer', 'ST_Buffer_Strategy', 'ST_Centroid', 'ST_Collect', 'ST_Contains', 'ST_ConvexHull', 'ST_Crosses', 'ST_Difference', 'ST_Dimension', 'ST_Disjoint', 'ST_Distance', 'ST_Distance_Sphere', 'ST_EndPoint', 'ST_Envelope', 'ST_Equals', 'ST_ExteriorRing', 'ST_FrechetDistance', 'ST_GeoHash', 'ST_GeomCollFromText', 'ST_GeomCollFromWKB', 'ST_GeometryN', 'ST_GeometryType', 'ST_GeomFromGeoJSON', 'ST_GeomFromText', 'ST_GeomFromWKB', 'ST_HausdorffDistance', 'ST_InteriorRingN', 'ST_Intersection', 'ST_Intersects', 'ST_IsClosed', 'ST_IsEmpty', 'ST_IsSimple', 'ST_IsValid', 'ST_LatFromGeoHash', 'ST_Latitude', 'ST_Length', 'ST_LineFromText', 'ST_LineFromWKB', 'ST_LineInterpolatePoint', 'ST_LineInterpolatePoints', 'ST_LongFromGeoHash', 'ST_Longitude', 'ST_MakeEnvelope', 'ST_MLineFromText', 'ST_MLineFromWKB', 'ST_MPointFromText', 'ST_MPointFromWKB', 'ST_MPolyFromText', 'ST_MPolyFromWKB', 'ST_NumGeometries', 'ST_NumInteriorRing', 'ST_NumPoints', 'ST_Overlaps', 'ST_PointAtDistance', 'ST_PointFromGeoHash', 'ST_PointFromText', 'ST_PointFromWKB', 'ST_PointN', 'ST_PolyFromText', 'ST_PolyFromWKB', 'ST_Simplify', 'ST_SRID', 'ST_StartPoint', 'ST_SwapXY', 'ST_SymDifference', 'ST_Touches', 'ST_Transform', 'ST_Union', 'ST_Validate', 'ST_Within', 'ST_X', 'ST_Y', 'STATEMENT_DIGEST', 'STATEMENT_DIGEST_TEXT', 'STD', 'STDDEV', 'STDDEV_POP', 'STDDEV_SAMP', 'STR_TO_DATE', 'STRCMP', 'SUBDATE', 'SUBSTR', 'SUBSTRING', 'SUBSTRING_INDEX', 'SUBTIME', 'SUM', 'SYSDATE', 'SYSTEM_USER', 'TAN', 'TIME', 'TIME_FORMAT', 'TIME_TO_SEC', 'TIMEDIFF', 'TIMESTAMP', 'TIMESTAMPADD', 'TIMESTAMPDIFF', 'TO_BASE64', 'TO_DAYS', 'TO_SECONDS', 'TRIM', 'TRUNCATE', 'UCASE', 'UNCOMPRESS', 'UNCOMPRESSED_LENGTH', 'UNHEX', 'UNIX_TIMESTAMP', 'UpdateXML', 'UPPER', 'USER', 'UTC_DATE', 'UTC_TIME', 'UTC_TIMESTAMP', 'UUID', 'UUID_SHORT', 'UUID_TO_BIN', 'VALIDATE_PASSWORD_STRENGTH', 'VALUES', 'VAR_POP', 'VAR_SAMP', 'VARIANCE', 'VERSION', 'WAIT_FOR_EXECUTED_GTID_SET', 'WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS', 'WEEK', 'WEEKDAY', 'WEEKOFYEAR', 'WEIGHT_STRING', 'XOR', 'YEAR', 'YEARWEEK'];
|
2839 | /**
|
2840 | * Priority 5 (last)
|
2841 | * Full list of reserved words
|
2842 | * any words that are in a higher priority are removed
|
2843 | */
|
2844 | // https://dev.mysql.com/doc/refman/8.0/en/keywords.html
|
2845 |
|
2846 | var reservedKeywords = ['ACCESSIBLE', 'ACCOUNT', 'ACTION', 'ACTIVE', 'ADMIN', 'AFTER', 'AGAINST', 'AGGREGATE', 'ALGORITHM', 'ALL', 'ALTER', 'ALWAYS', 'ANALYSE', 'ANALYZE', 'ANY', 'ARRAY', 'AS', 'ASC', 'ASENSITIVE', 'AT', 'ATTRIBUTE', 'AUTHENTICATION', 'AUTOEXTEND_SIZE', 'AUTO_INCREMENT', 'AVG_ROW_LENGTH', 'BACKUP', 'BEFORE', 'BEGIN', 'BETWEEN', 'BIGINT', 'BIT', 'BLOB', 'BLOCK', 'BOOL', 'BOOLEAN', 'BOTH', 'BTREE', 'BUCKETS', 'BY', 'BYTE', 'CACHE', 'CASCADE', 'CASCADED', 'CATALOG_NAME', 'CHAIN', 'CHALLENGE_RESPONSE', 'CHANGE', 'CHANGED', 'CHANNEL', 'CHARACTER', 'CHARACTER SET', 'CHECK', 'CHECKSUM', 'CIPHER', 'CLASS_ORIGIN', 'CLIENT', 'CLOSE', 'CODE', 'COLLATE', 'COLUMN', 'COLUMNS', 'COLUMN_FORMAT', 'COLUMN_NAME', 'COMMENT', 'COMMITTED', 'COMPACT', 'COMPLETION', 'COMPONENT', 'COMPRESSED', 'COMPRESSION', 'CONCURRENT', 'CONDITION', 'CONNECTION', 'CONSISTENT', 'CONSTRAINT', 'CONSTRAINT_CATALOG', 'CONSTRAINT_NAME', 'CONSTRAINT_SCHEMA', 'CONTAINS', 'CONTEXT', 'CONTINUE', 'CPU', 'CREATE', 'CROSS', 'CUBE', 'CURRENT', 'CURSOR', 'CURSOR_NAME', 'DATA', 'DATABASES', 'DATAFILE', 'DATETIME', 'DAY_HOUR', 'DAY_MICROSECOND', 'DAY_MINUTE', 'DAY_SECOND', 'DEALLOCATE', 'DEC', 'DECIMAL', 'DECLARE', 'DEFAULT_AUTH', 'DEFINER', 'DEFINITION', 'DELAYED', 'DELAY_KEY_WRITE', 'DESC', 'DESCRIPTION', 'DES_KEY_FILE', 'DETERMINISTIC', 'DIAGNOSTICS', 'DIRECTORY', 'DISABLE', 'DISCARD', 'DISK', 'DISTINCT', 'DISTINCTROW', 'DOUBLE', 'DROP', 'DUAL', 'DUMPFILE', 'DUPLICATE', 'DYNAMIC', 'EACH', 'EMPTY', 'ENABLE', 'ENCLOSED', 'ENCRYPTION', 'ENDS', 'ENFORCED', 'ENGINE', 'ENGINES', 'ENGINE_ATTRIBUTE', 'ENUM', 'ERROR', 'ERRORS', 'ESCAPE', 'ESCAPED', 'EVENT', 'EVENTS', 'EVERY', 'EXCHANGE', 'EXCLUDE', 'EXISTS', 'EXIT', 'EXPANSION', 'EXPIRE', 'EXPORT', 'EXTENDED', 'EXTENT_SIZE', 'FACTOR', 'FAILED_LOGIN_ATTEMPTS', 'FALSE', 'FAST', 'FAULTS', 'FETCH', 'FIELDS', 'FILE', 'FILE_BLOCK_SIZE', 'FILTER', 'FINISH', 'FIRST', 'FIXED', 'FLOAT', 'FLOAT4', 'FLOAT8', 'FOLLOWING', 'FOLLOWS', 'FOR', 'FORCE', 'FOREIGN', 'FOUND', 'FULL', 'FULLTEXT', 'FUNCTION', 'GENERAL', 'GENERATED', 'GEOMCOLLECTION', 'GEOMETRY', 'GEOMETRYCOLLECTION', 'GET', 'GET_MASTER_PUBLIC_KEY', 'GET_SOURCE_PUBLIC_KEY', 'GLOBAL', '@@GLOBAL', 'GRANTS', 'GROUP', 'GROUPS', 'GROUP_REPLICATION', 'GTID_ONLY', 'HASH', 'HIGH_PRIORITY', 'HISTOGRAM', 'HISTORY', 'HOST', 'HOSTS', 'HOUR_MICROSECOND', 'HOUR_MINUTE', 'HOUR_SECOND', 'IDENTIFIED', 'IGNORE', 'IGNORE_SERVER_IDS', 'IMPORT', 'INACTIVE', 'INDEX', 'INDEXES', 'INFILE', 'INITIAL', 'INITIAL_SIZE', 'INITIATE', 'INNER', 'INOUT', 'INSENSITIVE', 'INSERT_METHOD', 'INSTALL', 'INSTANCE', 'INT', 'INT1', 'INT2', 'INT3', 'INT4', 'INT8', 'INTEGER', 'INTO', 'INVISIBLE', 'INVOKER', 'IO', 'IO_AFTER_GTIDS', 'IO_BEFORE_GTIDS', 'IO_THREAD', 'IPC', 'ISOLATION', 'ISSUER', 'ITERATE', 'JSON', 'KEY', 'KEYRING', 'KEYS', 'KEY_BLOCK_SIZE', 'LANGUAGE', 'LAST', 'LATERAL', 'LEADING', 'LEAVE', 'LEAVES', 'LESS', 'LEVEL', 'LINEAR', 'LINES', 'LINESTRING', 'LIST', 'LOAD', 'LOCAL', 'LOCK', 'LOCKED', 'LOCKS', 'LOGFILE', 'LOGS', 'LONG', 'LONGBLOB', 'LONGTEXT', 'LOOP', 'LOW_PRIORITY', 'MASTER', 'MASTER_AUTO_POSITION', 'MASTER_BIND', 'MASTER_COMPRESSION_ALGORITHMS', 'MASTER_CONNECT_RETRY', 'MASTER_DELAY', 'MASTER_HEARTBEAT_PERIOD', 'MASTER_HOST', 'MASTER_LOG_FILE', 'MASTER_LOG_POS', 'MASTER_PASSWORD', 'MASTER_PORT', 'MASTER_PUBLIC_KEY_PATH', 'MASTER_RETRY_COUNT', 'MASTER_SERVER_ID', 'MASTER_SSL', 'MASTER_SSL_CA', 'MASTER_SSL_CAPATH', 'MASTER_SSL_CERT', 'MASTER_SSL_CIPHER', 'MASTER_SSL_CRL', 'MASTER_SSL_CRLPATH', 'MASTER_SSL_KEY', 'MASTER_SSL_VERIFY_SERVER_CERT', 'MASTER_TLS_CIPHERSUITES', 'MASTER_TLS_VERSION', 'MASTER_USER', 'MASTER_ZSTD_COMPRESSION_LEVEL', 'MAXVALUE', 'MAX_CONNECTIONS_PER_HOUR', 'MAX_QUERIES_PER_HOUR', 'MAX_ROWS', 'MAX_SIZE', 'MAX_UPDATES_PER_HOUR', 'MAX_USER_CONNECTIONS', 'MEDIUM', 'MEDIUMBLOB', 'MEDIUMINT', 'MEDIUMTEXT', 'MEMBER', 'MEMORY', 'MERGE', 'MESSAGE_TEXT', 'MIDDLEINT', 'MIGRATE', 'MINUTE_MICROSECOND', 'MINUTE_SECOND', 'MIN_ROWS', 'MODE', 'MODIFIES', 'MODIFY', 'MULTILINESTRING', 'MULTIPOINT', 'MULTIPOLYGON', 'MUTEX', 'MYSQL_ERRNO', 'NAME', 'NAMES', 'NATIONAL', 'NATURAL', 'NCHAR', 'NDB', 'NDBCLUSTER', 'NESTED', 'NETWORK_NAMESPACE', 'NEVER', 'NEW', 'NEXT', 'NO', 'NODEGROUP', 'NONE', 'NOWAIT', 'NO_WAIT', 'NO_WRITE_TO_BINLOG', 'NULL', 'NULLS', 'NUMBER', 'NUMERIC', 'NVARCHAR', 'OF', 'OFF', 'OFFSET', 'OJ', 'OLD', 'ON DELETE', 'ON UPDATE', 'ONE', 'ONLY', 'OPEN', 'OPTIMIZE', 'OPTIMIZER_COSTS', 'OPTION', 'OPTIONAL', 'OPTIONALLY', 'OPTIONS', 'ORDER', 'ORDINALITY', 'ORGANIZATION', 'OTHERS', 'OUT', 'OUTER', 'OUTFILE', 'OVER', 'OWNER', 'PACK_KEYS', 'PAGE', 'PARSER', 'PARSE_GCOL_EXPR', 'PARTIAL', 'PARTITION', 'PARTITIONING', 'PARTITIONS', 'PASSWORD', 'PASSWORD_LOCK_TIME', 'PATH', 'PERSIST', '@@PERSIST', 'PERSIST_ONLY', '@@PERSIST_ONLY', 'PHASE', 'PLUGIN', 'PLUGINS', 'PLUGIN_DIR', 'POINT', 'POLYGON', 'PORT', 'PRECEDES', 'PRECEDING', 'PRECISION', 'PRESERVE', 'PREV', 'PRIMARY', 'PRIVILEGES', 'PRIVILEGE_CHECKS_USER', 'PROCEDURE', 'PROCESS', 'PROCESSLIST', 'PROFILE', 'PROFILES', 'PROXY', 'PURGE', 'QUERY', 'QUICK', 'RANDOM', 'RANGE', 'READ', 'READS', 'READ_ONLY', 'READ_WRITE', 'REAL', 'REBUILD', 'RECOVER', 'RECURSIVE', 'REDOFILE', 'REDO_BUFFER_SIZE', 'REDUNDANT', 'REFERENCE', 'REFERENCES', 'REGISTRATION', 'RELAY', 'RELAYLOG', 'RELAY_LOG_FILE', 'RELAY_LOG_POS', 'RELAY_THREAD', 'RELEASE', 'RELOAD', 'REMOTE', 'REMOVE', 'RENAME', 'REORGANIZE', 'REPAIR', 'REPEATABLE', 'REPLICA', 'REPLICAS', 'REPLICATE_DO_DB', 'REPLICATE_DO_TABLE', 'REPLICATE_IGNORE_DB', 'REPLICATE_IGNORE_TABLE', 'REPLICATE_REWRITE_DB', 'REPLICATE_WILD_DO_TABLE', 'REPLICATE_WILD_IGNORE_TABLE', 'REPLICATION', 'REQUIRE', 'REQUIRE_ROW_FORMAT', 'RESIGNAL', 'RESOURCE', 'RESPECT', 'RESTORE', 'RESTRICT', 'RESUME', 'RETAIN', 'RETURN', 'RETURNED_SQLSTATE', 'RETURNING', 'RETURNS', 'REUSE', 'ROLE', 'ROLLUP', 'ROTATE', 'ROUTINE', 'ROW', 'ROWS', 'ROW_FORMAT', 'RTREE', 'SCHEDULE', 'SCHEMAS', 'SCHEMA_NAME', 'SECONDARY', 'SECONDARY_ENGINE', 'SECONDARY_ENGINE_ATTRIBUTE', 'SECONDARY_LOAD', 'SECONDARY_UNLOAD', 'SECOND_MICROSECOND', 'SECURITY', 'SENSITIVE', 'SEPARATOR', 'SERIAL', 'SERIALIZABLE', 'SERVER', 'SESSION', '@@SESSION', 'SHARE', 'SIGNAL', 'SIGNED', 'SIMPLE', 'SKIP', 'SLAVE', 'SLOW', 'SMALLINT', 'SNAPSHOT', 'SOCKET', 'SOME', 'SONAME', 'SOUNDS', 'SOURCE', 'SOURCE_AUTO_POSITION', 'SOURCE_BIND', 'SOURCE_COMPRESSION_ALGORITHMS', 'SOURCE_CONNECT_RETRY', 'SOURCE_DELAY', 'SOURCE_HEARTBEAT_PERIOD', 'SOURCE_HOST', 'SOURCE_LOG_FILE', 'SOURCE_LOG_POS', 'SOURCE_PASSWORD', 'SOURCE_PORT', 'SOURCE_PUBLIC_KEY_PATH', 'SOURCE_RETRY_COUNT', 'SOURCE_SSL', 'SOURCE_SSL_CA', 'SOURCE_SSL_CAPATH', 'SOURCE_SSL_CERT', 'SOURCE_SSL_CIPHER', 'SOURCE_SSL_CRL', 'SOURCE_SSL_CRLPATH', 'SOURCE_SSL_KEY', 'SOURCE_SSL_VERIFY_SERVER_CERT', 'SOURCE_TLS_CIPHERSUITES', 'SOURCE_TLS_VERSION', 'SOURCE_USER', 'SOURCE_ZSTD_COMPRESSION_LEVEL', 'SPATIAL', 'SPECIFIC', 'SQL', 'SQLEXCEPTION', 'SQLSTATE', 'SQLWARNING', 'SQL_AFTER_GTIDS', 'SQL_AFTER_MTS_GAPS', 'SQL_BEFORE_GTIDS', 'SQL_BIG_RESULT', 'SQL_BUFFER_RESULT', 'SQL_CACHE', 'SQL_CALC_FOUND_ROWS', 'SQL_NO_CACHE', 'SQL_SMALL_RESULT', 'SQL_THREAD', 'SQL_TSI_DAY', 'SQL_TSI_HOUR', 'SQL_TSI_MINUTE', 'SQL_TSI_MONTH', 'SQL_TSI_QUARTER', 'SQL_TSI_SECOND', 'SQL_TSI_WEEK', 'SQL_TSI_YEAR', 'SRID', 'SSL', 'STACKED', 'START', 'STARTING', 'STARTS', 'STATS_AUTO_RECALC', 'STATS_PERSISTENT', 'STATS_SAMPLE_PAGES', 'STATUS', 'STOP', 'STORAGE', 'STORED', 'STREAM', 'STRING', 'SUBCLASS_ORIGIN', 'SUBJECT', 'SUBPARTITION', 'SUBPARTITIONS', 'SUPER', 'SUSPEND', 'SWAPS', 'SWITCHES', 'SYSTEM', 'TABLES', 'TABLESPACE', 'TABLE_CHECKSUM', 'TABLE_NAME', 'TEMPORARY', 'TEMPTABLE', 'TERMINATED', 'TEXT', 'THAN', 'THEN', 'THREAD_PRIORITY', 'TIES', 'TINYBLOB', 'TINYINT', 'TINYTEXT', 'TLS', 'TO', 'TRAILING', 'TRANSACTION', 'TRIGGER', 'TRIGGERS', 'TRUE', 'TYPE', 'TYPES', 'UNBOUNDED', 'UNCOMMITTED', 'UNDEFINED', 'UNDO', 'UNDOFILE', 'UNDO_BUFFER_SIZE', 'UNICODE', 'UNINSTALL', 'UNIQUE', 'UNKNOWN', 'UNLOCK', 'UNREGISTER', 'UNSIGNED', 'UNTIL', 'UPGRADE', 'USAGE', 'USER_RESOURCES', 'USE_FRM', 'VALIDATION', 'VALUE', 'VARBINARY', 'VARCHAR', 'VARCHARACTER', 'VARIABLES', 'VARYING', 'VCPU', 'VIEW', 'VIRTUAL', 'VISIBLE', 'WAIT', 'WARNINGS', 'WHILE', 'WINDOW', 'WITHOUT', 'WORK', 'WRAPPER', 'WRITE', 'X509', 'XID', 'XML', 'YEAR_MONTH', 'ZEROFILL', 'ZONE'];
|
2847 | /**
|
2848 | * Priority 1 (first)
|
2849 | * keywords that begin a new statement
|
2850 | * will begin new indented block
|
2851 | */
|
2852 | // https://dev.mysql.com/doc/refman/8.0/en/sql-statements.html
|
2853 |
|
2854 | var reservedCommands = ['ALTER DATABASE', 'ALTER EVENT', 'ALTER FUNCTION', 'ALTER INSTANCE', 'ALTER LOGFILE GROUP', 'ALTER PROCEDURE', 'ALTER RESOURCE GROUP', 'ALTER SERVER', 'ALTER TABLE', 'ALTER TABLESPACE', 'ALTER USER', 'ALTER VIEW', 'ANALYZE TABLE', 'BINLOG', 'CACHE INDEX', 'CALL', 'CHANGE MASTER TO', 'CHANGE REPLICATION FILTER', 'CHANGE REPLICATION SOURCE TO', 'CHECK TABLE', 'CHECKSUM TABLE', 'CLONE', 'COMMIT', 'CREATE DATABASE', 'CREATE EVENT', 'CREATE FUNCTION', 'CREATE FUNCTION', 'CREATE INDEX', 'CREATE LOGFILE GROUP', 'CREATE PROCEDURE', 'CREATE RESOURCE GROUP', 'CREATE ROLE', 'CREATE SERVER', 'CREATE SPATIAL REFERENCE SYSTEM', 'CREATE TABLE', 'CREATE TABLESPACE', 'CREATE TRIGGER', 'CREATE USER', 'CREATE VIEW', 'DEALLOCATE PREPARE', 'DELETE', 'DESCRIBE', 'DO', 'DROP DATABASE', 'DROP EVENT', 'DROP FUNCTION', 'DROP FUNCTION', 'DROP INDEX', 'DROP LOGFILE GROUP', 'DROP PROCEDURE', 'DROP RESOURCE GROUP', 'DROP ROLE', 'DROP SERVER', 'DROP SPATIAL REFERENCE SYSTEM', 'DROP TABLE', 'DROP TABLESPACE', 'DROP TRIGGER', 'DROP USER', 'DROP VIEW', 'EXECUTE', 'EXPLAIN', 'FLUSH', 'GRANT', 'HANDLER', 'HELP', 'IMPORT TABLE', 'INSERT', 'INSTALL COMPONENT', 'INSTALL PLUGIN', 'KILL', 'LOAD DATA', 'LOAD INDEX INTO CACHE', 'LOAD XML', 'LOCK INSTANCE FOR BACKUP', 'LOCK TABLES', 'MASTER_POS_WAIT', 'OPTIMIZE TABLE', 'PREPARE', 'PURGE BINARY LOGS', 'RELEASE SAVEPOINT', 'RENAME TABLE', 'RENAME USER', 'REPAIR TABLE', 'REPLACE', 'RESET', 'RESET MASTER', 'RESET PERSIST', 'RESET REPLICA', 'RESET SLAVE', 'RESTART', 'REVOKE', 'ROLLBACK', 'ROLLBACK TO SAVEPOINT', 'SAVEPOINT', 'SELECT', 'SET', 'SET CHARACTER SET', 'SET DEFAULT ROLE', 'SET NAMES', 'SET PASSWORD', 'SET RESOURCE GROUP', 'SET ROLE', 'SET TRANSACTION', 'SHOW', 'SHOW BINARY LOGS', 'SHOW BINLOG EVENTS', 'SHOW CHARACTER SET', 'SHOW COLLATION', 'SHOW COLUMNS', 'SHOW CREATE DATABASE', 'SHOW CREATE EVENT', 'SHOW CREATE FUNCTION', 'SHOW CREATE PROCEDURE', 'SHOW CREATE TABLE', 'SHOW CREATE TRIGGER', 'SHOW CREATE USER', 'SHOW CREATE VIEW', 'SHOW DATABASES', 'SHOW ENGINE', 'SHOW ENGINES', 'SHOW ERRORS', 'SHOW EVENTS', 'SHOW FUNCTION CODE', 'SHOW FUNCTION STATUS', 'SHOW GRANTS', 'SHOW INDEX', 'SHOW MASTER STATUS', 'SHOW OPEN TABLES', 'SHOW PLUGINS', 'SHOW PRIVILEGES', 'SHOW PROCEDURE CODE', 'SHOW PROCEDURE STATUS', 'SHOW PROCESSLIST', 'SHOW PROFILE', 'SHOW PROFILES', 'SHOW RELAYLOG EVENTS', 'SHOW REPLICA STATUS', 'SHOW REPLICAS', 'SHOW SLAVE', 'SHOW SLAVE HOSTS', 'SHOW STATUS', 'SHOW TABLE STATUS', 'SHOW TABLES', 'SHOW TRIGGERS', 'SHOW VARIABLES', 'SHOW WARNINGS', 'SHUTDOWN', 'SOURCE_POS_WAIT', 'START GROUP_REPLICATION', 'START REPLICA', 'START SLAVE', 'START TRANSACTION', 'STOP GROUP_REPLICATION', 'STOP REPLICA', 'STOP SLAVE', 'TABLE', 'TRUNCATE TABLE', 'UNINSTALL COMPONENT', 'UNINSTALL PLUGIN', 'UNLOCK INSTANCE', 'UNLOCK TABLES', 'UPDATE', 'USE', 'VALUES', 'WITH', 'XA', // flow control
|
2855 | // 'IF',
|
2856 | 'ITERATE', 'LEAVE', 'LOOP', 'REPEAT', 'RETURN', 'WHILE', // other
|
2857 | 'ADD', 'ALTER COLUMN', 'FROM', 'GROUP BY', 'HAVING', 'INSERT INTO', 'LIMIT', 'OFFSET', 'ORDER BY', 'WHERE'];
|
2858 | /**
|
2859 | * Priority 2
|
2860 | * commands that operate on two tables or subqueries
|
2861 | * two main categories: joins and boolean set operators
|
2862 | */
|
2863 |
|
2864 | var reservedBinaryCommands = [// set booleans
|
2865 | 'INTERSECT', 'INTERSECT ALL', 'INTERSECT DISTINCT', 'UNION', 'UNION ALL', 'UNION DISTINCT', 'EXCEPT', 'EXCEPT ALL', 'EXCEPT DISTINCT', // joins
|
2866 | 'JOIN', 'INNER JOIN', 'LEFT JOIN', 'LEFT OUTER JOIN', 'RIGHT JOIN', 'RIGHT OUTER JOIN', 'CROSS JOIN', 'NATURAL JOIN', // non-standard joins
|
2867 | 'STRAIGHT_JOIN', 'NATURAL LEFT JOIN', 'NATURAL LEFT OUTER JOIN', 'NATURAL RIGHT JOIN', 'NATURAL RIGHT OUTER JOIN'];
|
2868 | /**
|
2869 | * Priority 3
|
2870 | * keywords that follow a previous Statement, must be attached to subsequent data
|
2871 | * can be fully inline or on newline with optional indent
|
2872 | */
|
2873 |
|
2874 | var reservedDependentClauses = ['WHEN', 'ELSE', 'ELSEIF']; // https://dev.mysql.com/doc/refman/8.0/en/
|
2875 |
|
2876 | var MySqlFormatter = /*#__PURE__*/function (_Formatter) {
|
2877 | _inherits(MySqlFormatter, _Formatter);
|
2878 |
|
2879 | var _super = _createSuper(MySqlFormatter);
|
2880 |
|
2881 | function MySqlFormatter() {
|
2882 | _classCallCheck(this, MySqlFormatter);
|
2883 |
|
2884 | return _super.apply(this, arguments);
|
2885 | }
|
2886 |
|
2887 | _createClass(MySqlFormatter, [{
|
2888 | key: "tokenizer",
|
2889 | value: function tokenizer() {
|
2890 | return new _core_Tokenizer__WEBPACK_IMPORTED_MODULE_1__["default"]({
|
2891 | reservedCommands: MySqlFormatter.reservedCommands,
|
2892 | reservedBinaryCommands: MySqlFormatter.reservedBinaryCommands,
|
2893 | reservedDependentClauses: MySqlFormatter.reservedDependentClauses,
|
2894 | reservedJoinConditions: MySqlFormatter.reservedJoinConditions,
|
2895 | reservedLogicalOperators: MySqlFormatter.reservedLogicalOperators,
|
2896 | reservedKeywords: MySqlFormatter.reservedKeywords,
|
2897 | stringTypes: MySqlFormatter.stringTypes,
|
2898 | blockStart: MySqlFormatter.blockStart,
|
2899 | blockEnd: MySqlFormatter.blockEnd,
|
2900 | indexedPlaceholderTypes: MySqlFormatter.indexedPlaceholderTypes,
|
2901 | namedPlaceholderTypes: MySqlFormatter.namedPlaceholderTypes,
|
2902 | lineCommentTypes: MySqlFormatter.lineCommentTypes,
|
2903 | specialWordChars: MySqlFormatter.specialWordChars,
|
2904 | operators: MySqlFormatter.operators
|
2905 | });
|
2906 | }
|
2907 | }, {
|
2908 | key: "tokenOverride",
|
2909 | value: function tokenOverride(token) {
|
2910 | // [SET] ( ...
|
2911 | if (_core_token__WEBPACK_IMPORTED_MODULE_2__.isToken.SET(token) && this.tokenLookAhead().value === '(') {
|
2912 | // This is SET datatype, not SET statement
|
2913 | return {
|
2914 | type: _core_token__WEBPACK_IMPORTED_MODULE_2__.TokenType.RESERVED_KEYWORD,
|
2915 | value: token.value
|
2916 | };
|
2917 | }
|
2918 |
|
2919 | return token;
|
2920 | }
|
2921 | }]);
|
2922 |
|
2923 | return MySqlFormatter;
|
2924 | }(_core_Formatter__WEBPACK_IMPORTED_MODULE_0__["default"]);
|
2925 |
|
2926 |
|
2927 | MySqlFormatter.reservedCommands = reservedCommands;
|
2928 | MySqlFormatter.reservedBinaryCommands = reservedBinaryCommands;
|
2929 | MySqlFormatter.reservedDependentClauses = reservedDependentClauses;
|
2930 | MySqlFormatter.reservedJoinConditions = ['ON', 'USING'];
|
2931 | MySqlFormatter.reservedLogicalOperators = ['AND', 'OR', 'XOR'];
|
2932 | MySqlFormatter.reservedKeywords = (0,_utils__WEBPACK_IMPORTED_MODULE_3__.dedupe)([].concat(reservedKeywords, reservedFunctions));
|
2933 | MySqlFormatter.stringTypes = ['``', "''", '""'];
|
2934 | MySqlFormatter.blockStart = ['(', 'CASE'];
|
2935 | MySqlFormatter.blockEnd = [')', 'END'];
|
2936 | MySqlFormatter.indexedPlaceholderTypes = ['?'];
|
2937 | MySqlFormatter.namedPlaceholderTypes = [];
|
2938 | MySqlFormatter.lineCommentTypes = ['--', '#'];
|
2939 | MySqlFormatter.specialWordChars = {
|
2940 | prefix: '@:'
|
2941 | };
|
2942 | MySqlFormatter.operators = [':=', '<<', '>>', '<=>', '&&', '||', '->', '->>'];
|
2943 |
|
2944 | /***/ }),
|
2945 |
|
2946 | /***/ "./src/languages/n1ql.formatter.ts":
|
2947 | /*!*****************************************!*\
|
2948 | !*** ./src/languages/n1ql.formatter.ts ***!
|
2949 | \*****************************************/
|
2950 | /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
2951 |
|
2952 | __webpack_require__.r(__webpack_exports__);
|
2953 | /* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
2954 | /* harmony export */ "default": () => (/* binding */ N1qlFormatter)
|
2955 | /* harmony export */ });
|
2956 | /* harmony import */ var _core_Formatter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../core/Formatter */ "./src/core/Formatter.ts");
|
2957 | /* harmony import */ var _core_Tokenizer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../core/Tokenizer */ "./src/core/Tokenizer.ts");
|
2958 | /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils */ "./src/utils.ts");
|
2959 | function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
2960 |
|
2961 | function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
2962 |
|
2963 | function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
2964 |
|
2965 | function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
2966 |
|
2967 | function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
|
2968 |
|
2969 | function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
|
2970 |
|
2971 | function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
2972 |
|
2973 | function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
|
2974 |
|
2975 | function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
|
2976 |
|
2977 | function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
2978 |
|
2979 | function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
|
2980 |
|
2981 |
|
2982 |
|
2983 | // TODO: split this into object with function categories
|
2984 |
|
2985 | /**
|
2986 | * Priority 5 (last)
|
2987 | * Full list of reserved functions
|
2988 | * distinct from Keywords due to interaction with parentheses
|
2989 | */
|
2990 | // https://docs.couchbase.com/server/current/n1ql/n1ql-language-reference/functions.html
|
2991 |
|
2992 | var reservedFunctions = ['ABORT', 'ABS', 'ACOS', 'ADVISOR', 'ARRAY_AGG', 'ARRAY_AGG', 'ARRAY_APPEND', 'ARRAY_AVG', 'ARRAY_BINARY_SEARCH', 'ARRAY_CONCAT', 'ARRAY_CONTAINS', 'ARRAY_COUNT', 'ARRAY_DISTINCT', 'ARRAY_EXCEPT', 'ARRAY_FLATTEN', 'ARRAY_IFNULL', 'ARRAY_INSERT', 'ARRAY_INTERSECT', 'ARRAY_LENGTH', 'ARRAY_MAX', 'ARRAY_MIN', 'ARRAY_MOVE', 'ARRAY_POSITION', 'ARRAY_PREPEND', 'ARRAY_PUT', 'ARRAY_RANGE', 'ARRAY_REMOVE', 'ARRAY_REPEAT', 'ARRAY_REPLACE', 'ARRAY_REVERSE', 'ARRAY_SORT', 'ARRAY_STAR', 'ARRAY_SUM', 'ARRAY_SYMDIFF', 'ARRAY_SYMDIFF1', 'ARRAY_SYMDIFFN', 'ARRAY_UNION', 'ASIN', 'ATAN', 'ATAN2', 'AVG', 'BASE64', 'BASE64_DECODE', 'BASE64_ENCODE', 'BITAND ', 'BITCLEAR ', 'BITNOT ', 'BITOR ', 'BITSET ', 'BITSHIFT ', 'BITTEST ', 'BITXOR ', 'CEIL', 'CLOCK_LOCAL', 'CLOCK_MILLIS', 'CLOCK_STR', 'CLOCK_TZ', 'CLOCK_UTC', 'COALESCE', 'CONCAT', 'CONCAT2', 'CONTAINS', 'CONTAINS_TOKEN', 'CONTAINS_TOKEN_LIKE', 'CONTAINS_TOKEN_REGEXP', 'COS', 'COUNT', 'COUNT', 'COUNTN', 'CUME_DIST', 'CURL', 'DATE_ADD_MILLIS', 'DATE_ADD_STR', 'DATE_DIFF_MILLIS', 'DATE_DIFF_STR', 'DATE_FORMAT_STR', 'DATE_PART_MILLIS', 'DATE_PART_STR', 'DATE_RANGE_MILLIS', 'DATE_RANGE_STR', 'DATE_TRUNC_MILLIS', 'DATE_TRUNC_STR', 'DECODE', 'DECODE_JSON', 'DEGREES', 'DENSE_RANK', 'DURATION_TO_STR', // 'E',
|
2993 | 'ENCODED_SIZE', 'ENCODE_JSON', 'EXP', 'FIRST_VALUE', 'FLOOR', 'GREATEST', 'HAS_TOKEN', 'IFINF', 'IFMISSING', 'IFMISSINGORNULL', 'IFNAN', 'IFNANORINF', 'IFNULL', 'INITCAP', 'ISARRAY', 'ISATOM', 'ISBITSET', 'ISBOOLEAN', 'ISNUMBER', 'ISOBJECT', 'ISSTRING', 'LAG', 'LAST_VALUE', 'LEAD', 'LEAST', 'LENGTH', 'LN', 'LOG', 'LOWER', 'LTRIM', 'MAX', 'MEAN', 'MEDIAN', 'META', 'MILLIS', 'MILLIS_TO_LOCAL', 'MILLIS_TO_STR', 'MILLIS_TO_TZ', 'MILLIS_TO_UTC', 'MILLIS_TO_ZONE_NAME', 'MIN', 'MISSINGIF', 'NANIF', 'NEGINFIF', 'NOW_LOCAL', 'NOW_MILLIS', 'NOW_STR', 'NOW_TZ', 'NOW_UTC', 'NTH_VALUE', 'NTILE', 'NULLIF', 'NVL', 'NVL2', 'OBJECT_ADD', 'OBJECT_CONCAT', 'OBJECT_INNER_PAIRS', 'OBJECT_INNER_VALUES', 'OBJECT_LENGTH', 'OBJECT_NAMES', 'OBJECT_PAIRS', 'OBJECT_PUT', 'OBJECT_REMOVE', 'OBJECT_RENAME', 'OBJECT_REPLACE', 'OBJECT_UNWRAP', 'OBJECT_VALUES', 'PAIRS', 'PERCENT_RANK', 'PI', 'POLY_LENGTH', 'POSINFIF', 'POSITION', 'POWER', 'RADIANS', 'RANDOM', 'RANK', 'RATIO_TO_REPORT', 'REGEXP_CONTAINS', 'REGEXP_LIKE', 'REGEXP_MATCHES', 'REGEXP_POSITION', 'REGEXP_REPLACE', 'REGEXP_SPLIT', 'REGEX_CONTAINS', 'REGEX_LIKE', 'REGEX_MATCHES', 'REGEX_POSITION', 'REGEX_REPLACE', 'REGEX_SPLIT', 'REPEAT', 'REPLACE', 'REVERSE', 'ROUND', 'ROW_NUMBER', 'RTRIM', 'SEARCH', 'SEARCH_META', 'SEARCH_SCORE', 'SIGN', 'SIN', 'SPLIT', 'SQRT', 'STDDEV', 'STDDEV_POP', 'STDDEV_SAMP', 'STR_TO_DURATION', 'STR_TO_MILLIS', 'STR_TO_TZ', 'STR_TO_UTC', 'STR_TO_ZONE_NAME', 'SUBSTR', 'SUFFIXES', 'SUM', 'TAN', 'TITLE', 'TOARRAY', 'TOATOM', 'TOBOOLEAN', 'TOKENS', 'TOKENS', 'TONUMBER', 'TOOBJECT', 'TOSTRING', 'TRIM', 'TRUNC', // 'TYPE', // disabled
|
2994 | 'UPPER', 'UUID', 'VARIANCE', 'VARIANCE_POP', 'VARIANCE_SAMP', 'VAR_POP', 'VAR_SAMP', 'WEEKDAY_MILLIS', 'WEEKDAY_STR'];
|
2995 | /**
|
2996 | * Priority 5 (last)
|
2997 | * Full list of reserved words
|
2998 | * any words that are in a higher priority are removed
|
2999 | */
|
3000 | // https://docs.couchbase.com/server/current/n1ql/n1ql-language-reference/reservedwords.html
|
3001 |
|
3002 | var reservedKeywords = ['ALL', 'ALTER', 'ANALYZE', 'ANY', 'ARRAY', 'AS', 'ASC', 'AT', 'BEGIN', 'BETWEEN', 'BINARY', 'BOOLEAN', 'BREAK', 'BUCKET', 'BUILD', 'BY', 'CALL', 'CAST', 'CHAR', 'CLUSTER', 'COLLATE', 'COLLECTION', 'COMMIT', 'COMMITTED', 'CONNECT', 'CONTINUE', 'CORRELATE', 'CORRELATED', 'COVER', 'CREATE', 'CURRENT', 'DATABASE', 'DATASET', 'DATASTORE', 'DECLARE', 'DECREMENT', 'DERIVED', 'DESC', 'DESCRIBE', 'DISTINCT', 'DO', 'DROP', 'EACH', 'ELEMENT', 'EVERY', 'EXCLUDE', 'EXISTS', 'FALSE', 'FETCH', 'FILTER', 'FIRST', 'FLATTEN', 'FLUSH', 'FOLLOWING', 'FOR', 'FORCE', 'FTS', 'FUNCTION', 'GOLANG', 'GROUP', 'GROUPS', 'GSI', 'HASH', 'IF', 'IGNORE', 'ILIKE', 'IN', 'INCLUDE', 'INCREMENT', 'INDEX', 'INLINE', 'INNER', 'INTO', 'IS', 'ISOLATION', 'JAVASCRIPT', 'KEY', 'KEYS', 'KEYSPACE', 'KNOWN', 'LANGUAGE', 'LAST', 'LEFT', 'LETTING', 'LEVEL', 'LIKE', 'LSM', 'MAP', 'MAPPING', 'MATCHED', 'MATERIALIZED', 'MISSING', 'NAMESPACE', 'NL', 'NO', 'NOT', 'NULL', 'NULLS', 'NUMBER', 'OBJECT', 'OFFSET', 'OPTION', 'OPTIONS', 'ORDER', 'OTHERS', 'OUTER', 'OVER', 'PARSE', 'PARTITION', 'PASSWORD', 'PATH', 'POOL', 'PRECEDING', 'PRIMARY', 'PRIVATE', 'PRIVILEGE', 'PROBE', 'PROCEDURE', 'PUBLIC', 'RANGE', 'RAW', 'REALM', 'REDUCE', 'RENAME', 'RESPECT', 'RETURN', 'RIGHT', 'ROLE', 'ROLLBACK', 'ROW', 'ROWS', 'SATISFIES', 'SCHEMA', 'SCOPE', 'SELF', 'SEMI', 'SOME', 'START', 'STATISTICS', 'STRING', 'SYSTEM', 'THEN', 'TIES', 'TO', 'TRAN', 'TRANSACTION', 'TRIGGER', 'TRUE', 'TRUNCATE', 'UNBOUNDED', 'UNDER', 'UNIQUE', 'UNKNOWN', 'UNSET', 'USE', 'USER', 'VALIDATE', 'VALUE', 'VALUED', 'VIA', 'VIEW', 'WHILE', 'WINDOW', 'WITHIN', 'WORK'];
|
3003 | /**
|
3004 | * Priority 1 (first)
|
3005 | * keywords that begin a new statement
|
3006 | * will begin new indented block
|
3007 | */
|
3008 | // https://docs.couchbase.com/server/current/n1ql/n1ql-language-reference/reservedwords.html
|
3009 |
|
3010 | var reservedCommands = ['ADVISE', 'ALTER INDEX', 'BEGIN TRANSACTION', 'BUILD INDEX', 'COMMIT TRANSACTION', 'CREATE COLLECTION', 'CREATE FUNCTION', 'CREATE INDEX', 'CREATE PRIMARY INDEX', 'CREATE SCOPE', 'CREATE TABLE', 'DELETE', 'DROP COLLECTION', 'DROP FUNCTION', 'DROP INDEX', 'DROP PRIMARY INDEX', 'DROP SCOPE', 'EXECUTE', 'EXECUTE FUNCTION', 'EXPLAIN', 'GRANT', 'INFER', 'INSERT', 'MERGE', 'PREPARE', 'RETURNING', 'REVOKE', 'ROLLBACK TRANSACTION', 'SAVEPOINT', 'SELECT', 'SET TRANSACTION', 'UPDATE', 'UPDATE STATISTICS', 'UPSERT', // other
|
3011 | 'DROP TABLE', 'FROM', 'GROUP BY', 'HAVING', 'INSERT INTO', 'LET', 'LIMIT', 'OFFSET', 'NEST', 'ORDER BY', 'SET CURRENT SCHEMA', 'SET SCHEMA', 'SET', 'SHOW', 'UNNEST', 'USE KEYS', 'VALUES', 'WHERE', 'WITH'];
|
3012 | /**
|
3013 | * Priority 2
|
3014 | * commands that operate on two tables or subqueries
|
3015 | * two main categories: joins and boolean set operators
|
3016 | */
|
3017 |
|
3018 | var reservedBinaryCommands = [// set booleans
|
3019 | 'INTERSECT', 'INTERSECT ALL', 'INTERSECT DISTINCT', 'UNION', 'UNION ALL', 'UNION DISTINCT', 'EXCEPT', 'EXCEPT ALL', 'EXCEPT DISTINCT', 'MINUS', 'MINUS ALL', 'MINUS DISTINCT', // joins
|
3020 | 'JOIN', 'INNER JOIN', 'LEFT JOIN', 'LEFT OUTER JOIN', 'RIGHT JOIN', 'RIGHT OUTER JOIN'];
|
3021 | /**
|
3022 | * Priority 3
|
3023 | * keywords that follow a previous Statement, must be attached to subsequent data
|
3024 | * can be fully inline or on newline with optional indent
|
3025 | */
|
3026 |
|
3027 | var reservedDependentClauses = ['WHEN', 'ELSE']; // For reference: http://docs.couchbase.com.s3-website-us-west-1.amazonaws.com/server/6.0/n1ql/n1ql-language-reference/index.html
|
3028 |
|
3029 | var N1qlFormatter = /*#__PURE__*/function (_Formatter) {
|
3030 | _inherits(N1qlFormatter, _Formatter);
|
3031 |
|
3032 | var _super = _createSuper(N1qlFormatter);
|
3033 |
|
3034 | function N1qlFormatter() {
|
3035 | _classCallCheck(this, N1qlFormatter);
|
3036 |
|
3037 | return _super.apply(this, arguments);
|
3038 | }
|
3039 |
|
3040 | _createClass(N1qlFormatter, [{
|
3041 | key: "tokenizer",
|
3042 | value: function tokenizer() {
|
3043 | return new _core_Tokenizer__WEBPACK_IMPORTED_MODULE_1__["default"]({
|
3044 | reservedCommands: N1qlFormatter.reservedCommands,
|
3045 | reservedBinaryCommands: N1qlFormatter.reservedBinaryCommands,
|
3046 | reservedDependentClauses: N1qlFormatter.reservedDependentClauses,
|
3047 | reservedJoinConditions: N1qlFormatter.reservedJoinConditions,
|
3048 | reservedLogicalOperators: N1qlFormatter.reservedLogicalOperators,
|
3049 | reservedKeywords: N1qlFormatter.reservedKeywords,
|
3050 | stringTypes: N1qlFormatter.stringTypes,
|
3051 | blockStart: N1qlFormatter.blockStart,
|
3052 | blockEnd: N1qlFormatter.blockEnd,
|
3053 | namedPlaceholderTypes: N1qlFormatter.namedPlaceholderTypes,
|
3054 | lineCommentTypes: N1qlFormatter.lineCommentTypes,
|
3055 | operators: N1qlFormatter.operators
|
3056 | });
|
3057 | }
|
3058 | }]);
|
3059 |
|
3060 | return N1qlFormatter;
|
3061 | }(_core_Formatter__WEBPACK_IMPORTED_MODULE_0__["default"]);
|
3062 |
|
3063 |
|
3064 | N1qlFormatter.reservedCommands = reservedCommands;
|
3065 | N1qlFormatter.reservedBinaryCommands = reservedBinaryCommands;
|
3066 | N1qlFormatter.reservedDependentClauses = reservedDependentClauses;
|
3067 | N1qlFormatter.reservedJoinConditions = ['ON', 'USING'];
|
3068 | N1qlFormatter.reservedLogicalOperators = ['AND', 'OR', 'XOR'];
|
3069 | N1qlFormatter.reservedKeywords = (0,_utils__WEBPACK_IMPORTED_MODULE_2__.dedupe)([].concat(reservedKeywords, reservedFunctions));
|
3070 | N1qlFormatter.stringTypes = ["\"\"", "''", '``'];
|
3071 | N1qlFormatter.blockStart = ['(', '[', '{', 'CASE'];
|
3072 | N1qlFormatter.blockEnd = [')', ']', '}', 'END'];
|
3073 | N1qlFormatter.namedPlaceholderTypes = ['$'];
|
3074 | N1qlFormatter.lineCommentTypes = ['#', '--'];
|
3075 | N1qlFormatter.operators = ['=='];
|
3076 |
|
3077 | /***/ }),
|
3078 |
|
3079 | /***/ "./src/languages/plsql.formatter.ts":
|
3080 | /*!******************************************!*\
|
3081 | !*** ./src/languages/plsql.formatter.ts ***!
|
3082 | \******************************************/
|
3083 | /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
3084 |
|
3085 | __webpack_require__.r(__webpack_exports__);
|
3086 | /* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
3087 | /* harmony export */ "default": () => (/* binding */ PlSqlFormatter)
|
3088 | /* harmony export */ });
|
3089 | /* harmony import */ var _core_Formatter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../core/Formatter */ "./src/core/Formatter.ts");
|
3090 | /* harmony import */ var _core_Tokenizer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../core/Tokenizer */ "./src/core/Tokenizer.ts");
|
3091 | /* harmony import */ var _core_token__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../core/token */ "./src/core/token.ts");
|
3092 | /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../utils */ "./src/utils.ts");
|
3093 | function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
3094 |
|
3095 | function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
3096 |
|
3097 | function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
3098 |
|
3099 | function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
3100 |
|
3101 | function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
|
3102 |
|
3103 | function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
|
3104 |
|
3105 | function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
3106 |
|
3107 | function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
|
3108 |
|
3109 | function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
|
3110 |
|
3111 | function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
3112 |
|
3113 | function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
|
3114 |
|
3115 |
|
3116 |
|
3117 | // convert to partial type import in TS 4.5
|
3118 |
|
3119 |
|
3120 | /**
|
3121 | * Priority 5 (last)
|
3122 | * Full list of reserved words
|
3123 | * any words that are in a higher priority are removed
|
3124 | */
|
3125 |
|
3126 | var reservedKeywords = [// 'A',
|
3127 | 'ACCESSIBLE', 'AGENT', 'AGGREGATE', 'ALL', 'ALTER', 'ANY', 'ARRAY', 'AS', 'ASC', 'AT', 'ATTRIBUTE', 'AUTHID', 'AVG', 'BETWEEN', 'BFILE_BASE', 'BINARY', 'BINARY_INTEGER', 'BLOB_BASE', 'BLOCK', 'BODY', 'BOOLEAN', 'BOTH', 'BOUND', 'BREADTH', 'BULK', 'BY', 'BYTE', // 'C',
|
3128 | 'CALL', 'CALLING', 'CASCADE', 'CAST', 'CHAR', 'CHARACTER', 'CHARSET', 'CHARSETFORM', 'CHARSETID', 'CHAR_BASE', 'CHECK', 'CLOB_BASE', 'CLONE', 'CLOSE', 'CLUSTER', 'CLUSTERS', 'COALESCE', 'COLAUTH', 'COLLECT', 'COLUMNS', 'COMMENT', 'COMMIT', 'COMMITTED', 'COMPILED', 'COMPRESS', 'CONNECT', 'CONSTANT', 'CONSTRUCTOR', 'CONTEXT', 'CONTINUE', 'CONVERT', 'COUNT', 'CRASH', 'CREATE', 'CREDENTIAL', 'CURRENT', 'CURRVAL', 'CURSOR', 'CUSTOMDATUM', 'DANGLING', 'DATA', 'DATE', 'DATE_BASE', 'DAY', 'DECIMAL', 'DEFAULT', 'DEFINE', 'DEPTH', 'DESC', 'DETERMINISTIC', 'DIRECTORY', 'DISTINCT', 'DO', 'DOUBLE', 'DROP', 'DURATION', 'ELEMENT', 'ELSIF', 'EMPTY', 'ESCAPE', 'EXCEPTIONS', 'EXCLUSIVE', 'EXECUTE', 'EXISTS', 'EXIT', 'EXTENDS', 'EXTERNAL', 'EXTRACT', 'FALSE', 'FETCH', 'FINAL', 'FIRST', 'FIXED', 'FLOAT', 'FOR', 'FORALL', 'FORCE', 'FUNCTION', 'GENERAL', 'GOTO', 'GRANT', 'GROUP', 'HASH', 'HEAP', 'HIDDEN', 'HOUR', 'IDENTIFIED', 'IF', 'IMMEDIATE', 'IN', 'INCLUDING', 'INDEX', 'INDEXES', 'INDICATOR', 'INDICES', 'INFINITE', 'INSTANTIABLE', 'INT', 'INTEGER', 'INTERFACE', 'INTERVAL', 'INTO', 'INVALIDATE', 'IS', 'ISOLATION', 'JAVA', 'LANGUAGE', 'LARGE', 'LEADING', 'LENGTH', 'LEVEL', 'LIBRARY', 'LIKE', 'LIKE2', 'LIKE4', 'LIKEC', 'LIMITED', 'LOCAL', 'LOCK', 'LONG', 'MAP', 'MAX', 'MAXLEN', 'MEMBER', 'MERGE', 'MIN', 'MINUTE', 'MLSLABEL', 'MOD', 'MODE', 'MONTH', 'MULTISET', 'NAME', 'NAN', 'NATIONAL', 'NATIVE', 'NATURAL', 'NATURALN', 'NCHAR', 'NEW', 'NEXTVAL', 'NOCOMPRESS', 'NOCOPY', 'NOT', 'NOWAIT', 'NULL', 'NULLIF', 'NUMBER', 'NUMBER_BASE', 'OBJECT', 'OCICOLL', 'OCIDATE', 'OCIDATETIME', 'OCIDURATION', 'OCIINTERVAL', 'OCILOBLOCATOR', 'OCINUMBER', 'OCIRAW', 'OCIREF', 'OCIREFCURSOR', 'OCIROWID', 'OCISTRING', 'OCITYPE', 'OF', 'OLD', 'ON DELETE', 'ON UPDATE', 'ONLY', 'OPAQUE', 'OPEN', 'OPERATOR', 'OPTION', 'ORACLE', 'ORADATA', 'ORDER', 'ORGANIZATION', 'ORLANY', 'ORLVARY', 'OTHERS', 'OUT', 'OVERLAPS', 'OVERRIDING', 'PACKAGE', 'PARALLEL_ENABLE', 'PARAMETER', 'PARAMETERS', 'PARENT', 'PARTITION', 'PASCAL', 'PCTFREE', 'PIPE', 'PIPELINED', 'PLS_INTEGER', 'PLUGGABLE', 'POSITIVE', 'POSITIVEN', 'PRAGMA', 'PRECISION', 'PRIOR', 'PRIVATE', 'PROCEDURE', 'PUBLIC', 'RAISE', 'RANGE', 'RAW', 'READ', 'REAL', 'RECORD', 'REF', 'REFERENCE', 'RELEASE', 'RELIES_ON', 'REM', 'REMAINDER', 'RENAME', 'RESOURCE', 'RESULT', 'RESULT_CACHE', 'RETURN', 'REVERSE', 'REVOKE', 'ROLLBACK', 'ROW', 'ROWID', 'ROWNUM', 'ROWTYPE', 'SAMPLE', 'SAVE', 'SAVEPOINT', 'SB1', 'SB2', 'SB4', 'SEARCH', 'SECOND', 'SEGMENT', 'SELF', 'SEPARATE', 'SEQUENCE', 'SERIALIZABLE', 'SHARE', 'SHORT', 'SIZE', 'SIZE_T', 'SMALLINT', 'SOME', 'SPACE', 'SPARSE', 'SQL', 'SQLCODE', 'SQLDATA', 'SQLERRM', 'SQLNAME', 'SQLSTATE', 'STANDARD', 'START', 'STATIC', 'STDDEV', 'STORED', 'STRING', 'STRUCT', 'STYLE', 'SUBMULTISET', 'SUBPARTITION', 'SUBSTITUTABLE', 'SUBTYPE', 'SUCCESSFUL', 'SUM', 'SYNONYM', 'SYSDATE', 'TABAUTH', 'TABLE', 'TDO', 'THE', 'THEN', 'TIME', 'TIMESTAMP', 'TIMEZONE_ABBR', 'TIMEZONE_HOUR', 'TIMEZONE_MINUTE', 'TIMEZONE_REGION', 'TO', 'TRAILING', 'TRANSACTION', 'TRANSACTIONAL', 'TRIGGER', 'TRUE', 'TRUSTED', 'TYPE', 'UB1', 'UB2', 'UB4', 'UID', 'UNDER', 'UNIQUE', 'UNPLUG', 'UNSIGNED', 'UNTRUSTED', 'USE', 'USER', 'VALIDATE', 'VALIST', 'VALUE', 'VARCHAR', 'VARCHAR2', 'VARIABLE', 'VARIANCE', 'VARRAY', 'VARYING', 'VIEW', 'VIEWS', 'VOID', 'WHENEVER', 'WHILE', 'WORK', 'WRAPPED', 'WRITE', 'YEAR', 'ZONE'];
|
3129 | /**
|
3130 | * Priority 1 (first)
|
3131 | * keywords that begin a new statement
|
3132 | * will begin new indented block
|
3133 | */
|
3134 |
|
3135 | var reservedCommands = ['ADD', 'ALTER COLUMN', 'ALTER TABLE', 'BEGIN', 'CONNECT BY', 'CREATE TABLE', 'DROP TABLE', 'DECLARE', // 'DELETE FROM', // disabled
|
3136 | 'DELETE', 'END', 'EXCEPT', 'EXCEPTION', 'FETCH FIRST', 'FROM', 'GROUP BY', 'HAVING', 'INSERT INTO', 'INSERT', 'LIMIT', 'OFFSET', 'LOOP', 'MODIFY', 'ORDER BY', 'RETURNING', 'SELECT', 'SET CURRENT SCHEMA', 'SET SCHEMA', 'SET', 'START WITH', 'UPDATE', 'VALUES', 'WHERE', 'WITH'];
|
3137 | /**
|
3138 | * Priority 2
|
3139 | * commands that operate on two tables or subqueries
|
3140 | * two main categories: joins and boolean set operators
|
3141 | */
|
3142 |
|
3143 | var reservedBinaryCommands = [// set booleans
|
3144 | 'INTERSECT', 'INTERSECT ALL', 'INTERSECT DISTINCT', 'UNION', 'UNION ALL', 'UNION DISTINCT', 'EXCEPT', 'EXCEPT ALL', 'EXCEPT DISTINCT', 'MINUS', 'MINUS ALL', 'MINUS DISTINCT', // joins
|
3145 | 'JOIN', 'INNER JOIN', 'LEFT JOIN', 'LEFT OUTER JOIN', 'RIGHT JOIN', 'RIGHT OUTER JOIN', 'FULL JOIN', 'FULL OUTER JOIN', 'CROSS JOIN', 'NATURAL JOIN', // apply
|
3146 | 'CROSS APPLY', 'OUTER APPLY'];
|
3147 | /**
|
3148 | * Priority 3
|
3149 | * keywords that follow a previous Statement, must be attached to subsequent data
|
3150 | * can be fully inline or on newline with optional indent
|
3151 | */
|
3152 |
|
3153 | var reservedDependentClauses = ['WHEN', 'ELSE'];
|
3154 |
|
3155 | var PlSqlFormatter = /*#__PURE__*/function (_Formatter) {
|
3156 | _inherits(PlSqlFormatter, _Formatter);
|
3157 |
|
3158 | var _super = _createSuper(PlSqlFormatter);
|
3159 |
|
3160 | function PlSqlFormatter() {
|
3161 | _classCallCheck(this, PlSqlFormatter);
|
3162 |
|
3163 | return _super.apply(this, arguments);
|
3164 | }
|
3165 |
|
3166 | _createClass(PlSqlFormatter, [{
|
3167 | key: "tokenizer",
|
3168 | value: function tokenizer() {
|
3169 | return new _core_Tokenizer__WEBPACK_IMPORTED_MODULE_1__["default"]({
|
3170 | reservedCommands: PlSqlFormatter.reservedCommands,
|
3171 | reservedBinaryCommands: PlSqlFormatter.reservedBinaryCommands,
|
3172 | reservedDependentClauses: PlSqlFormatter.reservedDependentClauses,
|
3173 | reservedJoinConditions: PlSqlFormatter.reservedJoinConditions,
|
3174 | reservedLogicalOperators: PlSqlFormatter.reservedLogicalOperators,
|
3175 | reservedKeywords: PlSqlFormatter.reservedKeywords,
|
3176 | stringTypes: PlSqlFormatter.stringTypes,
|
3177 | blockStart: PlSqlFormatter.blockStart,
|
3178 | blockEnd: PlSqlFormatter.blockEnd,
|
3179 | indexedPlaceholderTypes: PlSqlFormatter.indexedPlaceholderTypes,
|
3180 | namedPlaceholderTypes: PlSqlFormatter.namedPlaceholderTypes,
|
3181 | lineCommentTypes: PlSqlFormatter.lineCommentTypes,
|
3182 | specialWordChars: PlSqlFormatter.specialWordChars,
|
3183 | operators: PlSqlFormatter.operators
|
3184 | });
|
3185 | }
|
3186 | }, {
|
3187 | key: "tokenOverride",
|
3188 | value: function tokenOverride(token) {
|
3189 | // `table`[.]`column`
|
3190 | if (token.value === '.' && this.tokenLookAhead().value.startsWith('`') && this.tokenLookBehind().value.endsWith('`')) {
|
3191 | // This is an operator, do not insert spaces
|
3192 | return {
|
3193 | type: _core_token__WEBPACK_IMPORTED_MODULE_2__.TokenType.OPERATOR,
|
3194 | value: token.value
|
3195 | };
|
3196 | } // BY [SET]
|
3197 |
|
3198 |
|
3199 | if (_core_token__WEBPACK_IMPORTED_MODULE_2__.isToken.SET(token) && _core_token__WEBPACK_IMPORTED_MODULE_2__.isToken.BY(this.getPreviousReservedToken())) {
|
3200 | return {
|
3201 | type: _core_token__WEBPACK_IMPORTED_MODULE_2__.TokenType.RESERVED_KEYWORD,
|
3202 | value: token.value
|
3203 | };
|
3204 | }
|
3205 |
|
3206 | return token;
|
3207 | }
|
3208 | }]);
|
3209 |
|
3210 | return PlSqlFormatter;
|
3211 | }(_core_Formatter__WEBPACK_IMPORTED_MODULE_0__["default"]);
|
3212 |
|
3213 |
|
3214 | PlSqlFormatter.reservedCommands = reservedCommands;
|
3215 | PlSqlFormatter.reservedBinaryCommands = reservedBinaryCommands;
|
3216 | PlSqlFormatter.reservedDependentClauses = reservedDependentClauses;
|
3217 | PlSqlFormatter.reservedJoinConditions = ['ON', 'USING'];
|
3218 | PlSqlFormatter.reservedLogicalOperators = ['AND', 'OR', 'XOR'];
|
3219 | PlSqlFormatter.reservedKeywords = (0,_utils__WEBPACK_IMPORTED_MODULE_3__.dedupe)(reservedKeywords);
|
3220 | PlSqlFormatter.stringTypes = ["\"\"", "N''", "''", '``'];
|
3221 | PlSqlFormatter.blockStart = ['(', 'CASE'];
|
3222 | PlSqlFormatter.blockEnd = [')', 'END'];
|
3223 | PlSqlFormatter.indexedPlaceholderTypes = ['?'];
|
3224 | PlSqlFormatter.namedPlaceholderTypes = [':'];
|
3225 | PlSqlFormatter.lineCommentTypes = ['--'];
|
3226 | PlSqlFormatter.specialWordChars = {
|
3227 | any: '_$#.@'
|
3228 | };
|
3229 | PlSqlFormatter.operators = ['||', '**', ':=', '~=', '^=', '>>', '<<', '=>' // '..' // breaks operator test, handled by .
|
3230 | ];
|
3231 |
|
3232 | /***/ }),
|
3233 |
|
3234 | /***/ "./src/languages/postgresql.formatter.ts":
|
3235 | /*!***********************************************!*\
|
3236 | !*** ./src/languages/postgresql.formatter.ts ***!
|
3237 | \***********************************************/
|
3238 | /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
3239 |
|
3240 | __webpack_require__.r(__webpack_exports__);
|
3241 | /* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
3242 | /* harmony export */ "default": () => (/* binding */ PostgreSqlFormatter)
|
3243 | /* harmony export */ });
|
3244 | /* harmony import */ var _core_Formatter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../core/Formatter */ "./src/core/Formatter.ts");
|
3245 | /* harmony import */ var _core_Tokenizer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../core/Tokenizer */ "./src/core/Tokenizer.ts");
|
3246 | /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils */ "./src/utils.ts");
|
3247 | function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
3248 |
|
3249 | function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
|
3250 |
|
3251 | function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
3252 |
|
3253 | function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
3254 |
|
3255 | function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
|
3256 |
|
3257 | function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
|
3258 |
|
3259 | function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
3260 |
|
3261 | function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
3262 |
|
3263 | function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
3264 |
|
3265 | function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
3266 |
|
3267 | function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
|
3268 |
|
3269 | function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
|
3270 |
|
3271 | function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
3272 |
|
3273 | function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
|
3274 |
|
3275 | function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
|
3276 |
|
3277 | function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
3278 |
|
3279 | function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
|
3280 |
|
3281 |
|
3282 |
|
3283 |
|
3284 | /**
|
3285 | * Priority 5 (last)
|
3286 | * Full list of reserved functions
|
3287 | * distinct from Keywords due to interaction with parentheses
|
3288 | */
|
3289 | // https://www.postgresql.org/docs/14/functions.html
|
3290 |
|
3291 | var reservedFunctions = {
|
3292 | // https://www.postgresql.org/docs/14/functions-math.html
|
3293 | math: ['ABS', 'ACOS', 'ACOSD', 'ACOSH', 'ASIN', 'ASIND', 'ASINH', 'ATAN', 'ATAN2', 'ATAN2D', 'ATAND', 'ATANH', 'CBRT', 'CEIL', 'CEILING', 'COS', 'COSD', 'COSH', 'COT', 'COTD', 'DEGREES', 'DIV', 'EXP', 'FACTORIAL', 'FLOOR', 'GCD', 'LCM', 'LN', 'LOG', 'LOG10', 'MIN_SCALE', 'MOD', 'PI', 'POWER', 'RADIANS', 'RANDOM', 'ROUND', 'SCALE', 'SETSEED', 'SIGN', 'SIN', 'SIND', 'SINH', 'SQRT', 'TAN', 'TAND', 'TANH', 'TRIM_SCALE', 'TRUNC', 'WIDTH_BUCKET'],
|
3294 | // https://www.postgresql.org/docs/14/functions-string.html
|
3295 | string: ['ABS', 'ASCII', 'BIT_LENGTH', 'BTRIM', 'CHARACTER_LENGTH', 'CHAR_LENGTH', 'CHR', 'CONCAT', 'CONCAT_WS', 'FORMAT', 'INITCAP', 'LEFT', 'LENGTH', 'LOWER', 'LPAD', 'LTRIM', 'MD5', 'NORMALIZE', 'OCTET_LENGTH', 'OVERLAY', 'PARSE_IDENT', 'PG_CLIENT_ENCODING', 'POSITION', 'QUOTE_IDENT', 'QUOTE_LITERAL', 'QUOTE_NULLABLE', 'REGEXP_MATCH', 'REGEXP_MATCHES', 'REGEXP_REPLACE', 'REGEXP_SPLIT_TO_ARRAY', 'REGEXP_SPLIT_TO_TABLE', 'REPEAT', 'REPLACE', 'REVERSE', 'RIGHT', 'RPAD', 'RTRIM', 'SPLIT_PART', 'SPRINTF', 'STARTS_WITH', 'STRING_AGG', 'STRING_TO_ARRAY', 'STRING_TO_TABLE', 'STRPOS', 'SUBSTR', 'SUBSTRING', 'TO_ASCII', 'TO_HEX', 'TRANSLATE', 'TRIM', 'UNISTR', 'UPPER'],
|
3296 | // https://www.postgresql.org/docs/14/functions-binarystring.html
|
3297 | binary: ['BIT_COUNT', 'BIT_LENGTH', 'BTRIM', 'CONVERT', 'CONVERT_FROM', 'CONVERT_TO', 'DECODE', 'ENCODE', 'GET_BIT', 'GET_BYTE', 'LENGTH', 'LTRIM', 'MD5', 'OCTET_LENGTH', 'OVERLAY', 'POSITION', 'RTRIM', 'SET_BIT', 'SET_BYTE', 'SHA224', 'SHA256', 'SHA384', 'SHA512', 'STRING_AGG', 'SUBSTR', 'SUBSTRING', 'TRIM'],
|
3298 | // https://www.postgresql.org/docs/14/functions-bitstring.html
|
3299 | bitstring: ['BIT_COUNT', 'BIT_LENGTH', 'GET_BIT', 'LENGTH', 'OCTET_LENGTH', 'OVERLAY', 'POSITION', 'SET_BIT', 'SUBSTRING'],
|
3300 | // https://www.postgresql.org/docs/14/functions-matching.html
|
3301 | pattern: ['REGEXP_MATCH', 'REGEXP_MATCHES', 'REGEXP_REPLACE', 'REGEXP_SPLIT_TO_ARRAY', 'REGEXP_SPLIT_TO_TABLE'],
|
3302 | // https://www.postgresql.org/docs/14/functions-formatting.html
|
3303 | datatype: ['TO_CHAR', 'TO_DATE', 'TO_NUMBER', 'TO_TIMESTAMP'],
|
3304 | // https://www.postgresql.org/docs/14/functions-datetime.html
|
3305 | datetime: [// 'AGE',
|
3306 | 'CLOCK_TIMESTAMP', 'CURRENT_DATE', 'CURRENT_TIME', 'CURRENT_TIMESTAMP', 'DATE_BIN', 'DATE_PART', 'DATE_TRUNC', 'EXTRACT', 'ISFINITE', 'JUSTIFY_DAYS', 'JUSTIFY_HOURS', 'JUSTIFY_INTERVAL', 'LOCALTIME', 'LOCALTIMESTAMP', 'MAKE_DATE', 'MAKE_INTERVAL', 'MAKE_TIME', 'MAKE_TIMESTAMP', 'MAKE_TIMESTAMPTZ', 'NOW', 'PG_SLEEP', 'PG_SLEEP_FOR', 'PG_SLEEP_UNTIL', 'STATEMENT_TIMESTAMP', 'TIMEOFDAY', 'TO_TIMESTAMP', 'TRANSACTION_TIMESTAMP'],
|
3307 | // https://www.postgresql.org/docs/14/functions-enum.html
|
3308 | "enum": ['ENUM_FIRST', 'ENUM_LAST', 'ENUM_RANGE'],
|
3309 | // https://www.postgresql.org/docs/14/functions-geometry.html
|
3310 | geometry: ['AREA', 'BOUND_BOX', 'BOX', 'CENTER', 'CIRCLE', 'DIAGONAL', 'DIAMETER', 'HEIGHT', 'ISCLOSED', 'ISOPEN', 'LENGTH', 'LINE', 'LSEG', 'NPOINTS', 'PATH', 'PCLOSE', 'POINT', 'POLYGON', 'POPEN', 'RADIUS', 'SLOPE', 'WIDTH'],
|
3311 | // https://www.postgresql.org/docs/14/functions-net.html
|
3312 | network: ['ABBREV', 'BROADCAST', 'FAMILY', 'HOST', 'HOSTMASK', 'INET_MERGE', 'INET_SAME_FAMILY', 'MACADDR8_SET7BIT', 'MASKLEN', 'NETMASK', 'NETWORK', 'SET_MASKLEN', 'TEXT', 'TRUNC'],
|
3313 | // https://www.postgresql.org/docs/14/functions-textsearch.html
|
3314 | textsearch: ['ARRAY_TO_TSVECTOR', 'GET_CURRENT_TS_CONFIG', 'JSONB_TO_TSVECTOR', 'JSON_TO_TSVECTOR', 'LENGTH', 'NUMNODE', 'PHRASETO_TSQUERY', 'PLAINTO_TSQUERY', 'QUERYTREE', 'SETWEIGHT', 'STRIP', 'TO_TSQUERY', 'TO_TSVECTOR', 'TSQUERY_PHRASE', 'TSVECTOR_TO_ARRAY', 'TS_DEBUG', 'TS_DELETE', 'TS_FILTER', 'TS_HEADLINE', 'TS_LEXIZE', 'TS_PARSE', 'TS_RANK', 'TS_RANK_CD', 'TS_REWRITE', 'TS_STAT', 'TS_TOKEN_TYPE', 'WEBSEARCH_TO_TSQUERY'],
|
3315 | // https://www.postgresql.org/docs/14/functions-uuid.html
|
3316 | uuid: ['UUID'],
|
3317 | // https://www.postgresql.org/docs/14/functions-xml.html
|
3318 | xml: ['CURSOR_TO_XML', 'CURSOR_TO_XMLSCHEMA', 'DATABASE_TO_XML', 'DATABASE_TO_XMLSCHEMA', 'DATABASE_TO_XML_AND_XMLSCHEMA', 'NEXTVAL', 'QUERY_TO_XML', 'QUERY_TO_XMLSCHEMA', 'QUERY_TO_XML_AND_XMLSCHEMA', 'SCHEMA_TO_XML', 'SCHEMA_TO_XMLSCHEMA', 'SCHEMA_TO_XML_AND_XMLSCHEMA', 'STRING', 'TABLE_TO_XML', 'TABLE_TO_XMLSCHEMA', 'TABLE_TO_XML_AND_XMLSCHEMA', 'XMLAGG', 'XMLCOMMENT', 'XMLCONCAT', 'XMLELEMENT', 'XMLEXISTS', 'XMLFOREST', 'XMLPARSE', 'XMLPI', 'XMLROOT', 'XMLSERIALIZE', 'XMLTABLE', 'XML_IS_WELL_FORMED', 'XML_IS_WELL_FORMED_CONTENT', 'XML_IS_WELL_FORMED_DOCUMENT', 'XPATH', 'XPATH_EXISTS'],
|
3319 | // https://www.postgresql.org/docs/14/functions-json.html
|
3320 | json: ['ARRAY_TO_JSON', 'JSONB_AGG', 'JSONB_ARRAY_ELEMENTS', 'JSONB_ARRAY_ELEMENTS_TEXT', 'JSONB_ARRAY_LENGTH', 'JSONB_BUILD_ARRAY', 'JSONB_BUILD_OBJECT', 'JSONB_EACH', 'JSONB_EACH_TEXT', 'JSONB_EXTRACT_PATH', 'JSONB_EXTRACT_PATH_TEXT', 'JSONB_INSERT', 'JSONB_OBJECT', 'JSONB_OBJECT_AGG', 'JSONB_OBJECT_KEYS', 'JSONB_PATH_EXISTS', 'JSONB_PATH_EXISTS_TZ', 'JSONB_PATH_MATCH', 'JSONB_PATH_MATCH_TZ', 'JSONB_PATH_QUERY', 'JSONB_PATH_QUERY_ARRAY', 'JSONB_PATH_QUERY_ARRAY_TZ', 'JSONB_PATH_QUERY_FIRST', 'JSONB_PATH_QUERY_FIRST_TZ', 'JSONB_PATH_QUERY_TZ', 'JSONB_POPULATE_RECORD', 'JSONB_POPULATE_RECORDSET', 'JSONB_PRETTY', 'JSONB_SET', 'JSONB_SET_LAX', 'JSONB_STRIP_NULLS', 'JSONB_TO_RECORD', 'JSONB_TO_RECORDSET', 'JSONB_TYPEOF', 'JSON_AGG', 'JSON_ARRAY_ELEMENTS', 'JSON_ARRAY_ELEMENTS_TEXT', 'JSON_ARRAY_LENGTH', 'JSON_BUILD_ARRAY', 'JSON_BUILD_OBJECT', 'JSON_EACH', 'JSON_EACH_TEXT', 'JSON_EXTRACT_PATH', 'JSON_EXTRACT_PATH_TEXT', 'JSON_OBJECT', 'JSON_OBJECT_AGG', 'JSON_OBJECT_KEYS', 'JSON_POPULATE_RECORD', 'JSON_POPULATE_RECORDSET', 'JSON_STRIP_NULLS', 'JSON_TO_RECORD', 'JSON_TO_RECORDSET', 'JSON_TYPEOF', 'ROW_TO_JSON', 'TO_JSON', 'TO_JSONB', 'TO_TIMESTAMP'],
|
3321 | // https://www.postgresql.org/docs/14/functions-sequence.html
|
3322 | sequence: ['CURRVAL', 'LASTVAL', 'NEXTVAL', 'SETVAL'],
|
3323 | // https://www.postgresql.org/docs/14/functions-conditional.html
|
3324 | conditional: [// 'CASE',
|
3325 | 'COALESCE', 'GREATEST', 'LEAST', 'NULLIF'],
|
3326 | // https://www.postgresql.org/docs/14/functions-array.html
|
3327 | array: ['ARRAY_AGG', 'ARRAY_APPEND', 'ARRAY_CAT', 'ARRAY_DIMS', 'ARRAY_FILL', 'ARRAY_LENGTH', 'ARRAY_LOWER', 'ARRAY_NDIMS', 'ARRAY_POSITION', 'ARRAY_POSITIONS', 'ARRAY_PREPEND', 'ARRAY_REMOVE', 'ARRAY_REPLACE', 'ARRAY_TO_STRING', 'ARRAY_UPPER', 'CARDINALITY', 'STRING_TO_ARRAY', 'TRIM_ARRAY', 'UNNEST'],
|
3328 | // https://www.postgresql.org/docs/14/functions-range.html
|
3329 | range: ['ISEMPTY', 'LOWER', 'LOWER_INC', 'LOWER_INF', 'MULTIRANGE', 'RANGE_MERGE', 'UPPER', 'UPPER_INC', 'UPPER_INF'],
|
3330 | // https://www.postgresql.org/docs/14/functions-aggregate.html
|
3331 | aggregate: ['ANY', 'ARRAY_AGG', 'AVG', 'BIT_AND', 'BIT_OR', 'BIT_XOR', 'BOOL_AND', 'BOOL_OR', 'COALESCE', 'CORR', 'COUNT', 'COVAR_POP', 'COVAR_SAMP', 'CUME_DIST', 'DENSE_RANK', 'EVERY', 'GROUPING', 'JSONB_AGG', 'JSONB_OBJECT_AGG', 'JSON_AGG', 'JSON_OBJECT_AGG', 'MAX', 'MIN', 'MODE', 'PERCENTILE_CONT', 'PERCENTILE_DISC', 'PERCENT_RANK', 'RANGE_AGG', 'RANGE_INTERSECT_AGG', 'RANK', 'REGR_AVGX', 'REGR_AVGY', 'REGR_COUNT', 'REGR_INTERCEPT', 'REGR_R2', 'REGR_SLOPE', 'REGR_SXX', 'REGR_SXY', 'REGR_SYY', 'SOME', 'STDDEV', 'STDDEV_POP', 'STDDEV_SAMP', 'STRING_AGG', 'SUM', 'TO_JSON', 'TO_JSONB', 'VARIANCE', 'VAR_POP', 'VAR_SAMP', 'XMLAGG'],
|
3332 | // https://www.postgresql.org/docs/14/functions-window.html
|
3333 | window: ['CUME_DIST', 'DENSE_RANK', 'FIRST_VALUE', 'LAG', 'LAST_VALUE', 'LEAD', 'NTH_VALUE', 'NTILE', 'PERCENT_RANK', 'RANK', 'ROW_NUMBER'],
|
3334 | // https://www.postgresql.org/docs/14/functions-srf.html
|
3335 | set: ['GENERATE_SERIES', 'GENERATE_SUBSCRIPTS'],
|
3336 | // https://www.postgresql.org/docs/14/functions-info.html
|
3337 | sysInfo: ['ACLDEFAULT', 'ACLEXPLODE', 'COL_DESCRIPTION', 'CURRENT_CATALOG', 'CURRENT_DATABASE', 'CURRENT_QUERY', 'CURRENT_ROLE', 'CURRENT_SCHEMA', 'CURRENT_SCHEMAS', 'CURRENT_USER', 'FORMAT_TYPE', 'HAS_ANY_COLUMN_PRIVILEGE', 'HAS_COLUMN_PRIVILEGE', 'HAS_DATABASE_PRIVILEGE', 'HAS_FOREIGN_DATA_WRAPPER_PRIVILEGE', 'HAS_FUNCTION_PRIVILEGE', 'HAS_LANGUAGE_PRIVILEGE', 'HAS_SCHEMA_PRIVILEGE', 'HAS_SEQUENCE_PRIVILEGE', 'HAS_SERVER_PRIVILEGE', 'HAS_TABLESPACE_PRIVILEGE', 'HAS_TABLE_PRIVILEGE', 'HAS_TYPE_PRIVILEGE', 'INET_CLIENT_ADDR', 'INET_CLIENT_PORT', 'INET_SERVER_ADDR', 'INET_SERVER_PORT', 'MAKEACLITEM', 'OBJ_DESCRIPTION', 'PG_BACKEND_PID', 'PG_BLOCKING_PIDS', 'PG_COLLATION_IS_VISIBLE', 'PG_CONF_LOAD_TIME', 'PG_CONTROL_CHECKPOINT', 'PG_CONTROL_INIT', 'PG_CONTROL_SYSTEM', 'PG_CONVERSION_IS_VISIBLE', 'PG_CURRENT_LOGFILE', 'PG_CURRENT_SNAPSHOT', 'PG_CURRENT_XACT_ID', 'PG_CURRENT_XACT_ID_IF_ASSIGNED', 'PG_DESCRIBE_OBJECT', 'PG_FUNCTION_IS_VISIBLE', 'PG_GET_CATALOG_FOREIGN_KEYS', 'PG_GET_CONSTRAINTDEF', 'PG_GET_EXPR', 'PG_GET_FUNCTIONDEF', 'PG_GET_FUNCTION_ARGUMENTS', 'PG_GET_FUNCTION_IDENTITY_ARGUMENTS', 'PG_GET_FUNCTION_RESULT', 'PG_GET_INDEXDEF', 'PG_GET_KEYWORDS', 'PG_GET_OBJECT_ADDRESS', 'PG_GET_OWNED_SEQUENCE', 'PG_GET_RULEDEF', 'PG_GET_SERIAL_SEQUENCE', 'PG_GET_STATISTICSOBJDEF', 'PG_GET_TRIGGERDEF', 'PG_GET_USERBYID', 'PG_GET_VIEWDEF', 'PG_HAS_ROLE', 'PG_IDENTIFY_OBJECT', 'PG_IDENTIFY_OBJECT_AS_ADDRESS', 'PG_INDEXAM_HAS_PROPERTY', 'PG_INDEX_COLUMN_HAS_PROPERTY', 'PG_INDEX_HAS_PROPERTY', 'PG_IS_OTHER_TEMP_SCHEMA', 'PG_JIT_AVAILABLE', 'PG_LAST_COMMITTED_XACT', 'PG_LISTENING_CHANNELS', 'PG_MY_TEMP_SCHEMA', 'PG_NOTIFICATION_QUEUE_USAGE', 'PG_OPCLASS_IS_VISIBLE', 'PG_OPERATOR_IS_VISIBLE', 'PG_OPFAMILY_IS_VISIBLE', 'PG_OPTIONS_TO_TABLE', 'PG_POSTMASTER_START_TIME', 'PG_SAFE_SNAPSHOT_BLOCKING_PIDS', 'PG_SNAPSHOT_XIP', 'PG_SNAPSHOT_XMAX', 'PG_SNAPSHOT_XMIN', 'PG_STATISTICS_OBJ_IS_VISIBLE', 'PG_TABLESPACE_DATABASES', 'PG_TABLESPACE_LOCATION', 'PG_TABLE_IS_VISIBLE', 'PG_TRIGGER_DEPTH', 'PG_TS_CONFIG_IS_VISIBLE', 'PG_TS_DICT_IS_VISIBLE', 'PG_TS_PARSER_IS_VISIBLE', 'PG_TS_TEMPLATE_IS_VISIBLE', 'PG_TYPEOF', 'PG_TYPE_IS_VISIBLE', 'PG_VISIBLE_IN_SNAPSHOT', 'PG_XACT_COMMIT_TIMESTAMP', 'PG_XACT_COMMIT_TIMESTAMP_ORIGIN', 'PG_XACT_STATUS', 'PQSERVERVERSION', 'ROW_SECURITY_ACTIVE', 'SESSION_USER', 'SHOBJ_DESCRIPTION', 'TO_REGCLASS', 'TO_REGCOLLATION', 'TO_REGNAMESPACE', 'TO_REGOPER', 'TO_REGOPERATOR', 'TO_REGPROC', 'TO_REGPROCEDURE', 'TO_REGROLE', 'TO_REGTYPE', 'TXID_CURRENT', 'TXID_CURRENT_IF_ASSIGNED', 'TXID_CURRENT_SNAPSHOT', 'TXID_SNAPSHOT_XIP', 'TXID_SNAPSHOT_XMAX', 'TXID_SNAPSHOT_XMIN', 'TXID_STATUS', 'TXID_VISIBLE_IN_SNAPSHOT', 'USER', 'VERSION'],
|
3338 | // https://www.postgresql.org/docs/14/functions-admin.html
|
3339 | sysAdmin: ['BRIN_DESUMMARIZE_RANGE', 'BRIN_SUMMARIZE_NEW_VALUES', 'BRIN_SUMMARIZE_RANGE', 'CONVERT_FROM', 'CURRENT_SETTING', 'GIN_CLEAN_PENDING_LIST', 'PG_ADVISORY_LOCK', 'PG_ADVISORY_LOCK_SHARED', 'PG_ADVISORY_UNLOCK', 'PG_ADVISORY_UNLOCK_ALL', 'PG_ADVISORY_UNLOCK_SHARED', 'PG_ADVISORY_XACT_LOCK', 'PG_ADVISORY_XACT_LOCK_SHARED', 'PG_BACKUP_START_TIME', 'PG_CANCEL_BACKEND', 'PG_COLLATION_ACTUAL_VERSION', 'PG_COLUMN_COMPRESSION', 'PG_COLUMN_SIZE', 'PG_COPY_LOGICAL_REPLICATION_SLOT', 'PG_COPY_PHYSICAL_REPLICATION_SLOT', 'PG_CREATE_LOGICAL_REPLICATION_SLOT', 'PG_CREATE_PHYSICAL_REPLICATION_SLOT', 'PG_CREATE_RESTORE_POINT', 'PG_CURRENT_WAL_FLUSH_LSN', 'PG_CURRENT_WAL_INSERT_LSN', 'PG_CURRENT_WAL_LSN', 'PG_DATABASE_SIZE', 'PG_DROP_REPLICATION_SLOT', 'PG_EXPORT_SNAPSHOT', 'PG_FILENODE_RELATION', 'PG_GET_WAL_REPLAY_PAUSE_STATE', 'PG_IMPORT_SYSTEM_COLLATIONS', 'PG_INDEXES_SIZE', 'PG_IS_IN_BACKUP', 'PG_IS_IN_RECOVERY', 'PG_IS_WAL_REPLAY_PAUSED', 'PG_LAST_WAL_RECEIVE_LSN', 'PG_LAST_WAL_REPLAY_LSN', 'PG_LAST_XACT_REPLAY_TIMESTAMP', 'PG_LOGICAL_EMIT_MESSAGE', 'PG_LOGICAL_SLOT_GET_BINARY_CHANGES', 'PG_LOGICAL_SLOT_GET_CHANGES', 'PG_LOGICAL_SLOT_PEEK_BINARY_CHANGES', 'PG_LOGICAL_SLOT_PEEK_CHANGES', 'PG_LOG_BACKEND_MEMORY_CONTEXTS', 'PG_LS_ARCHIVE_STATUSDIR', 'PG_LS_DIR', 'PG_LS_LOGDIR', 'PG_LS_TMPDIR', 'PG_LS_WALDIR', 'PG_PARTITION_ANCESTORS', 'PG_PARTITION_ROOT', 'PG_PARTITION_TREE', 'PG_PROMOTE', 'PG_READ_BINARY_FILE', 'PG_READ_FILE', 'PG_RELATION_FILENODE', 'PG_RELATION_FILEPATH', 'PG_RELATION_SIZE', 'PG_RELOAD_CONF', 'PG_REPLICATION_ORIGIN_ADVANCE', 'PG_REPLICATION_ORIGIN_CREATE', 'PG_REPLICATION_ORIGIN_DROP', 'PG_REPLICATION_ORIGIN_OID', 'PG_REPLICATION_ORIGIN_PROGRESS', 'PG_REPLICATION_ORIGIN_SESSION_IS_SETUP', 'PG_REPLICATION_ORIGIN_SESSION_PROGRESS', 'PG_REPLICATION_ORIGIN_SESSION_RESET', 'PG_REPLICATION_ORIGIN_SESSION_SETUP', 'PG_REPLICATION_ORIGIN_XACT_RESET', 'PG_REPLICATION_ORIGIN_XACT_SETUP', 'PG_REPLICATION_SLOT_ADVANCE', 'PG_ROTATE_LOGFILE', 'PG_SIZE_BYTES', 'PG_SIZE_PRETTY', 'PG_START_BACKUP', 'PG_STAT_FILE', 'PG_STOP_BACKUP', 'PG_SWITCH_WAL', 'PG_TABLESPACE_SIZE', 'PG_TABLE_SIZE', 'PG_TERMINATE_BACKEND', 'PG_TOTAL_RELATION_SIZE', 'PG_TRY_ADVISORY_LOCK', 'PG_TRY_ADVISORY_LOCK_SHARED', 'PG_TRY_ADVISORY_XACT_LOCK', 'PG_TRY_ADVISORY_XACT_LOCK_SHARED', 'PG_WALFILE_NAME', 'PG_WALFILE_NAME_OFFSET', 'PG_WAL_LSN_DIFF', 'PG_WAL_REPLAY_PAUSE', 'PG_WAL_REPLAY_RESUME', 'SET_CONFIG'],
|
3340 | // https://www.postgresql.org/docs/14/functions-trigger.html
|
3341 | trigger: ['SUPPRESS_REDUNDANT_UPDATES_TRIGGER', 'TSVECTOR_UPDATE_TRIGGER', 'TSVECTOR_UPDATE_TRIGGER_COLUMN'],
|
3342 | // https://www.postgresql.org/docs/14/functions-event-triggers.html
|
3343 | eventTrigger: ['PG_EVENT_TRIGGER_DDL_COMMANDS', 'PG_EVENT_TRIGGER_DROPPED_OBJECTS', 'PG_EVENT_TRIGGER_TABLE_REWRITE_OID', 'PG_EVENT_TRIGGER_TABLE_REWRITE_REASON', 'PG_GET_OBJECT_ADDRESS'],
|
3344 | // https://www.postgresql.org/docs/14/functions-statistics.html
|
3345 | stats: ['PG_MCV_LIST_ITEMS']
|
3346 | };
|
3347 | /**
|
3348 | * Priority 5 (last)
|
3349 | * Full list of reserved words
|
3350 | * any words that are in a higher priority are removed
|
3351 | */
|
3352 | // https://www.postgresql.org/docs/14/sql-keywords-appendix.html
|
3353 |
|
3354 | var reservedKeywords = ['ABSENT', 'ABSOLUTE', 'ACCESS', 'ACCORDING', 'ACTION', 'ADA', 'ADMIN', 'AGGREGATE', 'ALL', 'ALLOCATE', 'ALSO', 'ALTER', 'ALWAYS', 'ANALYSE', 'ARE', 'ARRAY', 'ARRAY_MAX_CARDINALITY', 'AS', 'ASC', 'ASENSITIVE', 'ASSERTION', 'ASSIGNMENT', 'ASYMMETRIC', 'AT', 'ATOMIC', 'ATTACH', 'ATTRIBUTE', 'ATTRIBUTES', 'AUTHORIZATION', 'BACKWARD', 'BASE64', 'BEFORE', 'BEGIN_FRAME', 'BEGIN_PARTITION', 'BERNOULLI', 'BETWEEN', 'BIGINT', 'BINARY', 'BIT', 'BLOB', 'BLOCKED', 'BOM', 'BOOLEAN', 'BOTH', 'BREADTH', 'BY', 'CACHE', 'CALLED', 'CASCADE', 'CASCADED', 'CAST', 'CATALOG', 'CATALOG_NAME', 'CHAIN', 'CHAINING', 'CHAR', 'CHARACTER', 'CHARACTERISTICS', 'CHARACTERS', 'CHARACTER_SET_CATALOG', 'CHARACTER_SET_NAME', 'CHARACTER_SET_SCHEMA', 'CHECK', 'CLASS', 'CLASSIFIER', 'CLASS_ORIGIN', 'CLOB', 'COBOL', 'COLLATE', 'COLLATION', 'COLLATION_CATALOG', 'COLLATION_NAME', 'COLLATION_SCHEMA', 'COLLECT', 'COLUMN', 'COLUMNS', 'COLUMN_NAME', 'COMMAND_FUNCTION', 'COMMAND_FUNCTION_CODE', 'COMMENTS', 'COMMITTED', 'COMPRESSION', 'CONCURRENTLY', 'CONDITION', 'CONDITIONAL', 'CONDITION_NUMBER', 'CONFIGURATION', 'CONFLICT', 'CONNECT', 'CONNECTION', 'CONNECTION_NAME', 'CONSTRAINT', 'CONSTRAINTS', 'CONSTRAINT_CATALOG', 'CONSTRAINT_NAME', 'CONSTRAINT_SCHEMA', 'CONSTRUCTOR', 'CONTAINS', 'CONTENT', 'CONTINUE', 'CONTROL', 'CONVERSION', 'CORRESPONDING', 'COST', 'CREATE', 'CROSS', 'CSV', 'CUBE', 'CURRENT', 'CURRENT_DEFAULT_TRANSFORM_GROUP', 'CURRENT_PATH', 'CURRENT_ROW', 'CURRENT_TRANSFORM_GROUP_FOR_TYPE', 'CURSOR', 'CURSOR_NAME', 'CYCLE', 'DATA', 'DATABASE', 'DATALINK', 'DATE', 'DATETIME_INTERVAL_CODE', 'DATETIME_INTERVAL_PRECISION', 'DAY', 'DB', 'DEC', 'DECFLOAT', 'DECIMAL', 'DEFAULT', 'DEFAULTS', 'DEFERRABLE', 'DEFERRED', 'DEFINE', 'DEFINED', 'DEFINER', 'DEGREE', 'DELIMITER', 'DELIMITERS', 'DEPENDS', 'DEPTH', 'DEREF', 'DERIVED', 'DESC', 'DESCRIBE', 'DESCRIPTOR', 'DETACH', 'DETERMINISTIC', 'DIAGNOSTICS', 'DICTIONARY', 'DISABLE', 'DISCONNECT', 'DISPATCH', 'DISTINCT', 'DLNEWCOPY', 'DLPREVIOUSCOPY', 'DLURLCOMPLETE', 'DLURLCOMPLETEONLY', 'DLURLCOMPLETEWRITE', 'DLURLPATH', 'DLURLPATHONLY', 'DLURLPATHWRITE', 'DLURLSCHEME', 'DLURLSERVER', 'DLVALUE', 'DOCUMENT', 'DOMAIN', 'DOUBLE', 'DROP', 'DYNAMIC', 'DYNAMIC_FUNCTION', 'DYNAMIC_FUNCTION_CODE', 'EACH', 'ELEMENT', 'EMPTY', 'ENABLE', 'ENCODING', 'ENCRYPTED', 'END-EXEC', 'END_FRAME', 'END_PARTITION', 'ENFORCED', 'ENUM', 'EQUALS', 'ERROR', 'ESCAPE', 'EVENT', 'EXCEPTION', 'EXCLUDE', 'EXCLUDING', 'EXCLUSIVE', 'EXEC', 'EXISTS', 'EXPRESSION', 'EXTENSION', 'EXTERNAL', 'FALSE', 'FILE', 'FILTER', 'FINAL', 'FINALIZE', 'FINISH', 'FIRST', 'FLAG', 'FLOAT', 'FOLLOWING', 'FOR', 'FORCE', 'FOREIGN', 'FORTRAN', 'FORWARD', 'FOUND', 'FRAME_ROW', 'FREE', 'FREEZE', 'FS', 'FULFILL', 'FULL', 'FUNCTION', 'FUNCTIONS', 'FUSION', 'GENERAL', 'GENERATED', 'GET', 'GLOBAL', 'GO', 'GOTO', 'GRANTED', 'GROUP', 'GROUPS', 'HANDLER', 'HEADER', 'HEX', 'HIERARCHY', 'HOLD', 'HOUR', // 'ID',
|
3355 | 'IDENTITY', 'IF', 'IGNORE', 'ILIKE', 'IMMEDIATE', 'IMMEDIATELY', 'IMMUTABLE', 'IMPLEMENTATION', 'IMPLICIT', 'IMPORT', 'IN', 'INCLUDE', 'INCLUDING', 'INCREMENT', 'INDENT', 'INDEX', 'INDEXES', 'INDICATOR', 'INHERIT', 'INHERITS', 'INITIAL', 'INITIALLY', 'INLINE', 'INNER', 'INOUT', 'INPUT', 'INSENSITIVE', 'INSTANCE', 'INSTANTIABLE', 'INSTEAD', 'INT', 'INTEGER', 'INTEGRITY', 'INTERSECTION', 'INTERVAL', 'INTO', 'INVOKER', 'IS', 'ISNULL', 'ISOLATION', 'JSON', 'JSON_ARRAY', 'JSON_ARRAYAGG', 'JSON_EXISTS', 'JSON_OBJECTAGG', 'JSON_QUERY', 'JSON_TABLE', 'JSON_TABLE_PRIMITIVE', 'JSON_VALUE', 'KEEP', 'KEY', 'KEYS', 'KEY_MEMBER', 'KEY_TYPE', 'LABEL', 'LANGUAGE', 'LARGE', 'LAST', 'LATERAL', 'LEADING', 'LEAKPROOF', 'LEVEL', 'LIBRARY', 'LIKE', 'LIKE_REGEX', 'LINK', 'LISTAGG', 'LOCAL', 'LOCATION', 'LOCATOR', 'LOCKED', 'LOGGED', 'MAP', 'MAPPING', 'MATCH', 'MATCHED', 'MATCHES', 'MATCH_NUMBER', 'MATCH_RECOGNIZE', 'MATERIALIZED', 'MAXVALUE', 'MEASURES', 'MEMBER', 'MERGE', 'MESSAGE_LENGTH', 'MESSAGE_OCTET_LENGTH', 'MESSAGE_TEXT', 'METHOD', 'MINUTE', 'MINVALUE', 'MODIFIES', 'MODULE', 'MONTH', 'MORE', 'MULTISET', 'MUMPS', 'NAME', 'NAMES', 'NAMESPACE', 'NATIONAL', 'NATURAL', 'NCHAR', 'NCLOB', 'NESTED', 'NESTING', 'NEW', 'NEXT', 'NFC', 'NFD', 'NFKC', 'NFKD', 'NIL', 'NO', 'NONE', 'NORMALIZED', 'NOT', 'NOTHING', 'NOTNULL', 'NOWAIT', 'NULL', 'NULLABLE', 'NULLS', 'NUMBER', 'NUMERIC', 'OBJECT', 'OCCURRENCES_REGEX', 'OCTETS', 'OF', 'OFF', 'OFFSET', 'OIDS', 'OLD', 'OMIT', 'ON COMMIT', 'ON DELETE', 'ON UPDATE', 'ONE', 'ONLY', 'OPEN', 'OPERATOR', 'OPTION', 'OPTIONS', 'ORDER', 'ORDERING', 'ORDINALITY', 'OTHERS', 'OUT', 'OUTER', 'OUTPUT', 'OVER', 'OVERFLOW', 'OVERLAPS', 'OVERRIDING', 'OWNED', 'OWNER', 'PAD', 'PARALLEL', 'PARAMETER', 'PARAMETER_MODE', 'PARAMETER_NAME', 'PARAMETER_ORDINAL_POSITION', 'PARAMETER_SPECIFIC_CATALOG', 'PARAMETER_SPECIFIC_NAME', 'PARAMETER_SPECIFIC_SCHEMA', 'PARSER', 'PARTIAL', 'PARTITION', 'PASCAL', 'PASS', 'PASSING', 'PASSTHROUGH', 'PASSWORD', 'PAST', 'PATTERN', 'PER', 'PERCENT', 'PERIOD', 'PERMISSION', 'PERMUTE', 'PLACING', 'PLAN', 'PLANS', 'PLI', 'POLICY', 'PORTION', 'POSITION_REGEX', 'PRECEDES', 'PRECEDING', 'PRECISION', 'PREPARED', 'PRESERVE', 'PRIMARY', 'PRIOR', 'PRIVATE', 'PRIVILEGES', 'PROCEDURAL', 'PROCEDURE', 'PROCEDURES', 'PROGRAM', 'PRUNE', 'PTF', 'PUBLIC', 'PUBLICATION', 'QUOTE', 'QUOTES', 'RANGE', 'READ', 'READS', 'REAL', 'REASSIGN', 'RECHECK', 'RECOVERY', 'RECURSIVE', 'REF', 'REFERENCES', 'REFERENCING', 'REFRESH', 'RELATIVE', 'RELEASE', 'RENAME', 'REPEATABLE', 'REPLICA', 'REQUIRING', 'RESPECT', 'RESTART', 'RESTORE', 'RESTRICT', 'RESULT', 'RETURN', 'RETURNED_CARDINALITY', 'RETURNED_LENGTH', 'RETURNED_OCTET_LENGTH', 'RETURNED_SQLSTATE', 'RETURNS', 'ROLE', 'ROLLUP', 'ROUTINE', 'ROUTINES', 'ROUTINE_CATALOG', 'ROUTINE_NAME', 'ROUTINE_SCHEMA', 'ROW', 'ROWS', 'ROW_COUNT', 'RULE', 'RUNNING', 'SCALAR', 'SCHEMA', 'SCHEMAS', 'SCHEMA_NAME', 'SCOPE', 'SCOPE_CATALOG', 'SCOPE_NAME', 'SCOPE_SCHEMA', 'SCROLL', 'SEARCH', 'SECOND', 'SECTION', 'SECURITY', 'SEEK', 'SELECTIVE', 'SELF', 'SENSITIVE', 'SEQUENCE', 'SEQUENCES', 'SERIALIZABLE', 'SERVER', 'SERVER_NAME', 'SESSION', 'SETOF', 'SETS', 'SHARE', 'SIMILAR', 'SIMPLE', 'SIZE', 'SKIP', 'SMALLINT', 'SNAPSHOT', 'SOURCE', 'SPACE', 'SPECIFIC', 'SPECIFICTYPE', 'SPECIFIC_NAME', 'SQL', 'SQLCODE', 'SQLERROR', 'SQLEXCEPTION', 'SQLSTATE', 'SQLWARNING', 'STABLE', 'STANDALONE', 'START', 'STATE', 'STATEMENT', 'STATIC', 'STATISTICS', 'STDIN', 'STDOUT', 'STORAGE', 'STORED', 'STRICT', 'STRUCTURE', 'STYLE', 'SUBCLASS_ORIGIN', 'SUBMULTISET', 'SUBSCRIPTION', 'SUBSET', 'SUBSTRING_REGEX', 'SUCCEEDS', 'SUPPORT', 'SYMMETRIC', 'SYSID', 'SYSTEM', 'SYSTEM_TIME', 'SYSTEM_USER', 'TABLE', 'TABLES', 'TABLESAMPLE', 'TABLESPACE', 'TABLE_NAME', 'TEMP', 'TEMPLATE', 'TEMPORARY', 'THEN', 'THROUGH', 'TIES', 'TIME', 'TIMESTAMP', 'TIMEZONE_HOUR', 'TIMEZONE_MINUTE', 'TO', 'TOKEN', 'TOP_LEVEL_COUNT', 'TRAILING', 'TRANSACTION', 'TRANSACTIONS_COMMITTED', 'TRANSACTIONS_ROLLED_BACK', 'TRANSACTION_ACTIVE', 'TRANSFORM', 'TRANSFORMS', 'TRANSLATE_REGEX', 'TRANSLATION', 'TREAT', 'TRIGGER', 'TRIGGER_CATALOG', 'TRIGGER_NAME', 'TRIGGER_SCHEMA', 'TRUE', 'TRUSTED', 'TYPE', 'TYPES', 'UESCAPE', 'UNBOUNDED', 'UNCOMMITTED', 'UNCONDITIONAL', 'UNDER', 'UNENCRYPTED', 'UNIQUE', 'UNKNOWN', 'UNLINK', 'UNLOGGED', 'UNMATCHED', 'UNNAMED', 'UNTIL', 'UNTYPED', 'URI', 'USAGE', 'USER_DEFINED_TYPE_CATALOG', 'USER_DEFINED_TYPE_CODE', 'USER_DEFINED_TYPE_NAME', 'USER_DEFINED_TYPE_SCHEMA', 'UTF16', 'UTF32', 'UTF8', 'VALID', 'VALIDATE', 'VALIDATOR', 'VALUE', 'VALUE_OF', 'VARBINARY', 'VARCHAR', 'VARIADIC', 'VARYING', 'VERBOSE', 'VERSIONING', 'VIEW', 'VIEWS', 'VOLATILE', 'WHENEVER', 'WHITESPACE', 'WINDOW', 'WITHIN', 'WITHOUT', 'WORK', 'WRAPPER', 'WRITE', 'XML', 'XMLATTRIBUTES', 'XMLBINARY', 'XMLCAST', 'XMLDECLARATION', 'XMLDOCUMENT', 'XMLITERATE', 'XMLNAMESPACES', 'XMLQUERY', 'XMLSCHEMA', 'XMLTEXT', 'XMLVALIDATE', 'YEAR', 'YES', 'ZONE'];
|
3356 | /**
|
3357 | * Priority 1 (first)
|
3358 | * keywords that begin a new statement
|
3359 | * will begin new indented block
|
3360 | */
|
3361 | // https://www.postgresql.org/docs/14/sql-commands.html
|
3362 |
|
3363 | var reservedCommands = ['ABORT', 'ALTER AGGREGATE', 'ALTER COLLATION', 'ALTER CONVERSION', 'ALTER DATABASE', 'ALTER DEFAULT PRIVILEGES', 'ALTER DOMAIN', 'ALTER EVENT TRIGGER', 'ALTER EXTENSION', 'ALTER FOREIGN DATA WRAPPER', 'ALTER FOREIGN TABLE', 'ALTER FUNCTION', 'ALTER GROUP', 'ALTER INDEX', 'ALTER LANGUAGE', 'ALTER LARGE OBJECT', 'ALTER MATERIALIZED VIEW', 'ALTER OPERATOR', 'ALTER OPERATOR CLASS', 'ALTER OPERATOR FAMILY', 'ALTER POLICY', 'ALTER PROCEDURE', 'ALTER PUBLICATION', 'ALTER ROLE', 'ALTER ROUTINE', 'ALTER RULE', 'ALTER SCHEMA', 'ALTER SEQUENCE', 'ALTER SERVER', 'ALTER STATISTICS', 'ALTER SUBSCRIPTION', 'ALTER SYSTEM', 'ALTER TABLE', 'ALTER TABLESPACE', 'ALTER TEXT SEARCH CONFIGURATION', 'ALTER TEXT SEARCH DICTIONARY', 'ALTER TEXT SEARCH PARSER', 'ALTER TEXT SEARCH TEMPLATE', 'ALTER TRIGGER', 'ALTER TYPE', 'ALTER USER', 'ALTER USER MAPPING', 'ALTER VIEW', 'ANALYZE', 'BEGIN', 'CALL', 'CHECKPOINT', 'CLOSE', 'CLUSTER', 'COMMENT', 'COMMIT', 'COMMIT PREPARED', 'COPY', 'CREATE ACCESS METHOD', 'CREATE AGGREGATE', 'CREATE CAST', 'CREATE COLLATION', 'CREATE CONVERSION', 'CREATE DATABASE', 'CREATE DOMAIN', 'CREATE EVENT TRIGGER', 'CREATE EXTENSION', 'CREATE FOREIGN DATA WRAPPER', 'CREATE FOREIGN TABLE', 'CREATE FUNCTION', 'CREATE GROUP', 'CREATE INDEX', 'CREATE LANGUAGE', 'CREATE MATERIALIZED VIEW', 'CREATE OPERATOR', 'CREATE OPERATOR CLASS', 'CREATE OPERATOR FAMILY', 'CREATE POLICY', 'CREATE PROCEDURE', 'CREATE PUBLICATION', 'CREATE ROLE', 'CREATE RULE', 'CREATE SCHEMA', 'CREATE SEQUENCE', 'CREATE SERVER', 'CREATE STATISTICS', 'CREATE SUBSCRIPTION', 'CREATE TABLE', 'CREATE TABLE AS', 'CREATE TABLESPACE', 'CREATE TEXT SEARCH CONFIGURATION', 'CREATE TEXT SEARCH DICTIONARY', 'CREATE TEXT SEARCH PARSER', 'CREATE TEXT SEARCH TEMPLATE', 'CREATE TRANSFORM', 'CREATE TRIGGER', 'CREATE TYPE', 'CREATE USER', 'CREATE USER MAPPING', 'CREATE VIEW', 'DEALLOCATE', 'DECLARE', 'DELETE', 'DISCARD', 'DO', 'DROP ACCESS METHOD', 'DROP AGGREGATE', 'DROP CAST', 'DROP COLLATION', 'DROP CONVERSION', 'DROP DATABASE', 'DROP DOMAIN', 'DROP EVENT TRIGGER', 'DROP EXTENSION', 'DROP FOREIGN DATA WRAPPER', 'DROP FOREIGN TABLE', 'DROP FUNCTION', 'DROP GROUP', 'DROP INDEX', 'DROP LANGUAGE', 'DROP MATERIALIZED VIEW', 'DROP OPERATOR', 'DROP OPERATOR CLASS', 'DROP OPERATOR FAMILY', 'DROP OWNED', 'DROP POLICY', 'DROP PROCEDURE', 'DROP PUBLICATION', 'DROP ROLE', 'DROP ROUTINE', 'DROP RULE', 'DROP SCHEMA', 'DROP SEQUENCE', 'DROP SERVER', 'DROP STATISTICS', 'DROP SUBSCRIPTION', 'DROP TABLE', 'DROP TABLESPACE', 'DROP TEXT SEARCH CONFIGURATION', 'DROP TEXT SEARCH DICTIONARY', 'DROP TEXT SEARCH PARSER', 'DROP TEXT SEARCH TEMPLATE', 'DROP TRANSFORM', 'DROP TRIGGER', 'DROP TYPE', 'DROP USER', 'DROP USER MAPPING', 'DROP VIEW', 'END', 'EXECUTE', 'EXPLAIN', 'FETCH', 'GRANT', 'IMPORT FOREIGN SCHEMA', 'INSERT', 'LISTEN', 'LOAD', 'LOCK', 'MOVE', 'NOTIFY', 'PREPARE', 'PREPARE TRANSACTION', 'REASSIGN OWNED', 'REFRESH MATERIALIZED VIEW', 'REINDEX', 'RELEASE SAVEPOINT', 'RESET', 'RETURNING', 'REVOKE', 'ROLLBACK', 'ROLLBACK PREPARED', 'ROLLBACK TO SAVEPOINT', 'SAVEPOINT', 'SECURITY LABEL', 'SELECT', 'SELECT INTO', 'SET', 'SET CONSTRAINTS', 'SET ROLE', 'SET SESSION AUTHORIZATION', 'SET TRANSACTION', 'SHOW', 'START TRANSACTION', 'TRUNCATE', 'UNLISTEN', 'UPDATE', 'VACUUM', 'VALUES', // other
|
3364 | 'ADD', 'AFTER', 'ALTER COLUMN', 'INSERT INTO', 'SET SCHEMA', 'FROM', 'GROUP BY', 'HAVING', 'LIMIT', 'OFFSET', 'ORDER BY', 'WHERE', 'WITH'];
|
3365 | /**
|
3366 | * Priority 2
|
3367 | * commands that operate on two tables or subqueries
|
3368 | * two main categories: joins and boolean set operators
|
3369 | */
|
3370 |
|
3371 | var reservedBinaryCommands = [// set booleans
|
3372 | 'INTERSECT', 'INTERSECT ALL', 'INTERSECT DISTINCT', 'UNION', 'UNION ALL', 'UNION DISTINCT', 'EXCEPT', 'EXCEPT ALL', 'EXCEPT DISTINCT', 'MINUS', 'MINUS ALL', 'MINUS DISTINCT', // joins
|
3373 | 'JOIN', 'INNER JOIN', 'LEFT JOIN', 'LEFT OUTER JOIN', 'RIGHT JOIN', 'RIGHT OUTER JOIN', 'FULL JOIN', 'FULL OUTER JOIN', 'CROSS JOIN', 'NATURAL JOIN'];
|
3374 | /**
|
3375 | * Priority 3
|
3376 | * keywords that follow a previous Statement, must be attached to subsequent data
|
3377 | * can be fully inline or on newline with optional indent
|
3378 | */
|
3379 |
|
3380 | var reservedDependentClauses = ['WHEN', 'ELSE'];
|
3381 | var binaryOperators = ['<<', '>>', '||/', '|/', '::', ':=', '->>', '->', '=>', '~~*', '~~', '!~~*', '!~~', '~*', '!~*', '!~', '!!', '||', '@-@', '@@', '##', '<->', '&&', '&<', '&>', '<<|', '&<|', '|>>', '|&>', '<^', '^>', '?#', '?-', '?|', '?-|', '?||', '@>', '<@', '~=', '>>=', '<<=', '@@@']; // https://www.postgresql.org/docs/14/index.html
|
3382 |
|
3383 | var PostgreSqlFormatter = /*#__PURE__*/function (_Formatter) {
|
3384 | _inherits(PostgreSqlFormatter, _Formatter);
|
3385 |
|
3386 | var _super = _createSuper(PostgreSqlFormatter);
|
3387 |
|
3388 | function PostgreSqlFormatter() {
|
3389 | _classCallCheck(this, PostgreSqlFormatter);
|
3390 |
|
3391 | return _super.apply(this, arguments);
|
3392 | }
|
3393 |
|
3394 | _createClass(PostgreSqlFormatter, [{
|
3395 | key: "tokenizer",
|
3396 | value: function tokenizer() {
|
3397 | return new _core_Tokenizer__WEBPACK_IMPORTED_MODULE_1__["default"]({
|
3398 | reservedCommands: PostgreSqlFormatter.reservedCommands,
|
3399 | reservedBinaryCommands: PostgreSqlFormatter.reservedBinaryCommands,
|
3400 | reservedDependentClauses: PostgreSqlFormatter.reservedDependentClauses,
|
3401 | reservedJoinConditions: PostgreSqlFormatter.reservedJoinConditions,
|
3402 | reservedLogicalOperators: PostgreSqlFormatter.reservedLogicalOperators,
|
3403 | reservedKeywords: PostgreSqlFormatter.reservedKeywords,
|
3404 | stringTypes: PostgreSqlFormatter.stringTypes,
|
3405 | blockStart: PostgreSqlFormatter.blockStart,
|
3406 | blockEnd: PostgreSqlFormatter.blockEnd,
|
3407 | indexedPlaceholderTypes: PostgreSqlFormatter.indexedPlaceholderTypes,
|
3408 | namedPlaceholderTypes: PostgreSqlFormatter.namedPlaceholderTypes,
|
3409 | lineCommentTypes: PostgreSqlFormatter.lineCommentTypes,
|
3410 | operators: PostgreSqlFormatter.operators
|
3411 | });
|
3412 | }
|
3413 | }]);
|
3414 |
|
3415 | return PostgreSqlFormatter;
|
3416 | }(_core_Formatter__WEBPACK_IMPORTED_MODULE_0__["default"]);
|
3417 |
|
3418 |
|
3419 | PostgreSqlFormatter.reservedCommands = reservedCommands;
|
3420 | PostgreSqlFormatter.reservedBinaryCommands = reservedBinaryCommands;
|
3421 | PostgreSqlFormatter.reservedDependentClauses = reservedDependentClauses;
|
3422 | PostgreSqlFormatter.reservedJoinConditions = ['ON', 'USING'];
|
3423 | PostgreSqlFormatter.reservedLogicalOperators = ['AND', 'OR'];
|
3424 | PostgreSqlFormatter.reservedKeywords = (0,_utils__WEBPACK_IMPORTED_MODULE_2__.dedupe)([].concat(_toConsumableArray(Object.values(reservedFunctions).reduce(function (acc, arr) {
|
3425 | return [].concat(_toConsumableArray(acc), _toConsumableArray(arr));
|
3426 | }, [])), reservedKeywords));
|
3427 | PostgreSqlFormatter.stringTypes = ["\"\"", "''", "U&''", 'U&""', '$$', '``', "E''"];
|
3428 | PostgreSqlFormatter.blockStart = ['(', 'CASE'];
|
3429 | PostgreSqlFormatter.blockEnd = [')', 'END'];
|
3430 | PostgreSqlFormatter.indexedPlaceholderTypes = ['$'];
|
3431 | PostgreSqlFormatter.namedPlaceholderTypes = [':'];
|
3432 | PostgreSqlFormatter.lineCommentTypes = ['--'];
|
3433 | PostgreSqlFormatter.operators = binaryOperators;
|
3434 |
|
3435 | /***/ }),
|
3436 |
|
3437 | /***/ "./src/languages/redshift.formatter.ts":
|
3438 | /*!*********************************************!*\
|
3439 | !*** ./src/languages/redshift.formatter.ts ***!
|
3440 | \*********************************************/
|
3441 | /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
3442 |
|
3443 | __webpack_require__.r(__webpack_exports__);
|
3444 | /* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
3445 | /* harmony export */ "default": () => (/* binding */ RedshiftFormatter)
|
3446 | /* harmony export */ });
|
3447 | /* harmony import */ var _core_Formatter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../core/Formatter */ "./src/core/Formatter.ts");
|
3448 | /* harmony import */ var _core_Tokenizer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../core/Tokenizer */ "./src/core/Tokenizer.ts");
|
3449 | /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils */ "./src/utils.ts");
|
3450 | function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
3451 |
|
3452 | function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
|
3453 |
|
3454 | function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
3455 |
|
3456 | function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
3457 |
|
3458 | function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
|
3459 |
|
3460 | function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
|
3461 |
|
3462 | function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
3463 |
|
3464 | function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
3465 |
|
3466 | function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
3467 |
|
3468 | function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
3469 |
|
3470 | function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
|
3471 |
|
3472 | function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
|
3473 |
|
3474 | function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
3475 |
|
3476 | function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
|
3477 |
|
3478 | function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
|
3479 |
|
3480 | function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
3481 |
|
3482 | function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
|
3483 |
|
3484 |
|
3485 |
|
3486 |
|
3487 | /**
|
3488 | * Priority 5 (last)
|
3489 | * Full list of reserved functions
|
3490 | * distinct from Keywords due to interaction with parentheses
|
3491 | */
|
3492 |
|
3493 | var reservedFunctions = {
|
3494 | // https://docs.aws.amazon.com/redshift/latest/dg/c_Aggregate_Functions.html
|
3495 | aggregate: ['ANY_VALUE', 'APPROXIMATE PERCENTILE_DISC', 'AVG', 'COUNT', 'LISTAGG', 'MAX', 'MEDIAN', 'MIN', 'PERCENTILE_CONT', 'STDDEV_SAMP', 'STDDEV_POP', 'SUM', 'VAR_SAMP', 'VAR_POP'],
|
3496 | // https://docs.aws.amazon.com/redshift/latest/dg/c_Array_Functions.html
|
3497 | array: ['array', 'array_concat', 'array_flatten', 'get_array_length', 'split_to_array', 'subarray'],
|
3498 | // https://docs.aws.amazon.com/redshift/latest/dg/c_bitwise_aggregate_functions.html
|
3499 | bitwise: ['BIT_AND', 'BIT_OR', 'BOOL_AND', 'BOOL_OR'],
|
3500 | // https://docs.aws.amazon.com/redshift/latest/dg/c_conditional_expressions.html
|
3501 | conditional: ['CASE', 'COALESCE', 'DECODE', 'GREATEST', 'LEAST', 'NVL', 'NVL2', 'NULLIF'],
|
3502 | // https://docs.aws.amazon.com/redshift/latest/dg/Date_functions_header.html
|
3503 | dateTime: ['ADD_MONTHS', 'AT TIME ZONE', 'CONVERT_TIMEZONE', 'CURRENT_DATE', 'CURRENT_TIME', 'CURRENT_TIMESTAMP', 'DATE_CMP', 'DATE_CMP_TIMESTAMP', 'DATE_CMP_TIMESTAMPTZ', 'DATE_PART_YEAR', 'DATEADD', 'DATEDIFF', 'DATE_PART', 'DATE_TRUNC', 'EXTRACT', 'GETDATE', 'INTERVAL_CMP', 'LAST_DAY', 'MONTHS_BETWEEN', 'NEXT_DAY', 'SYSDATE', 'TIMEOFDAY', 'TIMESTAMP_CMP', 'TIMESTAMP_CMP_DATE', 'TIMESTAMP_CMP_TIMESTAMPTZ', 'TIMESTAMPTZ_CMP', 'TIMESTAMPTZ_CMP_DATE', 'TIMESTAMPTZ_CMP_TIMESTAMP', 'TIMEZONE', 'TO_TIMESTAMP', 'TRUNC'],
|
3504 | // https://docs.aws.amazon.com/redshift/latest/dg/geospatial-functions.html
|
3505 | spatial: ['AddBBox', 'DropBBox', 'GeometryType', 'ST_AddPoint', 'ST_Angle', 'ST_Area', 'ST_AsBinary', 'ST_AsEWKB', 'ST_AsEWKT', 'ST_AsGeoJSON', 'ST_AsText', 'ST_Azimuth', 'ST_Boundary', 'ST_Collect', 'ST_Contains', 'ST_ContainsProperly', 'ST_ConvexHull', 'ST_CoveredBy', 'ST_Covers', 'ST_Crosses', 'ST_Dimension', 'ST_Disjoint', 'ST_Distance', 'ST_DistanceSphere', 'ST_DWithin', 'ST_EndPoint', 'ST_Envelope', 'ST_Equals', 'ST_ExteriorRing', 'ST_Force2D', 'ST_Force3D', 'ST_Force3DM', 'ST_Force3DZ', 'ST_Force4D', 'ST_GeometryN', 'ST_GeometryType', 'ST_GeomFromEWKB', 'ST_GeomFromEWKT', 'ST_GeomFromText', 'ST_GeomFromWKB', 'ST_InteriorRingN', 'ST_Intersects', 'ST_IsPolygonCCW', 'ST_IsPolygonCW', 'ST_IsClosed', 'ST_IsCollection', 'ST_IsEmpty', 'ST_IsSimple', 'ST_IsValid', 'ST_Length', 'ST_LengthSphere', 'ST_Length2D', 'ST_LineFromMultiPoint', 'ST_LineInterpolatePoint', 'ST_M', 'ST_MakeEnvelope', 'ST_MakeLine', 'ST_MakePoint', 'ST_MakePolygon', 'ST_MemSize', 'ST_MMax', 'ST_MMin', 'ST_Multi', 'ST_NDims', 'ST_NPoints', 'ST_NRings', 'ST_NumGeometries', 'ST_NumInteriorRings', 'ST_NumPoints', 'ST_Perimeter', 'ST_Perimeter2D', 'ST_Point', 'ST_PointN', 'ST_Points', 'ST_Polygon', 'ST_RemovePoint', 'ST_Reverse', 'ST_SetPoint', 'ST_SetSRID', 'ST_Simplify', 'ST_SRID', 'ST_StartPoint', 'ST_Touches', 'ST_Within', 'ST_X', 'ST_XMax', 'ST_XMin', 'ST_Y', 'ST_YMax', 'ST_YMin', 'ST_Z', 'ST_ZMax', 'ST_ZMin', 'SupportsBBox'],
|
3506 | // https://docs.aws.amazon.com/redshift/latest/dg/hash-functions.html
|
3507 | hash: ['CHECKSUM', 'FUNC_SHA1', 'FNV_HASH', 'MD5', 'SHA', 'SHA1', 'SHA2'],
|
3508 | // https://docs.aws.amazon.com/redshift/latest/dg/hyperloglog-functions.html
|
3509 | hyperLogLog: ['HLL', 'HLL_CREATE_SKETCH', 'HLL_CARDINALITY', 'HLL_COMBINE'],
|
3510 | // https://docs.aws.amazon.com/redshift/latest/dg/json-functions.html
|
3511 | json: ['IS_VALID_JSON', 'IS_VALID_JSON_ARRAY', 'JSON_ARRAY_LENGTH', 'JSON_EXTRACT_ARRAY_ELEMENT_TEXT', 'JSON_EXTRACT_PATH_TEXT', 'JSON_PARSE', 'JSON_SERIALIZE'],
|
3512 | // https://docs.aws.amazon.com/redshift/latest/dg/Math_functions.html
|
3513 | math: ['ABS', 'ACOS', 'ASIN', 'ATAN', 'ATAN2', 'CBRT', 'CEILING', 'CEIL', 'COS', 'COT', 'DEGREES', 'DEXP', 'DLOG1', 'DLOG10', 'EXP', 'FLOOR', 'LN', 'LOG', 'MOD', 'PI', 'POWER', 'RADIANS', 'RANDOM', 'ROUND', 'SIN', 'SIGN', 'SQRT', 'TAN', 'TO_HEX', 'TRUNC'],
|
3514 | // https://docs.aws.amazon.com/redshift/latest/dg/ml-function.html
|
3515 | machineLearning: ['EXPLAIN_MODEL'],
|
3516 | // https://docs.aws.amazon.com/redshift/latest/dg/String_functions_header.html
|
3517 | string: ['ASCII', 'BPCHARCMP', 'BTRIM', 'BTTEXT_PATTERN_CMP', 'CHAR_LENGTH', 'CHARACTER_LENGTH', 'CHARINDEX', 'CHR', 'COLLATE', 'CONCAT', 'CRC32', 'DIFFERENCE', 'INITCAP', 'LEFT', 'RIGHT', 'LEN', 'LENGTH', 'LOWER', 'LPAD', 'RPAD', 'LTRIM', 'OCTETINDEX', 'OCTET_LENGTH', 'POSITION', 'QUOTE_IDENT', 'QUOTE_LITERAL', 'REGEXP_COUNT', 'REGEXP_INSTR', 'REGEXP_REPLACE', 'REGEXP_SUBSTR', 'REPEAT', 'REPLACE', 'REPLICATE', 'REVERSE', 'RTRIM', 'SOUNDEX', 'SPLIT_PART', 'STRPOS', 'STRTOL', 'SUBSTRING', 'TEXTLEN', 'TRANSLATE', 'TRIM', 'UPPER'],
|
3518 | // https://docs.aws.amazon.com/redshift/latest/dg/c_Type_Info_Functions.html
|
3519 | superType: ['decimal_precision', 'decimal_scale', 'is_array', 'is_bigint', 'is_boolean', 'is_char', 'is_decimal', 'is_float', 'is_integer', 'is_object', 'is_scalar', 'is_smallint', 'is_varchar', 'json_typeof'],
|
3520 | // https://docs.aws.amazon.com/redshift/latest/dg/c_Window_functions.html
|
3521 | window: ['AVG', 'COUNT', 'CUME_DIST', 'DENSE_RANK', 'FIRST_VALUE', 'LAST_VALUE', 'LAG', 'LEAD', 'LISTAGG', 'MAX', 'MEDIAN', 'MIN', 'NTH_VALUE', 'NTILE', 'PERCENT_RANK', 'PERCENTILE_CONT', 'PERCENTILE_DISC', 'RANK', 'RATIO_TO_REPORT', 'ROW_NUMBER', 'STDDEV_SAMP', 'STDDEV_POP', 'SUM', 'VAR_SAMP', 'VAR_POP'],
|
3522 | // https://docs.aws.amazon.com/redshift/latest/dg/r_Data_type_formatting.html
|
3523 | dataType: ['CAST', 'CONVERT', 'TO_CHAR', 'TO_DATE', 'TO_NUMBER', 'TEXT_TO_INT_ALT', 'TEXT_TO_NUMERIC_ALT'],
|
3524 | // https://docs.aws.amazon.com/redshift/latest/dg/r_System_administration_functions.html
|
3525 | sysAdmin: ['CHANGE_QUERY_PRIORITY', 'CHANGE_SESSION_PRIORITY', 'CHANGE_USER_PRIORITY', 'CURRENT_SETTING', 'PG_CANCEL_BACKEND', 'PG_TERMINATE_BACKEND', 'REBOOT_CLUSTER', 'SET_CONFIG'],
|
3526 | // https://docs.aws.amazon.com/redshift/latest/dg/r_System_information_functions.html
|
3527 | sysInfo: ['CURRENT_AWS_ACCOUNT', 'CURRENT_DATABASE', 'CURRENT_NAMESPACE', 'CURRENT_SCHEMA', 'CURRENT_SCHEMAS', 'CURRENT_USER', 'CURRENT_USER_ID', 'HAS_ASSUMEROLE_PRIVILEGE', 'HAS_DATABASE_PRIVILEGE', 'HAS_SCHEMA_PRIVILEGE', 'HAS_TABLE_PRIVILEGE', 'PG_BACKEND_PID', 'PG_GET_COLS', 'PG_GET_GRANTEE_BY_IAM_ROLE', 'PG_GET_IAM_ROLE_BY_USER', 'PG_GET_LATE_BINDING_VIEW_COLS', 'PG_LAST_COPY_COUNT', 'PG_LAST_COPY_ID', 'PG_LAST_UNLOAD_ID', 'PG_LAST_QUERY_ID', 'PG_LAST_UNLOAD_COUNT', 'SESSION_USER', 'SLICE_NUM', 'USER', 'VERSION']
|
3528 | };
|
3529 | /**
|
3530 | * Priority 5 (last)
|
3531 | * Full list of reserved words
|
3532 | * any words that are in a higher priority are removed
|
3533 | */
|
3534 |
|
3535 | var reservedKeywords = {
|
3536 | // https://docs.aws.amazon.com/redshift/latest/dg/r_pg_keywords.html
|
3537 | standard: ['AES128', 'AES256', 'ALL', 'ALLOWOVERWRITE', 'ANY', 'ARRAY', 'AS', 'ASC', 'AUTHORIZATION', 'BACKUP', 'BETWEEN', 'BINARY', 'BOTH', 'CHECK', 'COLUMN', 'CONSTRAINT', 'CREATE', 'CROSS', 'DEFAULT', 'DEFERRABLE', 'DEFLATE', 'DEFRAG', 'DESC', 'DISABLE', 'DISTINCT', 'DO', 'ENABLE', 'ENCODE', 'ENCRYPT', 'ENCRYPTION', 'EXPLICIT', 'FALSE', 'FOR', 'FOREIGN', 'FREEZE', 'FROM', 'FULL', 'GLOBALDICT256', 'GLOBALDICT64K', 'GROUP', 'IDENTITY', 'IGNORE', 'ILIKE', 'IN', 'INITIALLY', 'INNER', 'INTO', 'IS', 'ISNULL', 'LANGUAGE', 'LEADING', 'LIKE', 'LIMIT', 'LOCALTIME', 'LOCALTIMESTAMP', 'LUN', 'LUNS', 'MINUS', 'NATURAL', 'NEW', 'NOT', 'NOTNULL', 'NULL', 'NULLS', 'OFF', 'OFFLINE', 'OFFSET', 'OID', 'OLD', 'ONLY', 'OPEN', 'ORDER', 'OUTER', 'OVERLAPS', 'PARALLEL', 'PARTITION', 'PERCENT', 'PERMISSIONS', 'PLACING', 'PRIMARY', 'RECOVER', 'REFERENCES', 'REJECTLOG', 'RESORT', 'RESPECT', 'RESTORE', 'SIMILAR', 'SNAPSHOT', 'SOME', 'SYSTEM', 'TABLE', 'TAG', 'TDES', 'THEN', 'TIMESTAMP', 'TO', 'TOP', 'TRAILING', 'TRUE', 'UNIQUE', 'VERBOSE', 'WALLET', 'WITHOUT'],
|
3538 | // https://docs.aws.amazon.com/redshift/latest/dg/copy-parameters-data-conversion.html
|
3539 | dataConversionParams: ['ACCEPTANYDATE', 'ACCEPTINVCHARS', 'BLANKSASNULL', 'DATEFORMAT', 'EMPTYASNULL', 'ENCODING', 'ESCAPE', 'EXPLICIT_IDS', 'FILLRECORD', 'IGNOREBLANKLINES', 'IGNOREHEADER', 'NULL AS', 'REMOVEQUOTES', 'ROUNDEC', 'TIMEFORMAT', 'TRIMBLANKS', 'TRUNCATECOLUMNS'],
|
3540 | // https://docs.aws.amazon.com/redshift/latest/dg/copy-parameters-data-load.html
|
3541 | dataLoadParams: ['COMPROWS', 'COMPUPDATE', 'MAXERROR', 'NOLOAD', 'STATUPDATE'],
|
3542 | // https://docs.aws.amazon.com/redshift/latest/dg/copy-parameters-data-format.html
|
3543 | dataFormatParams: ['FORMAT', 'CSV', 'DELIMITER', 'FIXEDWIDTH', 'SHAPEFILE', 'AVRO', 'JSON', 'PARQUET', 'ORC'],
|
3544 | // https://docs.aws.amazon.com/redshift/latest/dg/copy-parameters-authorization.html
|
3545 | copyAuthParams: ['ACCESS_KEY_ID', 'CREDENTIALS', 'ENCRYPTED', 'IAM_ROLE', 'MASTER_SYMMETRIC_KEY', 'SECRET_ACCESS_KEY', 'SESSION_TOKEN'],
|
3546 | // https://docs.aws.amazon.com/redshift/latest/dg/copy-parameters-file-compression.html
|
3547 | copyCompressionParams: ['BZIP2', 'GZIP', 'LZOP', 'ZSTD'],
|
3548 | // https://docs.aws.amazon.com/redshift/latest/dg/r_COPY-alphabetical-parm-list.html
|
3549 | copyMiscParams: ['MANIFEST', 'READRATIO', 'REGION', 'SSH'],
|
3550 | // https://docs.aws.amazon.com/redshift/latest/dg/c_Compression_encodings.html
|
3551 | compressionEncodings: ['RAW', 'AZ64', 'BYTEDICT', 'DELTA', 'DELTA32K', 'LZO', 'MOSTLY8', 'MOSTLY16', 'MOSTLY32', 'RUNLENGTH', 'TEXT255', 'TEXT32K'],
|
3552 | misc: [// CREATE EXTERNAL SCHEMA (https://docs.aws.amazon.com/redshift/latest/dg/r_CREATE_EXTERNAL_SCHEMA.html)
|
3553 | 'CATALOG_ROLE', 'SECRET_ARN', 'EXTERNAL', 'HIVE METASTORE', // https://docs.aws.amazon.com/redshift/latest/dg/c_choosing_dist_sort.html
|
3554 | 'AUTO', 'EVEN', 'KEY', 'PREDICATE', // unknown
|
3555 | 'COMPRESSION', 'DATA CATALOG'],
|
3556 |
|
3557 | /**
|
3558 | * Other keywords not included:
|
3559 | * STL: https://docs.aws.amazon.com/redshift/latest/dg/c_intro_STL_tables.html
|
3560 | * SVCS: https://docs.aws.amazon.com/redshift/latest/dg/svcs_views.html
|
3561 | * SVL: https://docs.aws.amazon.com/redshift/latest/dg/svl_views.html
|
3562 | * SVV: https://docs.aws.amazon.com/redshift/latest/dg/svv_views.html
|
3563 | */
|
3564 | dataTypes: ['CHAR', 'CHARACTER', 'NCHAR', 'VARCHAR', 'CHARACTER VARYING', 'NVARCHAR', 'BPCHAR', 'TEXT']
|
3565 | };
|
3566 | /**
|
3567 | * Priority 1 (first)
|
3568 | * keywords that begin a new statement
|
3569 | * will begin new indented block
|
3570 | */
|
3571 | // https://docs.aws.amazon.com/redshift/latest/dg/c_SQL_commands.html
|
3572 |
|
3573 | var reservedCommands = ['ABORT', 'ALTER DATABASE', 'ALTER DATASHARE', 'ALTER DEFAULT PRIVILEGES', 'ALTER GROUP', 'ALTER MATERIALIZED VIEW', 'ALTER PROCEDURE', 'ALTER SCHEMA', 'ALTER TABLE', 'ALTER TABLE APPEND', 'ALTER USER', 'ANALYSE', 'ANALYZE', 'ANALYSE COMPRESSION', 'ANALYZE COMPRESSION', 'BEGIN', 'CALL', 'CANCEL', 'CLOSE', 'COMMENT', 'COMMIT', 'COPY', 'CREATE DATABASE', 'CREATE DATASHARE', 'CREATE EXTERNAL FUNCTION', 'CREATE EXTERNAL SCHEMA', 'CREATE EXTERNAL TABLE', 'CREATE FUNCTION', 'CREATE GROUP', 'CREATE LIBRARY', 'CREATE MATERIALIZED VIEW', 'CREATE MODEL', 'CREATE PROCEDURE', 'CREATE SCHEMA', 'CREATE TABLE', 'CREATE TABLE AS', 'CREATE USER', 'CREATE VIEW', 'DEALLOCATE', 'DECLARE', 'DELETE', 'DESC DATASHARE', 'DROP DATABASE', 'DROP DATASHARE', 'DROP FUNCTION', 'DROP GROUP', 'DROP LIBRARY', 'DROP MODEL', 'DROP MATERIALIZED VIEW', 'DROP PROCEDURE', 'DROP SCHEMA', 'DROP TABLE', 'DROP USER', 'DROP VIEW', 'DROP', 'END', 'EXECUTE', 'EXPLAIN', 'FETCH', 'FROM', 'GRANT', 'HAVING', 'INSERT', 'LOCK', 'PREPARE', 'REFRESH MATERIALIZED VIEW', 'RESET', 'REVOKE', 'ROLLBACK', 'SELECT', 'SELECT INTO', 'SET', 'SET SESSION AUTHORIZATION', 'SET SESSION CHARACTERISTICS', 'SHOW', 'SHOW EXTERNAL TABLE', 'SHOW MODEL', 'SHOW DATASHARES', 'SHOW PROCEDURE', 'SHOW TABLE', 'SHOW VIEW', 'START TRANSACTION', 'TRUNCATE', 'UNLOAD', 'UPDATE', 'VACUUM', 'WHERE', 'WITH', // other
|
3574 | 'GROUP BY', 'ORDER BY', 'LIMIT', 'OFFSET', 'VALUES', 'MODIFY', 'INSERT INTO', 'ALTER COLUMN', 'SET SCHEMA' // verify
|
3575 | ];
|
3576 | /**
|
3577 | * Priority 2
|
3578 | * commands that operate on two tables or subqueries
|
3579 | * two main categories: joins and boolean set operators
|
3580 | */
|
3581 |
|
3582 | var reservedBinaryCommands = [// set booleans
|
3583 | 'INTERSECT', 'INTERSECT ALL', 'INTERSECT DISTINCT', 'UNION', 'UNION ALL', 'UNION DISTINCT', 'EXCEPT', 'EXCEPT ALL', 'EXCEPT DISTINCT', // joins
|
3584 | 'JOIN', 'INNER JOIN', 'LEFT JOIN', 'LEFT OUTER JOIN', 'RIGHT JOIN', 'RIGHT OUTER JOIN', 'FULL JOIN', 'FULL OUTER JOIN', 'CROSS JOIN', 'NATURAL JOIN'];
|
3585 | /**
|
3586 | * Priority 3
|
3587 | * keywords that follow a previous Statement, must be attached to subsequent data
|
3588 | * can be fully inline or on newline with optional indent
|
3589 | */
|
3590 |
|
3591 | var reservedDependentClauses = ['WHEN', 'ELSE']; // https://docs.aws.amazon.com/redshift/latest/dg/cm_chap_SQLCommandRef.html
|
3592 |
|
3593 | var RedshiftFormatter = /*#__PURE__*/function (_Formatter) {
|
3594 | _inherits(RedshiftFormatter, _Formatter);
|
3595 |
|
3596 | var _super = _createSuper(RedshiftFormatter);
|
3597 |
|
3598 | function RedshiftFormatter() {
|
3599 | _classCallCheck(this, RedshiftFormatter);
|
3600 |
|
3601 | return _super.apply(this, arguments);
|
3602 | }
|
3603 |
|
3604 | _createClass(RedshiftFormatter, [{
|
3605 | key: "tokenizer",
|
3606 | value: function tokenizer() {
|
3607 | return new _core_Tokenizer__WEBPACK_IMPORTED_MODULE_1__["default"]({
|
3608 | reservedCommands: RedshiftFormatter.reservedCommands,
|
3609 | reservedBinaryCommands: RedshiftFormatter.reservedBinaryCommands,
|
3610 | reservedDependentClauses: RedshiftFormatter.reservedDependentClauses,
|
3611 | reservedJoinConditions: RedshiftFormatter.reservedJoinConditions,
|
3612 | reservedLogicalOperators: RedshiftFormatter.reservedLogicalOperators,
|
3613 | reservedKeywords: RedshiftFormatter.reservedKeywords,
|
3614 | stringTypes: RedshiftFormatter.stringTypes,
|
3615 | blockStart: RedshiftFormatter.blockStart,
|
3616 | blockEnd: RedshiftFormatter.blockEnd,
|
3617 | indexedPlaceholderTypes: RedshiftFormatter.indexedPlaceholderTypes,
|
3618 | namedPlaceholderTypes: RedshiftFormatter.namedPlaceholderTypes,
|
3619 | lineCommentTypes: RedshiftFormatter.lineCommentTypes,
|
3620 | operators: RedshiftFormatter.operators
|
3621 | });
|
3622 | }
|
3623 | }]);
|
3624 |
|
3625 | return RedshiftFormatter;
|
3626 | }(_core_Formatter__WEBPACK_IMPORTED_MODULE_0__["default"]);
|
3627 |
|
3628 |
|
3629 | RedshiftFormatter.reservedCommands = reservedCommands;
|
3630 | RedshiftFormatter.reservedBinaryCommands = reservedBinaryCommands;
|
3631 | RedshiftFormatter.reservedDependentClauses = reservedDependentClauses;
|
3632 | RedshiftFormatter.reservedJoinConditions = ['ON', 'USING'];
|
3633 | RedshiftFormatter.reservedLogicalOperators = ['AND', 'OR'];
|
3634 | RedshiftFormatter.reservedKeywords = (0,_utils__WEBPACK_IMPORTED_MODULE_2__.dedupe)([].concat(_toConsumableArray(Object.values(reservedFunctions).reduce(function (acc, arr) {
|
3635 | return [].concat(_toConsumableArray(acc), _toConsumableArray(arr));
|
3636 | }, [])), _toConsumableArray(Object.values(reservedKeywords).reduce(function (acc, arr) {
|
3637 | return [].concat(_toConsumableArray(acc), _toConsumableArray(arr));
|
3638 | }, []))));
|
3639 | RedshiftFormatter.stringTypes = ["\"\"", "''", '``'];
|
3640 | RedshiftFormatter.blockStart = ['('];
|
3641 | RedshiftFormatter.blockEnd = [')'];
|
3642 | RedshiftFormatter.indexedPlaceholderTypes = ['?'];
|
3643 | RedshiftFormatter.namedPlaceholderTypes = ['@', '#', '$'];
|
3644 | RedshiftFormatter.lineCommentTypes = ['--'];
|
3645 | RedshiftFormatter.operators = ['|/', '||/', '<<', '>>', '||'];
|
3646 |
|
3647 | /***/ }),
|
3648 |
|
3649 | /***/ "./src/languages/sparksql.formatter.ts":
|
3650 | /*!*********************************************!*\
|
3651 | !*** ./src/languages/sparksql.formatter.ts ***!
|
3652 | \*********************************************/
|
3653 | /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
3654 |
|
3655 | __webpack_require__.r(__webpack_exports__);
|
3656 | /* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
3657 | /* harmony export */ "default": () => (/* binding */ SparkSqlFormatter)
|
3658 | /* harmony export */ });
|
3659 | /* harmony import */ var _core_Formatter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../core/Formatter */ "./src/core/Formatter.ts");
|
3660 | /* harmony import */ var _core_Tokenizer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../core/Tokenizer */ "./src/core/Tokenizer.ts");
|
3661 | /* harmony import */ var _core_token__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../core/token */ "./src/core/token.ts");
|
3662 | /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../utils */ "./src/utils.ts");
|
3663 | function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
3664 |
|
3665 | function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
|
3666 |
|
3667 | function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
3668 |
|
3669 | function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
3670 |
|
3671 | function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
|
3672 |
|
3673 | function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
|
3674 |
|
3675 | function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
3676 |
|
3677 | function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
3678 |
|
3679 | function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
3680 |
|
3681 | function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
3682 |
|
3683 | function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
|
3684 |
|
3685 | function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
|
3686 |
|
3687 | function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
3688 |
|
3689 | function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
|
3690 |
|
3691 | function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
|
3692 |
|
3693 | function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
3694 |
|
3695 | function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
|
3696 |
|
3697 |
|
3698 |
|
3699 | // convert to partial type import in TS 4.5
|
3700 |
|
3701 |
|
3702 | /**
|
3703 | * Priority 5 (last)
|
3704 | * Full list of reserved functions
|
3705 | * distinct from Keywords due to interaction with parentheses
|
3706 | */
|
3707 | // http://spark.apache.org/docs/latest/sql-ref-functions.html
|
3708 |
|
3709 | var reservedFunctions = {
|
3710 | // http://spark.apache.org/docs/latest/sql-ref-functions-builtin.html#aggregate-functions
|
3711 | aggregate: ['ANY', 'APPROX_COUNT_DISTINCT', 'APPROX_PERCENTILE', 'AVG', 'BIT_AND', 'BIT_OR', 'BIT_XOR', 'BOOL_AND', 'BOOL_OR', 'COLLECT_LIST', 'COLLECT_SET', 'CORR', 'COUNT', 'COUNT', 'COUNT', 'COUNT_IF', 'COUNT_MIN_SKETCH', 'COVAR_POP', 'COVAR_SAMP', 'EVERY', 'FIRST', 'FIRST_VALUE', 'GROUPING', 'GROUPING_ID', 'KURTOSIS', 'LAST', 'LAST_VALUE', 'MAX', 'MAX_BY', 'MEAN', 'MIN', 'MIN_BY', 'PERCENTILE', 'PERCENTILE', 'PERCENTILE_APPROX', 'SKEWNESS', 'SOME', 'STD', 'STDDEV', 'STDDEV_POP', 'STDDEV_SAMP', 'SUM', 'VAR_POP', 'VAR_SAMP', 'VARIANCE'],
|
3712 | // http://spark.apache.org/docs/latest/sql-ref-functions-builtin.html#window-functions
|
3713 | window: ['CUME_DIST', 'DENSE_RANK', 'LAG', 'LEAD', 'NTH_VALUE', 'NTILE', 'PERCENT_RANK', 'RANK', 'ROW_NUMBER'],
|
3714 | // http://spark.apache.org/docs/latest/sql-ref-functions-builtin.html#array-functions
|
3715 | array: ['ARRAY', 'ARRAY_CONTAINS', 'ARRAY_DISTINCT', 'ARRAY_EXCEPT', 'ARRAY_INTERSECT', 'ARRAY_JOIN', 'ARRAY_MAX', 'ARRAY_MIN', 'ARRAY_POSITION', 'ARRAY_REMOVE', 'ARRAY_REPEAT', 'ARRAY_UNION', 'ARRAYS_OVERLAP', 'ARRAYS_ZIP', 'FLATTEN', 'SEQUENCE', 'SHUFFLE', 'SLICE', 'SORT_ARRAY'],
|
3716 | // http://spark.apache.org/docs/latest/sql-ref-functions-builtin.html#map-functions
|
3717 | map: ['ELEMENT_AT', 'ELEMENT_AT', 'MAP', 'MAP_CONCAT', 'MAP_ENTRIES', 'MAP_FROM_ARRAYS', 'MAP_FROM_ENTRIES', 'MAP_KEYS', 'MAP_VALUES', 'STR_TO_MAP'],
|
3718 | // http://spark.apache.org/docs/latest/sql-ref-functions-builtin.html#date-and-timestamp-functions
|
3719 | datetime: ['ADD_MONTHS', 'CURRENT_DATE', 'CURRENT_DATE', 'CURRENT_TIMESTAMP', 'CURRENT_TIMESTAMP', 'CURRENT_TIMEZONE', 'DATE_ADD', 'DATE_FORMAT', 'DATE_FROM_UNIX_DATE', 'DATE_PART', 'DATE_SUB', 'DATE_TRUNC', 'DATEDIFF', 'DAY', 'DAYOFMONTH', 'DAYOFWEEK', 'DAYOFYEAR', 'EXTRACT', 'FROM_UNIXTIME', 'FROM_UTC_TIMESTAMP', 'HOUR', 'LAST_DAY', 'MAKE_DATE', 'MAKE_DT_INTERVAL', 'MAKE_INTERVAL', 'MAKE_TIMESTAMP', 'MAKE_YM_INTERVAL', 'MINUTE', 'MONTH', 'MONTHS_BETWEEN', 'NEXT_DAY', 'NOW', 'QUARTER', 'SECOND', 'SESSION_WINDOW', 'TIMESTAMP_MICROS', 'TIMESTAMP_MILLIS', 'TIMESTAMP_SECONDS', 'TO_DATE', 'TO_TIMESTAMP', 'TO_UNIX_TIMESTAMP', 'TO_UTC_TIMESTAMP', 'TRUNC', 'UNIX_DATE', 'UNIX_MICROS', 'UNIX_MILLIS', 'UNIX_SECONDS', 'UNIX_TIMESTAMP', 'WEEKDAY', 'WEEKOFYEAR', 'WINDOW', 'YEAR'],
|
3720 | // http://spark.apache.org/docs/latest/sql-ref-functions-builtin.html#json-functions
|
3721 | json: ['FROM_JSON', 'GET_JSON_OBJECT', 'JSON_ARRAY_LENGTH', 'JSON_OBJECT_KEYS', 'JSON_TUPLE', 'SCHEMA_OF_JSON', 'TO_JSON'],
|
3722 | // http://spark.apache.org/docs/latest/api/sql/index.html
|
3723 | misc: ['ABS', 'ACOS', 'ACOSH', 'AGGREGATE', 'ARRAY_SORT', 'ASCII', 'ASIN', 'ASINH', 'ASSERT_TRUE', 'ATAN', 'ATAN2', 'ATANH', 'BASE64', 'BIGINT', 'BIN', 'BINARY', 'BIT_COUNT', 'BIT_GET', 'BIT_LENGTH', 'BOOLEAN', 'BROUND', 'BTRIM', 'CARDINALITY', 'CBRT', 'CEIL', 'CEILING', 'CHAR', 'CHAR_LENGTH', 'CHARACTER_LENGTH', 'CHR', 'CONCAT', 'CONCAT_WS', 'CONV', 'COS', 'COSH', 'COT', 'CRC32', 'CURRENT_CATALOG', 'CURRENT_DATABASE', 'CURRENT_USER', 'DATE', 'DECIMAL', 'DEGREES', 'DOUBLE', // 'E',
|
3724 | 'ELT', 'EXP', 'EXPM1', 'FACTORIAL', 'FIND_IN_SET', 'FLOAT', 'FLOOR', 'FORALL', 'FORMAT_NUMBER', 'FORMAT_STRING', 'FROM_CSV', 'GETBIT', 'HASH', 'HEX', 'HYPOT', 'INITCAP', 'INLINE', 'INLINE_OUTER', 'INPUT_FILE_BLOCK_LENGTH', 'INPUT_FILE_BLOCK_START', 'INPUT_FILE_NAME', 'INSTR', 'INT', 'ISNAN', 'ISNOTNULL', 'ISNULL', 'JAVA_METHOD', 'LCASE', 'LEFT', 'LENGTH', 'LEVENSHTEIN', 'LN', 'LOCATE', 'LOG', 'LOG10', 'LOG1P', 'LOG2', 'LOWER', 'LPAD', 'LTRIM', 'MAP_FILTER', 'MAP_ZIP_WITH', 'MD5', 'MOD', 'MONOTONICALLY_INCREASING_ID', 'NAMED_STRUCT', 'NANVL', 'NEGATIVE', 'NVL', 'NVL2', 'OCTET_LENGTH', 'OVERLAY', 'PARSE_URL', 'PI', 'PMOD', 'POSEXPLODE', 'POSEXPLODE_OUTER', 'POSITION', 'POSITIVE', 'POW', 'POWER', 'PRINTF', 'RADIANS', 'RAISE_ERROR', 'RAND', 'RANDN', 'RANDOM', 'REFLECT', 'REGEXP_EXTRACT', 'REGEXP_EXTRACT_ALL', 'REGEXP_LIKE', 'REGEXP_REPLACE', 'REPEAT', 'REPLACE', 'REVERSE', 'RIGHT', 'RINT', 'ROUND', 'RPAD', 'RTRIM', 'SCHEMA_OF_CSV', 'SENTENCES', 'SHA', 'SHA1', 'SHA2', 'SHIFTLEFT', 'SHIFTRIGHT', 'SHIFTRIGHTUNSIGNED', 'SIGN', 'SIGNUM', 'SIN', 'SINH', 'SMALLINT', 'SOUNDEX', 'SPACE', 'SPARK_PARTITION_ID', 'SPLIT', 'SQRT', 'STACK', 'SUBSTR', 'SUBSTRING', 'SUBSTRING_INDEX', 'TAN', 'TANH', 'TIMESTAMP', 'TINYINT', 'TO_CSV', 'TRANSFORM_KEYS', 'TRANSFORM_VALUES', 'TRANSLATE', 'TRIM', 'TRY_ADD', 'TRY_DIVIDE', 'TYPEOF', 'UCASE', 'UNBASE64', 'UNHEX', 'UPPER', 'UUID', 'VERSION', 'WIDTH_BUCKET', 'XPATH', 'XPATH_BOOLEAN', 'XPATH_DOUBLE', 'XPATH_FLOAT', 'XPATH_INT', 'XPATH_LONG', 'XPATH_NUMBER', 'XPATH_SHORT', 'XPATH_STRING', 'XXHASH64', 'ZIP_WITH']
|
3725 | };
|
3726 | /**
|
3727 | * Priority 5 (last)
|
3728 | * Full list of reserved words
|
3729 | * any words that are in a higher priority are removed
|
3730 | */
|
3731 | // https://deepkb.com/CO_000013/en/kb/IMPORT-fbfa59f0-2bf1-31fe-bb7b-0f9efe9932c6/spark-sql-keywords
|
3732 |
|
3733 | var reservedKeywords = ['ADD', 'AFTER', 'ALL', 'ALTER', 'ANALYZE', 'AND', 'ANTI', 'ANY', 'ARCHIVE', 'ARRAY', 'AS', 'ASC', 'AT', 'AUTHORIZATION', 'BETWEEN', 'BOTH', 'BUCKET', 'BUCKETS', 'BY', 'CACHE', 'CASCADE', 'CAST', 'CHANGE', 'CHECK', 'CLEAR', 'CLUSTER', 'CLUSTERED', 'CODEGEN', 'COLLATE', 'COLLECTION', 'COLUMN', 'COLUMNS', 'COMMENT', 'COMMIT', 'COMPACT', 'COMPACTIONS', 'COMPUTE', 'CONCATENATE', 'CONSTRAINT', 'COST', 'CREATE', 'CROSS', 'CUBE', 'CURRENT', 'CURRENT_DATE', 'CURRENT_TIME', 'CURRENT_TIMESTAMP', 'CURRENT_USER', 'DATA', 'DATABASE', 'DATABASES', 'DAY', 'DBPROPERTIES', 'DEFINED', 'DELETE', 'DELIMITED', 'DESC', 'DESCRIBE', 'DFS', 'DIRECTORIES', 'DIRECTORY', 'DISTINCT', 'DISTRIBUTE', 'DIV', 'DROP', 'ESCAPE', 'ESCAPED', 'EXCEPT', 'EXCHANGE', 'EXISTS', 'EXPORT', 'EXTENDED', 'EXTERNAL', 'EXTRACT', 'FALSE', 'FETCH', 'FIELDS', 'FILTER', 'FILEFORMAT', 'FIRST', 'FIRST_VALUE', 'FOLLOWING', 'FOR', 'FOREIGN', 'FORMAT', 'FORMATTED', 'FULL', 'FUNCTION', 'FUNCTIONS', 'GLOBAL', 'GRANT', 'GROUP', 'GROUPING', 'HOUR', 'IF', 'IGNORE', 'IMPORT', 'IN', 'INDEX', 'INDEXES', 'INNER', 'INPATH', 'INPUTFORMAT', 'INTERSECT', 'INTERVAL', 'INTO', 'IS', 'ITEMS', 'KEYS', 'LAST', 'LAST_VALUE', 'LATERAL', 'LAZY', 'LEADING', 'LEFT', 'LIKE', 'LINES', 'LIST', 'LOCAL', 'LOCATION', 'LOCK', 'LOCKS', 'LOGICAL', 'MACRO', 'MAP', 'MATCHED', 'MERGE', 'MINUTE', 'MONTH', 'MSCK', 'NAMESPACE', 'NAMESPACES', 'NATURAL', 'NO', 'NOT', 'NULL', 'NULLS', 'OF', 'ONLY', 'OPTION', 'OPTIONS', 'OR', 'ORDER', 'OUT', 'OUTER', 'OUTPUTFORMAT', 'OVER', 'OVERLAPS', 'OVERLAY', 'OVERWRITE', 'OWNER', 'PARTITION', 'PARTITIONED', 'PARTITIONS', 'PERCENT', 'PLACING', 'POSITION', 'PRECEDING', 'PRIMARY', 'PRINCIPALS', 'PROPERTIES', 'PURGE', 'QUERY', 'RANGE', 'RECORDREADER', 'RECORDWRITER', 'RECOVER', 'REDUCE', 'REFERENCES', 'RENAME', 'REPAIR', 'REPLACE', 'RESPECT', 'RESTRICT', 'REVOKE', 'RIGHT', 'RLIKE', 'ROLE', 'ROLES', 'ROLLBACK', 'ROLLUP', 'ROW', 'ROWS', 'SCHEMA', 'SECOND', 'SELECT', 'SEMI', 'SEPARATED', 'SERDE', 'SERDEPROPERTIES', 'SESSION_USER', 'SETS', 'SHOW', 'SKEWED', 'SOME', 'SORT', 'SORTED', 'START', 'STATISTICS', 'STORED', 'STRATIFY', 'STRUCT', 'SUBSTR', 'SUBSTRING', 'TABLE', 'TABLES', 'TBLPROPERTIES', 'TEMPORARY', 'TERMINATED', 'THEN', 'TO', 'TOUCH', 'TRAILING', 'TRANSACTION', 'TRANSACTIONS', 'TRIM', 'TRUE', 'TRUNCATE', 'UNARCHIVE', 'UNBOUNDED', 'UNCACHE', 'UNIQUE', 'UNKNOWN', 'UNLOCK', 'UNSET', 'USE', 'USER', 'VIEW', 'WINDOW', 'YEAR', // other
|
3734 | 'ANALYSE', 'ARRAY_ZIP', 'COALESCE', 'CONTAINS', 'CONVERT', 'CURRENT ROW', 'DAYS', 'DAY_HOUR', 'DAY_MINUTE', 'DAY_SECOND', 'DECODE', 'DEFAULT', 'DISTINCTROW', 'ENCODE', 'EXPLODE', 'EXPLODE_OUTER', 'FIXED', 'GREATEST', 'GROUP_CONCAT', 'HOURS', 'HOUR_MINUTE', 'HOUR_SECOND', 'IFNULL', 'LEAST', 'LEVEL', 'MINUTE_SECOND', 'NULLIF', 'OFFSET', 'ON DELETE', 'ON UPDATE', 'OPTIMIZE', 'REGEXP', 'SEPARATOR', 'SIZE', 'STRING', 'TYPE', 'TYPES', 'UNSIGNED', 'VARIABLES', 'YEAR_MONTH'];
|
3735 | /**
|
3736 | * Priority 1 (first)
|
3737 | * keywords that begin a new statement
|
3738 | * will begin new indented block
|
3739 | */
|
3740 | // http://spark.apache.org/docs/latest/sql-ref-syntax.html
|
3741 |
|
3742 | var reservedCommands = [// DDL
|
3743 | 'ALTER COLUMN', 'ALTER DATABASE', 'ALTER TABLE', 'ALTER VIEW', 'CREATE DATABASE', 'CREATE FUNCTION', 'CREATE TABLE', 'CREATE VIEW', 'DROP DATABASE', 'DROP FUNCTION', 'DROP TABLE', 'DROP VIEW', 'REPAIR TABLE', 'TRUNCATE TABLE', 'USE DATABASE', // DML
|
3744 | 'INSERT INTO', 'INSERT OVERWRITE', 'INSERT OVERWRITE DIRECTORY', 'LOAD', // Data Retrieval
|
3745 | 'SELECT', 'WITH', 'CLUSTER BY', 'DISTRIBUTE BY', 'PARTITION BY', 'GROUP BY', 'HAVING', 'VALUES', 'LIMIT', 'OFFSET', 'ORDER BY', 'SORT BY', 'TABLESAMPLE', 'WHERE', 'PIVOT', 'TRANSFORM', 'EXPLAIN', // Auxiliary
|
3746 | 'ADD FILE', 'ADD JAR', 'ANALYZE TABLE', 'CACHE TABLE', 'CLEAR CACHE', 'DESCRIBE DATABASE', 'DESCRIBE FUNCTION', 'DESCRIBE QUERY', 'DESCRIBE TABLE', 'LIST FILE', 'LIST JAR', 'REFRESH', 'REFRESH TABLE', 'REFRESH FUNCTION', 'RESET', 'SET', 'SET SCHEMA', 'SHOW COLUMNS', 'SHOW CREATE TABLE', 'SHOW DATABASES', 'SHOW FUNCTIONS', 'SHOW PARTITIONS', 'SHOW TABLE EXTENDED', 'SHOW TABLES', 'SHOW TBLPROPERTIES', 'SHOW VIEWS', 'UNCACHE TABLE', // other
|
3747 | 'FROM', 'INSERT', 'LATERAL VIEW', 'UPDATE', 'WINDOW' // verify
|
3748 | ];
|
3749 | /**
|
3750 | * Priority 2
|
3751 | * commands that operate on two tables or subqueries
|
3752 | * two main categories: joins and boolean set operators
|
3753 | */
|
3754 |
|
3755 | var reservedBinaryCommands = [// set booleans
|
3756 | 'INTERSECT', 'INTERSECT ALL', 'INTERSECT DISTINCT', 'UNION', 'UNION ALL', 'UNION DISTINCT', 'EXCEPT', 'EXCEPT ALL', 'EXCEPT DISTINCT', 'MINUS', 'MINUS ALL', 'MINUS DISTINCT', // joins
|
3757 | 'JOIN', 'INNER JOIN', 'LEFT JOIN', 'LEFT OUTER JOIN', 'RIGHT JOIN', 'RIGHT OUTER JOIN', 'FULL JOIN', 'FULL OUTER JOIN', 'CROSS JOIN', 'NATURAL JOIN', // apply
|
3758 | 'CROSS APPLY', 'OUTER APPLY', // non-standard-joins
|
3759 | 'ANTI JOIN', 'SEMI JOIN', 'LEFT ANTI JOIN', 'LEFT SEMI JOIN', 'RIGHT OUTER JOIN', 'RIGHT SEMI JOIN', 'NATURAL ANTI JOIN', 'NATURAL FULL OUTER JOIN', 'NATURAL INNER JOIN', 'NATURAL LEFT ANTI JOIN', 'NATURAL LEFT OUTER JOIN', 'NATURAL LEFT SEMI JOIN', 'NATURAL OUTER JOIN', 'NATURAL RIGHT OUTER JOIN', 'NATURAL RIGHT SEMI JOIN', 'NATURAL SEMI JOIN', 'CROSS APPLY', 'OUTER APPLY'];
|
3760 | /**
|
3761 | * Priority 3
|
3762 | * keywords that follow a previous Statement, must be attached to subsequent data
|
3763 | * can be fully inline or on newline with optional indent
|
3764 | */
|
3765 |
|
3766 | var reservedDependentClauses = ['WHEN', 'ELSE']; // http://spark.apache.org/docs/latest/sql-programming-guide.html
|
3767 |
|
3768 | var SparkSqlFormatter = /*#__PURE__*/function (_Formatter) {
|
3769 | _inherits(SparkSqlFormatter, _Formatter);
|
3770 |
|
3771 | var _super = _createSuper(SparkSqlFormatter);
|
3772 |
|
3773 | function SparkSqlFormatter() {
|
3774 | _classCallCheck(this, SparkSqlFormatter);
|
3775 |
|
3776 | return _super.apply(this, arguments);
|
3777 | }
|
3778 |
|
3779 | _createClass(SparkSqlFormatter, [{
|
3780 | key: "tokenizer",
|
3781 | value: function tokenizer() {
|
3782 | return new _core_Tokenizer__WEBPACK_IMPORTED_MODULE_1__["default"]({
|
3783 | reservedCommands: SparkSqlFormatter.reservedCommands,
|
3784 | reservedBinaryCommands: SparkSqlFormatter.reservedBinaryCommands,
|
3785 | reservedDependentClauses: SparkSqlFormatter.reservedDependentClauses,
|
3786 | reservedJoinConditions: SparkSqlFormatter.reservedJoinConditions,
|
3787 | reservedLogicalOperators: SparkSqlFormatter.reservedLogicalOperators,
|
3788 | reservedKeywords: SparkSqlFormatter.reservedKeywords,
|
3789 | stringTypes: SparkSqlFormatter.stringTypes,
|
3790 | blockStart: SparkSqlFormatter.blockStart,
|
3791 | blockEnd: SparkSqlFormatter.blockEnd,
|
3792 | indexedPlaceholderTypes: SparkSqlFormatter.indexedPlaceholderTypes,
|
3793 | namedPlaceholderTypes: SparkSqlFormatter.namedPlaceholderTypes,
|
3794 | lineCommentTypes: SparkSqlFormatter.lineCommentTypes,
|
3795 | operators: SparkSqlFormatter.operators
|
3796 | });
|
3797 | }
|
3798 | }, {
|
3799 | key: "tokenOverride",
|
3800 | value: function tokenOverride(token) {
|
3801 | // [WINDOW](...)
|
3802 | if (_core_token__WEBPACK_IMPORTED_MODULE_2__.isToken.WINDOW(token) && this.tokenLookAhead().type === _core_token__WEBPACK_IMPORTED_MODULE_2__.TokenType.BLOCK_START) {
|
3803 | // This is a function call, treat it as a reserved word
|
3804 | return {
|
3805 | type: _core_token__WEBPACK_IMPORTED_MODULE_2__.TokenType.RESERVED_KEYWORD,
|
3806 | value: token.value
|
3807 | };
|
3808 | } // .[END]
|
3809 |
|
3810 |
|
3811 | if (_core_token__WEBPACK_IMPORTED_MODULE_2__.isToken.END(token) && this.tokenLookBehind().value === '.') {
|
3812 | // This is window().end (or similar) not CASE ... END
|
3813 | return {
|
3814 | type: _core_token__WEBPACK_IMPORTED_MODULE_2__.TokenType.WORD,
|
3815 | value: token.value
|
3816 | };
|
3817 | } // TODO: deprecate this once ITEMS is merged with COLLECTION
|
3818 |
|
3819 |
|
3820 | if (/ITEMS/i.test(token.value) && token.type === _core_token__WEBPACK_IMPORTED_MODULE_2__.TokenType.RESERVED_KEYWORD) {
|
3821 | if (!(/COLLECTION/i.test(this.tokenLookBehind().value) && /TERMINATED/i.test(this.tokenLookAhead().value))) {
|
3822 | // this is a word and not COLLECTION ITEMS
|
3823 | return {
|
3824 | type: _core_token__WEBPACK_IMPORTED_MODULE_2__.TokenType.WORD,
|
3825 | value: token.value
|
3826 | };
|
3827 | }
|
3828 | }
|
3829 |
|
3830 | return token;
|
3831 | }
|
3832 | }]);
|
3833 |
|
3834 | return SparkSqlFormatter;
|
3835 | }(_core_Formatter__WEBPACK_IMPORTED_MODULE_0__["default"]);
|
3836 |
|
3837 |
|
3838 | SparkSqlFormatter.reservedCommands = reservedCommands;
|
3839 | SparkSqlFormatter.reservedBinaryCommands = reservedBinaryCommands;
|
3840 | SparkSqlFormatter.reservedDependentClauses = reservedDependentClauses;
|
3841 | SparkSqlFormatter.reservedJoinConditions = ['ON', 'USING'];
|
3842 | SparkSqlFormatter.reservedLogicalOperators = ['AND', 'OR', 'XOR'];
|
3843 | SparkSqlFormatter.reservedKeywords = (0,_utils__WEBPACK_IMPORTED_MODULE_3__.dedupe)([].concat(_toConsumableArray(Object.values(reservedFunctions).reduce(function (acc, arr) {
|
3844 | return [].concat(_toConsumableArray(acc), _toConsumableArray(arr));
|
3845 | }, [])), reservedKeywords));
|
3846 | SparkSqlFormatter.stringTypes = ["\"\"", "''", '``', '{}'];
|
3847 | SparkSqlFormatter.blockStart = ['(', 'CASE'];
|
3848 | SparkSqlFormatter.blockEnd = [')', 'END'];
|
3849 | SparkSqlFormatter.indexedPlaceholderTypes = ['?'];
|
3850 | SparkSqlFormatter.namedPlaceholderTypes = ['$'];
|
3851 | SparkSqlFormatter.lineCommentTypes = ['--'];
|
3852 | SparkSqlFormatter.operators = ['<=>', '&&', '||', '==', '->'];
|
3853 |
|
3854 | /***/ }),
|
3855 |
|
3856 | /***/ "./src/languages/standardsql.formatter.ts":
|
3857 | /*!************************************************!*\
|
3858 | !*** ./src/languages/standardsql.formatter.ts ***!
|
3859 | \************************************************/
|
3860 | /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
3861 |
|
3862 | __webpack_require__.r(__webpack_exports__);
|
3863 | /* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
3864 | /* harmony export */ "default": () => (/* binding */ StandardSqlFormatter)
|
3865 | /* harmony export */ });
|
3866 | /* harmony import */ var _core_Formatter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../core/Formatter */ "./src/core/Formatter.ts");
|
3867 | /* harmony import */ var _core_Tokenizer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../core/Tokenizer */ "./src/core/Tokenizer.ts");
|
3868 | /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils */ "./src/utils.ts");
|
3869 | function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
3870 |
|
3871 | function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
3872 |
|
3873 | function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
3874 |
|
3875 | function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
3876 |
|
3877 | function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
|
3878 |
|
3879 | function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
|
3880 |
|
3881 | function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
3882 |
|
3883 | function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
|
3884 |
|
3885 | function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
|
3886 |
|
3887 | function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
3888 |
|
3889 | function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
|
3890 |
|
3891 |
|
3892 |
|
3893 |
|
3894 | /**
|
3895 | * Priority 5 (last)
|
3896 | * Full list of reserved words
|
3897 | * any words that are in a higher priority are removed
|
3898 | */
|
3899 | // https://jakewheat.github.io/sql-overview/sql-2008-foundation-grammar.html#reserved-word
|
3900 |
|
3901 | var reservedKeywords = ['ABS', 'ALL', 'ALLOCATE', 'ALTER', 'ANY', 'ARE', 'ARRAY', 'AS', 'ASENSITIVE', 'ASYMMETRIC', 'AT', 'ATOMIC', 'AUTHORIZATION', 'AVG', 'BEGIN', 'BETWEEN', 'BIGINT', 'BINARY', 'BLOB', 'BOOLEAN', 'BOTH', 'BY', 'CALL', 'CALLED', 'CARDINALITY', 'CASCADED', 'CAST', 'CEIL', 'CEILING', 'CHAR', 'CHARACTER', 'CHARACTER_LENGTH', 'CHAR_LENGTH', 'CHECK', 'CLOB', 'CLOSE', 'COALESCE', 'COLLATE', 'COLLECT', 'COLUMN', 'COMMIT', 'CONDITION', 'CONNECT', 'CONSTRAINT', 'CONVERT', 'CORR', 'CORRESPONDING', 'COUNT', 'COVAR_POP', 'COVAR_SAMP', 'CREATE', 'CROSS', 'CUBE', 'CUME_DIST', 'CURRENT', 'CURRENT_CATALOG', 'CURRENT_DATE', 'CURRENT_DEFAULT_TRANSFORM_GROUP', 'CURRENT_PATH', 'CURRENT_ROLE', 'CURRENT_SCHEMA', 'CURRENT_TIME', 'CURRENT_TIMESTAMP', 'CURRENT_TRANSFORM_GROUP_FOR_TYPE', 'CURRENT_USER', 'CURSOR', 'CYCLE', 'DATE', 'DAY', 'DEALLOCATE', 'DEC', 'DECIMAL', 'DECLARE', 'DEFAULT', 'DELETE', 'DENSE_RANK', 'DEREF', 'DESCRIBE', 'DETERMINISTIC', 'DISCONNECT', 'DISTINCT', 'DOUBLE', 'DROP', 'DYNAMIC', 'EACH', 'ELEMENT', 'END-EXEC', 'ESCAPE', 'EVERY', 'EXCEPT', 'EXEC', 'EXECUTE', 'EXISTS', 'EXP', 'EXTERNAL', 'EXTRACT', 'FALSE', 'FETCH', 'FILTER', 'FLOAT', 'FLOOR', 'FOR', 'FOREIGN', 'FREE', 'FROM', 'FULL', 'FUNCTION', 'FUSION', 'GET', 'GLOBAL', 'GRANT', 'GROUP', 'GROUPING', 'HAVING', 'HOLD', 'HOUR', 'IDENTITY', 'IN', 'INDICATOR', 'INNER', 'INOUT', 'INSENSITIVE', 'INSERT', 'INT', 'INTEGER', 'INTERSECT', 'INTERSECTION', 'INTERVAL', 'INTO', 'IS', 'LANGUAGE', 'LARGE', 'LATERAL', 'LEADING', 'LEFT', 'LIKE', 'LIKE_REGEX', 'LN', 'LOCAL', 'LOCALTIME', 'LOCALTIMESTAMP', 'LOWER', 'MATCH', 'MAX', 'MEMBER', 'MERGE', 'METHOD', 'MIN', 'MINUTE', 'MOD', 'MODIFIES', 'MODULE', 'MONTH', 'MULTISET', 'NATIONAL', 'NATURAL', 'NCHAR', 'NCLOB', 'NEW', 'NO', 'NONE', 'NORMALIZE', 'NOT', 'NULL', 'NULLIF', 'NUMERIC', 'OCCURRENCES_REGEX', 'OCTET_LENGTH', 'OF', 'OLD', 'ON DELETE', 'ON UPDATE', 'ONLY', 'OPEN', 'ORDER', 'OUT', 'OUTER', 'OVER', 'OVERLAPS', 'OVERLAY', 'PARAMETER', 'PARTITION', 'PERCENTILE_CONT', 'PERCENTILE_DISC', 'PERCENT_RANK', 'POSITION', 'POSITION_REGEX', 'POWER', 'PRECISION', 'PREPARE', 'PRIMARY', 'PROCEDURE', 'RANGE', 'RANK', 'READS', 'REAL', 'RECURSIVE', 'REF', 'REFERENCES', 'REFERENCING', 'REGR_AVGX', 'REGR_AVGY', 'REGR_COUNT', 'REGR_INTERCEPT', 'REGR_R2', 'REGR_SLOPE', 'REGR_SXX', 'REGR_SXY', 'REGR_SYY', 'RELEASE', 'RESULT', 'RETURN', 'RETURNS', 'REVOKE', 'RIGHT', 'ROLLBACK', 'ROLLUP', 'ROW', 'ROWS', 'ROW_NUMBER', 'SAVEPOINT', 'SCOPE', 'SCROLL', 'SEARCH', 'SECOND', 'SELECT', 'SENSITIVE', 'SESSION_USER', 'SET', 'SIMILAR', 'SMALLINT', 'SOME', 'SPECIFIC', 'SPECIFICTYPE', 'SQL', 'SQLEXCEPTION', 'SQLSTATE', 'SQLWARNING', 'SQRT', 'START', 'STATIC', 'STDDEV_POP', 'STDDEV_SAMP', 'SUBMULTISET', 'SUBSTRING', 'SUBSTRING_REGEX', 'SUM', 'SYMMETRIC', 'SYSTEM', 'SYSTEM_USER', 'TABLE', 'TABLESAMPLE', 'THEN', 'TIME', 'TIMESTAMP', 'TIMEZONE_HOUR', 'TIMEZONE_MINUTE', 'TO', 'TRAILING', 'TRANSLATE', 'TRANSLATE_REGEX', 'TRANSLATION', 'TREAT', 'TRIGGER', 'TRIM', 'TRUE', 'UESCAPE', 'UNION', 'UNIQUE', 'UNKNOWN', 'UNNEST', 'UPDATE', 'UPPER', 'USER', 'VALUE', 'VALUES', 'VARBINARY', 'VARCHAR', 'VARYING', 'VAR_POP', 'VAR_SAMP', 'WHENEVER', 'WIDTH_BUCKET', 'WINDOW', 'WITHIN', 'WITHOUT', 'YEAR'];
|
3902 | /**
|
3903 | * Priority 1 (first)
|
3904 | * keywords that begin a new statement
|
3905 | * will begin new indented block
|
3906 | */
|
3907 |
|
3908 | var reservedCommands = ['ADD', 'ALTER COLUMN', 'ALTER TABLE', 'CREATE TABLE', 'DROP TABLE', 'END', 'FETCH FIRST', 'FETCH NEXT', 'FETCH PRIOR', 'FETCH LAST', 'FETCH ABSOLUTE', 'FETCH RELATIVE', 'FROM', 'GROUP BY', 'HAVING', 'INSERT INTO', 'LIMIT', 'OFFSET', 'ORDER BY', 'SELECT', 'SET SCHEMA', 'SET', 'UPDATE', 'VALUES', 'WHERE', 'WITH'];
|
3909 | /**
|
3910 | * Priority 2
|
3911 | * commands that operate on two tables or subqueries
|
3912 | * two main categories: joins and boolean set operators
|
3913 | */
|
3914 |
|
3915 | var reservedBinaryCommands = [// set booleans
|
3916 | 'INTERSECT', 'INTERSECT ALL', 'INTERSECT DISTINCT', 'UNION', 'UNION ALL', 'UNION DISTINCT', 'EXCEPT', 'EXCEPT ALL', 'EXCEPT DISTINCT', // joins
|
3917 | 'JOIN', 'INNER JOIN', 'LEFT JOIN', 'LEFT OUTER JOIN', 'RIGHT JOIN', 'RIGHT OUTER JOIN', 'FULL JOIN', 'FULL OUTER JOIN', 'CROSS JOIN', 'NATURAL JOIN'];
|
3918 | /**
|
3919 | * Priority 3
|
3920 | * keywords that follow a previous Statement, must be attached to subsequent data
|
3921 | * can be fully inline or on newline with optional indent
|
3922 | */
|
3923 |
|
3924 | var reservedDependentClauses = ['WHEN', 'ELSE'];
|
3925 |
|
3926 | var StandardSqlFormatter = /*#__PURE__*/function (_Formatter) {
|
3927 | _inherits(StandardSqlFormatter, _Formatter);
|
3928 |
|
3929 | var _super = _createSuper(StandardSqlFormatter);
|
3930 |
|
3931 | function StandardSqlFormatter() {
|
3932 | _classCallCheck(this, StandardSqlFormatter);
|
3933 |
|
3934 | return _super.apply(this, arguments);
|
3935 | }
|
3936 |
|
3937 | _createClass(StandardSqlFormatter, [{
|
3938 | key: "tokenizer",
|
3939 | value: function tokenizer() {
|
3940 | return new _core_Tokenizer__WEBPACK_IMPORTED_MODULE_1__["default"]({
|
3941 | reservedCommands: StandardSqlFormatter.reservedCommands,
|
3942 | reservedBinaryCommands: StandardSqlFormatter.reservedBinaryCommands,
|
3943 | reservedDependentClauses: StandardSqlFormatter.reservedDependentClauses,
|
3944 | reservedJoinConditions: StandardSqlFormatter.reservedJoinConditions,
|
3945 | reservedLogicalOperators: StandardSqlFormatter.reservedLogicalOperators,
|
3946 | reservedKeywords: StandardSqlFormatter.reservedKeywords,
|
3947 | stringTypes: StandardSqlFormatter.stringTypes,
|
3948 | blockStart: StandardSqlFormatter.blockStart,
|
3949 | blockEnd: StandardSqlFormatter.blockEnd,
|
3950 | indexedPlaceholderTypes: StandardSqlFormatter.indexedPlaceholderTypes,
|
3951 | namedPlaceholderTypes: StandardSqlFormatter.namedPlaceholderTypes,
|
3952 | lineCommentTypes: StandardSqlFormatter.lineCommentTypes
|
3953 | });
|
3954 | }
|
3955 | }]);
|
3956 |
|
3957 | return StandardSqlFormatter;
|
3958 | }(_core_Formatter__WEBPACK_IMPORTED_MODULE_0__["default"]);
|
3959 |
|
3960 |
|
3961 | StandardSqlFormatter.reservedCommands = reservedCommands;
|
3962 | StandardSqlFormatter.reservedBinaryCommands = reservedBinaryCommands;
|
3963 | StandardSqlFormatter.reservedDependentClauses = reservedDependentClauses;
|
3964 | StandardSqlFormatter.reservedJoinConditions = ['ON', 'USING'];
|
3965 | StandardSqlFormatter.reservedLogicalOperators = ['AND', 'OR'];
|
3966 | StandardSqlFormatter.reservedKeywords = (0,_utils__WEBPACK_IMPORTED_MODULE_2__.dedupe)(reservedKeywords);
|
3967 | StandardSqlFormatter.stringTypes = ["\"\"", "''", '``'];
|
3968 | StandardSqlFormatter.blockStart = ['(', 'CASE'];
|
3969 | StandardSqlFormatter.blockEnd = [')', 'END'];
|
3970 | StandardSqlFormatter.indexedPlaceholderTypes = ['?'];
|
3971 | StandardSqlFormatter.namedPlaceholderTypes = [];
|
3972 | StandardSqlFormatter.lineCommentTypes = ['--'];
|
3973 | StandardSqlFormatter.operators = [];
|
3974 |
|
3975 | /***/ }),
|
3976 |
|
3977 | /***/ "./src/languages/tsql.formatter.ts":
|
3978 | /*!*****************************************!*\
|
3979 | !*** ./src/languages/tsql.formatter.ts ***!
|
3980 | \*****************************************/
|
3981 | /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
3982 |
|
3983 | __webpack_require__.r(__webpack_exports__);
|
3984 | /* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
3985 | /* harmony export */ "default": () => (/* binding */ TSqlFormatter)
|
3986 | /* harmony export */ });
|
3987 | /* harmony import */ var _core_Formatter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../core/Formatter */ "./src/core/Formatter.ts");
|
3988 | /* harmony import */ var _core_Tokenizer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../core/Tokenizer */ "./src/core/Tokenizer.ts");
|
3989 | /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils */ "./src/utils.ts");
|
3990 | function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
3991 |
|
3992 | function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
|
3993 |
|
3994 | function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
3995 |
|
3996 | function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
3997 |
|
3998 | function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
|
3999 |
|
4000 | function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
|
4001 |
|
4002 | function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
4003 |
|
4004 | function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
4005 |
|
4006 | function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
4007 |
|
4008 | function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
4009 |
|
4010 | function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
|
4011 |
|
4012 | function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
|
4013 |
|
4014 | function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
4015 |
|
4016 | function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
|
4017 |
|
4018 | function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
|
4019 |
|
4020 | function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
4021 |
|
4022 | function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
|
4023 |
|
4024 |
|
4025 |
|
4026 |
|
4027 | /**
|
4028 | * Priority 5 (last)
|
4029 | * Full list of reserved functions
|
4030 | * distinct from Keywords due to interaction with parentheses
|
4031 | */
|
4032 | // https://docs.microsoft.com/en-us/sql/t-sql/functions/functions?view=sql-server-ver15
|
4033 |
|
4034 | var reservedFunctions = {
|
4035 | aggregate: ['APPROX_COUNT_DISTINCT', 'AVG', 'CHECKSUM_AGG', 'COUNT', 'COUNT_BIG', 'GROUPING', 'GROUPING_ID', 'MAX', 'MIN', 'STDEV', 'STDEVP', 'SUM', 'VAR', 'VARP'],
|
4036 | analytic: ['CUME_DIST', 'FIRST_VALUE', 'LAG', 'LAST_VALUE', 'LEAD', 'PERCENTILE_CONT', 'PERCENTILE_DISC', 'PERCENT_RANK', 'Collation - COLLATIONPROPERTY', 'Collation - TERTIARY_WEIGHTS'],
|
4037 | configuration: ['@@DBTS', '@@LANGID', '@@LANGUAGE', '@@LOCK_TIMEOUT', '@@MAX_CONNECTIONS', '@@MAX_PRECISION', '@@NESTLEVEL', '@@OPTIONS', '@@REMSERVER', '@@SERVERNAME', '@@SERVICENAME', '@@SPID', '@@TEXTSIZE', '@@VERSION'],
|
4038 | conversion: ['CAST', 'CONVERT', 'PARSE', 'TRY_CAST', 'TRY_CONVERT', 'TRY_PARSE'],
|
4039 | cryptographic: ['ASYMKEY_ID', 'ASYMKEYPROPERTY', 'CERTPROPERTY', 'CERT_ID', 'CRYPT_GEN_RANDOM', 'DECRYPTBYASYMKEY', 'DECRYPTBYCERT', 'DECRYPTBYKEY', 'DECRYPTBYKEYAUTOASYMKEY', 'DECRYPTBYKEYAUTOCERT', 'DECRYPTBYPASSPHRASE', 'ENCRYPTBYASYMKEY', 'ENCRYPTBYCERT', 'ENCRYPTBYKEY', 'ENCRYPTBYPASSPHRASE', 'HASHBYTES', 'IS_OBJECTSIGNED', 'KEY_GUID', 'KEY_ID', 'KEY_NAME', 'SIGNBYASYMKEY', 'SIGNBYCERT', 'SYMKEYPROPERTY', 'VERIFYSIGNEDBYCERT', 'VERIFYSIGNEDBYASYMKEY'],
|
4040 | cursor: ['@@CURSOR_ROWS', '@@FETCH_STATUS', 'CURSOR_STATUS'],
|
4041 | dataType: ['DATALENGTH', 'IDENT_CURRENT', 'IDENT_INCR', 'IDENT_SEED', 'IDENTITY', 'SQL_VARIANT_PROPERTY'],
|
4042 | datetime: ['@@DATEFIRST', 'CURRENT_TIMESTAMP', 'CURRENT_TIMEZONE', 'CURRENT_TIMEZONE_ID', 'DATEADD', 'DATEDIFF', 'DATEDIFF_BIG', 'DATEFROMPARTS', 'DATENAME', 'DATEPART', 'DATETIME2FROMPARTS', 'DATETIMEFROMPARTS', 'DATETIMEOFFSETFROMPARTS', 'DAY', 'EOMONTH', 'GETDATE', 'GETUTCDATE', 'ISDATE', 'MONTH', 'SMALLDATETIMEFROMPARTS', 'SWITCHOFFSET', 'SYSDATETIME', 'SYSDATETIMEOFFSET', 'SYSUTCDATETIME', 'TIMEFROMPARTS', 'TODATETIMEOFFSET', 'YEAR', 'JSON', 'ISJSON', 'JSON_VALUE', 'JSON_QUERY', 'JSON_MODIFY'],
|
4043 | mathematical: ['ABS', 'ACOS', 'ASIN', 'ATAN', 'ATN2', 'CEILING', 'COS', 'COT', 'DEGREES', 'EXP', 'FLOOR', 'LOG', 'LOG10', 'PI', 'POWER', 'RADIANS', 'RAND', 'ROUND', 'SIGN', 'SIN', 'SQRT', 'SQUARE', 'TAN', 'CHOOSE', 'GREATEST', 'IIF', 'LEAST'],
|
4044 | metadata: ['@@PROCID', 'APP_NAME', 'APPLOCK_MODE', 'APPLOCK_TEST', 'ASSEMBLYPROPERTY', 'COL_LENGTH', 'COL_NAME', 'COLUMNPROPERTY', 'DATABASEPROPERTYEX', 'DB_ID', 'DB_NAME', 'FILE_ID', 'FILE_IDEX', 'FILE_NAME', 'FILEGROUP_ID', 'FILEGROUP_NAME', 'FILEGROUPPROPERTY', 'FILEPROPERTY', 'FILEPROPERTYEX', 'FULLTEXTCATALOGPROPERTY', 'FULLTEXTSERVICEPROPERTY', 'INDEX_COL', 'INDEXKEY_PROPERTY', 'INDEXPROPERTY', 'NEXT VALUE FOR', 'OBJECT_DEFINITION', 'OBJECT_ID', 'OBJECT_NAME', 'OBJECT_SCHEMA_NAME', 'OBJECTPROPERTY', 'OBJECTPROPERTYEX', 'ORIGINAL_DB_NAME', 'PARSENAME', 'SCHEMA_ID', 'SCHEMA_NAME', 'SCOPE_IDENTITY', 'SERVERPROPERTY', 'STATS_DATE', 'TYPE_ID', 'TYPE_NAME', 'TYPEPROPERTY'],
|
4045 | ranking: ['DENSE_RANK', 'NTILE', 'RANK', 'ROW_NUMBER', 'PUBLISHINGSERVERNAME'],
|
4046 | security: ['CERTENCODED', 'CERTPRIVATEKEY', 'CURRENT_USER', 'DATABASE_PRINCIPAL_ID', 'HAS_DBACCESS', 'HAS_PERMS_BY_NAME', 'IS_MEMBER', 'IS_ROLEMEMBER', 'IS_SRVROLEMEMBER', 'LOGINPROPERTY', 'ORIGINAL_LOGIN', 'PERMISSIONS', 'PWDENCRYPT', 'PWDCOMPARE', 'SESSION_USER', 'SESSIONPROPERTY', 'SUSER_ID', 'SUSER_NAME', 'SUSER_SID', 'SUSER_SNAME', 'SYSTEM_USER', 'USER', 'USER_ID', 'USER_NAME'],
|
4047 | string: ['ASCII', 'CHAR', 'CHARINDEX', 'CONCAT', 'CONCAT_WS', 'DIFFERENCE', 'FORMAT', 'LEFT', 'LEN', 'LOWER', 'LTRIM', 'NCHAR', 'PATINDEX', 'QUOTENAME', 'REPLACE', 'REPLICATE', 'REVERSE', 'RIGHT', 'RTRIM', 'SOUNDEX', 'SPACE', 'STR', 'STRING_AGG', 'STRING_ESCAPE', 'STUFF', 'SUBSTRING', 'TRANSLATE', 'TRIM', 'UNICODE', 'UPPER'],
|
4048 | system: ['$PARTITION', '@@ERROR', '@@IDENTITY', '@@PACK_RECEIVED', '@@ROWCOUNT', '@@TRANCOUNT', 'BINARY_CHECKSUM', 'CHECKSUM', 'COMPRESS', 'CONNECTIONPROPERTY', 'CONTEXT_INFO', 'CURRENT_REQUEST_ID', 'CURRENT_TRANSACTION_ID', 'DECOMPRESS', 'ERROR_LINE', 'ERROR_MESSAGE', 'ERROR_NUMBER', 'ERROR_PROCEDURE', 'ERROR_SEVERITY', 'ERROR_STATE', 'FORMATMESSAGE', 'GET_FILESTREAM_TRANSACTION_CONTEXT', 'GETANSINULL', 'HOST_ID', 'HOST_NAME', 'ISNULL', 'ISNUMERIC', 'MIN_ACTIVE_ROWVERSION', 'NEWID', 'NEWSEQUENTIALID', 'ROWCOUNT_BIG', 'SESSION_CONTEXT', 'XACT_STATE'],
|
4049 | statistical: ['@@CONNECTIONS', '@@CPU_BUSY', '@@IDLE', '@@IO_BUSY', '@@PACK_SENT', '@@PACKET_ERRORS', '@@TIMETICKS', '@@TOTAL_ERRORS', '@@TOTAL_READ', '@@TOTAL_WRITE', 'TEXTPTR', 'TEXTVALID'],
|
4050 | trigger: ['COLUMNS_UPDATED', 'EVENTDATA', 'TRIGGER_NESTLEVEL', 'UPDATE']
|
4051 | }; // TODO: dedupe these reserved word lists
|
4052 | // https://docs.microsoft.com/en-us/sql/t-sql/language-elements/reserved-keywords-transact-sql?view=sql-server-ver15
|
4053 |
|
4054 | /**
|
4055 | * Priority 5 (last)
|
4056 | * Full list of reserved words
|
4057 | * any words that are in a higher priority are removed
|
4058 | */
|
4059 |
|
4060 | var reservedKeywords = {
|
4061 | standard: ['ADD', 'ALL', 'ALTER', 'AND', 'ANY', 'AS', 'ASC', 'AUTHORIZATION', 'BACKUP', 'BEGIN', 'BETWEEN', 'BREAK', 'BROWSE', 'BULK', 'BY', 'CASCADE', 'CASE', 'CHECK', 'CHECKPOINT', 'CLOSE', 'CLUSTERED', 'COALESCE', 'COLLATE', 'COLUMN', 'COMMIT', 'COMPUTE', 'CONSTRAINT', 'CONTAINS', 'CONTAINSTABLE', 'CONTINUE', 'CONVERT', 'CREATE', 'CROSS', 'CURRENT', 'CURRENT_DATE', 'CURRENT_TIME', 'CURRENT_TIMESTAMP', 'CURRENT_USER', 'CURSOR', 'DATABASE', 'DBCC', 'DEALLOCATE', 'DECLARE', 'DEFAULT', 'DELETE', 'DENY', 'DESC', 'DISK', 'DISTINCT', 'DISTRIBUTED', 'DOUBLE', 'DROP', 'DUMP', 'ERRLVL', 'ESCAPE', 'EXEC', 'EXECUTE', 'EXISTS', 'EXIT', 'EXTERNAL', 'FETCH', 'FILE', 'FILLFACTOR', 'FOR', 'FOREIGN', 'FREETEXT', 'FREETEXTTABLE', 'FROM', 'FULL', 'FUNCTION', 'GOTO', 'GRANT', 'GROUP', 'HAVING', 'HOLDLOCK', 'IDENTITY', 'IDENTITYCOL', 'IDENTITY_INSERT', 'IF', 'IN', 'INDEX', 'INNER', 'INSERT', 'INTERSECT', 'INTO', 'IS', 'JOIN', 'KEY', 'KILL', 'LEFT', 'LIKE', 'LINENO', 'LOAD', 'MERGE', 'NATIONAL', 'NOCHECK', 'NONCLUSTERED', 'NOT', 'NULL', 'NULLIF', 'OF', 'OFF', 'OFFSETS', 'ON DELETE', 'ON UPDATE', 'OPEN', 'OPENDATASOURCE', 'OPENQUERY', 'OPENROWSET', 'OPENXML', 'OPTION', 'OR', 'ORDER', 'OUTER', 'OVER', 'PERCENT', 'PIVOT', 'PLAN', 'PRECISION', 'PRIMARY', 'PRINT', 'PROC', 'PROCEDURE', 'PUBLIC', 'RAISERROR', 'READ', 'READTEXT', 'RECONFIGURE', 'REFERENCES', 'REPLICATION', 'RESTORE', 'RESTRICT', 'RETURN', 'REVERT', 'REVOKE', 'RIGHT', 'ROLLBACK', 'ROWCOUNT', 'ROWGUIDCOL', 'RULE', 'SAVE', 'SCHEMA', 'SECURITYAUDIT', 'SELECT', 'SEMANTICKEYPHRASETABLE', 'SEMANTICSIMILARITYDETAILSTABLE', 'SEMANTICSIMILARITYTABLE', 'SESSION_USER', 'SET', 'SETUSER', 'SHUTDOWN', 'SOME', 'STATISTICS', 'SYSTEM_USER', 'TABLE', 'TABLESAMPLE', 'TEXTSIZE', 'THEN', 'TO', 'TOP', 'TRAN', 'TRANSACTION', 'TRIGGER', 'TRUNCATE', 'TRY_CONVERT', 'TSEQUAL', 'UNION', 'UNIQUE', 'UNPIVOT', 'UPDATE', 'UPDATETEXT', 'USE', 'USER', 'VALUES', 'VARYING', 'VIEW', 'WAITFOR', 'WHERE', 'WHILE', 'WITH', 'WITHIN GROUP', 'WRITETEXT'],
|
4062 | odbc: ['ABSOLUTE', 'ACTION', 'ADA', 'ADD', 'ALL', 'ALLOCATE', 'ALTER', 'AND', 'ANY', 'ARE', 'AS', 'ASC', 'ASSERTION', 'AT', 'AUTHORIZATION', 'AVG', 'BEGIN', 'BETWEEN', 'BIT', 'BIT_LENGTH', 'BOTH', 'BY', 'CASCADE', 'CASCADED', 'CASE', 'CAST', 'CATALOG', 'CHAR', 'CHARACTER', 'CHARACTER_LENGTH', 'CHAR_LENGTH', 'CHECK', 'CLOSE', 'COALESCE', 'COLLATE', 'COLLATION', 'COLUMN', 'COMMIT', 'CONNECT', 'CONNECTION', 'CONSTRAINT', 'CONSTRAINTS', 'CONTINUE', 'CONVERT', 'CORRESPONDING', 'COUNT', 'CREATE', 'CROSS', 'CURRENT', 'CURRENT_DATE', 'CURRENT_TIME', 'CURRENT_TIMESTAMP', 'CURRENT_USER', 'CURSOR', 'DATE', 'DAY', 'DEALLOCATE', 'DEC', 'DECIMAL', 'DECLARE', 'DEFAULT', 'DEFERRABLE', 'DEFERRED', 'DELETE', 'DESC', 'DESCRIBE', 'DESCRIPTOR', 'DIAGNOSTICS', 'DISCONNECT', 'DISTINCT', 'DOMAIN', 'DOUBLE', 'DROP', 'END-EXEC', 'ESCAPE', 'EXCEPTION', 'EXEC', 'EXECUTE', 'EXISTS', 'EXTERNAL', 'EXTRACT', 'FALSE', 'FETCH', 'FIRST', 'FLOAT', 'FOR', 'FOREIGN', 'FORTRAN', 'FOUND', 'FROM', 'FULL', 'GET', 'GLOBAL', 'GO', 'GOTO', 'GRANT', 'GROUP', 'HAVING', 'HOUR', 'IDENTITY', 'IMMEDIATE', 'IN', 'INCLUDE', 'INDEX', 'INDICATOR', 'INITIALLY', 'INNER', 'INPUT', 'INSENSITIVE', 'INSERT', 'INT', 'INTEGER', 'INTERSECT', 'INTERVAL', 'INTO', 'IS', 'ISOLATION', 'JOIN', 'KEY', 'LANGUAGE', 'LAST', 'LEADING', 'LEFT', 'LEVEL', 'LIKE', 'LOCAL', 'LOWER', 'MATCH', 'MAX', 'MIN', 'MINUTE', 'MODULE', 'MONTH', 'NAMES', 'NATIONAL', 'NATURAL', 'NCHAR', 'NEXT', 'NO', 'NONE', 'NOT', 'NULL', 'NULLIF', 'NUMERIC', 'OCTET_LENGTH', 'OF', 'ONLY', 'OPEN', 'OPTION', 'OR', 'ORDER', 'OUTER', 'OUTPUT', 'OVERLAPS', 'PAD', 'PARTIAL', 'PASCAL', 'POSITION', 'PRECISION', 'PREPARE', 'PRESERVE', 'PRIMARY', 'PRIOR', 'PRIVILEGES', 'PROCEDURE', 'PUBLIC', 'READ', 'REAL', 'REFERENCES', 'RELATIVE', 'RESTRICT', 'REVOKE', 'RIGHT', 'ROLLBACK', 'ROWS', 'SCHEMA', 'SCROLL', 'SECOND', 'SECTION', 'SELECT', 'SESSION', 'SESSION_USER', 'SET', 'SIZE', 'SMALLINT', 'SOME', 'SPACE', 'SQL', 'SQLCA', 'SQLCODE', 'SQLERROR', 'SQLSTATE', 'SQLWARNING', 'SUBSTRING', 'SUM', 'SYSTEM_USER', 'TABLE', 'TEMPORARY', 'TIME', 'TIMESTAMP', 'TIMEZONE_HOUR', 'TIMEZONE_MINUTE', 'TO', 'TRAILING', 'TRANSACTION', 'TRANSLATE', 'TRANSLATION', 'TRIM', 'TRUE', 'UNION', 'UNIQUE', 'UNKNOWN', 'UPDATE', 'UPPER', 'USAGE', 'USER', 'VALUE', 'VALUES', 'VARCHAR', 'VARYING', 'VIEW', 'WHENEVER', 'WHERE', 'WITH', 'WORK', 'WRITE', 'YEAR', 'ZONE'],
|
4063 | future: ['ABSOLUTE', 'ACTION', 'ADMIN', 'AFTER', 'AGGREGATE', 'ALIAS', 'ALLOCATE', 'ARE', 'ARRAY', 'ASENSITIVE', 'ASSERTION', 'ASYMMETRIC', 'AT', 'ATOMIC', 'BEFORE', 'BINARY', 'BIT', 'BLOB', 'BOOLEAN', 'BOTH', 'BREADTH', 'CALL', 'CALLED', 'CARDINALITY', 'CASCADED', 'CAST', 'CATALOG', 'CHAR', 'CHARACTER', 'CLASS', 'CLOB', 'COLLATION', 'COLLECT', 'COMPLETION', 'CONDITION', 'CONNECT', 'CONNECTION', 'CONSTRAINTS', 'CONSTRUCTOR', 'CORR', 'CORRESPONDING', 'COVAR_POP', 'COVAR_SAMP', 'CUBE', 'CUME_DIST', 'CURRENT_CATALOG', 'CURRENT_DEFAULT_TRANSFORM_GROUP', 'CURRENT_PATH', 'CURRENT_ROLE', 'CURRENT_SCHEMA', 'CURRENT_TRANSFORM_GROUP_FOR_TYPE', 'CYCLE', 'DATA', 'DATE', 'DAY', 'DEC', 'DECIMAL', 'DEFERRABLE', 'DEFERRED', 'DEPTH', 'DEREF', 'DESCRIBE', 'DESCRIPTOR', 'DESTROY', 'DESTRUCTOR', 'DETERMINISTIC', 'DIAGNOSTICS', 'DICTIONARY', 'DISCONNECT', 'DOMAIN', 'DYNAMIC', 'EACH', 'ELEMENT', 'END-EXEC', 'EQUALS', 'EVERY', 'FALSE', 'FILTER', 'FIRST', 'FLOAT', 'FOUND', 'FREE', 'FULLTEXTTABLE', 'FUSION', 'GENERAL', 'GET', 'GLOBAL', 'GO', 'GROUPING', 'HOLD', 'HOST', 'HOUR', 'IGNORE', 'IMMEDIATE', 'INDICATOR', 'INITIALIZE', 'INITIALLY', 'INOUT', 'INPUT', 'INT', 'INTEGER', 'INTERSECTION', 'INTERVAL', 'ISOLATION', 'ITERATE', 'LANGUAGE', 'LARGE', 'LAST', 'LATERAL', 'LEADING', 'LESS', 'LEVEL', 'LIKE_REGEX', 'LIMIT', 'LN', 'LOCAL', 'LOCALTIME', 'LOCALTIMESTAMP', 'LOCATOR', 'MAP', 'MATCH', 'MEMBER', 'METHOD', 'MINUTE', 'MOD', 'MODIFIES', 'MODIFY', 'MODULE', 'MONTH', 'MULTISET', 'NAMES', 'NATURAL', 'NCHAR', 'NCLOB', 'NEW', 'NEXT', 'NO', 'NONE', 'NORMALIZE', 'NUMERIC', 'OBJECT', 'OCCURRENCES_REGEX', 'OLD', 'ONLY', 'OPERATION', 'ORDINALITY', 'OUT', 'OUTPUT', 'OVERLAY', 'PAD', 'PARAMETER', 'PARAMETERS', 'PARTIAL', 'PARTITION', 'PATH', 'PERCENTILE_CONT', 'PERCENTILE_DISC', 'PERCENT_RANK', 'POSITION_REGEX', 'POSTFIX', 'PREFIX', 'PREORDER', 'PREPARE', 'PRESERVE', 'PRIOR', 'PRIVILEGES', 'RANGE', 'READS', 'REAL', 'RECURSIVE', 'REF', 'REFERENCING', 'REGR_AVGX', 'REGR_AVGY', 'REGR_COUNT', 'REGR_INTERCEPT', 'REGR_R2', 'REGR_SLOPE', 'REGR_SXX', 'REGR_SXY', 'REGR_SYY', 'RELATIVE', 'RELEASE', 'RESULT', 'RETURNS', 'ROLE', 'ROLLUP', 'ROUTINE', 'ROW', 'ROWS', 'SAVEPOINT', 'SCOPE', 'SCROLL', 'SEARCH', 'SECOND', 'SECTION', 'SENSITIVE', 'SEQUENCE', 'SESSION', 'SETS', 'SIMILAR', 'SIZE', 'SMALLINT', 'SPACE', 'SPECIFIC', 'SPECIFICTYPE', 'SQL', 'SQLEXCEPTION', 'SQLSTATE', 'SQLWARNING', 'START', 'STATE', 'STATEMENT', 'STATIC', 'STDDEV_POP', 'STDDEV_SAMP', 'STRUCTURE', 'SUBMULTISET', 'SUBSTRING_REGEX', 'SYMMETRIC', 'SYSTEM', 'TEMPORARY', 'TERMINATE', 'THAN', 'TIME', 'TIMESTAMP', 'TIMEZONE_HOUR', 'TIMEZONE_MINUTE', 'TRAILING', 'TRANSLATE_REGEX', 'TRANSLATION', 'TREAT', 'TRUE', 'UESCAPE', 'UNDER', 'UNKNOWN', 'UNNEST', 'USAGE', 'USING', 'VALUE', 'VARCHAR', 'VARIABLE', 'VAR_POP', 'VAR_SAMP', 'WHENEVER', 'WIDTH_BUCKET', 'WINDOW', 'WITHIN', 'WITHOUT', 'WORK', 'WRITE', 'XMLAGG', 'XMLATTRIBUTES', 'XMLBINARY', 'XMLCAST', 'XMLCOMMENT', 'XMLCONCAT', 'XMLDOCUMENT', 'XMLELEMENT', 'XMLEXISTS', 'XMLFOREST', 'XMLITERATE', 'XMLNAMESPACES', 'XMLPARSE', 'XMLPI', 'XMLQUERY', 'XMLSERIALIZE', 'XMLTABLE', 'XMLTEXT', 'XMLVALIDATE', 'YEAR', 'ZONE']
|
4064 | };
|
4065 | /**
|
4066 | * Priority 1 (first)
|
4067 | * keywords that begin a new statement
|
4068 | * will begin new indented block
|
4069 | */
|
4070 | // https://docs.microsoft.com/en-us/sql/t-sql/statements/statements?view=sql-server-ver15
|
4071 |
|
4072 | var reservedCommands = ['ADD SENSITIVITY CLASSIFICATION', 'ADD SIGNATURE', 'AGGREGATE', 'ANSI_DEFAULTS', 'ANSI_NULLS', 'ANSI_NULL_DFLT_OFF', 'ANSI_NULL_DFLT_ON', 'ANSI_PADDING', 'ANSI_WARNINGS', 'APPLICATION ROLE', 'ARITHABORT', 'ARITHIGNORE', 'ASSEMBLY', 'ASYMMETRIC KEY', 'AUTHORIZATION', 'AVAILABILITY GROUP', 'BACKUP', 'BACKUP CERTIFICATE', 'BACKUP MASTER KEY', 'BACKUP SERVICE MASTER KEY', 'BEGIN CONVERSATION TIMER', 'BEGIN DIALOG CONVERSATION', 'BROKER PRIORITY', 'BULK INSERT', 'CERTIFICATE', 'CLOSE MASTER KEY', 'CLOSE SYMMETRIC KEY', 'COLLATE', 'COLUMN ENCRYPTION KEY', 'COLUMN MASTER KEY', 'COLUMNSTORE INDEX', 'CONCAT_NULL_YIELDS_NULL', 'CONTEXT_INFO', 'CONTRACT', 'CREDENTIAL', 'CRYPTOGRAPHIC PROVIDER', 'CURSOR_CLOSE_ON_COMMIT', 'DATABASE', 'DATABASE AUDIT SPECIFICATION', 'DATABASE ENCRYPTION KEY', 'DATABASE HADR', 'DATABASE SCOPED CONFIGURATION', 'DATABASE SCOPED CREDENTIAL', 'DATABASE SET', 'DATEFIRST', 'DATEFORMAT', 'DEADLOCK_PRIORITY', 'DEFAULT', 'DELETE', 'DENY', 'DENY XML', 'DISABLE TRIGGER', 'ENABLE TRIGGER', 'END CONVERSATION', 'ENDPOINT', 'EVENT NOTIFICATION', 'EVENT SESSION', 'EXECUTE AS', 'EXTERNAL DATA SOURCE', 'EXTERNAL FILE FORMAT', 'EXTERNAL LANGUAGE', 'EXTERNAL LIBRARY', 'EXTERNAL RESOURCE POOL', 'EXTERNAL TABLE', 'FIPS_FLAGGER', 'FMTONLY', 'FORCEPLAN', 'FULLTEXT CATALOG', 'FULLTEXT INDEX', 'FULLTEXT STOPLIST', 'FUNCTION', 'GET CONVERSATION GROUP', 'GET_TRANSMISSION_STATUS', 'GRANT', 'GRANT XML', 'IDENTITY_INSERT', 'IMPLICIT_TRANSACTIONS', 'INDEX', 'INSERT', 'LANGUAGE', 'LOCK_TIMEOUT', 'LOGIN', 'MASTER KEY', 'MERGE', 'MESSAGE TYPE', 'MOVE CONVERSATION', 'NOCOUNT', 'NOEXEC', 'NUMERIC_ROUNDABORT', 'OFFSETS', 'OPEN MASTER KEY', 'OPEN SYMMETRIC KEY', 'PARSEONLY', 'PARTITION FUNCTION', 'PARTITION SCHEME', 'PROCEDURE', 'QUERY_GOVERNOR_COST_LIMIT', 'QUEUE', 'QUOTED_IDENTIFIER', 'RECEIVE', 'REMOTE SERVICE BINDING', 'REMOTE_PROC_TRANSACTIONS', 'RESOURCE GOVERNOR', 'RESOURCE POOL', 'RESTORE', 'RESTORE FILELISTONLY', 'RESTORE HEADERONLY', 'RESTORE LABELONLY', 'RESTORE MASTER KEY', 'RESTORE REWINDONLY', 'RESTORE SERVICE MASTER KEY', 'RESTORE VERIFYONLY', 'REVERT', 'REVOKE', 'REVOKE XML', 'ROLE', 'ROUTE', 'ROWCOUNT', 'RULE', 'SCHEMA', 'SEARCH PROPERTY LIST', 'SECURITY POLICY', 'SELECTIVE XML INDEX', 'SEND', 'SENSITIVITY CLASSIFICATION', 'SEQUENCE', 'SERVER AUDIT', 'SERVER AUDIT SPECIFICATION', 'SERVER CONFIGURATION', 'SERVER ROLE', 'SERVICE', 'SERVICE MASTER KEY', 'SET', 'SETUSER', 'SHOWPLAN_ALL', 'SHOWPLAN_TEXT', 'SHOWPLAN_XML', 'SIGNATURE', 'SPATIAL INDEX', 'STATISTICS', 'STATISTICS IO', 'STATISTICS PROFILE', 'STATISTICS TIME', 'STATISTICS XML', 'SYMMETRIC KEY', 'SYNONYM', 'TABLE', 'TABLE IDENTITY', 'TEXTSIZE', 'TRANSACTION ISOLATION LEVEL', 'TRIGGER', 'TRUNCATE TABLE', 'TYPE', 'UPDATE', 'UPDATE STATISTICS', 'USER', 'VIEW', 'WORKLOAD GROUP', 'XACT_ABORT', 'XML INDEX', 'XML SCHEMA COLLECTION', // other
|
4073 | 'ALTER COLUMN', 'ALTER TABLE', 'CREATE TABLE', 'FROM', 'GROUP BY', 'HAVING', 'INSERT INTO', 'DROP TABLE', 'SET SCHEMA', 'LIMIT', 'OFFSET', 'ORDER BY', 'SELECT', 'VALUES', 'WHERE', 'WITH'];
|
4074 | /**
|
4075 | * Priority 2
|
4076 | * commands that operate on two tables or subqueries
|
4077 | * two main categories: joins and boolean set operators
|
4078 | */
|
4079 |
|
4080 | var reservedBinaryCommands = [// set booleans
|
4081 | 'INTERSECT', 'INTERSECT ALL', 'INTERSECT DISTINCT', 'UNION', 'UNION ALL', 'UNION DISTINCT', 'EXCEPT', 'EXCEPT ALL', 'EXCEPT DISTINCT', 'MINUS', 'MINUS ALL', 'MINUS DISTINCT', // joins
|
4082 | 'JOIN', 'INNER JOIN', 'LEFT JOIN', 'LEFT OUTER JOIN', 'RIGHT JOIN', 'RIGHT OUTER JOIN', 'FULL JOIN', 'FULL OUTER JOIN', 'CROSS JOIN'];
|
4083 | /**
|
4084 | * Priority 3
|
4085 | * keywords that follow a previous Statement, must be attached to subsequent data
|
4086 | * can be fully inline or on newline with optional indent
|
4087 | */
|
4088 |
|
4089 | var reservedDependentClauses = ['WHEN', 'ELSE']; // https://docs.microsoft.com/en-us/sql/t-sql/language-reference?view=sql-server-ver15
|
4090 |
|
4091 | var TSqlFormatter = /*#__PURE__*/function (_Formatter) {
|
4092 | _inherits(TSqlFormatter, _Formatter);
|
4093 |
|
4094 | var _super = _createSuper(TSqlFormatter);
|
4095 |
|
4096 | function TSqlFormatter() {
|
4097 | _classCallCheck(this, TSqlFormatter);
|
4098 |
|
4099 | return _super.apply(this, arguments);
|
4100 | }
|
4101 |
|
4102 | _createClass(TSqlFormatter, [{
|
4103 | key: "tokenizer",
|
4104 | value: function tokenizer() {
|
4105 | return new _core_Tokenizer__WEBPACK_IMPORTED_MODULE_1__["default"]({
|
4106 | reservedCommands: TSqlFormatter.reservedCommands,
|
4107 | reservedBinaryCommands: TSqlFormatter.reservedBinaryCommands,
|
4108 | reservedDependentClauses: TSqlFormatter.reservedDependentClauses,
|
4109 | reservedJoinConditions: TSqlFormatter.reservedJoinConditions,
|
4110 | reservedLogicalOperators: TSqlFormatter.reservedLogicalOperators,
|
4111 | reservedKeywords: TSqlFormatter.reservedKeywords,
|
4112 | stringTypes: TSqlFormatter.stringTypes,
|
4113 | blockStart: TSqlFormatter.blockStart,
|
4114 | blockEnd: TSqlFormatter.blockEnd,
|
4115 | indexedPlaceholderTypes: TSqlFormatter.indexedPlaceholderTypes,
|
4116 | namedPlaceholderTypes: TSqlFormatter.namedPlaceholderTypes,
|
4117 | lineCommentTypes: TSqlFormatter.lineCommentTypes,
|
4118 | specialWordChars: TSqlFormatter.specialWordChars,
|
4119 | operators: TSqlFormatter.operators // TODO: Support for money constants
|
4120 |
|
4121 | });
|
4122 | }
|
4123 | }]);
|
4124 |
|
4125 | return TSqlFormatter;
|
4126 | }(_core_Formatter__WEBPACK_IMPORTED_MODULE_0__["default"]);
|
4127 |
|
4128 |
|
4129 | TSqlFormatter.reservedCommands = reservedCommands;
|
4130 | TSqlFormatter.reservedBinaryCommands = reservedBinaryCommands;
|
4131 | TSqlFormatter.reservedDependentClauses = reservedDependentClauses;
|
4132 | TSqlFormatter.reservedJoinConditions = ['ON', 'USING'];
|
4133 | TSqlFormatter.reservedLogicalOperators = ['AND', 'OR'];
|
4134 | TSqlFormatter.reservedKeywords = (0,_utils__WEBPACK_IMPORTED_MODULE_2__.dedupe)([].concat(_toConsumableArray(Object.values(reservedFunctions).reduce(function (acc, arr) {
|
4135 | return [].concat(_toConsumableArray(acc), _toConsumableArray(arr));
|
4136 | }, [])), _toConsumableArray(Object.values(reservedKeywords).reduce(function (acc, arr) {
|
4137 | return [].concat(_toConsumableArray(acc), _toConsumableArray(arr));
|
4138 | }, []))));
|
4139 | TSqlFormatter.stringTypes = ["\"\"", "N''", "''", '[]', '``'];
|
4140 | TSqlFormatter.blockStart = ['(', 'CASE'];
|
4141 | TSqlFormatter.blockEnd = [')', 'END'];
|
4142 | TSqlFormatter.indexedPlaceholderTypes = [];
|
4143 | TSqlFormatter.namedPlaceholderTypes = ['@'];
|
4144 | TSqlFormatter.lineCommentTypes = ['--'];
|
4145 | TSqlFormatter.specialWordChars = {
|
4146 | any: '#@'
|
4147 | };
|
4148 | TSqlFormatter.operators = ['!<', '!>', '+=', '-=', '*=', '/=', '%=', '|=', '&=', '^=', '::'];
|
4149 |
|
4150 | /***/ }),
|
4151 |
|
4152 | /***/ "./src/sqlFormatter.ts":
|
4153 | /*!*****************************!*\
|
4154 | !*** ./src/sqlFormatter.ts ***!
|
4155 | \*****************************/
|
4156 | /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
4157 |
|
4158 | __webpack_require__.r(__webpack_exports__);
|
4159 | /* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
4160 | /* harmony export */ "ConfigError": () => (/* binding */ ConfigError),
|
4161 | /* harmony export */ "format": () => (/* binding */ format),
|
4162 | /* harmony export */ "formatters": () => (/* binding */ formatters),
|
4163 | /* harmony export */ "supportedDialects": () => (/* binding */ supportedDialects)
|
4164 | /* harmony export */ });
|
4165 | /* harmony import */ var _languages_bigquery_formatter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./languages/bigquery.formatter */ "./src/languages/bigquery.formatter.ts");
|
4166 | /* harmony import */ var _languages_db2_formatter__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./languages/db2.formatter */ "./src/languages/db2.formatter.ts");
|
4167 | /* harmony import */ var _languages_hive_formatter__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./languages/hive.formatter */ "./src/languages/hive.formatter.ts");
|
4168 | /* harmony import */ var _languages_mariadb_formatter__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./languages/mariadb.formatter */ "./src/languages/mariadb.formatter.ts");
|
4169 | /* harmony import */ var _languages_mysql_formatter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./languages/mysql.formatter */ "./src/languages/mysql.formatter.ts");
|
4170 | /* harmony import */ var _languages_n1ql_formatter__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./languages/n1ql.formatter */ "./src/languages/n1ql.formatter.ts");
|
4171 | /* harmony import */ var _languages_plsql_formatter__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./languages/plsql.formatter */ "./src/languages/plsql.formatter.ts");
|
4172 | /* harmony import */ var _languages_postgresql_formatter__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./languages/postgresql.formatter */ "./src/languages/postgresql.formatter.ts");
|
4173 | /* harmony import */ var _languages_redshift_formatter__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./languages/redshift.formatter */ "./src/languages/redshift.formatter.ts");
|
4174 | /* harmony import */ var _languages_sparksql_formatter__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./languages/sparksql.formatter */ "./src/languages/sparksql.formatter.ts");
|
4175 | /* harmony import */ var _languages_standardsql_formatter__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./languages/standardsql.formatter */ "./src/languages/standardsql.formatter.ts");
|
4176 | /* harmony import */ var _languages_tsql_formatter__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./languages/tsql.formatter */ "./src/languages/tsql.formatter.ts");
|
4177 | /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ./utils */ "./src/utils.ts");
|
4178 | function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
4179 |
|
4180 | function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
4181 |
|
4182 | function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
4183 |
|
4184 | function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
|
4185 |
|
4186 | function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
4187 |
|
4188 | function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
|
4189 |
|
4190 | function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
|
4191 |
|
4192 | function _wrapNativeSuper(Class) { var _cache = typeof Map === "function" ? new Map() : undefined; _wrapNativeSuper = function _wrapNativeSuper(Class) { if (Class === null || !_isNativeFunction(Class)) return Class; if (typeof Class !== "function") { throw new TypeError("Super expression must either be null or a function"); } if (typeof _cache !== "undefined") { if (_cache.has(Class)) return _cache.get(Class); _cache.set(Class, Wrapper); } function Wrapper() { return _construct(Class, arguments, _getPrototypeOf(this).constructor); } Wrapper.prototype = Object.create(Class.prototype, { constructor: { value: Wrapper, enumerable: false, writable: true, configurable: true } }); return _setPrototypeOf(Wrapper, Class); }; return _wrapNativeSuper(Class); }
|
4193 |
|
4194 | function _construct(Parent, args, Class) { if (_isNativeReflectConstruct()) { _construct = Reflect.construct; } else { _construct = function _construct(Parent, args, Class) { var a = [null]; a.push.apply(a, args); var Constructor = Function.bind.apply(Parent, a); var instance = new Constructor(); if (Class) _setPrototypeOf(instance, Class.prototype); return instance; }; } return _construct.apply(null, arguments); }
|
4195 |
|
4196 | function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
4197 |
|
4198 | function _isNativeFunction(fn) { return Function.toString.call(fn).indexOf("[native code]") !== -1; }
|
4199 |
|
4200 | function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
|
4201 |
|
4202 | function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
|
4203 |
|
4204 | function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
4205 |
|
4206 |
|
4207 |
|
4208 |
|
4209 |
|
4210 |
|
4211 |
|
4212 |
|
4213 |
|
4214 |
|
4215 |
|
4216 |
|
4217 |
|
4218 |
|
4219 | var formatters = {
|
4220 | bigquery: _languages_bigquery_formatter__WEBPACK_IMPORTED_MODULE_0__["default"],
|
4221 | db2: _languages_db2_formatter__WEBPACK_IMPORTED_MODULE_1__["default"],
|
4222 | hive: _languages_hive_formatter__WEBPACK_IMPORTED_MODULE_2__["default"],
|
4223 | mariadb: _languages_mariadb_formatter__WEBPACK_IMPORTED_MODULE_3__["default"],
|
4224 | mysql: _languages_mysql_formatter__WEBPACK_IMPORTED_MODULE_4__["default"],
|
4225 | n1ql: _languages_n1ql_formatter__WEBPACK_IMPORTED_MODULE_5__["default"],
|
4226 | plsql: _languages_plsql_formatter__WEBPACK_IMPORTED_MODULE_6__["default"],
|
4227 | postgresql: _languages_postgresql_formatter__WEBPACK_IMPORTED_MODULE_7__["default"],
|
4228 | redshift: _languages_redshift_formatter__WEBPACK_IMPORTED_MODULE_8__["default"],
|
4229 | spark: _languages_sparksql_formatter__WEBPACK_IMPORTED_MODULE_9__["default"],
|
4230 | sql: _languages_standardsql_formatter__WEBPACK_IMPORTED_MODULE_10__["default"],
|
4231 | tsql: _languages_tsql_formatter__WEBPACK_IMPORTED_MODULE_11__["default"]
|
4232 | };
|
4233 | var supportedDialects = Object.keys(formatters);
|
4234 | var defaultOptions = {
|
4235 | language: 'sql',
|
4236 | tabWidth: 2,
|
4237 | useTabs: false,
|
4238 | keywordCase: 'preserve',
|
4239 | indentStyle: 'standard',
|
4240 | multilineLists: 'always',
|
4241 | logicalOperatorNewline: 'before',
|
4242 | aliasAs: 'preserve',
|
4243 | tabulateAlias: false,
|
4244 | commaPosition: 'after',
|
4245 | newlineBeforeOpenParen: true,
|
4246 | newlineBeforeCloseParen: true,
|
4247 | expressionWidth: 50,
|
4248 | linesBetweenQueries: 1,
|
4249 | denseOperators: false,
|
4250 | newlineBeforeSemicolon: false
|
4251 | };
|
4252 | /**
|
4253 | * Format whitespace in a query to make it easier to read.
|
4254 | *
|
4255 | * @param {string} query - input SQL query string
|
4256 | * @param {FormatOptions} cfg Configuration options (see docs in README)
|
4257 | * @return {string} formatted query
|
4258 | */
|
4259 |
|
4260 | var format = function format(query) {
|
4261 | var cfg = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
|
4262 |
|
4263 | if (typeof query !== 'string') {
|
4264 | throw new Error('Invalid query argument. Expected string, instead got ' + _typeof(query));
|
4265 | }
|
4266 |
|
4267 | var options = validateConfig(Object.assign(Object.assign({}, defaultOptions), cfg));
|
4268 | var Formatter = formatters[options.language];
|
4269 | return new Formatter(options).format(query);
|
4270 | };
|
4271 | var ConfigError = /*#__PURE__*/function (_Error) {
|
4272 | _inherits(ConfigError, _Error);
|
4273 |
|
4274 | var _super = _createSuper(ConfigError);
|
4275 |
|
4276 | function ConfigError() {
|
4277 | _classCallCheck(this, ConfigError);
|
4278 |
|
4279 | return _super.apply(this, arguments);
|
4280 | }
|
4281 |
|
4282 | return _createClass(ConfigError);
|
4283 | }( /*#__PURE__*/_wrapNativeSuper(Error));
|
4284 |
|
4285 | function validateConfig(cfg) {
|
4286 | if (!supportedDialects.includes(cfg.language)) {
|
4287 | throw new ConfigError("Unsupported SQL dialect: ".concat(cfg.language));
|
4288 | }
|
4289 |
|
4290 | if ((0,_utils__WEBPACK_IMPORTED_MODULE_12__.isNumber)(cfg.multilineLists) && cfg.multilineLists <= 0) {
|
4291 | throw new ConfigError('multilineLists config must be a positive number.');
|
4292 | }
|
4293 |
|
4294 | if (cfg.expressionWidth <= 0) {
|
4295 | throw new ConfigError("expressionWidth config must be positive number. Received ".concat(cfg.expressionWidth, " instead."));
|
4296 | }
|
4297 |
|
4298 | if (cfg.commaPosition === 'before' && cfg.useTabs) {
|
4299 | throw new ConfigError('commaPosition: before does not work when tabs are used for indentation.');
|
4300 | }
|
4301 |
|
4302 | return cfg;
|
4303 | }
|
4304 |
|
4305 | /***/ }),
|
4306 |
|
4307 | /***/ "./src/types.ts":
|
4308 | /*!**********************!*\
|
4309 | !*** ./src/types.ts ***!
|
4310 | \**********************/
|
4311 | /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
4312 |
|
4313 | __webpack_require__.r(__webpack_exports__);
|
4314 |
|
4315 |
|
4316 | /***/ }),
|
4317 |
|
4318 | /***/ "./src/utils.ts":
|
4319 | /*!**********************!*\
|
4320 | !*** ./src/utils.ts ***!
|
4321 | \**********************/
|
4322 | /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
4323 |
|
4324 | __webpack_require__.r(__webpack_exports__);
|
4325 | /* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
4326 | /* harmony export */ "dedupe": () => (/* binding */ dedupe),
|
4327 | /* harmony export */ "escapeRegExp": () => (/* binding */ escapeRegExp),
|
4328 | /* harmony export */ "isEmpty": () => (/* binding */ isEmpty),
|
4329 | /* harmony export */ "isNumber": () => (/* binding */ isNumber),
|
4330 | /* harmony export */ "last": () => (/* binding */ last),
|
4331 | /* harmony export */ "maxLength": () => (/* binding */ maxLength),
|
4332 | /* harmony export */ "sortByLengthDesc": () => (/* binding */ sortByLengthDesc),
|
4333 | /* harmony export */ "trimSpacesEnd": () => (/* binding */ trimSpacesEnd)
|
4334 | /* harmony export */ });
|
4335 | function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
|
4336 |
|
4337 | function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
4338 |
|
4339 | function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
4340 |
|
4341 | function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
|
4342 |
|
4343 | function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
|
4344 |
|
4345 | function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
4346 |
|
4347 | var dedupe = function dedupe(arr) {
|
4348 | return _toConsumableArray(new Set(arr));
|
4349 | }; // Only removes spaces, not newlines
|
4350 |
|
4351 | var trimSpacesEnd = function trimSpacesEnd(str) {
|
4352 | return str.replace(/[\t ]+$/, '');
|
4353 | }; // Last element from array
|
4354 |
|
4355 | var last = function last(arr) {
|
4356 | return arr[arr.length - 1];
|
4357 | }; // True array is empty, or it's not an array at all
|
4358 |
|
4359 | var isEmpty = function isEmpty(arr) {
|
4360 | return !Array.isArray(arr) || arr.length === 0;
|
4361 | }; // Escapes regex special chars
|
4362 |
|
4363 | var escapeRegExp = function escapeRegExp(string) {
|
4364 | return string.replace(/[\$\(-\+\.\?\[-\^\{-\}]/g, '\\$&');
|
4365 | }; // Sorts strings by length, so that longer ones are first
|
4366 | // Also sorts alphabetically after sorting by length.
|
4367 |
|
4368 | var sortByLengthDesc = function sortByLengthDesc(strings) {
|
4369 | return strings.sort(function (a, b) {
|
4370 | return b.length - a.length || a.localeCompare(b);
|
4371 | });
|
4372 | };
|
4373 | /** Get length of longest string in list of strings */
|
4374 |
|
4375 | var maxLength = function maxLength(strings) {
|
4376 | return strings.reduce(function (max, cur) {
|
4377 | return Math.max(max, cur.length);
|
4378 | }, 0);
|
4379 | };
|
4380 | var isNumber = function isNumber(value) {
|
4381 | return typeof value === 'number';
|
4382 | };
|
4383 |
|
4384 | /***/ })
|
4385 |
|
4386 | /******/ });
|
4387 | /************************************************************************/
|
4388 | /******/ // The module cache
|
4389 | /******/ var __webpack_module_cache__ = {};
|
4390 | /******/
|
4391 | /******/ // The require function
|
4392 | /******/ function __webpack_require__(moduleId) {
|
4393 | /******/ // Check if module is in cache
|
4394 | /******/ var cachedModule = __webpack_module_cache__[moduleId];
|
4395 | /******/ if (cachedModule !== undefined) {
|
4396 | /******/ return cachedModule.exports;
|
4397 | /******/ }
|
4398 | /******/ // Create a new module (and put it into the cache)
|
4399 | /******/ var module = __webpack_module_cache__[moduleId] = {
|
4400 | /******/ // no module.id needed
|
4401 | /******/ // no module.loaded needed
|
4402 | /******/ exports: {}
|
4403 | /******/ };
|
4404 | /******/
|
4405 | /******/ // Execute the module function
|
4406 | /******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
|
4407 | /******/
|
4408 | /******/ // Return the exports of the module
|
4409 | /******/ return module.exports;
|
4410 | /******/ }
|
4411 | /******/
|
4412 | /************************************************************************/
|
4413 | /******/ /* webpack/runtime/define property getters */
|
4414 | /******/ (() => {
|
4415 | /******/ // define getter functions for harmony exports
|
4416 | /******/ __webpack_require__.d = (exports, definition) => {
|
4417 | /******/ for(var key in definition) {
|
4418 | /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
|
4419 | /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
|
4420 | /******/ }
|
4421 | /******/ }
|
4422 | /******/ };
|
4423 | /******/ })();
|
4424 | /******/
|
4425 | /******/ /* webpack/runtime/hasOwnProperty shorthand */
|
4426 | /******/ (() => {
|
4427 | /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
|
4428 | /******/ })();
|
4429 | /******/
|
4430 | /******/ /* webpack/runtime/make namespace object */
|
4431 | /******/ (() => {
|
4432 | /******/ // define __esModule on exports
|
4433 | /******/ __webpack_require__.r = (exports) => {
|
4434 | /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
|
4435 | /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
|
4436 | /******/ }
|
4437 | /******/ Object.defineProperty(exports, '__esModule', { value: true });
|
4438 | /******/ };
|
4439 | /******/ })();
|
4440 | /******/
|
4441 | /************************************************************************/
|
4442 | var __webpack_exports__ = {};
|
4443 | // This entry need to be wrapped in an IIFE because it need to be isolated against other modules in the chunk.
|
4444 | (() => {
|
4445 | /*!**********************!*\
|
4446 | !*** ./src/index.ts ***!
|
4447 | \**********************/
|
4448 | __webpack_require__.r(__webpack_exports__);
|
4449 | /* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
4450 | /* harmony export */ "ConfigError": () => (/* reexport safe */ _sqlFormatter__WEBPACK_IMPORTED_MODULE_0__.ConfigError),
|
4451 | /* harmony export */ "format": () => (/* reexport safe */ _sqlFormatter__WEBPACK_IMPORTED_MODULE_0__.format),
|
4452 | /* harmony export */ "formatters": () => (/* reexport safe */ _sqlFormatter__WEBPACK_IMPORTED_MODULE_0__.formatters),
|
4453 | /* harmony export */ "supportedDialects": () => (/* reexport safe */ _sqlFormatter__WEBPACK_IMPORTED_MODULE_0__.supportedDialects)
|
4454 | /* harmony export */ });
|
4455 | /* harmony import */ var _sqlFormatter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./sqlFormatter */ "./src/sqlFormatter.ts");
|
4456 | /* harmony import */ var _types__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./types */ "./src/types.ts");
|
4457 |
|
4458 |
|
4459 | })();
|
4460 |
|
4461 | /******/ return __webpack_exports__;
|
4462 | /******/ })()
|
4463 | ;
|
4464 | });
|
4465 | //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"sql-formatter.js","mappings":"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","sources":["webpack://sqlFormatter/webpack/universalModuleDefinition","webpack://sqlFormatter/./src/core/AliasAs.ts","webpack://sqlFormatter/./src/core/AsTokenFactory.ts","webpack://sqlFormatter/./src/core/Formatter.ts","webpack://sqlFormatter/./src/core/Indentation.ts","webpack://sqlFormatter/./src/core/InlineBlock.ts","webpack://sqlFormatter/./src/core/Params.ts","webpack://sqlFormatter/./src/core/Tokenizer.ts","webpack://sqlFormatter/./src/core/formatAliasPositions.ts","webpack://sqlFormatter/./src/core/formatCommaPositions.ts","webpack://sqlFormatter/./src/core/regexFactory.ts","webpack://sqlFormatter/./src/core/tabularStyle.ts","webpack://sqlFormatter/./src/core/token.ts","webpack://sqlFormatter/./src/languages/bigquery.formatter.ts","webpack://sqlFormatter/./src/languages/db2.formatter.ts","webpack://sqlFormatter/./src/languages/hive.formatter.ts","webpack://sqlFormatter/./src/languages/mariadb.formatter.ts","webpack://sqlFormatter/./src/languages/mysql.formatter.ts","webpack://sqlFormatter/./src/languages/n1ql.formatter.ts","webpack://sqlFormatter/./src/languages/plsql.formatter.ts","webpack://sqlFormatter/./src/languages/postgresql.formatter.ts","webpack://sqlFormatter/./src/languages/redshift.formatter.ts","webpack://sqlFormatter/./src/languages/sparksql.formatter.ts","webpack://sqlFormatter/./src/languages/standardsql.formatter.ts","webpack://sqlFormatter/./src/languages/tsql.formatter.ts","webpack://sqlFormatter/./src/sqlFormatter.ts","webpack://sqlFormatter/./src/utils.ts","webpack://sqlFormatter/webpack/bootstrap","webpack://sqlFormatter/webpack/runtime/define property getters","webpack://sqlFormatter/webpack/runtime/hasOwnProperty shorthand","webpack://sqlFormatter/webpack/runtime/make namespace object","webpack://sqlFormatter/./src/index.ts"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"sqlFormatter\"] = factory();\n\telse\n\t\troot[\"sqlFormatter\"] = factory();\n})(self, () => {\nreturn ","import { AliasMode } from '../types';\nimport { isCommand, isToken, Token, TokenType } from './token';\n\nexport interface TokenStream {\n  isWithinSelect(): boolean;\n  getPreviousReservedToken(): Token;\n  tokenLookBehind(n?: number): Token;\n  tokenLookAhead(n?: number): Token;\n}\n\n/** Decides addition and removal of AS tokens */\nexport default class AliasAs {\n  constructor(private aliasAs: AliasMode, private formatter: TokenStream) {}\n\n  /** True when AS keyword should be added *before* current token */\n  public shouldAddBefore(token: Token): boolean {\n    return this.isMissingTableAlias(token) || this.isMissingSelectColumnAlias(token);\n  }\n\n  // if table alias is missing and should be added\n  private isMissingTableAlias(token: Token): boolean {\n    return (\n      this.aliasAs === 'always' && token.type === TokenType.WORD && this.lookBehind().value === ')'\n    );\n  }\n\n  // if select column alias is missing and should be added\n  private isMissingSelectColumnAlias(token: Token): boolean {\n    const prevToken = this.lookBehind();\n    const nextToken = this.lookAhead();\n    return (\n      (this.aliasAs === 'always' || this.aliasAs === 'select') &&\n      this.formatter.isWithinSelect() &&\n      token.type === TokenType.WORD &&\n      (isToken.END(prevToken) ||\n        ((prevToken.type === TokenType.WORD || prevToken.type === TokenType.NUMBER) &&\n          (nextToken.value === ',' || isCommand(nextToken))))\n    );\n  }\n\n  /** True when AS keyword should be added *after* current token */\n  public shouldAddAfter(): boolean {\n    return this.isEdgeCaseCTE() || this.isEdgeCaseCreateTable() || this.isMissingTypeCastAs();\n  }\n\n  // checks for CAST(«expression» [AS] type)\n  private isMissingTypeCastAs(): boolean {\n    return (\n      this.aliasAs === 'never' &&\n      this.formatter.isWithinSelect() &&\n      isToken.CAST(this.formatter.getPreviousReservedToken()) &&\n      isToken.AS(this.lookAhead()) &&\n      (this.lookAhead(2).type === TokenType.WORD ||\n        this.lookAhead(2).type === TokenType.RESERVED_KEYWORD) &&\n      this.lookAhead(3).value === ')'\n    );\n  }\n\n  // checks for WITH `table` [AS] (\n  private isEdgeCaseCTE(): boolean {\n    const nextToken = this.lookAhead();\n    return (\n      this.aliasAs === 'never' &&\n      isToken.WITH(this.lookBehind()) &&\n      (nextToken.value === '(' || (isToken.AS(nextToken) && this.lookAhead(2).value === '('))\n    );\n  }\n\n  // checks for CREATE TABLE `table` [AS] WITH (\n  private isEdgeCaseCreateTable(): boolean {\n    const prevToken = this.lookBehind();\n    const nextToken = this.lookAhead();\n    return (\n      this.aliasAs === 'never' &&\n      (isToken.TABLE(prevToken) || prevToken.value.endsWith('TABLE')) &&\n      (isToken.WITH(nextToken) || (isToken.AS(nextToken) && isToken.WITH(this.lookAhead(2))))\n    );\n  }\n\n  /* True when the current AS token should be discarded */\n  public shouldRemove(): boolean {\n    return this.aliasAs === 'never' || (this.aliasAs === 'select' && this.isRemovableNonSelectAs());\n  }\n\n  private isRemovableNonSelectAs(): boolean {\n    return (\n      this.lookBehind().value === ')' && // ) [AS] alias but not SELECT (a) [AS] alpha\n      !this.formatter.isWithinSelect() &&\n      this.lookAhead().value !== '(' // skip WITH foo [AS] ( ...\n    );\n  }\n\n  private lookBehind(n?: number): Token {\n    return this.formatter.tokenLookBehind(n);\n  }\n\n  private lookAhead(n?: number): Token {\n    return this.formatter.tokenLookAhead(n);\n  }\n}\n","import { KeywordCase } from '../types';\nimport { isToken, Token, TokenType } from './token';\n\nexport default class AsTokenFactory {\n  private detectedCase: KeywordCase;\n\n  constructor(private keywordCase: KeywordCase, tokens: Token[] = []) {\n    this.detectedCase = this.autoDetectCase(tokens);\n  }\n\n  private autoDetectCase(tokens: Token[]) {\n    const asTokens = tokens.filter(isToken.AS);\n    const upperAsTokens = asTokens.filter(({ value }) => value === 'AS');\n    return upperAsTokens.length > asTokens.length / 2 ? 'upper' : 'lower';\n  }\n\n  /** Returns AS token with either upper- or lowercase text */\n  public token(): Token {\n    return {\n      type: TokenType.RESERVED_KEYWORD,\n      value: this.asTokenValue(),\n    };\n  }\n\n  private asTokenValue(): 'AS' | 'as' {\n    const keywordCase = this.keywordCase === 'preserve' ? this.detectedCase : this.keywordCase;\n    return keywordCase === 'upper' ? 'AS' : 'as';\n  }\n}\n","import Indentation from './Indentation';\nimport InlineBlock from './InlineBlock';\nimport Params from './Params';\nimport { trimSpacesEnd } from '../utils';\nimport { isReserved, isCommand, isToken, Token, TokenType, EOF_TOKEN } from './token';\nimport Tokenizer from './Tokenizer';\nimport { FormatOptions } from '../types';\nimport formatCommaPositions from './formatCommaPositions';\nimport formatAliasPositions from './formatAliasPositions';\nimport { toTabularToken, replaceTabularPlaceholders } from './tabularStyle';\nimport AliasAs from './AliasAs';\nimport AsTokenFactory from './AsTokenFactory';\n\n/** Main formatter class that produces a final output string from list of tokens */\nexport default class Formatter {\n  private cfg: FormatOptions;\n  private indentation: Indentation;\n  private inlineBlock: InlineBlock;\n  private aliasAs: AliasAs;\n  private params: Params;\n  private asTokenFactory: AsTokenFactory;\n\n  private currentNewline = true;\n  private previousReservedToken: Token = EOF_TOKEN;\n  private previousCommandToken: Token = EOF_TOKEN;\n  protected tokens: Token[] = [];\n  protected index = -1;\n\n  constructor(cfg: FormatOptions) {\n    this.cfg = cfg;\n    this.indentation = new Indentation(this.indentString());\n    this.inlineBlock = new InlineBlock(this.cfg.expressionWidth);\n    this.aliasAs = new AliasAs(this.cfg.aliasAs, this);\n    this.params = new Params(this.cfg.params);\n    this.asTokenFactory = new AsTokenFactory(this.cfg.keywordCase);\n  }\n\n  private indentString(): string {\n    if (this.isTabularStyle()) {\n      return ' '.repeat(10);\n    }\n    if (this.cfg.useTabs) {\n      return '\\t';\n    }\n    return ' '.repeat(this.cfg.tabWidth);\n  }\n\n  /**\n   * SQL Tokenizer for this formatter, provided by subclasses.\n   */\n  protected tokenizer(): Tokenizer {\n    throw new Error('tokenizer() not implemented by subclass');\n  }\n\n  /**\n   * Reprocess and modify a token based on parsed context.\n   * Subclasses can override this to modify tokens during formatting.\n   * @param {Token} token - The token to modify\n   * @return {Token} new token or the original\n   */\n  protected tokenOverride(token: Token): Token {\n    return token;\n  }\n\n  /**\n   * Formats an SQL query.\n   * @param {string} query - The SQL query string to be formatted\n   * @return {string} The formatter query\n   */\n  public format(query: string): string {\n    this.tokens = this.tokenizer().tokenize(query);\n    this.asTokenFactory = new AsTokenFactory(this.cfg.keywordCase, this.tokens);\n    const formattedQuery = this.getFormattedQueryFromTokens();\n    const finalQuery = this.postFormat(formattedQuery);\n\n    return finalQuery.replace(/^\\n*/u, '').trimEnd();\n  }\n\n  /**\n   * Does post-processing on the formatted query.\n   */\n  private postFormat(query: string): string {\n    if (this.cfg.tabulateAlias) {\n      query = formatAliasPositions(query);\n    }\n    if (this.cfg.commaPosition === 'before' || this.cfg.commaPosition === 'tabular') {\n      query = formatCommaPositions(query, this.cfg.commaPosition, this.indentString());\n    }\n\n    return query;\n  }\n\n  /**\n   * Performs main construction of query from token list, delegates to other methods for formatting based on token criteria\n   */\n  private getFormattedQueryFromTokens(): string {\n    let formattedQuery = '';\n\n    for (this.index = 0; this.index < this.tokens.length; this.index++) {\n      let token = this.tokenOverride(this.tokens[this.index]);\n\n      // if token is a Reserved Keyword, Command, Binary Command, Dependent Clause, Logical Operator\n      if (isReserved(token)) {\n        this.previousReservedToken = token;\n        if (\n          token.type !== TokenType.RESERVED_KEYWORD &&\n          token.type !== TokenType.RESERVED_JOIN_CONDITION\n        ) {\n          // convert Reserved Command or Logical Operator to tabular format if needed\n          token = toTabularToken(token, this.cfg.indentStyle);\n        }\n        if (token.type === TokenType.RESERVED_COMMAND) {\n          this.previousCommandToken = token;\n        }\n      }\n\n      if (token.type === TokenType.LINE_COMMENT) {\n        formattedQuery = this.formatLineComment(token, formattedQuery);\n      } else if (token.type === TokenType.BLOCK_COMMENT) {\n        formattedQuery = this.formatBlockComment(token, formattedQuery);\n      } else if (token.type === TokenType.RESERVED_COMMAND) {\n        this.currentNewline = this.checkNewline(token);\n        formattedQuery = this.formatCommand(token, formattedQuery);\n      } else if (token.type === TokenType.RESERVED_BINARY_COMMAND) {\n        formattedQuery = this.formatBinaryCommand(token, formattedQuery);\n      } else if (token.type === TokenType.RESERVED_DEPENDENT_CLAUSE) {\n        formattedQuery = this.formatDependentClause(token, formattedQuery);\n      } else if (token.type === TokenType.RESERVED_JOIN_CONDITION) {\n        formattedQuery = this.formatJoinCondition(token, formattedQuery);\n      } else if (token.type === TokenType.RESERVED_LOGICAL_OPERATOR) {\n        formattedQuery = this.formatLogicalOperator(token, formattedQuery);\n      } else if (token.type === TokenType.RESERVED_KEYWORD) {\n        formattedQuery = this.formatKeyword(token, formattedQuery);\n      } else if (token.type === TokenType.BLOCK_START) {\n        formattedQuery = this.formatBlockStart(token, formattedQuery);\n      } else if (token.type === TokenType.BLOCK_END) {\n        formattedQuery = this.formatBlockEnd(token, formattedQuery);\n      } else if (token.type === TokenType.PLACEHOLDER) {\n        formattedQuery = this.formatPlaceholder(token, formattedQuery);\n      } else if (token.type === TokenType.OPERATOR) {\n        formattedQuery = this.formatOperator(token, formattedQuery);\n      } else {\n        formattedQuery = this.formatWord(token, formattedQuery);\n      }\n    }\n    return replaceTabularPlaceholders(formattedQuery);\n  }\n\n  /**\n   * Formats word tokens + any potential AS tokens for aliases\n   */\n  private formatWord(token: Token, query: string): string {\n    let finalQuery = query;\n    if (this.aliasAs.shouldAddBefore(token)) {\n      finalQuery = this.formatWithSpaces(this.asTokenFactory.token(), finalQuery);\n    }\n\n    finalQuery = this.formatWithSpaces(token, finalQuery);\n\n    if (this.aliasAs.shouldAddAfter()) {\n      finalQuery = this.formatWithSpaces(this.asTokenFactory.token(), finalQuery);\n    }\n\n    return finalQuery;\n  }\n\n  /**\n   * Checks if a newline should currently be inserted\n   */\n  private checkNewline(token: Token): boolean {\n    const nextTokens = this.tokensUntilNextCommandOrQueryEnd();\n\n    // auto break if SELECT includes CASE statements\n    if (this.isWithinSelect() && nextTokens.some(isToken.CASE)) {\n      return true;\n    }\n\n    switch (this.cfg.multilineLists) {\n      case 'always':\n        return true;\n      case 'avoid':\n        return false;\n      case 'expressionWidth':\n        return this.inlineWidth(token, nextTokens) > this.cfg.expressionWidth;\n      default: // multilineLists mode is a number\n        return (\n          this.countClauses(nextTokens) > this.cfg.multilineLists ||\n          this.inlineWidth(token, nextTokens) > this.cfg.expressionWidth\n        );\n    }\n  }\n\n  private inlineWidth(token: Token, tokens: Token[]): number {\n    const tokensString = tokens.map(({ value }) => (value === ',' ? value + ' ' : value)).join('');\n    return `${token.whitespaceBefore}${token.value} ${tokensString}`.length;\n  }\n\n  /**\n   * Counts comma-separated clauses (doesn't count commas inside blocks)\n   * Note: There's always at least one clause.\n   */\n  private countClauses(tokens: Token[]): number {\n    let count = 1;\n    let openBlocks = 0;\n    for (const { type, value } of tokens) {\n      if (value === ',' && openBlocks === 0) {\n        count++;\n      }\n      if (type === TokenType.BLOCK_START) {\n        openBlocks++;\n      }\n      if (type === TokenType.BLOCK_END) {\n        openBlocks--;\n      }\n    }\n    return count;\n  }\n\n  /** get all tokens between current token and next Reserved Command or query end */\n  private tokensUntilNextCommandOrQueryEnd(): Token[] {\n    const tail = this.tokens.slice(this.index + 1);\n    return tail.slice(\n      0,\n      tail.length ? tail.findIndex(token => isCommand(token) || token.value === ';') : undefined\n    );\n  }\n\n  /** Formats a line comment onto query */\n  private formatLineComment(token: Token, query: string): string {\n    return this.addNewline(query + this.show(token));\n  }\n\n  /** Formats a block comment onto query */\n  private formatBlockComment(token: Token, query: string): string {\n    return this.addNewline(this.addNewline(query) + this.indentComment(token.value));\n  }\n\n  /** Aligns comment to current indentation level */\n  private indentComment(comment: string): string {\n    return comment.replace(/\\n[ \\t]*/gu, '\\n' + this.indentation.getIndent() + ' ');\n  }\n\n  /**\n   * Formats a Reserved Command onto query, increasing indentation level where necessary\n   */\n  private formatCommand(token: Token, query: string): string {\n    this.indentation.decreaseTopLevel();\n\n    query = this.addNewline(query);\n\n    // indent tabular formats, except when preceding a (\n    if (this.isTabularStyle()) {\n      if (this.tokenLookAhead().value !== '(') {\n        this.indentation.increaseTopLevel();\n      }\n    } else {\n      this.indentation.increaseTopLevel();\n    }\n\n    query += this.equalizeWhitespace(this.show(token)); // print token onto query\n    if (this.currentNewline && !this.isTabularStyle()) {\n      query = this.addNewline(query);\n    } else {\n      query += ' ';\n    }\n    return query;\n  }\n\n  /**\n   * Formats a Reserved Binary Command onto query, joining neighbouring tokens\n   */\n  private formatBinaryCommand(token: Token, query: string): string {\n    const isJoin = /JOIN/i.test(token.value); // check if token contains JOIN\n    if (!isJoin || this.isTabularStyle()) {\n      // decrease for boolean set operators or in tabular mode\n      this.indentation.decreaseTopLevel();\n    }\n    query = this.addNewline(query) + this.equalizeWhitespace(this.show(token));\n    return isJoin ? query + ' ' : this.addNewline(query);\n  }\n\n  /**\n   * Formats a Reserved Keyword onto query, skipping AS if disabled\n   */\n  private formatKeyword(token: Token, query: string): string {\n    if (isToken.AS(token) && this.aliasAs.shouldRemove()) {\n      return query;\n    }\n\n    return this.formatWithSpaces(token, query);\n  }\n\n  /**\n   * Formats a Reserved Dependent Clause token onto query, supporting the keyword that precedes it\n   */\n  private formatDependentClause(token: Token, query: string): string {\n    return this.addNewline(query) + this.equalizeWhitespace(this.show(token)) + ' ';\n  }\n\n  // Formats ON and USING keywords\n  private formatJoinCondition(token: Token, query: string): string {\n    return query + this.equalizeWhitespace(this.show(token)) + ' ';\n  }\n\n  /**\n   * Formats an Operator onto query, following rules for specific characters\n   */\n  private formatOperator(token: Token, query: string): string {\n    // special operator\n    if (token.value === ',') {\n      return this.formatComma(token, query);\n    } else if (token.value === ';') {\n      return this.formatQuerySeparator(token, query);\n    } else if (['$', '['].includes(token.value)) {\n      return this.formatWithSpaces(token, query, 'before');\n    } else if ([':', ']'].includes(token.value)) {\n      return this.formatWithSpaces(token, query, 'after');\n    } else if (['.', '{', '}', '`'].includes(token.value)) {\n      return this.formatWithoutSpaces(token, query);\n    }\n\n    // regular operator\n    if (this.cfg.denseOperators && this.tokenLookBehind().type !== TokenType.RESERVED_COMMAND) {\n      // do not trim whitespace if SELECT *\n      return this.formatWithoutSpaces(token, query);\n    }\n    return this.formatWithSpaces(token, query);\n  }\n\n  /**\n   * Formats a Logical Operator onto query, joining boolean conditions\n   */\n  private formatLogicalOperator(token: Token, query: string): string {\n    // ignore AND when BETWEEN x [AND] y\n    if (isToken.AND(token) && isToken.BETWEEN(this.tokenLookBehind(2))) {\n      return this.formatWithSpaces(token, query);\n    }\n\n    if (this.isTabularStyle()) {\n      this.indentation.decreaseTopLevel();\n    }\n\n    if (this.cfg.logicalOperatorNewline === 'before') {\n      return (\n        (this.currentNewline ? this.addNewline(query) : query) +\n        this.equalizeWhitespace(this.show(token)) +\n        ' '\n      );\n    } else {\n      query += this.show(token);\n      return this.currentNewline ? this.addNewline(query) : query;\n    }\n  }\n\n  /** Replace any sequence of whitespace characters with single space */\n  private equalizeWhitespace(string: string): string {\n    return string.replace(/\\s+/gu, ' ');\n  }\n\n  /**\n   * Formats a Block Start token (left paren/bracket/brace, CASE) onto query, beginning an Inline Block or increasing indentation where necessary\n   */\n  private formatBlockStart(token: Token, query: string): string {\n    if (isToken.CASE(token)) {\n      query = this.formatWithSpaces(token, query);\n    } else {\n      // Take out the preceding space unless there was whitespace there in the original query\n      // or another opening parens or line comment\n      const preserveWhitespaceFor = [\n        TokenType.BLOCK_START,\n        TokenType.LINE_COMMENT,\n        TokenType.OPERATOR,\n      ];\n      if (\n        token.whitespaceBefore?.length === 0 &&\n        !preserveWhitespaceFor.includes(this.tokenLookBehind().type)\n      ) {\n        query = trimSpacesEnd(query);\n      } else if (!this.cfg.newlineBeforeOpenParen) {\n        query = query.trimEnd() + ' ';\n      }\n      query += this.show(token);\n      this.inlineBlock.beginIfPossible(this.tokens, this.index);\n    }\n\n    if (!this.inlineBlock.isActive()) {\n      this.indentation.increaseBlockLevel();\n      if (!isToken.CASE(token) || this.cfg.multilineLists === 'always') {\n        query = this.addNewline(query);\n      }\n    }\n    return query;\n  }\n\n  /**\n   * Formats a Block End token (right paren/bracket/brace, END) onto query, closing an Inline Block or decreasing indentation where necessary\n   */\n  private formatBlockEnd(token: Token, query: string): string {\n    if (this.inlineBlock.isActive()) {\n      this.inlineBlock.end();\n      if (isToken.END(token)) {\n        return this.formatWithSpaces(token, query); // add space before END when closing inline block\n      }\n      return this.formatWithSpaces(token, query, 'after'); // do not add space before )\n    } else {\n      this.indentation.decreaseBlockLevel();\n\n      if (this.isTabularStyle()) {\n        // +1 extra indentation step for the closing paren\n        query = this.addNewline(query) + this.indentation.getSingleIndent();\n      } else if (this.cfg.newlineBeforeCloseParen) {\n        query = this.addNewline(query);\n      } else {\n        query = query.trimEnd() + ' ';\n      }\n\n      return this.formatWithSpaces(token, query);\n    }\n  }\n\n  /**\n   * Formats a Placeholder item onto query, to be replaced with the value of the placeholder\n   */\n  formatPlaceholder(token: Token, query: string): string {\n    return query + this.params.get(token) + ' ';\n  }\n\n  /**\n   * Formats a comma Operator onto query, ending line unless in an Inline Block\n   */\n  private formatComma(token: Token, query: string): string {\n    query = trimSpacesEnd(query) + this.show(token) + ' ';\n\n    if (this.inlineBlock.isActive()) {\n      return query;\n    } else if (isToken.LIMIT(this.getPreviousReservedToken())) {\n      return query;\n    } else if (this.currentNewline) {\n      return this.addNewline(query);\n    } else {\n      return query;\n    }\n  }\n\n  /** Simple append of token onto query */\n  private formatWithoutSpaces(token: Token, query: string): string {\n    return trimSpacesEnd(query) + this.show(token);\n  }\n\n  /**\n   * Add token onto query with spaces - either before, after, or both\n   */\n  private formatWithSpaces(\n    token: Token,\n    query: string,\n    addSpace: 'before' | 'after' | 'both' = 'both'\n  ): string {\n    const before = addSpace === 'after' ? trimSpacesEnd(query) : query;\n    const after = addSpace === 'before' ? '' : ' ';\n    return before + this.show(token) + after;\n  }\n\n  private formatQuerySeparator(token: Token, query: string): string {\n    this.indentation.resetIndentation();\n    return [\n      trimSpacesEnd(query),\n      this.cfg.newlineBeforeSemicolon ? '\\n' : '',\n      this.show(token),\n      '\\n'.repeat(this.cfg.linesBetweenQueries + 1),\n    ].join('');\n  }\n\n  /** Converts token to string, uppercasing if enabled */\n  private show(token: Token): string {\n    if (\n      isReserved(token) ||\n      token.type === TokenType.BLOCK_START ||\n      token.type === TokenType.BLOCK_END\n    ) {\n      switch (this.cfg.keywordCase) {\n        case 'preserve':\n          return token.value;\n        case 'upper':\n          return token.value.toUpperCase();\n        case 'lower':\n          return token.value.toLowerCase();\n      }\n    } else {\n      return token.value;\n    }\n  }\n\n  /** Inserts a newline onto the query */\n  private addNewline(query: string): string {\n    query = trimSpacesEnd(query);\n    if (!query.endsWith('\\n')) {\n      query += '\\n';\n    }\n    return query + this.indentation.getIndent();\n  }\n\n  private isTabularStyle(): boolean {\n    return this.cfg.indentStyle === 'tabularLeft' || this.cfg.indentStyle === 'tabularRight';\n  }\n\n  /** Returns the latest encountered reserved keyword token */\n  public getPreviousReservedToken(): Token {\n    return this.previousReservedToken;\n  }\n\n  /** True when currently within SELECT command */\n  public isWithinSelect(): boolean {\n    return isToken.SELECT(this.previousCommandToken);\n  }\n\n  /** Fetches nth previous token from the token stream */\n  public tokenLookBehind(n = 1): Token {\n    return this.tokens[this.index - n] || EOF_TOKEN;\n  }\n\n  /** Fetches nth next token from the token stream */\n  public tokenLookAhead(n = 1): Token {\n    return this.tokens[this.index + n] || EOF_TOKEN;\n  }\n}\n","import { last } from '../utils';\n\nconst INDENT_TYPE_TOP_LEVEL = 'top-level';\nconst INDENT_TYPE_BLOCK_LEVEL = 'block-level';\n\n/**\n * Manages indentation levels.\n *\n * There are two types of indentation levels:\n *\n * - BLOCK_LEVEL : increased by open-parenthesis\n * - TOP_LEVEL : increased by RESERVED_COMMAND words\n */\nexport default class Indentation {\n  private indentTypes: string[] = [];\n\n  /**\n   * @param {string} indent A string to indent with\n   */\n  constructor(private indent: string) {}\n\n  /**\n   * Returns indentation string for single indentation step.\n   */\n  getSingleIndent(): string {\n    return this.indent;\n  }\n\n  /**\n   * Returns current indentation string.\n   * @return {string} indentation string based on indentTypes\n   */\n  getIndent(): string {\n    return this.indent.repeat(this.indentTypes.length);\n  }\n\n  /**\n   * Increases indentation by one top-level indent.\n   */\n  increaseTopLevel() {\n    this.indentTypes.push(INDENT_TYPE_TOP_LEVEL);\n  }\n\n  /**\n   * Increases indentation by one block-level indent.\n   */\n  increaseBlockLevel() {\n    this.indentTypes.push(INDENT_TYPE_BLOCK_LEVEL);\n  }\n\n  /**\n   * Decreases indentation by one top-level indent.\n   * Does nothing when the previous indent is not top-level.\n   */\n  decreaseTopLevel() {\n    if (this.indentTypes.length > 0 && last(this.indentTypes) === INDENT_TYPE_TOP_LEVEL) {\n      this.indentTypes.pop();\n    }\n  }\n\n  /**\n   * Decreases indentation by one block-level indent.\n   * If there are top-level indents within the block-level indent,\n   * throws away these as well.\n   */\n  decreaseBlockLevel() {\n    while (this.indentTypes.length > 0) {\n      const type = this.indentTypes.pop();\n      if (type !== INDENT_TYPE_TOP_LEVEL) {\n        break;\n      }\n    }\n  }\n\n  /** Clears all indentation */\n  resetIndentation() {\n    this.indentTypes = [];\n  }\n}\n","import { isToken, Token, TokenType } from './token';\n\n/**\n * Bookkeeper for inline blocks.\n *\n * Inline blocks are parenthesised expressions that are shorter than INLINE_MAX_LENGTH.\n * These blocks are formatted on a single line, unlike longer parenthesised\n * expressions where open-parenthesis causes newline and increase of indentation.\n */\nexport default class InlineBlock {\n  level: number;\n  expressionWidth: number;\n\n  constructor(expressionWidth: number) {\n    this.level = 0;\n    this.expressionWidth = expressionWidth;\n  }\n\n  /**\n   * Begins inline block when lookahead through upcoming tokens determines\n   * that the block would be smaller than INLINE_MAX_LENGTH.\n   * @param  {Token[]} tokens Array of all tokens\n   * @param  {Number} index Current token position\n   */\n  beginIfPossible(tokens: Token[], index: number) {\n    if (this.level === 0 && this.isInlineBlock(tokens, index)) {\n      this.level = 1;\n    } else if (this.level > 0) {\n      this.level++;\n    } else {\n      this.level = 0;\n    }\n  }\n\n  /**\n   * Finishes current inline block.\n   * There might be several nested ones.\n   */\n  end() {\n    this.level--;\n  }\n\n  /**\n   * True when inside an inline block\n   */\n  isActive(): boolean {\n    return this.level > 0;\n  }\n\n  /**\n   * Check if this should be an inline parentheses block\n   * Examples are \"NOW()\", \"COUNT(*)\", \"int(10)\", key(`somecolumn`), DECIMAL(7,2)\n   */\n  isInlineBlock(tokens: Token[], index: number): boolean {\n    let length = 0;\n    let level = 0;\n\n    for (let i = index; i < tokens.length; i++) {\n      const token = tokens[i];\n      length += token.value.length;\n\n      if (this.isForbiddenToken(token)) {\n        return false;\n      }\n\n      // Overran max length\n      if (length > this.expressionWidth) {\n        return false;\n      }\n\n      if (token.type === TokenType.BLOCK_START) {\n        level++;\n      } else if (token.type === TokenType.BLOCK_END) {\n        level--;\n        if (level === 0) {\n          return true;\n        }\n      }\n    }\n    return false;\n  }\n\n  // Reserved words that cause newlines, comments and semicolons\n  // are not allowed inside inline parentheses block\n  isForbiddenToken({ type, value }: Token) {\n    return (\n      type === TokenType.RESERVED_COMMAND ||\n      type === TokenType.RESERVED_LOGICAL_OPERATOR ||\n      // type === TokenType.LINE_COMMENT ||\n      type === TokenType.BLOCK_COMMENT ||\n      value === ';' ||\n      isToken.CASE({ type, value }) // CASE cannot have inline blocks\n    );\n  }\n}\n","import type { Token } from './token';\n\nexport type ParamItems = { [k: string]: string };\n\n/**\n * Handles placeholder replacement with given params.\n */\nexport default class Params {\n  /**\n   * @param {ParamItems} params\n   */\n  params: ParamItems | string[] | undefined;\n  index: number;\n\n  constructor(params: ParamItems | string[] | undefined) {\n    this.params = params;\n    this.index = 0;\n  }\n\n  /**\n   * Returns param value that matches given placeholder with param key.\n   * @param {Token} token\n   * @return {string} param or token.value when params are missing\n   */\n  get({ key, value }: Token): string {\n    if (!this.params) {\n      return value;\n    }\n\n    if (key) {\n      return (this.params as ParamItems)[key];\n    }\n    return (this.params as string[])[this.index++];\n  }\n}\n","import * as regexFactory from './regexFactory';\nimport { escapeRegExp } from '../utils';\nimport { Token, TokenType } from './token'; // convert to partial type import in TS 4.5\n\nexport const WHITESPACE_REGEX = /^(\\s+)/u;\nconst NULL_REGEX = /(?!)/; // zero-width negative lookahead, matches nothing\n\n/** Struct that defines how a SQL language can be broken into tokens */\ninterface TokenizerOptions {\n  reservedKeywords: string[];\n  reservedCommands: string[];\n  reservedLogicalOperators: string[];\n  reservedDependentClauses: string[];\n  reservedBinaryCommands: string[];\n  reservedJoinConditions: string[];\n  stringTypes: regexFactory.StringPatternType[];\n  blockStart: string[];\n  blockEnd: string[];\n  indexedPlaceholderTypes?: string[];\n  namedPlaceholderTypes: string[];\n  lineCommentTypes: string[];\n  specialWordChars?: { prefix?: string; any?: string; suffix?: string };\n  operators?: string[];\n}\n\n/** Converts SQL language string into a token stream */\nexport default class Tokenizer {\n  REGEX_MAP: { [tokenType in TokenType]: RegExp };\n\n  INDEXED_PLACEHOLDER_REGEX?: RegExp;\n  IDENT_NAMED_PLACEHOLDER_REGEX?: RegExp;\n  STRING_NAMED_PLACEHOLDER_REGEX?: RegExp;\n\n  /**\n   * @param {TokenizerOptions} cfg\n   *  @param {string[]} cfg.reservedKeywords - Reserved words in SQL\n   *  @param {string[]} cfg.reservedDependentClauses - Words that following a specific Statement and must have data attached\n   *  @param {string[]} cfg.reservedLogicalOperators - Words that are set to newline\n   *  @param {string[]} cfg.reservedCommands - Words that are set to new line separately\n   *  @param {string[]} cfg.reservedBinaryCommands - Words that are top level but have no indentation\n   *  @param {string[]} cfg.reservedJoinConditions - ON and USING\n   *  @param {string[]} cfg.stringTypes - string types to enable - \"\", '', ``, [], N''\n   *  @param {string[]} cfg.blockStart - Opening parentheses to enable, like (, [\n   *  @param {string[]} cfg.blockEnd - Closing parentheses to enable, like ), ]\n   *  @param {string[]} cfg.indexedPlaceholderTypes - Prefixes for indexed placeholders, like ?\n   *  @param {string[]} cfg.namedPlaceholderTypes - Prefixes for named placeholders, like @ and :\n   *  @param {string[]} cfg.lineCommentTypes - Line comments to enable, like # and --\n   *  @param {string[]} cfg.specialWordChars - Special chars that can be found inside of words, like @ and #\n   *  @param {string[]} cfg.operators - Additional operators to recognize\n   */\n  constructor(cfg: TokenizerOptions) {\n    const specialWordCharsAll = Object.values(cfg.specialWordChars ?? {}).join('');\n    this.REGEX_MAP = {\n      [TokenType.WORD]: regexFactory.createWordRegex(cfg.specialWordChars),\n      [TokenType.STRING]: regexFactory.createStringRegex(cfg.stringTypes),\n      [TokenType.RESERVED_KEYWORD]: regexFactory.createReservedWordRegex(\n        cfg.reservedKeywords,\n        specialWordCharsAll\n      ),\n      [TokenType.RESERVED_DEPENDENT_CLAUSE]: regexFactory.createReservedWordRegex(\n        cfg.reservedDependentClauses ?? [],\n        specialWordCharsAll\n      ),\n      [TokenType.RESERVED_LOGICAL_OPERATOR]: regexFactory.createReservedWordRegex(\n        cfg.reservedLogicalOperators,\n        specialWordCharsAll\n      ),\n      [TokenType.RESERVED_COMMAND]: regexFactory.createReservedWordRegex(\n        cfg.reservedCommands,\n        specialWordCharsAll\n      ),\n      [TokenType.RESERVED_BINARY_COMMAND]: regexFactory.createReservedWordRegex(\n        cfg.reservedBinaryCommands,\n        specialWordCharsAll\n      ),\n      [TokenType.RESERVED_JOIN_CONDITION]: regexFactory.createReservedWordRegex(\n        cfg.reservedJoinConditions,\n        specialWordCharsAll\n      ),\n      [TokenType.OPERATOR]: regexFactory.createOperatorRegex('+-/*%&|^><=.,;[]{}`:$', [\n        '<>',\n        '<=',\n        '>=',\n        '!=',\n        ...(cfg.operators ?? []),\n      ]),\n      [TokenType.BLOCK_START]: regexFactory.createParenRegex(cfg.blockStart),\n      [TokenType.BLOCK_END]: regexFactory.createParenRegex(cfg.blockEnd),\n      [TokenType.LINE_COMMENT]: regexFactory.createLineCommentRegex(cfg.lineCommentTypes),\n      [TokenType.BLOCK_COMMENT]: /^(\\/\\*[^]*?(?:\\*\\/|$))/u,\n      [TokenType.NUMBER]:\n        /^(0x[0-9a-fA-F]+|0b[01]+|(-\\s*)?[0-9]+(\\.[0-9]*)?([eE][-+]?[0-9]+(\\.[0-9]+)?)?)/u,\n      [TokenType.PLACEHOLDER]: NULL_REGEX, // matches nothing\n      [TokenType.EOF]: NULL_REGEX, // matches nothing\n    };\n\n    this.INDEXED_PLACEHOLDER_REGEX = regexFactory.createPlaceholderRegex(\n      cfg.indexedPlaceholderTypes ?? [],\n      '[0-9]*'\n    );\n    this.IDENT_NAMED_PLACEHOLDER_REGEX = regexFactory.createPlaceholderRegex(\n      cfg.namedPlaceholderTypes,\n      '[a-zA-Z0-9._$]+'\n    );\n    this.STRING_NAMED_PLACEHOLDER_REGEX = regexFactory.createPlaceholderRegex(\n      cfg.namedPlaceholderTypes,\n      regexFactory.createStringPattern(cfg.stringTypes)\n    );\n  }\n\n  /**\n   * Takes a SQL string and breaks it into tokens.\n   * Each token is an object with type and value.\n   *\n   * @param {string} input - The SQL string\n   * @returns {Token[]} output token stream\n   */\n  tokenize(input: string): Token[] {\n    const tokens: Token[] = [];\n    let token: Token | undefined;\n\n    // Keep processing the string until it is empty\n    while (input.length) {\n      // grab any preceding whitespace\n      const whitespaceBefore = this.getWhitespace(input);\n      input = input.substring(whitespaceBefore.length);\n\n      if (input.length) {\n        // Get the next token and the token type\n        token = this.getNextToken(input, token);\n        // Advance the string\n        input = input.substring(token.value.length);\n\n        tokens.push({ ...token, whitespaceBefore });\n      }\n    }\n    return tokens;\n  }\n\n  /** Matches preceding whitespace if present */\n  getWhitespace(input: string): string {\n    const matches = input.match(WHITESPACE_REGEX);\n    return matches ? matches[1] : '';\n  }\n\n  /** Curried function of `getTokenOnFirstMatch` that allows token type to be passed first */\n  matchToken =\n    (tokenType: TokenType) =>\n    (input: string): Token | undefined =>\n      this.getTokenOnFirstMatch({\n        input,\n        type: tokenType,\n        regex: this.REGEX_MAP[tokenType],\n      });\n\n  /** Attempts to match next token from input string, tests RegExp patterns in decreasing priority */\n  getNextToken(input: string, previousToken?: Token) {\n    return (this.matchToken(TokenType.LINE_COMMENT)(input) ||\n      this.matchToken(TokenType.BLOCK_COMMENT)(input) ||\n      this.matchToken(TokenType.STRING)(input) ||\n      this.matchToken(TokenType.BLOCK_START)(input) ||\n      this.matchToken(TokenType.BLOCK_END)(input) ||\n      this.getPlaceholderToken(input) ||\n      this.matchToken(TokenType.NUMBER)(input) ||\n      this.getReservedWordToken(input, previousToken) ||\n      this.matchToken(TokenType.WORD)(input) ||\n      this.matchToken(TokenType.OPERATOR)(input)) as Token;\n  }\n\n  /**\n   * Attempts to match a placeholder token pattern\n   * @return {Token | undefined} - The placeholder token if found, otherwise undefined\n   */\n  getPlaceholderToken(input: string): Token | undefined {\n    const placeholderTokenRegexMap: { regex: RegExp; parseKey: (s: string) => string }[] = [\n      // pattern for placeholder with identifier name\n      {\n        regex: this.IDENT_NAMED_PLACEHOLDER_REGEX ?? NULL_REGEX,\n        parseKey: v => v.slice(1),\n      },\n      // pattern for placeholder with string name\n      {\n        regex: this.STRING_NAMED_PLACEHOLDER_REGEX ?? NULL_REGEX,\n        parseKey: v =>\n          this.getEscapedPlaceholderKey({ key: v.slice(2, -1), quoteChar: v.slice(-1) }),\n      },\n      // pattern for placeholder with numeric index\n      {\n        regex: this.INDEXED_PLACEHOLDER_REGEX ?? NULL_REGEX,\n        parseKey: v => v.slice(1),\n      },\n    ];\n\n    return placeholderTokenRegexMap.reduce((acc, { regex, parseKey }) => {\n      const token = this.getTokenOnFirstMatch({ input, regex, type: TokenType.PLACEHOLDER });\n      return token ? { ...token, key: parseKey(token.value) } : acc;\n    }, undefined as Token | undefined);\n  }\n\n  getEscapedPlaceholderKey({ key, quoteChar }: { key: string; quoteChar: string }): string {\n    return key.replace(new RegExp(escapeRegExp('\\\\' + quoteChar), 'gu'), quoteChar);\n  }\n\n  /**\n   * Attempts to match a Reserved word token pattern, avoiding edge cases of Reserved words within string tokens\n   * @return {Token | undefined} - The Reserved word token if found, otherwise undefined\n   */\n  getReservedWordToken(input: string, previousToken?: Token): Token | undefined {\n    // A reserved word cannot be preceded by a '.'\n    // this makes it so in \"mytable.from\", \"from\" is not considered a reserved word\n    if (previousToken?.value === '.') {\n      return undefined;\n    }\n\n    // prioritised list of Reserved token types\n    const reservedTokenList = [\n      TokenType.RESERVED_COMMAND,\n      TokenType.RESERVED_BINARY_COMMAND,\n      TokenType.RESERVED_DEPENDENT_CLAUSE,\n      TokenType.RESERVED_LOGICAL_OPERATOR,\n      TokenType.RESERVED_KEYWORD,\n      TokenType.RESERVED_JOIN_CONDITION,\n    ];\n\n    return reservedTokenList.reduce(\n      (matchedToken, tokenType) => matchedToken || this.matchToken(tokenType)(input),\n      undefined as Token | undefined\n    );\n  }\n\n  /**\n   * Attempts to match RegExp from head of input, returning undefined if not found\n   * @param {string} _.input - The string to match\n   * @param {TokenType} _.type - The type of token to match against\n   * @param {RegExp} _.regex - The regex to match\n   * @return {Token | undefined} - The matched token if found, otherwise undefined\n   */\n  getTokenOnFirstMatch({\n    input,\n    type,\n    regex,\n  }: {\n    input: string;\n    type: TokenType;\n    regex: RegExp;\n  }): Token | undefined {\n    const matches = input.match(regex);\n    return matches ? ({ type, value: matches[1] } as Token) : undefined;\n  }\n}\n","import { maxLength } from '../utils';\n\n/**\n * Handles select alias placement - tabulates if enabled\n */\nexport default function formatAliasPositions(query: string): string {\n  const lines = query.split('\\n');\n\n  let newQuery: string[] = [];\n  for (let i = 0; i < lines.length; i++) {\n    // find SELECT rows with trailing comma, if no comma (only one row) - no-op\n    if (lines[i].match(/^\\s*SELECT/i)) {\n      let aliasLines: string[] = [];\n      if (lines[i].match(/.*,$/)) {\n        aliasLines = [lines[i]]; // add select to aliasLines in case of tabular formats\n      } else {\n        newQuery.push(lines[i]); // add select to new query\n        if (lines[i].match(/^\\s*SELECT\\s+.+(?!,$)/i)) {\n          continue;\n        }\n        aliasLines.push(lines[++i]);\n      }\n\n      // get all lines in SELECT clause\n      while (lines[i++].match(/.*,$/)) {\n        aliasLines.push(lines[i]);\n      }\n\n      // break lines into alias with optional AS, and all preceding text\n      const splitLines = aliasLines\n        .map(line => ({ line, matches: line.match(/(^.*?\\S) (AS )?(\\S+,?$)/i) }))\n        .map(({ line, matches }) => {\n          if (!matches) {\n            return { precedingText: line };\n          }\n          return {\n            precedingText: matches[1],\n            as: matches[2],\n            alias: matches[3],\n          };\n        });\n\n      // get longest of precedingText, trim trailing comma for non-alias columns\n      const aliasMaxLength = maxLength(\n        splitLines.map(({ precedingText }) => precedingText.replace(/\\s*,\\s*$/, ''))\n      );\n      // re-construct line, aligning by inserting space before AS or alias\n      aliasLines = splitLines.map(\n        ({ precedingText, as, alias }) =>\n          precedingText +\n          (alias ? ' '.repeat(aliasMaxLength - precedingText.length + 1) + (as ?? '') + alias : '')\n      );\n      newQuery = [...newQuery, ...aliasLines];\n    }\n    newQuery.push(lines[i]);\n  }\n\n  return newQuery.join('\\n');\n}\n","import { CommaPosition } from '../types';\nimport { maxLength } from '../utils';\nimport { WHITESPACE_REGEX } from './Tokenizer';\n\n/**\n * Handles comma placement - either before, after or tabulated\n */\nexport default function formatCommaPositions(\n  query: string,\n  commaPosition: CommaPosition,\n  indent: string\n): string {\n  return groupCommaDelimitedLines(query.split('\\n'))\n    .flatMap(commaLines => {\n      if (commaLines.length === 1) {\n        return commaLines;\n      } else if (commaPosition === 'tabular') {\n        return formatTabular(commaLines);\n      } else if (commaPosition === 'before') {\n        return formatBefore(commaLines, indent);\n      } else {\n        throw new Error(`Unexpected commaPosition: ${commaPosition}`);\n      }\n    })\n    .join('\\n');\n}\n\n/**\n * Given lines like this:\n *\n *     [\n *       'SELECT',\n *       '  foo,',\n *       '  bar,',\n *       '  baz',\n *       'FROM'\n *     ]\n *\n * Returns groups like this:\n *\n *     [\n *       ['SELECT'],\n *       ['  foo,', '  bar,', '  baz'],\n *       ['FROM']\n *     ]\n */\nfunction groupCommaDelimitedLines(lines: string[]): string[][] {\n  const groups: string[][] = [];\n  for (let i = 0; i < lines.length; i++) {\n    const group = [lines[i]];\n    // when line ends with comma,\n    // gather together all following lines that also end with comma,\n    // plus one (which doesn't end with comma)\n    while (lines[i].match(/.*,$/)) {\n      i++;\n      group.push(lines[i]);\n    }\n    groups.push(group);\n  }\n  return groups;\n}\n\n// makes all lines the same length by appending spaces before comma\nfunction formatTabular(commaLines: string[]): string[] {\n  const maxLineLength = maxLength(commaLines);\n  return trimTrailingCommas(commaLines).map((line, i) => {\n    if (i === commaLines.length - 1) {\n      return line; // do not add comma for last item\n    }\n    return line + ' '.repeat(maxLineLength - line.length - 1) + ',';\n  });\n}\n\nfunction formatBefore(commaLines: string[], indent: string): string[] {\n  return trimTrailingCommas(commaLines).map((line, i) => {\n    if (i === 0) {\n      return line; // do not add comma for first item\n    }\n    const [whitespace] = line.match(WHITESPACE_REGEX) || [''];\n    return (\n      removeLastIndent(whitespace, indent) +\n      indent.replace(/ {2}$/, ', ') + // add comma to the end of last indent\n      line.trimStart()\n    );\n  });\n}\n\nfunction removeLastIndent(whitespace: string, indent: string): string {\n  return whitespace.replace(new RegExp(indent + '$'), '');\n}\n\nfunction trimTrailingCommas(lines: string[]): string[] {\n  return lines.map(line => line.replace(/,$/, ''));\n}\n","import { escapeRegExp, isEmpty, sortByLengthDesc } from '../utils';\n\n/**\n * Builds a RegExp containing all operators for a SQL dialect\n * @param {string} monadOperators - concatenated string of all 1-length operators\n * @param {string[]} polyadOperators - list of strings of all >1-length operators\n */\nexport const createOperatorRegex = (monadOperators: string, polyadOperators: string[]): RegExp =>\n  new RegExp(\n    `^(${sortByLengthDesc(polyadOperators).map(escapeRegExp).join('|')}|` +\n      `[${monadOperators.split('').map(escapeRegExp).join('')}])`,\n    'u'\n  );\n\n/**\n * Builds a RegExp for valid line comments in a SQL dialect\n * @param {string[]} lineCommentTypes - list of character strings that denote line comments\n */\nexport const createLineCommentRegex = (lineCommentTypes: string[]): RegExp =>\n  new RegExp(\n    `^((?:${lineCommentTypes.map(c => escapeRegExp(c)).join('|')}).*?)(?:\\r\\n|\\r|\\n|$)`,\n    'u'\n  );\n\n/**\n * Builds a RegExp for all Reserved Keywords in a SQL dialect\n * @param {string[]} reservedKeywords - list of strings of all Reserved Keywords\n * @param {string} specialWordChars - concatenated string of all special chars that can appear in valid identifiers (and not in Reserved Keywords)\n */\nexport const createReservedWordRegex = (\n  reservedKeywords: string[],\n  specialWordChars: string = ''\n): RegExp => {\n  if (reservedKeywords.length === 0) {\n    return /^\\b$/u;\n  }\n  const reservedKeywordsPattern = sortByLengthDesc(reservedKeywords)\n    .join('|')\n    .replace(/ /gu, '\\\\s+');\n  return new RegExp(\n    `^(${reservedKeywordsPattern})(?![${escapeRegExp(specialWordChars)}]+)\\\\b`,\n    'iu'\n  );\n};\n\n/**\n * Builds a RegExp for valid identifiers in a SQL dialect\n * @param {Object} specialChars\n * @param {string} specialChars.any - concatenated string of chars that can appear anywhere in a valid identifier\n * @param {string} specialChars.prefix - concatenated string of chars that only appear at the beginning of a valid identifier\n * @param {string} specialChars.suffix - concatenated string of chars that only appear at the end of a valid identifier\n */\nexport const createWordRegex = (\n  specialChars: { any?: string; prefix?: string; suffix?: string } = {}\n): RegExp => {\n  const prefixLookBehind = `[${escapeRegExp(specialChars.prefix ?? '')}]*`;\n  const suffixLookAhead = `[${escapeRegExp(specialChars.suffix ?? '')}]*`;\n  const unicodeWordChar =\n    '\\\\p{Alphabetic}\\\\p{Mark}\\\\p{Decimal_Number}\\\\p{Connector_Punctuation}\\\\p{Join_Control}';\n  const specialWordChars = `${escapeRegExp(specialChars.any ?? '')}`;\n\n  const arrayAccessor = '\\\\[\\\\d\\\\]';\n  const mapAccessor = `\\\\[['\"][${unicodeWordChar}]+['\"]\\\\]`;\n\n  return new RegExp(\n    `^((${prefixLookBehind}([${unicodeWordChar}${specialWordChars}]+)${suffixLookAhead})(${arrayAccessor}|${mapAccessor})?)`,\n    'u'\n  );\n};\n\n// This enables the following string patterns:\n// 1. backtick quoted string using `` to escape\n// 2. square bracket quoted string (SQL Server) using ]] to escape\n// 3. double quoted string using \"\" or \\\" to escape\n// 4. single quoted string using '' or \\' to escape\n// 5. national character quoted string using N'' or N\\' to escape\n// 6. Unicode single-quoted string using \\' to escape\n// 7. Unicode double-quoted string using \\\" to escape\n// 8. PostgreSQL dollar-quoted strings\nconst patterns = {\n  '``': '((`[^`]*($|`))+)',\n  '{}': '((\\\\{[^\\\\}]*($|\\\\}))+)',\n  '[]': '((\\\\[[^\\\\]]*($|\\\\]))(\\\\][^\\\\]]*($|\\\\]))*)',\n  '\"\"': '((\"[^\"\\\\\\\\]*(?:\\\\\\\\.[^\"\\\\\\\\]*)*(\"|$))+)',\n  \"''\": \"(('[^'\\\\\\\\]*(?:\\\\\\\\.[^'\\\\\\\\]*)*('|$))+)\",\n  \"N''\": \"((N'[^'\\\\\\\\]*(?:\\\\\\\\.[^'\\\\\\\\]*)*('|$))+)\",\n  \"x''\": \"(([xX]'[^'\\\\\\\\]*(?:\\\\\\\\.[^'\\\\\\\\]*)*('|$))+)\",\n  \"E''\": \"((E'[^'\\\\\\\\]*(?:\\\\\\\\.[^'\\\\\\\\]*)*('|$))+)\",\n  \"U&''\": \"((U&'[^'\\\\\\\\]*(?:\\\\\\\\.[^'\\\\\\\\]*)*('|$))+)\",\n  'U&\"\"': '((U&\"[^\"\\\\\\\\]*(?:\\\\\\\\.[^\"\\\\\\\\]*)*(\"|$))+)',\n  '$$': '((?<tag>\\\\$\\\\w*\\\\$)[\\\\s\\\\S]*?(?:\\\\k<tag>|$))',\n};\nexport type StringPatternType = keyof typeof patterns;\n\n/**\n * Builds a string pattern for matching string patterns for all given string types\n * @param {StringPatternType[]} stringTypes - list of strings that denote string patterns\n */\nexport const createStringPattern = (stringTypes: StringPatternType[]): string =>\n  stringTypes.map(t => patterns[t]).join('|');\n\n/**\n * Builds a RegExp for matching string patterns using `createStringPattern`\n * @param {StringPatternType[]} stringTypes - list of strings that denote string patterns\n */\nexport const createStringRegex = (stringTypes: StringPatternType[]): RegExp =>\n  new RegExp('^(' + createStringPattern(stringTypes) + ')', 'u');\n\n/** Escapes paren characters for RegExp patterns */\nconst escapeParen = (paren: string): string => {\n  if (paren.length === 1) {\n    // A single punctuation character\n    return escapeRegExp(paren);\n  } else {\n    // longer word\n    return '\\\\b' + paren + '\\\\b';\n  }\n};\n\n/**\n * Builds a RegExp for matching parenthesis patterns, escaping them with `escapeParen`\n * @param {string[]} parens - list of strings that denote parenthesis patterns\n */\nexport const createParenRegex = (parens: string[]): RegExp =>\n  new RegExp('^(' + parens.map(escapeParen).join('|') + ')', 'iu');\n\n/**\n * Builds a RegExp for placeholder patterns\n * @param {string[]} types - list of strings that denote placeholder types\n * @param {string} pattern - string that denotes placeholder pattern\n */\nexport const createPlaceholderRegex = (types: string[], pattern: string): RegExp | undefined => {\n  if (isEmpty(types)) {\n    return undefined;\n  }\n  const typesRegex = types.map(escapeRegExp).join('|');\n\n  return new RegExp(`^((?:${typesRegex})(?:${pattern}))`, 'u');\n};\n","import { IndentStyle } from '../types';\nimport { Token, ZWS } from './token';\n\n/**\n * When tabular style enabled,\n * produces a 10-char wide version of reserved token.\n *\n * It'll be padded by zero-width space characters\n * instead of normal spaces, so that these spaces will survive\n * trimming of spaces in other parts of formatter.\n * They'll be converted to normal spaces in the end of\n * all the normal formatting with the replaceTabularPlaceholders()\n */\nexport function toTabularToken(token: Token, indentStyle: IndentStyle): Token {\n  if (indentStyle === 'standard') {\n    return token;\n  }\n\n  let bufferItem = token.value; // store which part of keyword receives 10-space buffer\n  let tail = [] as string[]; // rest of keyword\n  if (bufferItem.length >= 10 && bufferItem.includes(' ')) {\n    // split for long keywords like INNER JOIN or UNION DISTINCT\n    [bufferItem, ...tail] = bufferItem.split(' ');\n  }\n\n  if (indentStyle === 'tabularLeft') {\n    bufferItem = bufferItem.padEnd(9, ZWS);\n  } else {\n    bufferItem = bufferItem.padStart(9, ZWS);\n  }\n\n  return {\n    ...token,\n    value: bufferItem + ['', ...tail].join(' '),\n  };\n}\n\n/**\n * Replaces zero-width-spaces added by the above function\n */\nexport function replaceTabularPlaceholders(query: string): string {\n  return query.replace(new RegExp(ZWS, 'ugim'), ' ');\n}\n","/** Token type enum for all possible Token categories */\nexport enum TokenType {\n  WORD = 'WORD',\n  STRING = 'STRING',\n  RESERVED_KEYWORD = 'RESERVED_KEYWORD',\n  RESERVED_LOGICAL_OPERATOR = 'RESERVED_LOGICAL_OPERATOR',\n  RESERVED_DEPENDENT_CLAUSE = 'RESERVED_DEPENDENT_CLAUSE',\n  RESERVED_BINARY_COMMAND = 'RESERVED_BINARY_COMMAND',\n  RESERVED_COMMAND = 'RESERVED_COMMAND',\n  RESERVED_JOIN_CONDITION = 'RESERVED_JOIN_CONDITION',\n  OPERATOR = 'OPERATOR',\n  BLOCK_START = 'BLOCK_START',\n  BLOCK_END = 'BLOCK_END',\n  LINE_COMMENT = 'LINE_COMMENT',\n  BLOCK_COMMENT = 'BLOCK_COMMENT',\n  NUMBER = 'NUMBER',\n  PLACEHOLDER = 'PLACEHOLDER',\n  EOF = 'EOF',\n}\n\n/** Struct to store the most basic cohesive unit of language grammar */\nexport interface Token {\n  value: string;\n  type: TokenType;\n  key?: string;\n  whitespaceBefore?: string;\n}\n\n/**\n * For use as a \"missing token\"\n * e.g. in lookAhead and lookBehind to avoid dealing with null values\n */\nexport const EOF_TOKEN = { type: TokenType.EOF, value: '«EOF»' };\n\n/** Special Unicode character to serve as a placeholder for tabular formats as \\w whitespace is unavailable */\nexport const ZWS = '​'; // uses zero-width space (&#8203; / U+200B)\nconst ZWS_REGEX = '\\u200b';\nconst spaces = `[${ZWS_REGEX}\\\\s]`;\n\n/** Checks if two tokens are equivalent */\nexport const testToken =\n  (compareToken: Token) =>\n  (token: Token): boolean =>\n    token.type === compareToken.type &&\n    new RegExp(`^${spaces}*${compareToken.value}${spaces}*$`, 'iu').test(token.value);\n\n/** Util object that allows for easy checking of Reserved Keywords */\nexport const isToken = {\n  AS: testToken({ value: 'AS', type: TokenType.RESERVED_KEYWORD }),\n  AND: testToken({ value: 'AND', type: TokenType.RESERVED_LOGICAL_OPERATOR }),\n  BETWEEN: testToken({ value: 'BETWEEN', type: TokenType.RESERVED_KEYWORD }),\n  CASE: testToken({ value: 'CASE', type: TokenType.BLOCK_START }),\n  CAST: testToken({ value: 'CAST', type: TokenType.RESERVED_KEYWORD }),\n  BY: testToken({ value: 'BY', type: TokenType.RESERVED_KEYWORD }),\n  END: testToken({ value: 'END', type: TokenType.BLOCK_END }),\n  FROM: testToken({ value: 'FROM', type: TokenType.RESERVED_COMMAND }),\n  LIMIT: testToken({ value: 'LIMIT', type: TokenType.RESERVED_COMMAND }),\n  SELECT: testToken({ value: 'SELECT', type: TokenType.RESERVED_COMMAND }),\n  SET: testToken({ value: 'SET', type: TokenType.RESERVED_COMMAND }),\n  TABLE: testToken({ value: 'TABLE', type: TokenType.RESERVED_KEYWORD }),\n  WINDOW: testToken({ value: 'WINDOW', type: TokenType.RESERVED_COMMAND }),\n  WITH: testToken({ value: 'WITH', type: TokenType.RESERVED_COMMAND }),\n};\n\n/** Checks if token is a Reserved Command or Reserved Binary Command */\nexport const isCommand = (token: Token): boolean =>\n  token.type === TokenType.RESERVED_COMMAND || token.type === TokenType.RESERVED_BINARY_COMMAND;\n\n/** Checks if token is any Reserved Keyword or Command */\nexport const isReserved = (token: Token): boolean =>\n  token.type === TokenType.RESERVED_KEYWORD ||\n  token.type === TokenType.RESERVED_LOGICAL_OPERATOR ||\n  token.type === TokenType.RESERVED_DEPENDENT_CLAUSE ||\n  token.type === TokenType.RESERVED_JOIN_CONDITION ||\n  token.type === TokenType.RESERVED_COMMAND ||\n  token.type === TokenType.RESERVED_BINARY_COMMAND;\n","import Formatter from '../core/Formatter';\nimport Tokenizer from '../core/Tokenizer';\nimport type { StringPatternType } from '../core/regexFactory';\nimport { Token } from '../core/token';\nimport { dedupe } from '../utils';\n\n/**\n * Priority 5 (last)\n * Full list of reserved functions\n * distinct from Keywords due to interaction with parentheses\n */\nconst reservedFunctions = {\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/aead_encryption_functions\n  aead: [\n    'KEYS.NEW_KEYSET',\n    'KEYS.ADD_KEY_FROM_RAW_BYTES',\n    'AEAD.DECRYPT_BYTES',\n    'AEAD.DECRYPT_STRING',\n    'AEAD.ENCRYPT',\n    'KEYS.KEYSET_CHAIN',\n    'KEYS.KEYSET_FROM_JSON',\n    'KEYS.KEYSET_TO_JSON',\n    'KEYS.ROTATE_KEYSET',\n    'KEYS.KEYSET_LENGTH',\n  ],\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/aggregate_analytic_functions\n  aggregateAnalytic: [\n    'ANY_VALUE',\n    'ARRAY_AGG',\n    'AVG',\n    'CORR',\n    'COUNT',\n    'COUNTIF',\n    'COVAR_POP',\n    'COVAR_SAMP',\n    'MAX',\n    'MIN',\n    'ST_CLUSTERDBSCAN',\n    'STDDEV_POP',\n    'STDDEV_SAMP',\n    'STRING_AGG',\n    'SUM',\n    'VAR_POP',\n    'VAR_SAMP',\n  ],\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/aggregate_functions\n  aggregate: [\n    'ANY_VALUE',\n    'ARRAY_AGG',\n    'ARRAY_CONCAT_AGG',\n    'AVG',\n    'BIT_AND',\n    'BIT_OR',\n    'BIT_XOR',\n    'COUNT',\n    'COUNTIF',\n    'LOGICAL_AND',\n    'LOGICAL_OR',\n    'MAX',\n    'MIN',\n    'STRING_AGG',\n    'SUM',\n  ],\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/approximate_aggregate_functions\n  approximateAggregate: [\n    'APPROX_COUNT_DISTINCT',\n    'APPROX_QUANTILES',\n    'APPROX_TOP_COUNT',\n    'APPROX_TOP_SUM',\n  ],\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/array_functions\n  array: [\n    'ARRAY',\n    'ARRAY_CONCAT',\n    'ARRAY_LENGTH',\n    'ARRAY_TO_STRING',\n    'GENERATE_ARRAY',\n    'GENERATE_DATE_ARRAY',\n    'GENERATE_TIMESTAMP_ARRAY',\n    'ARRAY_REVERSE',\n    'OFFSET',\n    'SAFE_OFFSET',\n    'ORDINAL',\n    'SAFE_ORDINAL',\n  ],\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/bit_functions\n  bitwise: ['BIT_COUNT'],\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/conversion_functions\n  conversion: ['CASE', 'PARSE_BIGNUMERIC', 'PARSE_NUMERIC', 'SAFE_CAST'],\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/date_functions\n  date: [\n    'CURRENT_DATE',\n    'EXTRACT',\n    'DATE',\n    'DATE_ADD',\n    'DATE_SUB',\n    'DATE_DIFF',\n    'DATE_TRUNC',\n    'DATE_FROM_UNIX_DATE',\n    'FORMAT_DATE',\n    'LAST_DAY',\n    'PARSE_DATE',\n    'UNIX_DATE',\n  ],\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/datetime_functions\n  datetime: [\n    'CURRENT_DATETIME',\n    'DATETIME',\n    'EXTRACT',\n    'DATETIME_ADD',\n    'DATETIME_SUB',\n    'DATETIME_DIFF',\n    'DATETIME_TRUNC',\n    'FORMAT_DATETIME',\n    'LAST_DAY',\n    'PARSE_DATETIME',\n  ],\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/debugging_functions\n  debugging: ['ERROR'],\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/federated_query_functions\n  federatedQuery: ['EXTERNAL_QUERY'],\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/geography_functions\n  geography: [\n    'S2_CELLIDFROMPOINT',\n    'S2_COVERINGCELLIDS',\n    'ST_ANGLE',\n    'ST_AREA',\n    'ST_ASBINARY',\n    'ST_ASGEOJSON',\n    'ST_ASTEXT',\n    'ST_AZIMUTH',\n    'ST_BOUNDARY',\n    'ST_BOUNDINGBOX',\n    'ST_BUFFER',\n    'ST_BUFFERWITHTOLERANCE',\n    'ST_CENTROID',\n    'ST_CENTROID_AGG',\n    'ST_CLOSESTPOINT',\n    'ST_CLUSTERDBSCAN',\n    'ST_CONTAINS',\n    'ST_CONVEXHULL',\n    'ST_COVEREDBY',\n    'ST_COVERS',\n    'ST_DIFFERENCE',\n    'ST_DIMENSION',\n    'ST_DISJOINT',\n    'ST_DISTANCE',\n    'ST_DUMP',\n    'ST_DWITHIN',\n    'ST_ENDPOINT',\n    'ST_EQUALS',\n    'ST_EXTENT',\n    'ST_EXTERIORRING',\n    'ST_GEOGFROM',\n    'ST_GEOGFROMGEOJSON',\n    'ST_GEOGFROMTEXT',\n    'ST_GEOGFROMWKB',\n    'ST_GEOGPOINT',\n    'ST_GEOGPOINTFROMGEOHASH',\n    'ST_GEOHASH',\n    'ST_GEOMETRYTYPE',\n    'ST_INTERIORRINGS',\n    'ST_INTERSECTION',\n    'ST_INTERSECTS',\n    'ST_INTERSECTSBOX',\n    'ST_ISCOLLECTION',\n    'ST_ISEMPTY',\n    'ST_LENGTH',\n    'ST_MAKELINE',\n    'ST_MAKEPOLYGON',\n    'ST_MAKEPOLYGONORIENTED',\n    'ST_MAXDISTANCE',\n    'ST_NPOINTS',\n    'ST_NUMGEOMETRIES',\n    'ST_NUMPOINTS',\n    'ST_PERIMETER',\n    'ST_POINTN',\n    'ST_SIMPLIFY',\n    'ST_SNAPTOGRID',\n    'ST_STARTPOINT',\n    'ST_TOUCHES',\n    'ST_UNION',\n    'ST_UNION_AGG',\n    'ST_WITHIN',\n    'ST_X',\n    'ST_Y',\n  ],\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/hash_functions\n  hash: ['FARM_FINGERPRINT', 'MD5', 'SHA1', 'SHA256', 'SHA512'],\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/hll_functions\n  hll: ['HLL_COUNT.INIT', 'HLL_COUNT.MERGE', 'HLL_COUNT.MERGE_PARTIAL', 'HLL_COUNT.EXTRACT'],\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/interval_functions\n  interval: ['MAKE_INTERVAL', 'EXTRACT', 'JUSTIFY_DAYS', 'JUSTIFY_HOURS', 'JUSTIFY_INTERVAL'],\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/json_functions\n  json: [\n    'JSON_EXTRACT',\n    'JSON_QUERY',\n    'JSON_EXTRACT_SCALAR',\n    'JSON_VALUE',\n    'JSON_EXTRACT_ARRAY',\n    'JSON_QUERY_ARRAY',\n    'JSON_EXTRACT_STRING_ARRAY',\n    'JSON_VALUE_ARRAY',\n    'TO_JSON_STRING',\n  ],\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/mathematical_functions\n  math: [\n    'ABS',\n    'SIGN',\n    'IS_INF',\n    'IS_NAN',\n    'IEEE_DIVIDE',\n    'RAND',\n    'SQRT',\n    'POW',\n    'POWER',\n    'EXP',\n    'LN',\n    'LOG',\n    'LOG10',\n    'GREATEST',\n    'LEAST',\n    'DIV',\n    'SAFE_DIVIDE',\n    'SAFE_MULTIPLY',\n    'SAFE_NEGATE',\n    'SAFE_ADD',\n    'SAFE_SUBTRACT',\n    'MOD',\n    'ROUND',\n    'TRUNC',\n    'CEIL',\n    'CEILING',\n    'FLOOR',\n    'COS',\n    'COSH',\n    'ACOS',\n    'ACOSH',\n    'SIN',\n    'SINH',\n    'ASIN',\n    'ASINH',\n    'TAN',\n    'TANH',\n    'ATAN',\n    'ATANH',\n    'ATAN2',\n    'RANGE_BUCKET',\n  ],\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/navigation_functions\n  navigation: [\n    'FIRST_VALUE',\n    'LAST_VALUE',\n    'NTH_VALUE',\n    'LEAD',\n    'LAG',\n    'PERCENTILE_CONT',\n    'PERCENTILE_DISC',\n  ],\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/net_functions\n  net: [\n    'NET.IP_FROM_STRING',\n    'NET.SAFE_IP_FROM_STRING',\n    'NET.IP_TO_STRING',\n    'NET.IP_NET_MASK',\n    'NET.IP_TRUNC',\n    'NET.IPV4_FROM_INT64',\n    'NET.IPV4_TO_INT64',\n    'NET.HOST',\n    'NET.PUBLIC_SUFFIX',\n    'NET.REG_DOMAIN',\n  ],\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/numbering_functions\n  numbering: ['RANK', 'DENSE_RANK', 'PERCENT_RANK', 'CUME_DIST', 'NTILE', 'ROW_NUMBER'],\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/security_functions\n  security: ['SESSION_USER'],\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/statistical_aggregate_functions\n  statisticalAggregate: [\n    'CORR',\n    'COVAR_POP',\n    'COVAR_SAMP',\n    'STDDEV_POP',\n    'STDDEV_SAMP',\n    'STDDEV',\n    'VAR_POP',\n    'VAR_SAMP',\n    'VARIANCE',\n  ],\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/string_functions\n  string: [\n    'ASCII',\n    'BYTE_LENGTH',\n    'CHAR_LENGTH',\n    'CHARACTER_LENGTH',\n    'CHR',\n    'CODE_POINTS_TO_BYTES',\n    'CODE_POINTS_TO_STRING',\n    'CONCAT',\n    'CONTAINS_SUBSTR',\n    'ENDS_WITH',\n    'FORMAT',\n    'FROM_BASE32',\n    'FROM_BASE64',\n    'FROM_HEX',\n    'INITCAP',\n    'INSTR',\n    'LEFT',\n    'LENGTH',\n    'LPAD',\n    'LOWER',\n    'LTRIM',\n    'NORMALIZE',\n    'NORMALIZE_AND_CASEFOLD',\n    'OCTET_LENGTH',\n    'REGEXP_CONTAINS',\n    'REGEXP_EXTRACT',\n    'REGEXP_EXTRACT_ALL',\n    'REGEXP_INSTR',\n    'REGEXP_REPLACE',\n    'REGEXP_SUBSTR',\n    'REPLACE',\n    'REPEAT',\n    'REVERSE',\n    'RIGHT',\n    'RPAD',\n    'RTRIM',\n    'SAFE_CONVERT_BYTES_TO_STRING',\n    'SOUNDEX',\n    'SPLIT',\n    'STARTS_WITH',\n    'STRPOS',\n    'SUBSTR',\n    'SUBSTRING',\n    'TO_BASE32',\n    'TO_BASE64',\n    'TO_CODE_POINTS',\n    'TO_HEX',\n    'TRANSLATE',\n    'TRIM',\n    'UNICODE',\n    'UPPER',\n  ],\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/time_functions\n  time: [\n    'CURRENT_TIME',\n    'TIME',\n    'EXTRACT',\n    'TIME_ADD',\n    'TIME_SUB',\n    'TIME_DIFF',\n    'TIME_TRUNC',\n    'FORMAT_TIME',\n    'PARSE_TIME',\n  ],\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/timestamp_functions\n  timestamp: [\n    'CURRENT_TIMESTAMP',\n    'EXTRACT',\n    'STRING',\n    'TIMESTAMP',\n    'TIMESTAMP_ADD',\n    'TIMESTAMP_SUB',\n    'TIMESTAMP_DIFF',\n    'TIMESTAMP_TRUNC',\n    'FORMAT_TIMESTAMP',\n    'PARSE_TIMESTAMP',\n    'TIMESTAMP_SECONDS',\n    'TIMESTAMP_MILLIS',\n    'TIMESTAMP_MICROS',\n    'UNIX_SECONDS',\n    'UNIX_MILLIS',\n    'UNIX_MICROS',\n  ],\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/uuid_functions\n  uuid: ['GENERATE_UUID'],\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/conditional_expressions\n  conditional: ['COALESCE', 'IF', 'IFNULL', 'NULLIF'],\n  // https://cloud.google.com/bigquery/docs/reference/legacy-sql\n  legacyAggregate: [\n    'AVG',\n    'BIT_AND',\n    'BIT_OR',\n    'BIT_XOR',\n    'CORR',\n    'COUNT',\n    'COVAR_POP',\n    'COVAR_SAMP',\n    'EXACT_COUNT_DISTINCT',\n    'FIRST',\n    'GROUP_CONCAT',\n    'GROUP_CONCAT_UNQUOTED',\n    'LAST',\n    'MAX',\n    'MIN',\n    'NEST',\n    'NTH',\n    'QUANTILES',\n    'STDDEV',\n    'STDDEV_POP',\n    'STDDEV_SAMP',\n    'SUM',\n    'TOP',\n    'UNIQUE',\n    'VARIANCE',\n    'VAR_POP',\n    'VAR_SAMP',\n  ],\n  legacyBitwise: ['BIT_COUNT'],\n  legacyCasting: ['BOOLEAN', 'BYTES', 'CAST', 'FLOAT', 'HEX_STRING', 'INTEGER', 'STRING'],\n  legacyComparison: [\n    // expr 'IN',\n    'COALESCE',\n    'GREATEST',\n    'IFNULL',\n    'IS_INF',\n    'IS_NAN',\n    'IS_EXPLICITLY_DEFINED',\n    'LEAST',\n    'NVL',\n  ],\n  legacyDatetime: [\n    'CURRENT_DATE',\n    'CURRENT_TIME',\n    'CURRENT_TIMESTAMP',\n    'DATE',\n    'DATE_ADD',\n    'DATEDIFF',\n    'DAY',\n    'DAYOFWEEK',\n    'DAYOFYEAR',\n    'FORMAT_UTC_USEC',\n    'HOUR',\n    'MINUTE',\n    'MONTH',\n    'MSEC_TO_TIMESTAMP',\n    'NOW',\n    'PARSE_UTC_USEC',\n    'QUARTER',\n    'SEC_TO_TIMESTAMP',\n    'SECOND',\n    'STRFTIME_UTC_USEC',\n    'TIME',\n    'TIMESTAMP',\n    'TIMESTAMP_TO_MSEC',\n    'TIMESTAMP_TO_SEC',\n    'TIMESTAMP_TO_USEC',\n    'USEC_TO_TIMESTAMP',\n    'UTC_USEC_TO_DAY',\n    'UTC_USEC_TO_HOUR',\n    'UTC_USEC_TO_MONTH',\n    'UTC_USEC_TO_WEEK',\n    'UTC_USEC_TO_YEAR',\n    'WEEK',\n    'YEAR',\n  ],\n  legacyIp: ['FORMAT_IP', 'PARSE_IP', 'FORMAT_PACKED_IP', 'PARSE_PACKED_IP'],\n  legacyJson: ['JSON_EXTRACT', 'JSON_EXTRACT_SCALAR'],\n  legacyMath: [\n    'ABS',\n    'ACOS',\n    'ACOSH',\n    'ASIN',\n    'ASINH',\n    'ATAN',\n    'ATANH',\n    'ATAN2',\n    'CEIL',\n    'COS',\n    'COSH',\n    'DEGREES',\n    'EXP',\n    'FLOOR',\n    'LN',\n    'LOG',\n    'LOG2',\n    'LOG10',\n    'PI',\n    'POW',\n    'RADIANS',\n    'RAND',\n    'ROUND',\n    'SIN',\n    'SINH',\n    'SQRT',\n    'TAN',\n    'TANH',\n  ],\n  legacyRegex: ['REGEXP_MATCH', 'REGEXP_EXTRACT', 'REGEXP_REPLACE'],\n  legacyString: [\n    'CONCAT',\n    // expr CONTAINS 'str'\n    'INSTR',\n    'LEFT',\n    'LENGTH',\n    'LOWER',\n    'LPAD',\n    'LTRIM',\n    'REPLACE',\n    'RIGHT',\n    'RPAD',\n    'RTRIM',\n    'SPLIT',\n    'SUBSTR',\n    'UPPER',\n  ],\n  legacyTableWildcard: ['TABLE_DATE_RANGE', 'TABLE_DATE_RANGE_STRICT', 'TABLE_QUERY'],\n  legacyUrl: ['HOST', 'DOMAIN', 'TLD'],\n  legacyWindow: [\n    'AVG',\n    'COUNT',\n    'MAX',\n    'MIN',\n    'STDDEV',\n    'SUM',\n    'CUME_DIST',\n    'DENSE_RANK',\n    'FIRST_VALUE',\n    'LAG',\n    'LAST_VALUE',\n    'LEAD',\n    'NTH_VALUE',\n    'NTILE',\n    'PERCENT_RANK',\n    'PERCENTILE_CONT',\n    'PERCENTILE_DISC',\n    'RANK',\n    'RATIO_TO_REPORT',\n    'ROW_NUMBER',\n  ],\n  legacyMisc: [\n    'CURRENT_USER',\n    'EVERY',\n    'FROM_BASE64',\n    'HASH',\n    'FARM_FINGERPRINT',\n    'IF',\n    'POSITION',\n    'SHA1',\n    'SOME',\n    'TO_BASE64',\n  ],\n  other: ['BQ.JOBS.CANCEL', 'BQ.REFRESH_MATERIALIZED_VIEW'],\n};\n\n/**\n * Priority 5 (last)\n * Full list of reserved words\n * any words that are in a higher priority are removed\n */\nconst reservedKeywords = {\n  keywords: [\n    'ALL',\n    // 'AND',\n    'ANY',\n    // 'ARRAY',\n    'AS',\n    'ASC',\n    'ASSERT_ROWS_MODIFIED',\n    'AT',\n    'BETWEEN',\n    'BY',\n    // 'CASE',\n    'CAST',\n    'COLLATE',\n    'CONTAINS',\n    // 'CREATE',\n    // 'CROSS',\n    'CUBE',\n    'CURRENT',\n    'DEFAULT',\n    'DEFINE',\n    'DESC',\n    'DISTINCT',\n    // 'ELSE',\n    // 'END',\n    'ENUM',\n    'ESCAPE',\n    // 'EXCEPT',\n    // 'EXCLUDE',\n    'EXISTS',\n    'EXTRACT',\n    'FALSE',\n    // 'FETCH',\n    'FOLLOWING',\n    'FOR',\n    // 'FROM',\n    'FULL',\n    // 'GROUP',\n    'GROUPING',\n    'GROUPS',\n    'HASH',\n    // 'HAVING',\n    'IF',\n    'IGNORE',\n    'IN',\n    // 'INNER',\n    // 'INTERSECT',\n    // 'INTERVAL',\n    'INTO',\n    'IS',\n    // 'JOIN',\n    // 'LATERAL',\n    // 'LEFT',\n    'LIKE',\n    // 'LIMIT',\n    'LOOKUP',\n    // 'MERGE',\n    // 'NATURAL',\n    'NEW',\n    'NO',\n    'NOT',\n    'NULL',\n    'NULLS',\n    'OF',\n    // 'ON',\n    // 'OR',\n    // 'ORDER',\n    // 'OUTER',\n    'OVER',\n    'PARTITION',\n    'PRECEDING',\n    'PROTO',\n    'RANGE',\n    'RECURSIVE',\n    'RESPECT',\n    // 'RIGHT',\n    'ROLLUP',\n    'ROWS',\n    // 'SELECT',\n    // 'SET',\n    'SOME',\n    // 'STRUCT',\n    'TABLE',\n    // 'TABLESAMPLE',\n    'THEN',\n    'TO',\n    'TREAT',\n    'TRUE',\n    'UNBOUNDED',\n    // 'UNION',\n    // 'UNNEST',\n    // 'USING',\n    // 'WHEN',\n    // 'WHERE',\n    // 'WINDOW',\n    // 'WITH',\n    'WITHIN',\n  ],\n  datatypes: [\n    'ARRAY', // parametric, ARRAY<T>\n    'BOOL',\n    'BYTES', // parameterised, BYTES(Length)\n    'DATE',\n    'DATETIME',\n    'GEOGRAPHY',\n    'INTERVAL',\n    'INT64',\n    'INT',\n    'SMALLINT',\n    'INTEGER',\n    'BIGINT',\n    'TINYINT',\n    'BYTEINT',\n    'NUMERIC', // parameterised, NUMERIC(Precision[, Scale])\n    'DECIMAL', // parameterised, DECIMAL(Precision[, Scale])\n    'BIGNUMERIC', // parameterised, BIGNUMERIC(Precision[, Scale])\n    'BIGDECIMAL', // parameterised, BIGDECIMAL(Precision[, Scale])\n    'FLOAT64',\n    'STRING', // parameterised, STRING(Length)\n    'STRUCT', // parametric, STRUCT<T>\n    'TIME',\n    'TIMEZONE',\n  ],\n  // https://cloud.google.com/bigquery/docs/reference/standard-sql/conversion_functions#formatting_syntax\n  stringFormat: ['HEX', 'BASEX', 'BASE64M', 'ASCII', 'UTF-8', 'UTF8'],\n  misc: ['SAFE'],\n};\n\n/**\n * Priority 1 (first)\n * keywords that begin a new statement\n * will begin new indented block\n */\nconst reservedCommands = [\n  // DQL, https://cloud.google.com/bigquery/docs/reference/standard-sql/query-syntax\n  'SELECT',\n  'FROM',\n  'UNNEST',\n  'PIVOT',\n  'UNPIVOT',\n  'TABLESAMPLE SYSTEM',\n  'WHERE',\n  'GROUP BY',\n  'HAVING',\n  'ORDER BY',\n  'QUALIFY',\n  'WINDOW',\n  'LIMIT',\n  'OFFSET',\n  'WITH',\n  'OMIT RECORD IF', // legacy\n  // DML, https://cloud.google.com/bigquery/docs/reference/standard-sql/dml-syntax\n  'INSERT',\n  'INSERT INTO',\n  'VALUES',\n  'DELETE',\n  // 'DELETE FROM',\n  'TRUNCATE TABLE',\n  'UPDATE',\n  'MERGE',\n  'MERGE INTO',\n  // 'USING',\n  // DDL, https://cloud.google.com/bigquery/docs/reference/standard-sql/data-definition-language\n  'SET SCHEMA', // added\n  'CREATE SCHEMA',\n  'CREATE TABLE',\n  'CREATE TABLE LIKE',\n  'CREATE TABLE COPY',\n  'CREATE SNAPSHOT TABLE',\n  'CREATE TABLE CLONE',\n  'CREATE VIEW',\n  'CREATE MATERIALIZED VIEW',\n  'CREATE EXTERNAL TABLE',\n  'CREATE FUNCTION',\n  'CREATE TABLE FUNCTION',\n  'CREATE PROCEDURE',\n  'CREATE ROW ACCESS POLICY',\n  'ALTER SCHEMA SET OPTIONS',\n  'ALTER TABLE SET OPTIONS',\n  'ALTER TABLE ADD COLUMN',\n  'ALTER TABLE RENAME TO',\n  'ALTER TABLE DROP COLUMN',\n  'ALTER COLUMN SET OPTIONS',\n  'ALTER COLUMN DROP NOT NULL',\n  'ALTER COLUMN SET DATA TYPE',\n  'ALTER VIEW SET OPTIONS',\n  'ALTER MATERIALIZED VIEW SET OPTIONS',\n  'DROP SCHEMA',\n  'DROP TABLE',\n  'DROP SNAPSHOT TABLE',\n  'DROP EXTERNAL TABLE',\n  'DROP VIEW',\n  'DROP MATERIALIZED VIEW',\n  'DROP FUNCTION',\n  'DROP TABLE FUNCTION',\n  'DROP PROCEDURE',\n  'DROP ROW ACCESS POLICY',\n  // DCL, https://cloud.google.com/bigquery/docs/reference/standard-sql/data-control-language\n  'GRANT',\n  'REVOKE',\n  'CREATE CAPACITY',\n  'CREATE RESERVATION',\n  'CREATE ASSIGNMENT',\n  'DROP CAPACITY',\n  'DROP RESERVATION',\n  'DROP ASSIGNMENT',\n  // Script, https://cloud.google.com/bigquery/docs/reference/standard-sql/scripting\n  'DECLARE',\n  'SET',\n  'EXECUTE IMMEDIATE',\n  'LOOP',\n  'END LOOP',\n  'REPEAT',\n  'END REPEAT',\n  'WHILE',\n  'END WHILE',\n  'BREAK',\n  'LEAVE',\n  'CONTINUE',\n  'ITERATE',\n  'FOR',\n  'END FOR',\n  'BEGIN',\n  'BEGIN TRANSACTION',\n  'COMMIT TRANSACTION',\n  'ROLLBACK TRANSACTION',\n  'RAISE',\n  'RETURN',\n  'CALL',\n  // Debug, https://cloud.google.com/bigquery/docs/reference/standard-sql/debugging-statements\n  'ASSERT',\n  // Other, https://cloud.google.com/bigquery/docs/reference/standard-sql/other-statements\n  'EXPORT DATA',\n];\n\n/**\n * Priority 2\n * commands that operate on two tables or subqueries\n * two main categories: joins and boolean set operators\n */\nconst reservedBinaryCommands = [\n  // set booleans\n  'INTERSECT',\n  'INTERSECT ALL',\n  'INTERSECT DISTINCT',\n  'UNION',\n  'UNION ALL',\n  'UNION DISTINCT',\n  'EXCEPT',\n  'EXCEPT ALL',\n  'EXCEPT DISTINCT',\n  // joins\n  'JOIN',\n  'INNER JOIN',\n  'LEFT JOIN',\n  'LEFT OUTER JOIN',\n  'RIGHT JOIN',\n  'RIGHT OUTER JOIN',\n  'FULL JOIN',\n  'FULL OUTER JOIN',\n  'CROSS JOIN',\n];\n\n/**\n * Priority 3\n * keywords that follow a previous Statement, must be attached to subsequent data\n * can be fully inline or on newline with optional indent\n */\nconst reservedDependentClauses = ['WHEN', 'ELSE'];\n\n// https://cloud.google.com/bigquery/docs/reference/#standard-sql-reference\nexport default class BigQueryFormatter extends Formatter {\n  static reservedCommands = reservedCommands;\n  static reservedBinaryCommands = reservedBinaryCommands;\n  static reservedDependentClauses = reservedDependentClauses;\n  static reservedJoinConditions = ['ON', 'USING'];\n  static reservedLogicalOperators = ['AND', 'OR'];\n  static fullReservedWords = dedupe([\n    ...Object.values(reservedFunctions).reduce((acc, arr) => [...acc, ...arr], []),\n    ...Object.values(reservedKeywords).reduce((acc, arr) => [...acc, ...arr], []),\n  ]);\n\n  static stringTypes: StringPatternType[] = ['\"\"', \"''\", '``']; // add: '''''', \"\"\"\"\"\" ; prefixes: r, b\n  static blockStart = ['(', 'CASE'];\n  static blockEnd = [')', 'END'];\n  static indexedPlaceholderTypes = ['?'];\n  static namedPlaceholderTypes = [];\n  static lineCommentTypes = ['--', '#'];\n  static specialWordChars = { any: '_@$-' };\n  static operators = ['>>', '<<', '||'];\n  // TODO: handle trailing comma in select clause\n\n  tokenizer() {\n    return new Tokenizer({\n      reservedCommands: BigQueryFormatter.reservedCommands,\n      reservedBinaryCommands: BigQueryFormatter.reservedBinaryCommands,\n      reservedDependentClauses: BigQueryFormatter.reservedDependentClauses,\n      reservedJoinConditions: BigQueryFormatter.reservedJoinConditions,\n      reservedLogicalOperators: BigQueryFormatter.reservedLogicalOperators,\n      reservedKeywords: BigQueryFormatter.fullReservedWords,\n      stringTypes: BigQueryFormatter.stringTypes,\n      blockStart: BigQueryFormatter.blockStart,\n      blockEnd: BigQueryFormatter.blockEnd,\n      indexedPlaceholderTypes: BigQueryFormatter.indexedPlaceholderTypes,\n      namedPlaceholderTypes: BigQueryFormatter.namedPlaceholderTypes,\n      lineCommentTypes: BigQueryFormatter.lineCommentTypes,\n      specialWordChars: BigQueryFormatter.specialWordChars,\n      operators: BigQueryFormatter.operators,\n    });\n  }\n\n  tokenOverride(token: Token) {\n    if (\n      (/ARRAY/i.test(token.value) || /STRUCT/i.test(token.value)) &&\n      this.tokenLookAhead().value === '<'\n    ) {\n      let level = 0;\n      let finalToken = token.value;\n\n      do {\n        const nextToken = this.tokenLookAhead();\n        if (nextToken.value === '>' || nextToken.value === '>>') {\n          level -= nextToken.value.length;\n        } else if (nextToken.value === '<') {\n          level++;\n        }\n        finalToken += this.tokens.splice(this.index + 1, 1)[0].value;\n      } while (level > 0);\n\n      return { ...token, value: finalToken };\n    }\n\n    return token;\n  }\n}\n","import Formatter from '../core/Formatter';\nimport Tokenizer from '../core/Tokenizer';\nimport type { StringPatternType } from '../core/regexFactory';\nimport { dedupe } from '../utils';\n\n/**\n * Priority 5 (last)\n * Full list of reserved functions\n * distinct from Keywords due to interaction with parentheses\n */\nconst reservedFunctions = {\n  // https://www.ibm.com/docs/en/db2-for-zos/11?topic=functions-aggregate\n  aggregate: [\n    'ARRAY_AGG',\n    'AVG',\n    'CORR',\n    'CORRELATION',\n    'COUNT',\n    'COUNT_BIG',\n    'COVAR_POP',\n    'COVARIANCE',\n    'COVAR',\n    'COVAR_SAMP',\n    'COVARIANCE_SAMP',\n    'CUME_DIST',\n    'GROUPING',\n    'LISTAGG',\n    'MAX',\n    'MEDIAN',\n    'MIN',\n    'PERCENTILE_CONT',\n    'PERCENTILE_DISC',\n    'PERCENT_RANK',\n    'REGR_AVGX',\n    'REGR_AVGY',\n    'REGR_COUNT',\n    'REGR_INTERCEPT',\n    'REGR_ICPT',\n    'REGR_R2',\n    'REGR_SLOPE',\n    'REGR_SXX',\n    'REGR_SXY',\n    'REGR_SYY',\n    'STDDEV_POP',\n    'STDDEV',\n    'STDDEV_SAMP',\n    'SUM',\n    'VAR_POP',\n    'VARIANCE',\n    'VAR',\n    'VAR_SAMP',\n    'VARIANCE_SAMP',\n    'XMLAGG',\n  ],\n  // https://www.ibm.com/docs/en/db2-for-zos/11?topic=functions-scalar\n  scalar: [\n    'ABS',\n    'ABSVAL',\n    'ACOS',\n    'ADD_DAYS',\n    'ADD_MONTHS',\n    'ARRAY_DELETE',\n    'ARRAY_FIRST',\n    'ARRAY_LAST',\n    'ARRAY_NEXT',\n    'ARRAY_PRIOR',\n    'ARRAY_TRIM',\n    'ASCII',\n    'ASCII_CHR',\n    'ASCII_STR',\n    'ASCIISTR',\n    'ASIN',\n    'ATAN',\n    'ATANH',\n    'ATAN2',\n    'BIGINT',\n    'BINARY',\n    'BITAND',\n    'BITANDNOT',\n    'BITOR',\n    'BITXOR',\n    'BITNOT',\n    'BLOB',\n    'BTRIM',\n    'CARDINALITY',\n    'CCSID_ENCODING',\n    'CEILING',\n    'CEIL',\n    'CHAR',\n    'CHAR9',\n    'CHARACTER_LENGTH',\n    'CHAR_LENGTH',\n    'CHR',\n    'CLOB',\n    'COALESCE',\n    'COLLATION_KEY',\n    'COMPARE_DECFLOAT',\n    'CONCAT',\n    'CONTAINS',\n    'COS',\n    'COSH',\n    'DATE',\n    'DAY',\n    'DAYOFMONTH',\n    'DAYOFWEEK',\n    'DAYOFWEEK_ISO',\n    'DAYOFYEAR',\n    'DAYS',\n    'DAYS_BETWEEN',\n    'DBCLOB',\n    'DECFLOAT',\n    'DECFLOAT_FORMAT',\n    'DECFLOAT_SORTKEY',\n    'DECIMAL',\n    'DEC',\n    'DECODE',\n    'DECRYPT_BINARY',\n    'DECRYPT_BIT',\n    'DECRYPT_CHAR',\n    'DECRYPT_DB',\n    'DECRYPT_DATAKEY_BIGINT',\n    'DECRYPT_DATAKEY_BIT',\n    'DECRYPT_DATAKEY_CLOB',\n    'DECRYPT_DATAKEY_DBCLOB',\n    'DECRYPT_DATAKEY_DECIMAL',\n    'DECRYPT_DATAKEY_INTEGER',\n    'DECRYPT_DATAKEY_VARCHAR',\n    'DECRYPT_DATAKEY_VARGRAPHIC',\n    'DEGREES',\n    'DIFFERENCE',\n    'DIGITS',\n    'DOUBLE_PRECISION',\n    'DOUBLE',\n    'DSN_XMLVALIDATE',\n    'EBCDIC_CHR',\n    'EBCDIC_STR',\n    'ENCRYPT_DATAKEY',\n    'ENCRYPT_TDES',\n    'EXP',\n    'EXTRACT',\n    'FLOAT',\n    'FLOOR',\n    'GENERATE_UNIQUE',\n    'GENERATE_UNIQUE_BINARY',\n    'GETHINT',\n    'GETVARIABLE',\n    'GRAPHIC',\n    'GREATEST',\n    'HASH',\n    'HASH_CRC32',\n    'HASH_MD5',\n    'HASH_SHA1',\n    'HASH_SHA256',\n    'HEX',\n    'HOUR',\n    'IDENTITY_VAL_LOCAL',\n    'IFNULL',\n    'INSERT',\n    'INSTR',\n    'INTEGER',\n    'INT',\n    'JULIAN_DAY',\n    'LAST_DAY',\n    'LCASE',\n    'LEAST',\n    'LEFT',\n    'LENGTH',\n    'LN',\n    'LOCATE',\n    'LOCATE_IN_STRING',\n    'LOG10',\n    'LOWER',\n    'LPAD',\n    'LTRIM',\n    'MAX',\n    'MAX_CARDINALITY',\n    'MICROSECOND',\n    'MIDNIGHT_SECONDS',\n    'MIN',\n    'MINUTE',\n    'MOD',\n    'MONTH',\n    'MONTHS_BETWEEN',\n    'MQREAD',\n    'MQREADCLOB',\n    'MQRECEIVE',\n    'MQRECEIVECLOB',\n    'MQSEND',\n    'MULTIPLY_ALT',\n    'NEXT_DAY',\n    'NEXT_MONTH',\n    'NORMALIZE_DECFLOAT',\n    'NORMALIZE_STRING',\n    'NULLIF',\n    'NVL',\n    'OVERLAY',\n    'PACK',\n    'POSITION',\n    'POSSTR',\n    'POWER',\n    'POW',\n    'QUANTIZE',\n    'QUARTER',\n    'RADIANS',\n    'RAISE_ERROR',\n    'RANDOM',\n    'RAND',\n    'REAL',\n    'REGEXP_COUNT',\n    'REGEXP_INSTR',\n    'REGEXP_LIKE',\n    'REGEXP_REPLACE',\n    'REGEXP_SUBSTR',\n    'REPEAT',\n    'REPLACE',\n    'RID',\n    'RIGHT',\n    'ROUND',\n    'ROUND_TIMESTAMP',\n    'ROWID',\n    'RPAD',\n    'RTRIM',\n    'SCORE',\n    'SECOND',\n    'SIGN',\n    'SIN',\n    'SINH',\n    'SMALLINT',\n    'SOUNDEX',\n    'SOAPHTTPC',\n    'SOAPHTTPV',\n    'SOAPHTTPNC',\n    'SOAPHTTPNV',\n    'SPACE',\n    'SQRT',\n    'STRIP',\n    'STRLEFT',\n    'STRPOS',\n    'STRRIGHT',\n    'SUBSTR',\n    'SUBSTRING',\n    'TAN',\n    'TANH',\n    'TIME',\n    'TIMESTAMP',\n    'TIMESTAMPADD',\n    'TIMESTAMPDIFF',\n    'TIMESTAMP_FORMAT',\n    'TIMESTAMP_ISO',\n    'TIMESTAMP_TZ',\n    'TO_CHAR',\n    'TO_CLOB',\n    'TO_DATE',\n    'TO_NUMBER',\n    'TOTALORDER',\n    'TO_TIMESTAMP',\n    'TRANSLATE',\n    'TRIM',\n    'TRIM_ARRAY',\n    'TRUNCATE',\n    'TRUNC',\n    'TRUNC_TIMESTAMP',\n    'UCASE',\n    'UNICODE',\n    'UNICODE_STR',\n    'UNISTR',\n    'UPPER',\n    'VALUE',\n    'VARBINARY',\n    'VARCHAR',\n    'VARCHAR9',\n    'VARCHAR_BIT_FORMAT',\n    'VARCHAR_FORMAT',\n    'VARGRAPHIC',\n    'VERIFY_GROUP_FOR_USER',\n    'VERIFY_ROLE_FOR_USER',\n    'VERIFY_TRUSTED_CONTEXT_ROLE_FOR_USER',\n    'WEEK',\n    'WEEK_ISO',\n    'WRAP',\n    'XMLATTRIBUTES',\n    'XMLCOMMENT',\n    'XMLCONCAT',\n    'XMLDOCUMENT',\n    'XMLELEMENT',\n    'XMLFOREST',\n    'XMLMODIFY',\n    'XMLNAMESPACES',\n    'XMLPARSE',\n    'XMLPI',\n    'XMLQUERY',\n    'XMLSERIALIZE',\n    'XMLTEXT',\n    'XMLXSROBJECTID',\n    'XSLTRANSFORM',\n    'YEAR',\n  ],\n  // https://www.ibm.com/docs/en/db2-for-zos/11?topic=functions-table\n  table: [\n    'ADMIN_TASK_LIST',\n    'ADMIN_TASK_OUTPUT',\n    'ADMIN_TASK_STATUS',\n    'BLOCKING_THREADS',\n    'MQREADALL',\n    'MQREADALLCLOB',\n    'MQRECEIVEALL',\n    'MQRECEIVEALLCLOB',\n    'XMLTABLE',\n  ],\n  // https://www.ibm.com/docs/en/db2-for-zos/11?topic=functions-row\n  row: ['UNPACK'],\n  // https://www.ibm.com/docs/en/db2-for-zos/12?topic=expressions-olap-specification\n  olap: ['FIRST_VALUE', 'LAG', 'LAST_VALUE', 'LEAD', 'NTH_VALUE', 'NTILE', 'RATIO_TO_REPORT'],\n};\n\n/**\n * Priority 5 (last)\n * Full list of reserved words\n * any words that are in a higher priority are removed\n */\nconst reservedKeywords = {\n  // https://www.ibm.com/docs/en/db2-for-zos/11?topic=words-reserved#db2z_reservedwords__newresword\n  standard: [\n    'ALL',\n    'ALLOCATE',\n    'ALLOW',\n    'ALTERAND',\n    'ANY',\n    'AS',\n    'ARRAY',\n    'ARRAY_EXISTS',\n    'ASENSITIVE',\n    'ASSOCIATE',\n    'ASUTIME',\n    'AT',\n    'AUDIT',\n    'AUX',\n    'AUXILIARY',\n    'BEFORE',\n    'BEGIN',\n    'BETWEEN',\n    'BUFFERPOOL',\n    'BY',\n    'CAPTURE',\n    'CASCADED',\n    'CASE',\n    'CAST',\n    'CCSID',\n    'CHARACTER',\n    'CHECK',\n    'CLONE',\n    'CLUSTER',\n    'COLLECTION',\n    'COLLID',\n    'COLUMN',\n    'CONDITION',\n    'CONNECTION',\n    'CONSTRAINT',\n    'CONTENT',\n    'CONTINUE',\n    'CREATE',\n    'CUBE',\n    'CURRENT',\n    'CURRENT_DATE',\n    'CURRENT_LC_CTYPE',\n    'CURRENT_PATH',\n    'CURRENT_SCHEMA',\n    'CURRENT_TIME',\n    'CURRENT_TIMESTAMP',\n    'CURRVAL',\n    'CURSOR',\n    'DATA',\n    'DATABASE',\n    'DBINFO',\n    'DECLARE',\n    'DEFAULT',\n    'DESCRIPTOR',\n    'DETERMINISTIC',\n    'DISABLE',\n    'DISALLOW',\n    'DISTINCT',\n    'DO',\n    'DOCUMENT',\n    'DSSIZE',\n    'DYNAMIC',\n    'EDITPROC',\n    'ENCODING',\n    'ENCRYPTION',\n    'ENDING',\n    'END-EXEC',\n    'ERASE',\n    'ESCAPE',\n    'EXCEPTION',\n    'EXISTS',\n    'EXIT',\n    'EXTERNAL',\n    'FENCED',\n    'FIELDPROC',\n    'FINAL',\n    'FIRST',\n    'FOR',\n    'FREE',\n    'FULL',\n    'FUNCTION',\n    'GENERATED',\n    'GET',\n    'GLOBAL',\n    'GOTO',\n    'GROUP',\n    'HANDLER',\n    'HOLD',\n    'HOURS',\n    'IF',\n    'IMMEDIATE',\n    'IN',\n    'INCLUSIVE',\n    'INDEX',\n    'INHERIT',\n    'INNER',\n    'INOUT',\n    'INSENSITIVE',\n    'INTO',\n    'IS',\n    'ISOBID',\n    'ITERATE',\n    'JAR',\n    'KEEP',\n    'KEY',\n    'LANGUAGE',\n    'LAST',\n    'LC_CTYPE',\n    'LEAVE',\n    'LIKE',\n    'LOCAL',\n    'LOCALE',\n    'LOCATOR',\n    'LOCATORS',\n    'LOCK',\n    'LOCKMAX',\n    'LOCKSIZE',\n    'LONG',\n    'LOOP',\n    'MAINTAINED',\n    'MATERIALIZED',\n    'MICROSECONDS',\n    'MINUTEMINUTES',\n    'MODIFIES',\n    'MONTHS',\n    'NEXT',\n    'NEXTVAL',\n    'NO',\n    'NONE',\n    'NOT',\n    'NULL',\n    'NULLS',\n    'NUMPARTS',\n    'OBID',\n    'OF',\n    'OLD',\n    'ON DELETE',\n    'ON UPDATE',\n    'OPTIMIZATION',\n    'OPTIMIZE',\n    'ORDER',\n    'ORGANIZATION',\n    'OUT',\n    'OUTER',\n    'PACKAGE',\n    'PARAMETER',\n    'PART',\n    'PADDED',\n    'PARTITION',\n    'PARTITIONED',\n    'PARTITIONING',\n    'PATH',\n    'PIECESIZE',\n    'PERIOD',\n    'PLAN',\n    'PRECISION',\n    'PREVVAL',\n    'PRIOR',\n    'PRIQTY',\n    'PRIVILEGES',\n    'PROCEDURE',\n    'PROGRAM',\n    'PSID',\n    'PUBLIC',\n    'QUERY',\n    'QUERYNO',\n    'READS',\n    'REFERENCES',\n    'RESIGNAL',\n    'RESTRICT',\n    'RESULT',\n    'RESULT_SET_LOCATOR',\n    'RETURN',\n    'RETURNS',\n    'ROLE',\n    'ROLLUP',\n    'ROUND_CEILING',\n    'ROUND_DOWN',\n    'ROUND_FLOOR',\n    'ROUND_HALF_DOWN',\n    'ROUND_HALF_EVEN',\n    'ROUND_HALF_UP',\n    'ROUND_UP',\n    'ROW',\n    'ROWSET',\n    'SCHEMA',\n    'SCRATCHPAD',\n    'SECONDS',\n    'SECQTY',\n    'SECURITY',\n    'SEQUENCE',\n    'SENSITIVE',\n    'SESSION_USER',\n    'SIMPLE',\n    'SOME',\n    'SOURCE',\n    'SPECIFIC',\n    'STANDARD',\n    'STATIC',\n    'STATEMENT',\n    'STAY',\n    'STOGROUP',\n    'STORES',\n    'STYLE',\n    'SUMMARY',\n    'SYNONYM',\n    'SYSDATE',\n    'SYSTEM',\n    'SYSTIMESTAMP',\n    'TABLE',\n    'TABLESPACE',\n    'THEN',\n    'TO',\n    'TRIGGER',\n    'TYPE',\n    'UNDO',\n    'UNIQUE',\n    'UNTIL',\n    'USER',\n    'VALIDPROC',\n    'VARIABLE',\n    'VARIANT',\n    'VCAT',\n    'VERSIONING',\n    'VIEW',\n    'VOLATILE',\n    'VOLUMES',\n    'WHILE',\n    'WLM',\n    'XMLEXISTS',\n    'XMLCAST',\n    'YEARS',\n    'ZONE',\n  ],\n  // https://www.ibm.com/docs/en/db2-for-zos/11?topic=utilities-db2-online\n  onlineUtilies: [\n    'BACKUP SYSTEM',\n    'CATENFM',\n    'CATMAINT',\n    'CHECK DATA',\n    'CHECK INDEX',\n    'CHECK LOB',\n    'COPY',\n    'COPYTOCOPY',\n    'DIAGNOSE',\n    'EXEC SQL',\n    'LISTDEF',\n    'LOAD',\n    'MERGECOPY',\n    'MODIFY RECOVERY',\n    'MODIFY STATISTICS',\n    'OPTIONS',\n    'QUIESCE',\n    'REBUILD INDEX',\n    'RECOVER',\n    'REORG INDEX',\n    'REORG TABLESPACE',\n    'REPAIR',\n    'REPORT',\n    'RESTORE SYSTEM',\n    'RUNSTATS',\n    'STOSPACE',\n    'TEMPLATE',\n    'UNLOAD',\n  ],\n  // https://www.ibm.com/docs/en/db2-for-zos/11?topic=db2-commands\n  commands: [\n    'ABEND',\n    'ACCESS DATABASE',\n    'ALTER BUFFERPOOL',\n    'ALTER GROUPBUFFERPOOL',\n    'ALTER UTILITY',\n    'ARCHIVE LOG',\n    'BIND PACKAGE',\n    'BIND PLAN',\n    'BIND QUERY',\n    'BIND SERVICE',\n    'BIND',\n    'REBIND',\n    'CANCEL THREAD',\n    'DCLGEN',\n    'DISPLAY ACCEL',\n    'DISPLAY ARCHIVE',\n    'DISPLAY BLOCKERS',\n    'DISPLAY BUFFERPOOL',\n    'DISPLAY DATABASE',\n    'DISPLAY DDF',\n    'DISPLAY FUNCTION SPECIFIC',\n    'DISPLAY GROUP',\n    'DISPLAY GROUPBUFFERPOOL',\n    'DISPLAY LOCATION',\n    'DISPLAY LOG',\n    'DISPLAY PROCEDURE',\n    'DISPLAY PROFILE',\n    'DISPLAY RLIMIT',\n    'DISPLAY RESTSVC',\n    'DISPLAY THREAD',\n    'DISPLAY TRACE',\n    'DISPLAY UTILITY',\n    'DSN',\n    'DSNH',\n    'END',\n    'FREE PACKAGE',\n    'FREE PLAN',\n    'FREE QUERY',\n    'FREE SERVICE',\n    'MODIFY admtproc,APPL=SHUTDOWN',\n    'MODIFY admtproc,APPL=TRACE',\n    'MODIFY DDF',\n    'MODIFY irlmproc,ABEND',\n    'MODIFY irlmproc,DIAG',\n    'MODIFY irlmproc,PURGE',\n    'MODIFY irlmproc,SET',\n    'MODIFY irlmproc,STATUS',\n    'MODIFY TRACE',\n    'REBIND PACKAGE',\n    'REBIND PLAN',\n    'REBIND TRIGGER PACKAGE',\n    'RECOVER BSDS',\n    'RECOVER INDOUBT',\n    'RECOVER POSTPONED',\n    'REFRESH DB2,EARLY',\n    'RESET GENERICLU',\n    'RESET INDOUBT',\n    'RUN',\n    'SET ARCHIVE',\n    'SET LOG',\n    'SET SYSPARM',\n    'SPUFI',\n    'START ACCEL',\n    'START admtproc',\n    'START CDDS',\n    'START DATABASE',\n    'START DB2',\n    'START DDF',\n    'START FUNCTION SPECIFIC',\n    'START irlmproc',\n    'START PROCEDURE',\n    'START PROFILE',\n    'START RLIMIT',\n    'START RESTSVC',\n    'START TRACE',\n    'STOP ACCEL',\n    'STOP admtproc',\n    'STOP CDDS',\n    'STOP DATABASE',\n    'STOP DB2',\n    'STOP DDF',\n    'STOP FUNCTION SPECIFIC',\n    'STOP irlmproc',\n    'STOP PROCEDURE',\n    'STOP PROFILE',\n    'STOP RLIMIT',\n    'STOP RESTSVC',\n    'STOP TRACE',\n    'TERM UTILITY',\n    'TRACE CT',\n  ],\n};\n\n/**\n * Priority 1 (first)\n * keywords that begin a new statement\n * will begin new indented block\n */\n// https://www.ibm.com/docs/en/db2-for-zos/11?topic=statements-list-supported\nconst reservedCommands = [\n  'ALLOCATE CURSOR',\n  'ALTER DATABASE',\n  'ALTER FUNCTION',\n  'ALTER INDEX',\n  'ALTER MASK',\n  'ALTER PERMISSION',\n  'ALTER PROCEDURE',\n  'ALTER SEQUENCE',\n  'ALTER STOGROUP',\n  'ALTER TABLE',\n  'ALTER TABLESPACE',\n  'ALTER TRIGGER',\n  'ALTER TRUSTED CONTEXT',\n  'ALTER VIEW',\n  'ASSOCIATE LOCATORS',\n  'BEGIN DECLARE SECTION',\n  'CALL',\n  'CLOSE',\n  'COMMENT',\n  'COMMIT',\n  'CONNECT',\n  'CREATE ALIAS',\n  'CREATE AUXILIARY TABLE',\n  'CREATE DATABASE',\n  'CREATE FUNCTION',\n  'CREATE GLOBAL TEMPORARY TABLE',\n  'CREATE INDEX',\n  'CREATE LOB TABLESPACE',\n  'CREATE MASK',\n  'CREATE PERMISSION',\n  'CREATE PROCEDURE',\n  'CREATE ROLE',\n  'CREATE SEQUENCE',\n  'CREATE STOGROUP',\n  'CREATE SYNONYM',\n  'CREATE TABLE',\n  'CREATE TABLESPACE',\n  'CREATE TRIGGER',\n  'CREATE TRUSTED CONTEXT',\n  'CREATE TYPE',\n  'CREATE VARIABLE',\n  'CREATE VIEW',\n  'DECLARE CURSOR',\n  'DECLARE GLOBAL TEMPORARY TABLE',\n  'DECLARE STATEMENT',\n  'DECLARE TABLE',\n  'DECLARE VARIABLE',\n  'DELETE',\n  'DESCRIBE CURSOR',\n  'DESCRIBE INPUT',\n  'DESCRIBE OUTPUT',\n  'DESCRIBE PROCEDURE',\n  'DESCRIBE TABLE',\n  'DROP',\n  'END DECLARE SECTION',\n  'EXCHANGE',\n  'EXECUTE',\n  'EXECUTE IMMEDIATE',\n  'EXPLAIN',\n  'FETCH',\n  'FREE LOCATOR',\n  'GET DIAGNOSTICS',\n  'GRANT',\n  'HOLD LOCATOR',\n  'INCLUDE',\n  'INSERT',\n  'LABEL',\n  'LOCK TABLE',\n  'MERGE',\n  'OPEN',\n  'PREPARE',\n  'REFRESH',\n  'RELEASE',\n  'RELEASE SAVEPOINT',\n  'RENAME',\n  'REVOKE',\n  'ROLLBACK',\n  'SAVEPOINT',\n  'SELECT',\n  'SELECT INTO',\n  'SET CONNECTION',\n  'SET',\n  'SET CURRENT ACCELERATOR',\n  'SET CURRENT APPLICATION COMPATIBILITY',\n  'SET CURRENT APPLICATION ENCODING SCHEME',\n  'SET CURRENT DEBUG MODE',\n  'SET CURRENT DECFLOAT ROUNDING MODE',\n  'SET CURRENT DEGREE',\n  'SET CURRENT EXPLAIN MODE',\n  'SET CURRENT GET_ACCEL_ARCHIVE',\n  'SET CURRENT LOCALE LC_CTYPE',\n  'SET CURRENT MAINTAINED TABLE TYPES FOR OPTIMIZATION',\n  'SET CURRENT OPTIMIZATION HINT',\n  'SET CURRENT PACKAGE PATH',\n  'SET CURRENT PACKAGESET',\n  'SET CURRENT PRECISION',\n  'SET CURRENT QUERY ACCELERATION',\n  'SET CURRENT QUERY ACCELERATION WAITFORDATA',\n  'SET CURRENT REFRESH AGE',\n  'SET CURRENT ROUTINE VERSION',\n  'SET CURRENT RULES',\n  'SET CURRENT SQLID',\n  'SET CURRENT TEMPORAL BUSINESS_TIME',\n  'SET CURRENT TEMPORAL SYSTEM_TIME',\n  'SET ENCRYPTION PASSWORD',\n  'SET PATH',\n  'SET SCHEMA',\n  'SET SESSION TIME ZONE',\n  'SIGNAL',\n  'TRUNCATE',\n  'UPDATE',\n  'VALUES',\n  'VALUES INTO',\n  'WHENEVER',\n  // other\n  'ADD',\n  'ALTER COLUMN', // verify\n  'AFTER',\n  'DROP TABLE', // verify\n  'FETCH FIRST',\n  'FROM',\n  'GROUP BY',\n  'GO',\n  'HAVING',\n  'INSERT INTO',\n  'LIMIT',\n  'OFFSET',\n  'ORDER BY',\n  'SELECT',\n  'SET CURRENT SCHEMA',\n  'WHERE',\n  'WITH',\n];\n\n/**\n * Priority 2\n * commands that operate on two tables or subqueries\n * two main categories: joins and boolean set operators\n */\nconst reservedBinaryCommands = [\n  // set booleans\n  'INTERSECT',\n  'INTERSECT ALL',\n  'INTERSECT DISTINCT',\n  'UNION',\n  'UNION ALL',\n  'UNION DISTINCT',\n  'EXCEPT',\n  'EXCEPT ALL',\n  'EXCEPT DISTINCT',\n  // joins\n  'JOIN',\n  'INNER JOIN',\n  'LEFT JOIN',\n  'LEFT OUTER JOIN',\n  'RIGHT JOIN',\n  'RIGHT OUTER JOIN',\n  'FULL JOIN',\n  'FULL OUTER JOIN',\n  'CROSS JOIN',\n  'NATURAL JOIN',\n];\n\n/**\n * Priority 3\n * keywords that follow a previous Statement, must be attached to subsequent data\n * can be fully inline or on newline with optional indent\n */\nconst reservedDependentClauses = ['WHEN', 'ELSE', 'ELSEIF'];\n\n// https://www.ibm.com/support/knowledgecenter/en/ssw_ibm_i_72/db2/rbafzintro.htm\nexport default class Db2Formatter extends Formatter {\n  static reservedCommands = reservedCommands;\n  static reservedBinaryCommands = reservedBinaryCommands;\n  static reservedDependentClauses = reservedDependentClauses;\n  static reservedJoinConditions = ['ON', 'USING'];\n  static reservedLogicalOperators = ['AND', 'OR'];\n  static fullReservedWords = dedupe([\n    ...Object.values(reservedFunctions).reduce((acc, arr) => [...acc, ...arr], []),\n    ...Object.values(reservedKeywords).reduce((acc, arr) => [...acc, ...arr], []),\n  ]);\n\n  static stringTypes: StringPatternType[] = [`\"\"`, \"''\", '``', '[]', \"x''\"];\n  static blockStart = ['('];\n  static blockEnd = [')'];\n  static indexedPlaceholderTypes = ['?'];\n  static namedPlaceholderTypes = [':'];\n  static lineCommentTypes = ['--'];\n  static specialWordChars = { any: '#@' };\n  static operators = ['**', '!>', '!<', '||'];\n\n  tokenizer() {\n    return new Tokenizer({\n      reservedCommands: Db2Formatter.reservedCommands,\n      reservedBinaryCommands: Db2Formatter.reservedBinaryCommands,\n      reservedDependentClauses: Db2Formatter.reservedDependentClauses,\n      reservedJoinConditions: Db2Formatter.reservedJoinConditions,\n      reservedLogicalOperators: Db2Formatter.reservedLogicalOperators,\n      reservedKeywords: Db2Formatter.fullReservedWords,\n      stringTypes: Db2Formatter.stringTypes,\n      blockStart: Db2Formatter.blockStart,\n      blockEnd: Db2Formatter.blockEnd,\n      indexedPlaceholderTypes: Db2Formatter.indexedPlaceholderTypes,\n      namedPlaceholderTypes: Db2Formatter.namedPlaceholderTypes,\n      lineCommentTypes: Db2Formatter.lineCommentTypes,\n      specialWordChars: Db2Formatter.specialWordChars,\n      operators: Db2Formatter.operators,\n    });\n  }\n}\n","import Formatter from '../core/Formatter';\nimport Tokenizer from '../core/Tokenizer';\nimport type { StringPatternType } from '../core/regexFactory';\nimport { dedupe } from '../utils';\n\n/**\n * Priority 5 (last)\n * Full list of reserved functions\n * distinct from Keywords due to interaction with parentheses\n */\n// https://cwiki.apache.org/confluence/display/Hive/LanguageManual+UDF\nconst reservedFunctions = {\n  math: [\n    'ABS',\n    'ACOS',\n    'ASIN',\n    'ATAN',\n    'BIN',\n    'BROUND',\n    'CBRT',\n    'CEIL',\n    'CEILING',\n    'CONV',\n    'COS',\n    'DEGREES',\n    // 'E',\n    'EXP',\n    'FACTORIAL',\n    'FLOOR',\n    'GREATEST',\n    'HEX',\n    'LEAST',\n    'LN',\n    'LOG',\n    'LOG10',\n    'LOG2',\n    'NEGATIVE',\n    'PI',\n    'PMOD',\n    'POSITIVE',\n    'POW',\n    'POWER',\n    'RADIANS',\n    'RAND',\n    'ROUND',\n    'SHIFTLEFT',\n    'SHIFTRIGHT',\n    'SHIFTRIGHTUNSIGNED',\n    'SIGN',\n    'SIN',\n    'SQRT',\n    'TAN',\n    'UNHEX',\n    'WIDTH_BUCKET',\n  ],\n  array: ['ARRAY_CONTAINS', 'MAP_KEYS', 'MAP_VALUES', 'SIZE', 'SORT_ARRAY'],\n  conversion: ['BINARY', 'CAST'],\n  date: [\n    'ADD_MONTHS',\n    'DATE',\n    'DATE_ADD',\n    'DATE_FORMAT',\n    'DATE_SUB',\n    'DATEDIFF',\n    'DAY',\n    'DAYNAME',\n    'DAYOFMONTH',\n    'DAYOFYEAR',\n    'EXTRACT',\n    'FROM_UNIXTIME',\n    'FROM_UTC_TIMESTAMP',\n    'HOUR',\n    'LAST_DAY',\n    'MINUTE',\n    'MONTH',\n    'MONTHS_BETWEEN',\n    'NEXT_DAY',\n    'QUARTER',\n    'SECOND',\n    'TIMESTAMP',\n    'TO_DATE',\n    'TO_UTC_TIMESTAMP',\n    'TRUNC',\n    'UNIX_TIMESTAMP',\n    'WEEKOFYEAR',\n    'YEAR',\n  ],\n  conditional: ['ASSERT_TRUE', 'COALESCE', 'IF', 'ISNOTNULL', 'ISNULL', 'NULLIF', 'NVL'],\n  string: [\n    'ASCII',\n    'BASE64',\n    'CHARACTER_LENGTH',\n    'CHR',\n    'CONCAT',\n    'CONCAT_WS',\n    'CONTEXT_NGRAMS',\n    'DECODE',\n    'ELT',\n    'ENCODE',\n    'FIELD',\n    'FIND_IN_SET',\n    'FORMAT_NUMBER',\n    'GET_JSON_OBJECT',\n    'IN_FILE',\n    'INITCAP',\n    'INSTR',\n    'LCASE',\n    'LENGTH',\n    'LEVENSHTEIN',\n    'LOCATE',\n    'LOWER',\n    'LPAD',\n    'LTRIM',\n    'NGRAMS',\n    'OCTET_LENGTH',\n    'PARSE_URL',\n    'PRINTF',\n    'QUOTE',\n    'REGEXP_EXTRACT',\n    'REGEXP_REPLACE',\n    'REPEAT',\n    'REVERSE',\n    'RPAD',\n    'RTRIM',\n    'SENTENCES',\n    'SOUNDEX',\n    'SPACE',\n    'SPLIT',\n    'STR_TO_MAP',\n    'SUBSTR',\n    'SUBSTRING',\n    'TRANSLATE',\n    'TRIM',\n    'UCASE',\n    'UNBASE64',\n    'UPPER',\n  ],\n  masking: [\n    'MASK',\n    'MASK_FIRST_N',\n    'MASK_HASH',\n    'MASK_LAST_N',\n    'MASK_SHOW_FIRST_N',\n    'MASK_SHOW_LAST_N',\n  ],\n  misc: [\n    'AES_DECRYPT',\n    'AES_ENCRYPT',\n    'CRC32',\n    'CURRENT_DATABASE',\n    'CURRENT_USER',\n    'HASH',\n    'JAVA_METHOD',\n    'LOGGED_IN_USER',\n    'MD5',\n    'REFLECT',\n    'SHA',\n    'SHA1',\n    'SHA2',\n    'SURROGATE_KEY',\n    'VERSION',\n  ],\n  aggregate: [\n    'AVG',\n    'COLLECT_LIST',\n    'COLLECT_SET',\n    'CORR',\n    'COUNT',\n    'COVAR_POP',\n    'COVAR_SAMP',\n    'HISTOGRAM_NUMERIC',\n    'MAX',\n    'MIN',\n    'NTILE',\n    'PERCENTILE',\n    'PERCENTILE_APPROX',\n    'REGR_AVGX',\n    'REGR_AVGY',\n    'REGR_COUNT',\n    'REGR_INTERCEPT',\n    'REGR_R2',\n    'REGR_SLOPE',\n    'REGR_SXX',\n    'REGR_SXY',\n    'REGR_SYY',\n    'STDDEV_POP',\n    'STDDEV_SAMP',\n    'SUM',\n    'VAR_POP',\n    'VAR_SAMP',\n    'VARIANCE',\n  ],\n  table: ['EXPLODE', 'INLINE', 'JSON_TUPLE', 'PARSE_URL_TUPLE', 'POSEXPLODE', 'STACK'],\n};\n\n/**\n * Priority 5 (last)\n * Full list of reserved words\n * any words that are in a higher priority are removed\n */\n// https://cwiki.apache.org/confluence/display/hive/languagemanual+ddl\nconst reservedKeywords = {\n  // Non-reserved keywords have proscribed meanings in. HiveQL, but can still be used as table or column names\n  nonReserved: [\n    'ADD',\n    'ADMIN',\n    'AFTER',\n    'ANALYZE',\n    'ARCHIVE',\n    'ASC',\n    'BEFORE',\n    'BUCKET',\n    'BUCKETS',\n    'CASCADE',\n    'CHANGE',\n    'CLUSTER',\n    'CLUSTERED',\n    'CLUSTERSTATUS',\n    'COLLECTION',\n    'COLUMNS',\n    'COMMENT',\n    'COMPACT',\n    'COMPACTIONS',\n    'COMPUTE',\n    'CONCATENATE',\n    'CONTINUE',\n    'DATA',\n    'DATABASES',\n    'DATETIME',\n    'DAY',\n    'DBPROPERTIES',\n    'DEFERRED',\n    'DEFINED',\n    'DELIMITED',\n    'DEPENDENCY',\n    'DESC',\n    'DIRECTORIES',\n    'DIRECTORY',\n    'DISABLE',\n    'DISTRIBUTE',\n    'ELEM_TYPE',\n    'ENABLE',\n    'ESCAPED',\n    'EXCLUSIVE',\n    'EXPLAIN',\n    'EXPORT',\n    'FIELDS',\n    'FILE',\n    'FILEFORMAT',\n    'FIRST',\n    'FORMAT',\n    'FORMATTED',\n    'FUNCTIONS',\n    'HOLD_DDLTIME',\n    'HOUR',\n    'IDXPROPERTIES',\n    'IGNORE',\n    'INDEX',\n    'INDEXES',\n    'INPATH',\n    'INPUTDRIVER',\n    'INPUTFORMAT',\n    'ITEMS',\n    'JAR',\n    'KEYS',\n    'KEY_TYPE',\n    'LIMIT',\n    'LINES',\n    'LOAD',\n    'LOCATION',\n    'LOCK',\n    'LOCKS',\n    'LOGICAL',\n    'LONG',\n    'MAPJOIN',\n    'MATERIALIZED',\n    'METADATA',\n    'MINUS',\n    'MINUTE',\n    'MONTH',\n    'MSCK',\n    'NOSCAN',\n    'NO_DROP',\n    'OFFLINE',\n    'OPTION',\n    'OUTPUTDRIVER',\n    'OUTPUTFORMAT',\n    'OVERWRITE',\n    'OWNER',\n    'PARTITIONED',\n    'PARTITIONS',\n    'PLUS',\n    'PRETTY',\n    'PRINCIPALS',\n    'PROTECTION',\n    'PURGE',\n    'READ',\n    'READONLY',\n    'REBUILD',\n    'RECORDREADER',\n    'RECORDWRITER',\n    'RELOAD',\n    'RENAME',\n    'REPAIR',\n    'REPLACE',\n    'REPLICATION',\n    'RESTRICT',\n    'REWRITE',\n    'ROLE',\n    'ROLES',\n    'SCHEMA',\n    'SCHEMAS',\n    'SECOND',\n    'SEMI',\n    'SERDE',\n    'SERDEPROPERTIES',\n    'SERVER',\n    'SETS',\n    'SHARED',\n    'SHOW',\n    'SHOW_DATABASE',\n    'SKEWED',\n    'SORT',\n    'SORTED',\n    'SSL',\n    'STATISTICS',\n    'STORED',\n    'STREAMTABLE',\n    'STRING',\n    'STRUCT',\n    'TABLES',\n    'TBLPROPERTIES',\n    'TEMPORARY',\n    'TERMINATED',\n    'TINYINT',\n    'TOUCH',\n    'TRANSACTIONS',\n    'UNARCHIVE',\n    'UNDO',\n    'UNIONTYPE',\n    'UNLOCK',\n    'UNSET',\n    'UNSIGNED',\n    'URI',\n    // 'USE',\n    'UTC',\n    'UTCTIMESTAMP',\n    'VALUE_TYPE',\n    'VIEW',\n    'WHILE',\n    'YEAR',\n    'AUTOCOMMIT',\n    'ISOLATION',\n    'LEVEL',\n    'OFFSET',\n    'SNAPSHOT',\n    'TRANSACTION',\n    'WORK',\n    'WRITE',\n    'ABORT',\n    'KEY',\n    'LAST',\n    'NORELY',\n    'NOVALIDATE',\n    'NULLS',\n    'RELY',\n    'VALIDATE',\n    'DETAIL',\n    'DOW',\n    'EXPRESSION',\n    'OPERATOR',\n    'QUARTER',\n    'SUMMARY',\n    'VECTORIZATION',\n    'WEEK',\n    'YEARS',\n    'MONTHS',\n    'WEEKS',\n    'DAYS',\n    'HOURS',\n    'MINUTES',\n    'SECONDS',\n    'TIMESTAMPTZ',\n    'ZONE',\n  ],\n  reserved: [\n    // reserved\n    'ALL',\n    // 'ALTER',\n    // 'AND',\n    'ARRAY',\n    'AS',\n    'AUTHORIZATION',\n    'BETWEEN',\n    'BIGINT',\n    'BINARY',\n    'BOOLEAN',\n    'BOTH',\n    'BY',\n    // 'CASE',\n    'CAST',\n    'CHAR',\n    'COLUMN',\n    'CONF',\n    // 'CREATE',\n    'CROSS',\n    'CUBE',\n    'CURRENT',\n    'CURRENT_DATE',\n    'CURRENT_TIMESTAMP',\n    'CURSOR',\n    'DATABASE',\n    'DATE',\n    'DECIMAL',\n    'DELETE',\n    // 'DESCRIBE',\n    'DISTINCT',\n    'DOUBLE',\n    // 'DROP',\n    // 'ELSE',\n    // 'END',\n    'EXCHANGE',\n    'EXISTS',\n    'EXTENDED',\n    'EXTERNAL',\n    'FALSE',\n    // 'FETCH',\n    'FLOAT',\n    'FOLLOWING',\n    'FOR',\n    // 'FROM',\n    'FULL',\n    'FUNCTION',\n    'GRANT',\n    // 'GROUP',\n    'GROUPING',\n    // 'HAVING',\n    'IF',\n    'IMPORT',\n    'IN',\n    'INNER',\n    // 'INSERT',\n    'INT',\n    // 'INTERSECT',\n    'INTERVAL',\n    'INTO',\n    'IS',\n    // 'JOIN',\n    'LATERAL',\n    'LEFT',\n    'LESS',\n    'LIKE',\n    'LOCAL',\n    'MACRO',\n    'MAP',\n    'MORE',\n    'NONE',\n    'NOT',\n    'NULL',\n    'OF',\n    // 'ON',\n    // 'OR',\n    'ORDER',\n    'OUT',\n    'OUTER',\n    'OVER',\n    'PARTIALSCAN',\n    'PARTITION',\n    'PERCENT',\n    'PRECEDING',\n    'PRESERVE',\n    'PROCEDURE',\n    'RANGE',\n    'READS',\n    'REDUCE',\n    'REVOKE',\n    'RIGHT',\n    'ROLLUP',\n    'ROW',\n    'ROWS',\n    // 'SELECT',\n    'SET',\n    'SMALLINT',\n    'TABLE',\n    'TABLESAMPLE',\n    'THEN',\n    'TIMESTAMP',\n    'TO',\n    'TRANSFORM',\n    'TRIGGER',\n    'TRUE',\n    // 'TRUNCATE',\n    'UNBOUNDED',\n    // 'UNION',\n    'UNIQUEJOIN',\n    // 'UPDATE',\n    'USER',\n    'UTC_TMESTAMP',\n    // 'VALUES',\n    'VARCHAR',\n    // 'WHEN',\n    // 'WHERE',\n    'WINDOW',\n    // 'WITH',\n    'COMMIT',\n    'ONLY',\n    'REGEXP',\n    'RLIKE',\n    'ROLLBACK',\n    'START',\n    'CACHE',\n    'CONSTRAINT',\n    'FOREIGN',\n    'PRIMARY',\n    'REFERENCES',\n    'DAYOFWEEK',\n    'EXTRACT',\n    'FLOOR',\n    'INTEGER',\n    'PRECISION',\n    'VIEWS',\n    'TIME',\n    'NUMERIC',\n    'SYNC',\n  ],\n  fileTypes: [\n    'TEXTFILE',\n    'SEQUENCEFILE',\n    'ORC',\n    'CSV',\n    'TSV',\n    'PARQUET',\n    'AVRO',\n    'RCFILE',\n    'JSONFILE',\n    'INPUTFORMAT',\n    'OUTPUTFORMAT',\n  ],\n};\n\n/**\n * Priority 1 (first)\n * keywords that begin a new statement\n * will begin new indented block\n */\nconst reservedCommands = [\n  // commands\n  'ALTER',\n  'ALTER COLUMN', // added\n  'ALTER TABLE', // added\n  'CREATE',\n  'CREATE TABLE', // added\n  'USE',\n  'DESCRIBE',\n  'DROP',\n  'DROP TABLE', // added\n  'FETCH',\n  'FROM',\n  'GROUP BY',\n  'HAVING',\n  'INSERT',\n  'INSERT INTO', // added\n  'LIMIT',\n  'OFFSET',\n  'ORDER BY',\n  'SELECT',\n  'SET',\n  'SET SCHEMA', // added\n  'SHOW',\n  'SORT BY',\n  'TRUNCATE',\n  'UPDATE',\n  'VALUES',\n  'WHERE',\n  'WITH',\n\n  // newline keywords\n  'STORED AS',\n  'STORED BY',\n  'ROW FORMAT',\n];\n\n/**\n * Priority 2\n * commands that operate on two tables or subqueries\n * two main categories: joins and boolean set operators\n */\nconst reservedBinaryCommands = [\n  // set booleans\n  'INTERSECT',\n  'INTERSECT ALL',\n  'INTERSECT DISTINCT',\n  'UNION',\n  'UNION ALL',\n  'UNION DISTINCT',\n  // joins\n  'JOIN',\n  'INNER JOIN',\n  'LEFT JOIN',\n  'LEFT OUTER JOIN',\n  'RIGHT JOIN',\n  'RIGHT OUTER JOIN',\n  'FULL JOIN',\n  'FULL OUTER JOIN',\n  'CROSS JOIN',\n];\n\n/**\n * Priority 3\n * keywords that follow a previous 'Statement', must be attached to subsequent data\n * can be fully inline or on newline with optional indent\n */\nconst reservedDependentClauses = ['WHEN', 'ELSE'];\n\n// https://cwiki.apache.org/confluence/display/Hive/LanguageManual\nexport default class HiveFormatter extends Formatter {\n  static reservedCommands = reservedCommands;\n  static reservedBinaryCommands = reservedBinaryCommands;\n  static reservedDependentClauses = reservedDependentClauses;\n  static reservedJoinConditions = ['ON', 'USING'];\n  static reservedLogicalOperators = ['AND', 'OR'];\n  static fullReservedWords = dedupe([\n    ...Object.values(reservedFunctions).reduce((acc, arr) => [...acc, ...arr], []),\n    ...Object.values(reservedKeywords).reduce((acc, arr) => [...acc, ...arr], []),\n  ]);\n\n  static stringTypes: StringPatternType[] = ['\"\"', \"''\", '``'];\n  static blockStart = ['(', 'CASE'];\n  static blockEnd = [')', 'END'];\n  static indexedPlaceholderTypes = ['?'];\n  static namedPlaceholderTypes = [];\n  static lineCommentTypes = ['--'];\n  static specialWordChars = {};\n  static operators = ['<=>', '==', '||'];\n\n  tokenizer() {\n    return new Tokenizer({\n      reservedCommands: HiveFormatter.reservedCommands,\n      reservedBinaryCommands: HiveFormatter.reservedBinaryCommands,\n      reservedDependentClauses: HiveFormatter.reservedDependentClauses,\n      reservedJoinConditions: HiveFormatter.reservedJoinConditions,\n      reservedLogicalOperators: HiveFormatter.reservedLogicalOperators,\n      reservedKeywords: HiveFormatter.fullReservedWords,\n      stringTypes: HiveFormatter.stringTypes,\n      blockStart: HiveFormatter.blockStart,\n      blockEnd: HiveFormatter.blockEnd,\n      indexedPlaceholderTypes: HiveFormatter.indexedPlaceholderTypes,\n      namedPlaceholderTypes: HiveFormatter.namedPlaceholderTypes,\n      lineCommentTypes: HiveFormatter.lineCommentTypes,\n      specialWordChars: HiveFormatter.specialWordChars,\n      operators: HiveFormatter.operators,\n    });\n  }\n}\n","import Formatter from '../core/Formatter';\nimport Tokenizer from '../core/Tokenizer';\nimport { isToken, Token, TokenType } from '../core/token';\nimport type { StringPatternType } from '../core/regexFactory';\nimport { dedupe } from '../utils';\n\n/**\n * Priority 5 (last)\n * Full list of reserved functions\n * distinct from Keywords due to interaction with parentheses\n */\n// https://mariadb.com/kb/en/information-schema-sql_functions-table/\nconst reservedFunctions = [\n  'ADDDATE',\n  'ADD_MONTHS',\n  'BIT_AND',\n  'BIT_OR',\n  'BIT_XOR',\n  'CAST',\n  'COUNT',\n  'CUME_DIST',\n  'CURDATE',\n  'CURTIME',\n  'DATE_ADD',\n  'DATE_SUB',\n  'DATE_FORMAT',\n  'DECODE',\n  'DENSE_RANK',\n  'EXTRACT',\n  'FIRST_VALUE',\n  'GROUP_CONCAT',\n  'JSON_ARRAYAGG',\n  'JSON_OBJECTAGG',\n  'LAG',\n  'LEAD',\n  'MAX',\n  'MEDIAN',\n  'MID',\n  'MIN',\n  'NOW',\n  'NTH_VALUE',\n  'NTILE',\n  'POSITION',\n  'PERCENT_RANK',\n  'PERCENTILE_CONT',\n  'PERCENTILE_DISC',\n  'RANK',\n  'ROW_NUMBER',\n  'SESSION_USER',\n  'STD',\n  'STDDEV',\n  'STDDEV_POP',\n  'STDDEV_SAMP',\n  'SUBDATE',\n  'SUBSTR',\n  'SUBSTRING',\n  'SUM',\n  'SYSTEM_USER',\n  'TRIM',\n  'TRIM_ORACLE',\n  'VARIANCE',\n  'VAR_POP',\n  'VAR_SAMP',\n  'ABS',\n  'ACOS',\n  'ADDTIME',\n  'AES_DECRYPT',\n  'AES_ENCRYPT',\n  'ASIN',\n  'ATAN',\n  'ATAN2',\n  'BENCHMARK',\n  'BIN',\n  'BINLOG_GTID_POS',\n  'BIT_COUNT',\n  'BIT_LENGTH',\n  'CEIL',\n  'CEILING',\n  'CHARACTER_LENGTH',\n  'CHAR_LENGTH',\n  'CHR',\n  'COERCIBILITY',\n  'COLUMN_CHECK',\n  'COLUMN_EXISTS',\n  'COLUMN_LIST',\n  'COLUMN_JSON',\n  'COMPRESS',\n  'CONCAT',\n  'CONCAT_OPERATOR_ORACLE',\n  'CONCAT_WS',\n  'CONNECTION_ID',\n  'CONV',\n  'CONVERT_TZ',\n  'COS',\n  'COT',\n  'CRC32',\n  'DATEDIFF',\n  'DAYNAME',\n  'DAYOFMONTH',\n  'DAYOFWEEK',\n  'DAYOFYEAR',\n  'DEGREES',\n  'DECODE_HISTOGRAM',\n  'DECODE_ORACLE',\n  'DES_DECRYPT',\n  'DES_ENCRYPT',\n  'ELT',\n  'ENCODE',\n  'ENCRYPT',\n  'EXP',\n  'EXPORT_SET',\n  'EXTRACTVALUE',\n  'FIELD',\n  'FIND_IN_SET',\n  'FLOOR',\n  'FORMAT',\n  'FOUND_ROWS',\n  'FROM_BASE64',\n  'FROM_DAYS',\n  'FROM_UNIXTIME',\n  'GET_LOCK',\n  'GREATEST',\n  'HEX',\n  'IFNULL',\n  'INSTR',\n  'ISNULL',\n  'IS_FREE_LOCK',\n  'IS_USED_LOCK',\n  'JSON_ARRAY',\n  'JSON_ARRAY_APPEND',\n  'JSON_ARRAY_INSERT',\n  'JSON_COMPACT',\n  'JSON_CONTAINS',\n  'JSON_CONTAINS_PATH',\n  'JSON_DEPTH',\n  'JSON_DETAILED',\n  'JSON_EXISTS',\n  'JSON_EXTRACT',\n  'JSON_INSERT',\n  'JSON_KEYS',\n  'JSON_LENGTH',\n  'JSON_LOOSE',\n  'JSON_MERGE',\n  'JSON_MERGE_PATCH',\n  'JSON_MERGE_PRESERVE',\n  'JSON_QUERY',\n  'JSON_QUOTE',\n  'JSON_OBJECT',\n  'JSON_REMOVE',\n  'JSON_REPLACE',\n  'JSON_SET',\n  'JSON_SEARCH',\n  'JSON_TYPE',\n  'JSON_UNQUOTE',\n  'JSON_VALID',\n  'JSON_VALUE',\n  'LAST_DAY',\n  'LAST_INSERT_ID',\n  'LCASE',\n  'LEAST',\n  'LENGTH',\n  'LENGTHB',\n  'LN',\n  'LOAD_FILE',\n  'LOCATE',\n  'LOG',\n  'LOG10',\n  'LOG2',\n  'LOWER',\n  'LPAD',\n  'LPAD_ORACLE',\n  'LTRIM',\n  'LTRIM_ORACLE',\n  'MAKEDATE',\n  'MAKETIME',\n  'MAKE_SET',\n  'MASTER_GTID_WAIT',\n  'MASTER_POS_WAIT',\n  'MD5',\n  'MONTHNAME',\n  'NAME_CONST',\n  'NVL',\n  'NVL2',\n  'NULLIF',\n  'OCT',\n  'OCTET_LENGTH',\n  'ORD',\n  'PERIOD_ADD',\n  'PERIOD_DIFF',\n  'PI',\n  'POW',\n  'POWER',\n  'QUOTE',\n  'REGEXP_INSTR',\n  'REGEXP_REPLACE',\n  'REGEXP_SUBSTR',\n  'RADIANS',\n  'RAND',\n  'RELEASE_ALL_LOCKS',\n  'RELEASE_LOCK',\n  'REPLACE_ORACLE',\n  'REVERSE',\n  'ROUND',\n  'RPAD',\n  'RPAD_ORACLE',\n  'RTRIM',\n  'RTRIM_ORACLE',\n  'SEC_TO_TIME',\n  'SHA',\n  'SHA1',\n  'SHA2',\n  'SIGN',\n  'SIN',\n  'SLEEP',\n  'SOUNDEX',\n  'SPACE',\n  'SQRT',\n  'STRCMP',\n  'STR_TO_DATE',\n  'SUBSTR_ORACLE',\n  'SUBSTRING_INDEX',\n  'SUBTIME',\n  'SYS_GUID',\n  'TAN',\n  'TIMEDIFF',\n  'TIME_FORMAT',\n  'TIME_TO_SEC',\n  'TO_BASE64',\n  'TO_CHAR',\n  'TO_DAYS',\n  'TO_SECONDS',\n  'UCASE',\n  'UNCOMPRESS',\n  'UNCOMPRESSED_LENGTH',\n  'UNHEX',\n  'UNIX_TIMESTAMP',\n  'UPDATEXML',\n  'UPPER',\n  'UUID',\n  'UUID_SHORT',\n  'VERSION',\n  'WEEKDAY',\n  'WEEKOFYEAR',\n  'WSREP_LAST_WRITTEN_GTID',\n  'WSREP_LAST_SEEN_GTID',\n  'WSREP_SYNC_WAIT_UPTO_GTID',\n  'YEARWEEK',\n];\n\n/**\n * Priority 5 (last)\n * Full list of reserved words\n * any words that are in a higher priority are removed\n */\n// https://mariadb.com/kb/en/information-schema-keywords-table/\nconst reservedKeywords = [\n  'ACCESSIBLE',\n  'ACCOUNT',\n  'ACTION',\n  'ADMIN',\n  'AFTER',\n  'AGAINST',\n  'AGGREGATE',\n  'ALL',\n  'ALGORITHM',\n  'ALTER',\n  'ALWAYS',\n  'ANY',\n  'AS',\n  'ASC',\n  'ASCII',\n  'ASENSITIVE',\n  'AT',\n  'ATOMIC',\n  'AUTHORS',\n  'AUTO_INCREMENT',\n  'AUTOEXTEND_SIZE',\n  'AUTO',\n  'AVG',\n  'AVG_ROW_LENGTH',\n  'BACKUP',\n  'BEFORE',\n  'BETWEEN',\n  'BIGINT',\n  'BINARY',\n  'BIT',\n  'BLOB',\n  'BLOCK',\n  'BODY',\n  'BOOL',\n  'BOOLEAN',\n  'BOTH',\n  'BTREE',\n  'BY',\n  'BYTE',\n  'CACHE',\n  'CASCADE',\n  'CASCADED',\n  'CATALOG_NAME',\n  'CHAIN',\n  'CHANGE',\n  'CHANGED',\n  'CHAR',\n  'CHARACTER',\n  'CHARACTER SET',\n  'CHARSET',\n  'CHECK',\n  'CHECKPOINT',\n  'CHECKSUM',\n  'CIPHER',\n  'CLASS_ORIGIN',\n  'CLIENT',\n  'CLOB',\n  'CLOSE',\n  'COALESCE',\n  'CODE',\n  'COLLATE',\n  'COLLATION',\n  'COLUMN',\n  'COLUMN_NAME',\n  'COLUMNS',\n  'COLUMN_ADD',\n  'COLUMN_CREATE',\n  'COLUMN_DELETE',\n  'COLUMN_GET',\n  'COMMENT',\n  'COMMITTED',\n  'COMPACT',\n  'COMPLETION',\n  'COMPRESSED',\n  'CONCURRENT',\n  'CONDITION',\n  'CONNECTION',\n  'CONSISTENT',\n  'CONSTRAINT',\n  'CONSTRAINT_CATALOG',\n  'CONSTRAINT_NAME',\n  'CONSTRAINT_SCHEMA',\n  'CONTAINS',\n  'CONTEXT',\n  'CONTINUE',\n  'CONTRIBUTORS',\n  'CONVERT',\n  'CPU',\n  'CREATE',\n  'CROSS',\n  'CUBE',\n  'CURRENT',\n  'CURRENT_DATE',\n  'CURRENT_POS',\n  'CURRENT_ROLE',\n  'CURRENT_TIME',\n  'CURRENT_TIMESTAMP',\n  'CURRENT_USER',\n  'CURSOR',\n  'CURSOR_NAME',\n  'CYCLE',\n  'DATA',\n  'DATABASE',\n  'DATABASES',\n  'DATAFILE',\n  'DATE',\n  'DATETIME',\n  'DAY',\n  'DAY_HOUR',\n  'DAY_MICROSECOND',\n  'DAY_MINUTE',\n  'DAY_SECOND',\n  'DEALLOCATE',\n  'DEC',\n  'DECIMAL',\n  'DECLARE',\n  'DEFAULT',\n  'DEFINER',\n  'DELAYED',\n  'DELAY_KEY_WRITE',\n  'DELETE_DOMAIN_ID',\n  'DES_KEY_FILE',\n  'DETERMINISTIC',\n  'DIAGNOSTICS',\n  'DIRECTORY',\n  'DISABLE',\n  'DISCARD',\n  'DISK',\n  'DISTINCT',\n  'DISTINCTROW',\n  'DIV',\n  'DOUBLE',\n  'DO_DOMAIN_IDS',\n  'DROP',\n  'DUAL',\n  'DUMPFILE',\n  'DUPLICATE',\n  'DYNAMIC',\n  'EACH',\n  'EMPTY',\n  'ENABLE',\n  'ENCLOSED',\n  'ENDS',\n  'ENGINE',\n  'ENGINES',\n  'ENUM',\n  'ERROR',\n  'ERRORS',\n  'ESCAPE',\n  'ESCAPED',\n  'EVENT',\n  'EVENTS',\n  'EVERY',\n  'EXAMINED',\n  'EXCHANGE',\n  'EXCLUDE',\n  'EXCEPTION',\n  'EXISTS',\n  'EXIT',\n  'EXPANSION',\n  'EXPIRE',\n  'EXPORT',\n  'EXTENDED',\n  'EXTENT_SIZE',\n  'FALSE',\n  'FAST',\n  'FAULTS',\n  'FEDERATED',\n  'FETCH',\n  'FIELDS',\n  'FILE',\n  'FIRST',\n  'FIXED',\n  'FLOAT',\n  'FLOAT4',\n  'FLOAT8',\n  'FOLLOWING',\n  'FOLLOWS',\n  'FOR',\n  'FORCE',\n  'FOREIGN',\n  'FOUND',\n  'FULL',\n  'FULLTEXT',\n  'FUNCTION',\n  'GENERAL',\n  'GENERATED',\n  'GET_FORMAT',\n  'GET',\n  'GLOBAL',\n  'GOTO',\n  'GRANTS',\n  'GROUP',\n  'HARD',\n  'HASH',\n  'HIGH_PRIORITY',\n  'HISTORY',\n  'HOST',\n  'HOSTS',\n  'HOUR',\n  'HOUR_MICROSECOND',\n  'HOUR_MINUTE',\n  'HOUR_SECOND',\n  // 'ID',\n  'IDENTIFIED',\n  'IF',\n  'IGNORE',\n  'IGNORED',\n  'IGNORE_DOMAIN_IDS',\n  'IGNORE_SERVER_IDS',\n  'IMMEDIATE',\n  'IMPORT',\n  'IN',\n  'INCREMENT',\n  'INDEX',\n  'INDEXES',\n  'INFILE',\n  'INITIAL_SIZE',\n  'INNER',\n  'INOUT',\n  'INSENSITIVE',\n  'INSERT_METHOD',\n  'INSTALL',\n  'INT',\n  'INT1',\n  'INT2',\n  'INT3',\n  'INT4',\n  'INT8',\n  'INTEGER',\n  'INTERVAL',\n  'INVISIBLE',\n  'INTO',\n  'IO',\n  'IO_THREAD',\n  'IPC',\n  'IS',\n  'ISOLATION',\n  'ISOPEN',\n  'ISSUER',\n  'ITERATE',\n  'INVOKER',\n  'JSON',\n  'JSON_TABLE',\n  'KEY',\n  'KEYS',\n  'KEY_BLOCK_SIZE',\n  'LANGUAGE',\n  'LAST',\n  'LAST_VALUE',\n  'LASTVAL',\n  'LEADING',\n  'LEAVE',\n  'LEAVES',\n  'LEFT',\n  'LESS',\n  'LEVEL',\n  'LIKE',\n  'LINEAR',\n  'LINES',\n  'LIST',\n  'LOAD',\n  'LOCAL',\n  'LOCALTIME',\n  'LOCALTIMESTAMP',\n  'LOCK',\n  'LOCKED',\n  'LOCKS',\n  'LOGFILE',\n  'LOGS',\n  'LONG',\n  'LONGBLOB',\n  'LONGTEXT',\n  'LOOP',\n  'LOW_PRIORITY',\n  'MASTER',\n  'MASTER_CONNECT_RETRY',\n  'MASTER_DELAY',\n  'MASTER_GTID_POS',\n  'MASTER_HOST',\n  'MASTER_LOG_FILE',\n  'MASTER_LOG_POS',\n  'MASTER_PASSWORD',\n  'MASTER_PORT',\n  'MASTER_SERVER_ID',\n  'MASTER_SSL',\n  'MASTER_SSL_CA',\n  'MASTER_SSL_CAPATH',\n  'MASTER_SSL_CERT',\n  'MASTER_SSL_CIPHER',\n  'MASTER_SSL_CRL',\n  'MASTER_SSL_CRLPATH',\n  'MASTER_SSL_KEY',\n  'MASTER_SSL_VERIFY_SERVER_CERT',\n  'MASTER_USER',\n  'MASTER_USE_GTID',\n  'MASTER_HEARTBEAT_PERIOD',\n  'MATCH',\n  'MAX_CONNECTIONS_PER_HOUR',\n  'MAX_QUERIES_PER_HOUR',\n  'MAX_ROWS',\n  'MAX_SIZE',\n  'MAX_STATEMENT_TIME',\n  'MAX_UPDATES_PER_HOUR',\n  'MAX_USER_CONNECTIONS',\n  'MAXVALUE',\n  'MEDIUM',\n  'MEDIUMBLOB',\n  'MEDIUMINT',\n  'MEDIUMTEXT',\n  'MEMORY',\n  'MERGE',\n  'MESSAGE_TEXT',\n  'MICROSECOND',\n  'MIDDLEINT',\n  'MIGRATE',\n  'MINUS',\n  'MINUTE',\n  'MINUTE_MICROSECOND',\n  'MINUTE_SECOND',\n  'MINVALUE',\n  'MIN_ROWS',\n  'MOD',\n  'MODE',\n  'MODIFIES',\n  'MODIFY',\n  'MONITOR',\n  'MONTH',\n  'MUTEX',\n  'MYSQL',\n  'MYSQL_ERRNO',\n  'NAME',\n  'NAMES',\n  'NATIONAL',\n  'NATURAL',\n  'NCHAR',\n  'NESTED',\n  'NEVER',\n  'NEW',\n  'NEXT',\n  'NEXTVAL',\n  'NO',\n  'NOMAXVALUE',\n  'NOMINVALUE',\n  'NOCACHE',\n  'NOCYCLE',\n  'NO_WAIT',\n  'NOWAIT',\n  'NODEGROUP',\n  'NONE',\n  'NOT',\n  'NOTFOUND',\n  'NO_WRITE_TO_BINLOG',\n  'NULL',\n  'NUMBER',\n  'NUMERIC',\n  'NVARCHAR',\n  'OF',\n  'OFFSET',\n  'OLD_PASSWORD',\n  'ON DELETE',\n  'ON UPDATE',\n  'ONE',\n  'ONLINE',\n  'ONLY',\n  'OPEN',\n  'OPTIMIZE',\n  'OPTIONS',\n  'OPTION',\n  'OPTIONALLY',\n  'ORDER',\n  'ORDINALITY',\n  'OTHERS',\n  'OUT',\n  'OUTER',\n  'OUTFILE',\n  'OVER',\n  'OVERLAPS',\n  'OWNER',\n  'PACKAGE',\n  'PACK_KEYS',\n  'PAGE',\n  'PAGE_CHECKSUM',\n  'PARSER',\n  'PARSE_VCOL_EXPR',\n  'PATH',\n  'PERIOD',\n  'PARTIAL',\n  'PARTITION',\n  'PARTITIONING',\n  'PARTITIONS',\n  'PASSWORD',\n  'PERSISTENT',\n  'PHASE',\n  'PLUGIN',\n  'PLUGINS',\n  'PORT',\n  'PORTION',\n  'PRECEDES',\n  'PRECEDING',\n  'PRECISION',\n  'PRESERVE',\n  'PREV',\n  'PREVIOUS',\n  'PRIMARY',\n  'PRIVILEGES',\n  'PROCEDURE',\n  'PROCESS',\n  'PROCESSLIST',\n  'PROFILE',\n  'PROFILES',\n  'PROXY',\n  'PURGE',\n  'QUARTER',\n  'QUERY',\n  'QUICK',\n  'RAISE',\n  'RANGE',\n  'RAW',\n  'READ',\n  'READ_ONLY',\n  'READ_WRITE',\n  'READS',\n  'REAL',\n  'REBUILD',\n  'RECOVER',\n  'RECURSIVE',\n  'REDO_BUFFER_SIZE',\n  'REDOFILE',\n  'REDUNDANT',\n  'REFERENCES',\n  'REGEXP',\n  'RELAY',\n  'RELAYLOG',\n  'RELAY_LOG_FILE',\n  'RELAY_LOG_POS',\n  'RELAY_THREAD',\n  'RELEASE',\n  'RELOAD',\n  'REMOVE',\n  'RENAME',\n  'REORGANIZE',\n  'REPAIR',\n  'REPEATABLE',\n  'REPLAY',\n  'REPLICA',\n  'REPLICAS',\n  'REPLICA_POS',\n  'REPLICATION',\n  'REPEAT',\n  'REQUIRE',\n  'RESET',\n  'RESTART',\n  'RESTORE',\n  'RESTRICT',\n  'RESUME',\n  'RETURNED_SQLSTATE',\n  'RETURN',\n  'RETURNS',\n  'REUSE',\n  'RIGHT',\n  'RLIKE',\n  'ROLE',\n  'ROLLUP',\n  'ROUTINE',\n  'ROW',\n  'ROWCOUNT',\n  'ROWNUM',\n  'ROWS',\n  'ROWTYPE',\n  'ROW_COUNT',\n  'ROW_FORMAT',\n  'RTREE',\n  'SCHEDULE',\n  'SCHEMA',\n  'SCHEMA_NAME',\n  'SCHEMAS',\n  'SECOND',\n  'SECOND_MICROSECOND',\n  'SECURITY',\n  'SENSITIVE',\n  'SEPARATOR',\n  'SEQUENCE',\n  'SERIAL',\n  'SERIALIZABLE',\n  'SESSION',\n  'SERVER',\n  'SETVAL',\n  'SHARE',\n  'SIGNED',\n  'SIMPLE',\n  'SKIP',\n  'SLAVE',\n  'SLAVES',\n  'SLAVE_POS',\n  'SLOW',\n  'SNAPSHOT',\n  'SMALLINT',\n  'SOCKET',\n  'SOFT',\n  'SOME',\n  'SONAME',\n  'SOUNDS',\n  'SOURCE',\n  'STAGE',\n  'STORED',\n  'SPATIAL',\n  'SPECIFIC',\n  'REF_SYSTEM_ID',\n  'SQL',\n  'SQLEXCEPTION',\n  'SQLSTATE',\n  'SQLWARNING',\n  'SQL_BIG_RESULT',\n  'SQL_BUFFER_RESULT',\n  'SQL_CACHE',\n  'SQL_CALC_FOUND_ROWS',\n  'SQL_NO_CACHE',\n  'SQL_SMALL_RESULT',\n  'SQL_THREAD',\n  'SQL_TSI_SECOND',\n  'SQL_TSI_MINUTE',\n  'SQL_TSI_HOUR',\n  'SQL_TSI_DAY',\n  'SQL_TSI_WEEK',\n  'SQL_TSI_MONTH',\n  'SQL_TSI_QUARTER',\n  'SQL_TSI_YEAR',\n  'SSL',\n  'START',\n  'STARTING',\n  'STARTS',\n  'STATEMENT',\n  'STATS_AUTO_RECALC',\n  'STATS_PERSISTENT',\n  'STATS_SAMPLE_PAGES',\n  'STATUS',\n  'STOP',\n  'STORAGE',\n  'STRING',\n  'SUBCLASS_ORIGIN',\n  'SUBJECT',\n  'SUBPARTITION',\n  'SUBPARTITIONS',\n  'SUPER',\n  'SUSPEND',\n  'SWAPS',\n  'SWITCHES',\n  'SYSDATE',\n  'SYSTEM',\n  'SYSTEM_TIME',\n  'TABLE',\n  'TABLE_NAME',\n  'TABLES',\n  'TABLESPACE',\n  'TABLE_CHECKSUM',\n  'TEMPORARY',\n  'TEMPTABLE',\n  'TERMINATED',\n  'TEXT',\n  'THAN',\n  'THEN',\n  'TIES',\n  'TIME',\n  'TIMESTAMP',\n  'TIMESTAMPADD',\n  'TIMESTAMPDIFF',\n  'TINYBLOB',\n  'TINYINT',\n  'TINYTEXT',\n  'TO',\n  'TRAILING',\n  'TRANSACTION',\n  'TRANSACTIONAL',\n  'THREADS',\n  'TRIGGER',\n  'TRIGGERS',\n  'TRUE',\n  'TYPE',\n  'TYPES',\n  'UNBOUNDED',\n  'UNCOMMITTED',\n  'UNDEFINED',\n  'UNDO_BUFFER_SIZE',\n  'UNDOFILE',\n  'UNDO',\n  'UNICODE',\n  'UNIQUE',\n  'UNKNOWN',\n  'UNLOCK',\n  'UNINSTALL',\n  'UNSIGNED',\n  'UNTIL',\n  'UPGRADE',\n  'USAGE',\n  'USER',\n  'USER_RESOURCES',\n  'USE_FRM',\n  'UTC_DATE',\n  'UTC_TIME',\n  'UTC_TIMESTAMP',\n  'VALUE',\n  'VARBINARY',\n  'VARCHAR',\n  'VARCHARACTER',\n  'VARCHAR2',\n  'VARIABLES',\n  'VARYING',\n  'VIA',\n  'VIEW',\n  'VIRTUAL',\n  'VISIBLE',\n  'VERSIONING',\n  'WAIT',\n  'WARNINGS',\n  'WEEK',\n  'WEIGHT_STRING',\n  'WHILE',\n  'WINDOW',\n  'WITHIN',\n  'WITHOUT',\n  'WORK',\n  'WRAPPER',\n  'WRITE',\n  'X509',\n  'XA',\n  'XML',\n  'YEAR',\n  'YEAR_MONTH',\n  'ZEROFILL',\n];\n\n/**\n * Priority 1 (first)\n * keywords that begin a new statement\n * will begin new indented block\n */\n// https://mariadb.com/docs/reference/mdb/sql-statements/\nconst reservedCommands = [\n  'ALTER DATABASE',\n  'ALTER DATABASE COMMENT',\n  'ALTER EVENT',\n  'ALTER FUNCTION',\n  'ALTER PROCEDURE',\n  'ALTER SCHEMA',\n  'ALTER SCHEMA COMMENT',\n  'ALTER SEQUENCE',\n  'ALTER SERVER',\n  'ALTER TABLE',\n  'ALTER USER',\n  'ALTER VIEW',\n  'ANALYZE',\n  'ANALYZE TABLE',\n  'BACKUP LOCK',\n  'BACKUP STAGE',\n  'BACKUP UNLOCK',\n  'BEGIN',\n  'BINLOG',\n  'CACHE INDEX',\n  'CALL',\n  'CHANGE MASTER TO',\n  'CHECK TABLE',\n  'CHECK VIEW',\n  'CHECKSUM TABLE',\n  'COMMIT',\n  'CREATE AGGREGATE FUNCTION',\n  'CREATE DATABASE',\n  'CREATE EVENT',\n  'CREATE FUNCTION',\n  'CREATE INDEX',\n  'CREATE PROCEDURE',\n  'CREATE ROLE',\n  'CREATE SEQUENCE',\n  'CREATE SERVER',\n  'CREATE SPATIAL INDEX',\n  'CREATE TABLE',\n  'CREATE TRIGGER',\n  'CREATE UNIQUE INDEX',\n  'CREATE USER',\n  'CREATE VIEW',\n  'DEALLOCATE PREPARE',\n  'DELETE',\n  'DESC',\n  'DESCRIBE',\n  'DO',\n  'DROP DATABASE',\n  'DROP EVENT',\n  'DROP FUNCTION',\n  'DROP INDEX',\n  'DROP PREPARE',\n  'DROP PROCEDURE',\n  'DROP ROLE',\n  'DROP SEQUENCE',\n  'DROP SERVER',\n  'DROP TABLE',\n  'DROP TRIGGER',\n  'DROP USER',\n  'DROP VIEW',\n  'EXECUTE',\n  'EXPLAIN',\n  'FLUSH',\n  'GET DIAGNOSTICS',\n  'GET DIAGNOSTICS CONDITION',\n  'GRANT',\n  'HANDLER',\n  'HELP',\n  'INSERT',\n  'INSTALL PLUGIN',\n  'INSTALL SONAME',\n  'KILL',\n  'LOAD DATA INFILE',\n  'LOAD INDEX INTO CACHE',\n  'LOAD XML INFILE',\n  'LOCK TABLE',\n  'OPTIMIZE TABLE',\n  'PREPARE',\n  'PURGE BINARY LOGS',\n  'PURGE MASTER LOGS',\n  'RELEASE SAVEPOINT',\n  'RENAME TABLE',\n  'RENAME USER',\n  'REPAIR TABLE',\n  'REPAIR VIEW',\n  'REPLACE',\n  'RESET MASTER',\n  'RESET QUERY CACHE',\n  'RESET REPLICA',\n  'RESET SLAVE',\n  'RESIGNAL',\n  'RETURNING',\n  'REVOKE',\n  'ROLLBACK',\n  'SAVEPOINT',\n  'SELECT',\n  'SET',\n  'SET CHARACTER SET',\n  'SET DEFAULT ROLE',\n  'SET GLOBAL TRANSACTION',\n  'SET NAMES',\n  'SET PASSWORD',\n  'SET ROLE',\n  'SET STATEMENT',\n  'SET TRANSACTION',\n  'SHOW',\n  'SHOW ALL REPLICAS STATUS',\n  'SHOW ALL SLAVES STATUS',\n  'SHOW AUTHORS',\n  'SHOW BINARY LOGS',\n  'SHOW BINLOG EVENTS',\n  'SHOW BINLOG STATUS',\n  'SHOW CHARACTER SET',\n  'SHOW CLIENT_STATISTICS',\n  'SHOW COLLATION',\n  'SHOW COLUMNS',\n  'SHOW CONTRIBUTORS',\n  'SHOW CREATE DATABASE',\n  'SHOW CREATE EVENT',\n  'SHOW CREATE FUNCTION',\n  'SHOW CREATE PACKAGE',\n  'SHOW CREATE PACKAGE BODY',\n  'SHOW CREATE PROCEDURE',\n  'SHOW CREATE SEQUENCE',\n  'SHOW CREATE TABLE',\n  'SHOW CREATE TRIGGER',\n  'SHOW CREATE USER',\n  'SHOW CREATE VIEW',\n  'SHOW DATABASES',\n  'SHOW ENGINE',\n  'SHOW ENGINE INNODB STATUS',\n  'SHOW ENGINES',\n  'SHOW ERRORS',\n  'SHOW EVENTS',\n  'SHOW EXPLAIN',\n  'SHOW FUNCTION CODE',\n  'SHOW FUNCTION STATUS',\n  'SHOW GRANTS',\n  'SHOW INDEX',\n  'SHOW INDEXES',\n  'SHOW INDEX_STATISTICS',\n  'SHOW KEYS',\n  'SHOW LOCALES',\n  'SHOW MASTER LOGS',\n  'SHOW MASTER STATUS',\n  'SHOW OPEN TABLES',\n  'SHOW PACKAGE BODY CODE',\n  'SHOW PACKAGE BODY STATUS',\n  'SHOW PACKAGE STATUS',\n  'SHOW PLUGINS',\n  'SHOW PLUGINS SONAME',\n  'SHOW PRIVILEGES',\n  'SHOW PROCEDURE CODE',\n  'SHOW PROCEDURE STATUS',\n  'SHOW PROCESSLIST',\n  'SHOW PROFILE',\n  'SHOW PROFILES',\n  'SHOW QUERY_RESPONSE_TIME',\n  'SHOW RELAYLOG EVENTS',\n  'SHOW REPLICA',\n  'SHOW REPLICA HOSTS',\n  'SHOW REPLICA STATUS',\n  'SHOW SCHEMAS',\n  'SHOW SLAVE',\n  'SHOW SLAVE HOSTS',\n  'SHOW SLAVE STATUS',\n  'SHOW STATUS',\n  'SHOW STORAGE ENGINES',\n  'SHOW TABLE STATUS',\n  'SHOW TABLES',\n  'SHOW TRIGGERS',\n  'SHOW USER_STATISTICS',\n  'SHOW VARIABLES',\n  'SHOW WARNINGS',\n  'SHOW WSREP_MEMBERSHIP',\n  'SHOW WSREP_STATUS',\n  'SHUTDOWN',\n  'SIGNAL',\n  'START ALL REPLICAS',\n  'START ALL SLAVES',\n  'START REPLICA',\n  'START SLAVE',\n  'START TRANSACTION',\n  'STOP ALL REPLICAS',\n  'STOP ALL SLAVES',\n  'STOP REPLICA',\n  'STOP SLAVE',\n  'TRUNCATE',\n  'TRUNCATE TABLE',\n  'UNINSTALL PLUGIN',\n  'UNINSTALL SONAME',\n  'UNLOCK TABLE',\n  'UPDATE',\n  'USE',\n  'WITH',\n  'XA BEGIN',\n  'XA COMMIT',\n  'XA END',\n  'XA PREPARE',\n  'XA RECOVER',\n  'XA ROLLBACK',\n  'XA START',\n  // other\n  'ADD',\n  'ALTER COLUMN',\n  'FROM',\n  'GROUP BY',\n  'HAVING',\n  'INSERT INTO',\n  'INSERT',\n  'LIMIT',\n  'OFFSET',\n  'ORDER BY',\n  'SELECT',\n  'VALUES',\n  'WHERE',\n];\n\n/**\n * Priority 2\n * commands that operate on two tables or subqueries\n * two main categories: joins and boolean set operators\n */\nconst reservedBinaryCommands = [\n  // set booleans\n  'INTERSECT',\n  'INTERSECT ALL',\n  'INTERSECT DISTINCT',\n  'UNION',\n  'UNION ALL',\n  'UNION DISTINCT',\n  'EXCEPT',\n  'EXCEPT ALL',\n  'EXCEPT DISTINCT',\n  'MINUS',\n  'MINUS ALL',\n  'MINUS DISTINCT',\n  // joins\n  'JOIN',\n  'INNER JOIN',\n  'LEFT JOIN',\n  'LEFT OUTER JOIN',\n  'RIGHT JOIN',\n  'RIGHT OUTER JOIN',\n  'CROSS JOIN',\n  'NATURAL JOIN',\n  // non-standard joins\n  'STRAIGHT_JOIN',\n  'NATURAL LEFT JOIN',\n  'NATURAL LEFT OUTER JOIN',\n  'NATURAL RIGHT JOIN',\n  'NATURAL RIGHT OUTER JOIN',\n];\n\n/**\n * Priority 3\n * keywords that follow a previous Statement, must be attached to subsequent data\n * can be fully inline or on newline with optional indent\n */\nconst reservedDependentClauses = ['WHEN', 'ELSE', 'ELSEIF', 'ELSIF'];\n\n// For reference: https://mariadb.com/kb/en/sql-statements-structure/\nexport default class MariaDbFormatter extends Formatter {\n  static reservedCommands = reservedCommands;\n  static reservedBinaryCommands = reservedBinaryCommands;\n  static reservedJoinConditions = ['ON', 'USING'];\n  static reservedLogicalOperators = ['AND', 'OR', 'XOR'];\n  static reservedDependentClauses = reservedDependentClauses;\n  static reservedKeywords = dedupe([...reservedKeywords, ...reservedFunctions]);\n  static stringTypes: StringPatternType[] = ['``', \"''\", '\"\"'];\n  static blockStart = ['(', 'CASE'];\n  static blockEnd = [')', 'END'];\n  static indexedPlaceholderTypes = ['?'];\n  static namedPlaceholderTypes = [];\n  static lineCommentTypes = ['--', '#'];\n  static specialWordChars = { prefix: '@' };\n  static operators = [':=', '<<', '>>', '<=>', '&&', '||'];\n\n  tokenizer() {\n    return new Tokenizer({\n      reservedCommands: MariaDbFormatter.reservedCommands,\n      reservedBinaryCommands: MariaDbFormatter.reservedBinaryCommands,\n      reservedDependentClauses: MariaDbFormatter.reservedDependentClauses,\n      reservedJoinConditions: MariaDbFormatter.reservedJoinConditions,\n      reservedLogicalOperators: MariaDbFormatter.reservedLogicalOperators,\n      reservedKeywords: MariaDbFormatter.reservedKeywords,\n      stringTypes: MariaDbFormatter.stringTypes,\n      blockStart: MariaDbFormatter.blockStart,\n      blockEnd: MariaDbFormatter.blockEnd,\n      indexedPlaceholderTypes: MariaDbFormatter.indexedPlaceholderTypes,\n      namedPlaceholderTypes: MariaDbFormatter.namedPlaceholderTypes,\n      lineCommentTypes: MariaDbFormatter.lineCommentTypes,\n      specialWordChars: MariaDbFormatter.specialWordChars,\n      operators: MariaDbFormatter.operators,\n    });\n  }\n\n  tokenOverride(token: Token) {\n    // [SET] ( ...\n    if (isToken.SET(token) && this.tokenLookAhead().value === '(') {\n      // This is SET datatype, not SET statement\n      return { type: TokenType.RESERVED_KEYWORD, value: token.value };\n    }\n\n    return token;\n  }\n}\n","import Formatter from '../core/Formatter';\nimport Tokenizer from '../core/Tokenizer';\nimport { isToken, Token, TokenType } from '../core/token';\nimport type { StringPatternType } from '../core/regexFactory';\nimport { dedupe } from '../utils';\n\n// TODO: split this into object with function categories\n/**\n * Priority 5 (last)\n * Full list of reserved functions\n * distinct from Keywords due to interaction with parentheses\n */\n// https://dev.mysql.com/doc/refman/8.0/en/built-in-function-reference.html\nconst reservedFunctions = [\n  'ABS',\n  'ACOS',\n  'ADDDATE',\n  'ADDTIME',\n  'AES_DECRYPT',\n  'AES_ENCRYPT',\n  'AND',\n  'ANY_VALUE',\n  'ASCII',\n  'ASIN',\n  'ATAN',\n  'ATAN2',\n  'AVG',\n  'BENCHMARK',\n  'BIN',\n  'BIN_TO_UUID',\n  'BINARY',\n  'BIT_AND',\n  'BIT_COUNT',\n  'BIT_LENGTH',\n  'BIT_OR',\n  'BIT_XOR',\n  'CAN_ACCESS_COLUMN',\n  'CAN_ACCESS_DATABASE',\n  'CAN_ACCESS_TABLE',\n  'CAN_ACCESS_USER',\n  'CAN_ACCESS_VIEW',\n  'CASE',\n  'CAST',\n  'CEIL',\n  'CEILING',\n  'CHAR',\n  'CHAR_LENGTH',\n  'CHARACTER_LENGTH',\n  'CHARSET',\n  'COALESCE',\n  'COERCIBILITY',\n  'COLLATION',\n  'COMPRESS',\n  'CONCAT',\n  'CONCAT_WS',\n  'CONNECTION_ID',\n  'CONV',\n  'CONVERT',\n  'CONVERT_TZ',\n  'COS',\n  'COT',\n  'COUNT',\n  'CRC32',\n  'CUME_DIST',\n  'CURDATE',\n  'CURRENT_DATE',\n  'CURRENT_ROLE',\n  'CURRENT_TIME',\n  'CURRENT_TIMESTAMP',\n  'CURRENT_USER',\n  'CURTIME',\n  'DATABASE',\n  'DATE',\n  'DATE_ADD',\n  'DATE_FORMAT',\n  'DATE_SUB',\n  'DATEDIFF',\n  'DAY',\n  'DAYNAME',\n  'DAYOFMONTH',\n  'DAYOFWEEK',\n  'DAYOFYEAR',\n  'DEFAULT',\n  'DEGREES',\n  'DENSE_RANK',\n  'DIV',\n  'ELT',\n  'EXP',\n  'EXPORT_SET',\n  'EXTRACT',\n  'ExtractValue',\n  'FIELD',\n  'FIND_IN_SET',\n  'FIRST_VALUE',\n  'FLOOR',\n  'FORMAT',\n  'FORMAT_BYTES',\n  'FORMAT_PICO_TIME',\n  'FOUND_ROWS',\n  'FROM_BASE64',\n  'FROM_DAYS',\n  'FROM_UNIXTIME',\n  'GeomCollection',\n  'GeometryCollection',\n  'GET_DD_COLUMN_PRIVILEGES',\n  'GET_DD_CREATE_OPTIONS',\n  'GET_DD_INDEX_SUB_PART_LENGTH',\n  'GET_FORMAT',\n  'GET_LOCK',\n  'GREATEST',\n  'GROUP_CONCAT',\n  'GROUPING',\n  'GTID_SUBSET',\n  'GTID_SUBTRACT',\n  'HEX',\n  'HOUR',\n  'ICU_VERSION',\n  'IF',\n  'IFNULL',\n  'IN',\n  'INET_ATON',\n  'INET_NTOA',\n  'INET6_ATON',\n  'INET6_NTOA',\n  'INSERT',\n  'INSTR',\n  'INTERNAL_AUTO_INCREMENT',\n  'INTERNAL_AVG_ROW_LENGTH',\n  'INTERNAL_CHECK_TIME',\n  'INTERNAL_CHECKSUM',\n  'INTERNAL_DATA_FREE',\n  'INTERNAL_DATA_LENGTH',\n  'INTERNAL_DD_CHAR_LENGTH',\n  'INTERNAL_GET_COMMENT_OR_ERROR',\n  'INTERNAL_GET_ENABLED_ROLE_JSON',\n  'INTERNAL_GET_HOSTNAME',\n  'INTERNAL_GET_USERNAME',\n  'INTERNAL_GET_VIEW_WARNING_OR_ERROR',\n  'INTERNAL_INDEX_COLUMN_CARDINALITY',\n  'INTERNAL_INDEX_LENGTH',\n  'INTERNAL_IS_ENABLED_ROLE',\n  'INTERNAL_IS_MANDATORY_ROLE',\n  'INTERNAL_KEYS_DISABLED',\n  'INTERNAL_MAX_DATA_LENGTH',\n  'INTERNAL_TABLE_ROWS',\n  'INTERNAL_UPDATE_TIME',\n  'INTERVAL',\n  'IS',\n  'IS_FREE_LOCK',\n  'IS_IPV4',\n  'IS_IPV4_COMPAT',\n  'IS_IPV4_MAPPED',\n  'IS_IPV6',\n  'IS NOT',\n  'IS NOT NULL',\n  'IS NULL',\n  'IS_USED_LOCK',\n  'IS_UUID',\n  'ISNULL',\n  'JSON_ARRAY',\n  'JSON_ARRAY_APPEND',\n  'JSON_ARRAY_INSERT',\n  'JSON_ARRAYAGG',\n  'JSON_CONTAINS',\n  'JSON_CONTAINS_PATH',\n  'JSON_DEPTH',\n  'JSON_EXTRACT',\n  'JSON_INSERT',\n  'JSON_KEYS',\n  'JSON_LENGTH',\n  'JSON_MERGE',\n  'JSON_MERGE_PATCH',\n  'JSON_MERGE_PRESERVE',\n  'JSON_OBJECT',\n  'JSON_OBJECTAGG',\n  'JSON_OVERLAPS',\n  'JSON_PRETTY',\n  'JSON_QUOTE',\n  'JSON_REMOVE',\n  'JSON_REPLACE',\n  'JSON_SCHEMA_VALID',\n  'JSON_SCHEMA_VALIDATION_REPORT',\n  'JSON_SEARCH',\n  'JSON_SET',\n  'JSON_STORAGE_FREE',\n  'JSON_STORAGE_SIZE',\n  'JSON_TABLE',\n  'JSON_TYPE',\n  'JSON_UNQUOTE',\n  'JSON_VALID',\n  'JSON_VALUE',\n  'LAG',\n  'LAST_DAY',\n  'LAST_INSERT_ID',\n  'LAST_VALUE',\n  'LCASE',\n  'LEAD',\n  'LEAST',\n  'LEFT',\n  'LENGTH',\n  'LIKE',\n  'LineString',\n  'LN',\n  'LOAD_FILE',\n  'LOCALTIME',\n  'LOCALTIMESTAMP',\n  'LOCATE',\n  'LOG',\n  'LOG10',\n  'LOG2',\n  'LOWER',\n  'LPAD',\n  'LTRIM',\n  'MAKE_SET',\n  'MAKEDATE',\n  'MAKETIME',\n  'MASTER_POS_WAIT',\n  'MATCH',\n  'MAX',\n  'MBRContains',\n  'MBRCoveredBy',\n  'MBRCovers',\n  'MBRDisjoint',\n  'MBREquals',\n  'MBRIntersects',\n  'MBROverlaps',\n  'MBRTouches',\n  'MBRWithin',\n  'MD5',\n  'MEMBER OF',\n  'MICROSECOND',\n  'MID',\n  'MIN',\n  'MINUTE',\n  'MOD',\n  'MONTH',\n  'MONTHNAME',\n  'MultiLineString',\n  'MultiPoint',\n  'MultiPolygon',\n  'NAME_CONST',\n  'NOT',\n  'NOT IN',\n  'NOT LIKE',\n  'NOT REGEXP',\n  'NOW',\n  'NTH_VALUE',\n  'NTILE',\n  'NULLIF',\n  'OCT',\n  'OCTET_LENGTH',\n  'OR',\n  'ORD',\n  'PERCENT_RANK',\n  'PERIOD_ADD',\n  'PERIOD_DIFF',\n  'PI',\n  'Point',\n  'Polygon',\n  'POSITION',\n  'POW',\n  'POWER',\n  'PS_CURRENT_THREAD_ID',\n  'PS_THREAD_ID',\n  'QUARTER',\n  'QUOTE',\n  'RADIANS',\n  'RAND',\n  'RANDOM_BYTES',\n  'RANK',\n  'REGEXP',\n  'REGEXP_INSTR',\n  'REGEXP_LIKE',\n  'REGEXP_REPLACE',\n  'REGEXP_SUBSTR',\n  'RELEASE_ALL_LOCKS',\n  'RELEASE_LOCK',\n  'REPEAT',\n  'REPLACE',\n  'REVERSE',\n  'RIGHT',\n  'RLIKE',\n  'ROLES_GRAPHML',\n  'ROUND',\n  'ROW_COUNT',\n  'ROW_NUMBER',\n  'RPAD',\n  'RTRIM',\n  'SCHEMA',\n  'SEC_TO_TIME',\n  'SECOND',\n  'SESSION_USER',\n  'SHA1',\n  'SHA2',\n  'SIGN',\n  'SIN',\n  'SLEEP',\n  'SOUNDEX',\n  'SOUNDS LIKE',\n  'SOURCE_POS_WAIT',\n  'SPACE',\n  'SQRT',\n  'ST_Area',\n  'ST_AsBinary',\n  'ST_AsGeoJSON',\n  'ST_AsText',\n  'ST_Buffer',\n  'ST_Buffer_Strategy',\n  'ST_Centroid',\n  'ST_Collect',\n  'ST_Contains',\n  'ST_ConvexHull',\n  'ST_Crosses',\n  'ST_Difference',\n  'ST_Dimension',\n  'ST_Disjoint',\n  'ST_Distance',\n  'ST_Distance_Sphere',\n  'ST_EndPoint',\n  'ST_Envelope',\n  'ST_Equals',\n  'ST_ExteriorRing',\n  'ST_FrechetDistance',\n  'ST_GeoHash',\n  'ST_GeomCollFromText',\n  'ST_GeomCollFromWKB',\n  'ST_GeometryN',\n  'ST_GeometryType',\n  'ST_GeomFromGeoJSON',\n  'ST_GeomFromText',\n  'ST_GeomFromWKB',\n  'ST_HausdorffDistance',\n  'ST_InteriorRingN',\n  'ST_Intersection',\n  'ST_Intersects',\n  'ST_IsClosed',\n  'ST_IsEmpty',\n  'ST_IsSimple',\n  'ST_IsValid',\n  'ST_LatFromGeoHash',\n  'ST_Latitude',\n  'ST_Length',\n  'ST_LineFromText',\n  'ST_LineFromWKB',\n  'ST_LineInterpolatePoint',\n  'ST_LineInterpolatePoints',\n  'ST_LongFromGeoHash',\n  'ST_Longitude',\n  'ST_MakeEnvelope',\n  'ST_MLineFromText',\n  'ST_MLineFromWKB',\n  'ST_MPointFromText',\n  'ST_MPointFromWKB',\n  'ST_MPolyFromText',\n  'ST_MPolyFromWKB',\n  'ST_NumGeometries',\n  'ST_NumInteriorRing',\n  'ST_NumPoints',\n  'ST_Overlaps',\n  'ST_PointAtDistance',\n  'ST_PointFromGeoHash',\n  'ST_PointFromText',\n  'ST_PointFromWKB',\n  'ST_PointN',\n  'ST_PolyFromText',\n  'ST_PolyFromWKB',\n  'ST_Simplify',\n  'ST_SRID',\n  'ST_StartPoint',\n  'ST_SwapXY',\n  'ST_SymDifference',\n  'ST_Touches',\n  'ST_Transform',\n  'ST_Union',\n  'ST_Validate',\n  'ST_Within',\n  'ST_X',\n  'ST_Y',\n  'STATEMENT_DIGEST',\n  'STATEMENT_DIGEST_TEXT',\n  'STD',\n  'STDDEV',\n  'STDDEV_POP',\n  'STDDEV_SAMP',\n  'STR_TO_DATE',\n  'STRCMP',\n  'SUBDATE',\n  'SUBSTR',\n  'SUBSTRING',\n  'SUBSTRING_INDEX',\n  'SUBTIME',\n  'SUM',\n  'SYSDATE',\n  'SYSTEM_USER',\n  'TAN',\n  'TIME',\n  'TIME_FORMAT',\n  'TIME_TO_SEC',\n  'TIMEDIFF',\n  'TIMESTAMP',\n  'TIMESTAMPADD',\n  'TIMESTAMPDIFF',\n  'TO_BASE64',\n  'TO_DAYS',\n  'TO_SECONDS',\n  'TRIM',\n  'TRUNCATE',\n  'UCASE',\n  'UNCOMPRESS',\n  'UNCOMPRESSED_LENGTH',\n  'UNHEX',\n  'UNIX_TIMESTAMP',\n  'UpdateXML',\n  'UPPER',\n  'USER',\n  'UTC_DATE',\n  'UTC_TIME',\n  'UTC_TIMESTAMP',\n  'UUID',\n  'UUID_SHORT',\n  'UUID_TO_BIN',\n  'VALIDATE_PASSWORD_STRENGTH',\n  'VALUES',\n  'VAR_POP',\n  'VAR_SAMP',\n  'VARIANCE',\n  'VERSION',\n  'WAIT_FOR_EXECUTED_GTID_SET',\n  'WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS',\n  'WEEK',\n  'WEEKDAY',\n  'WEEKOFYEAR',\n  'WEIGHT_STRING',\n  'XOR',\n  'YEAR',\n  'YEARWEEK',\n];\n\n/**\n * Priority 5 (last)\n * Full list of reserved words\n * any words that are in a higher priority are removed\n */\n// https://dev.mysql.com/doc/refman/8.0/en/keywords.html\nconst reservedKeywords = [\n  'ACCESSIBLE',\n  'ACCOUNT',\n  'ACTION',\n  'ACTIVE',\n  'ADMIN',\n  'AFTER',\n  'AGAINST',\n  'AGGREGATE',\n  'ALGORITHM',\n  'ALL',\n  'ALTER',\n  'ALWAYS',\n  'ANALYSE',\n  'ANALYZE',\n  'ANY',\n  'ARRAY',\n  'AS',\n  'ASC',\n  'ASENSITIVE',\n  'AT',\n  'ATTRIBUTE',\n  'AUTHENTICATION',\n  'AUTOEXTEND_SIZE',\n  'AUTO_INCREMENT',\n  'AVG_ROW_LENGTH',\n  'BACKUP',\n  'BEFORE',\n  'BEGIN',\n  'BETWEEN',\n  'BIGINT',\n  'BIT',\n  'BLOB',\n  'BLOCK',\n  'BOOL',\n  'BOOLEAN',\n  'BOTH',\n  'BTREE',\n  'BUCKETS',\n  'BY',\n  'BYTE',\n  'CACHE',\n  'CASCADE',\n  'CASCADED',\n  'CATALOG_NAME',\n  'CHAIN',\n  'CHALLENGE_RESPONSE',\n  'CHANGE',\n  'CHANGED',\n  'CHANNEL',\n  'CHARACTER',\n  'CHARACTER SET',\n  'CHECK',\n  'CHECKSUM',\n  'CIPHER',\n  'CLASS_ORIGIN',\n  'CLIENT',\n  'CLOSE',\n  'CODE',\n  'COLLATE',\n  'COLUMN',\n  'COLUMNS',\n  'COLUMN_FORMAT',\n  'COLUMN_NAME',\n  'COMMENT',\n  'COMMITTED',\n  'COMPACT',\n  'COMPLETION',\n  'COMPONENT',\n  'COMPRESSED',\n  'COMPRESSION',\n  'CONCURRENT',\n  'CONDITION',\n  'CONNECTION',\n  'CONSISTENT',\n  'CONSTRAINT',\n  'CONSTRAINT_CATALOG',\n  'CONSTRAINT_NAME',\n  'CONSTRAINT_SCHEMA',\n  'CONTAINS',\n  'CONTEXT',\n  'CONTINUE',\n  'CPU',\n  'CREATE',\n  'CROSS',\n  'CUBE',\n  'CURRENT',\n  'CURSOR',\n  'CURSOR_NAME',\n  'DATA',\n  'DATABASES',\n  'DATAFILE',\n  'DATETIME',\n  'DAY_HOUR',\n  'DAY_MICROSECOND',\n  'DAY_MINUTE',\n  'DAY_SECOND',\n  'DEALLOCATE',\n  'DEC',\n  'DECIMAL',\n  'DECLARE',\n  'DEFAULT_AUTH',\n  'DEFINER',\n  'DEFINITION',\n  'DELAYED',\n  'DELAY_KEY_WRITE',\n  'DESC',\n  'DESCRIPTION',\n  'DES_KEY_FILE',\n  'DETERMINISTIC',\n  'DIAGNOSTICS',\n  'DIRECTORY',\n  'DISABLE',\n  'DISCARD',\n  'DISK',\n  'DISTINCT',\n  'DISTINCTROW',\n  'DOUBLE',\n  'DROP',\n  'DUAL',\n  'DUMPFILE',\n  'DUPLICATE',\n  'DYNAMIC',\n  'EACH',\n  'EMPTY',\n  'ENABLE',\n  'ENCLOSED',\n  'ENCRYPTION',\n  'ENDS',\n  'ENFORCED',\n  'ENGINE',\n  'ENGINES',\n  'ENGINE_ATTRIBUTE',\n  'ENUM',\n  'ERROR',\n  'ERRORS',\n  'ESCAPE',\n  'ESCAPED',\n  'EVENT',\n  'EVENTS',\n  'EVERY',\n  'EXCHANGE',\n  'EXCLUDE',\n  'EXISTS',\n  'EXIT',\n  'EXPANSION',\n  'EXPIRE',\n  'EXPORT',\n  'EXTENDED',\n  'EXTENT_SIZE',\n  'FACTOR',\n  'FAILED_LOGIN_ATTEMPTS',\n  'FALSE',\n  'FAST',\n  'FAULTS',\n  'FETCH',\n  'FIELDS',\n  'FILE',\n  'FILE_BLOCK_SIZE',\n  'FILTER',\n  'FINISH',\n  'FIRST',\n  'FIXED',\n  'FLOAT',\n  'FLOAT4',\n  'FLOAT8',\n  'FOLLOWING',\n  'FOLLOWS',\n  'FOR',\n  'FORCE',\n  'FOREIGN',\n  'FOUND',\n  'FULL',\n  'FULLTEXT',\n  'FUNCTION',\n  'GENERAL',\n  'GENERATED',\n  'GEOMCOLLECTION',\n  'GEOMETRY',\n  'GEOMETRYCOLLECTION',\n  'GET',\n  'GET_MASTER_PUBLIC_KEY',\n  'GET_SOURCE_PUBLIC_KEY',\n  'GLOBAL',\n  '@@GLOBAL',\n  'GRANTS',\n  'GROUP',\n  'GROUPS',\n  'GROUP_REPLICATION',\n  'GTID_ONLY',\n  'HASH',\n  'HIGH_PRIORITY',\n  'HISTOGRAM',\n  'HISTORY',\n  'HOST',\n  'HOSTS',\n  'HOUR_MICROSECOND',\n  'HOUR_MINUTE',\n  'HOUR_SECOND',\n  'IDENTIFIED',\n  'IGNORE',\n  'IGNORE_SERVER_IDS',\n  'IMPORT',\n  'INACTIVE',\n  'INDEX',\n  'INDEXES',\n  'INFILE',\n  'INITIAL',\n  'INITIAL_SIZE',\n  'INITIATE',\n  'INNER',\n  'INOUT',\n  'INSENSITIVE',\n  'INSERT_METHOD',\n  'INSTALL',\n  'INSTANCE',\n  'INT',\n  'INT1',\n  'INT2',\n  'INT3',\n  'INT4',\n  'INT8',\n  'INTEGER',\n  'INTO',\n  'INVISIBLE',\n  'INVOKER',\n  'IO',\n  'IO_AFTER_GTIDS',\n  'IO_BEFORE_GTIDS',\n  'IO_THREAD',\n  'IPC',\n  'ISOLATION',\n  'ISSUER',\n  'ITERATE',\n  'JSON',\n  'KEY',\n  'KEYRING',\n  'KEYS',\n  'KEY_BLOCK_SIZE',\n  'LANGUAGE',\n  'LAST',\n  'LATERAL',\n  'LEADING',\n  'LEAVE',\n  'LEAVES',\n  'LESS',\n  'LEVEL',\n  'LINEAR',\n  'LINES',\n  'LINESTRING',\n  'LIST',\n  'LOAD',\n  'LOCAL',\n  'LOCK',\n  'LOCKED',\n  'LOCKS',\n  'LOGFILE',\n  'LOGS',\n  'LONG',\n  'LONGBLOB',\n  'LONGTEXT',\n  'LOOP',\n  'LOW_PRIORITY',\n  'MASTER',\n  'MASTER_AUTO_POSITION',\n  'MASTER_BIND',\n  'MASTER_COMPRESSION_ALGORITHMS',\n  'MASTER_CONNECT_RETRY',\n  'MASTER_DELAY',\n  'MASTER_HEARTBEAT_PERIOD',\n  'MASTER_HOST',\n  'MASTER_LOG_FILE',\n  'MASTER_LOG_POS',\n  'MASTER_PASSWORD',\n  'MASTER_PORT',\n  'MASTER_PUBLIC_KEY_PATH',\n  'MASTER_RETRY_COUNT',\n  'MASTER_SERVER_ID',\n  'MASTER_SSL',\n  'MASTER_SSL_CA',\n  'MASTER_SSL_CAPATH',\n  'MASTER_SSL_CERT',\n  'MASTER_SSL_CIPHER',\n  'MASTER_SSL_CRL',\n  'MASTER_SSL_CRLPATH',\n  'MASTER_SSL_KEY',\n  'MASTER_SSL_VERIFY_SERVER_CERT',\n  'MASTER_TLS_CIPHERSUITES',\n  'MASTER_TLS_VERSION',\n  'MASTER_USER',\n  'MASTER_ZSTD_COMPRESSION_LEVEL',\n  'MAXVALUE',\n  'MAX_CONNECTIONS_PER_HOUR',\n  'MAX_QUERIES_PER_HOUR',\n  'MAX_ROWS',\n  'MAX_SIZE',\n  'MAX_UPDATES_PER_HOUR',\n  'MAX_USER_CONNECTIONS',\n  'MEDIUM',\n  'MEDIUMBLOB',\n  'MEDIUMINT',\n  'MEDIUMTEXT',\n  'MEMBER',\n  'MEMORY',\n  'MERGE',\n  'MESSAGE_TEXT',\n  'MIDDLEINT',\n  'MIGRATE',\n  'MINUTE_MICROSECOND',\n  'MINUTE_SECOND',\n  'MIN_ROWS',\n  'MODE',\n  'MODIFIES',\n  'MODIFY',\n  'MULTILINESTRING',\n  'MULTIPOINT',\n  'MULTIPOLYGON',\n  'MUTEX',\n  'MYSQL_ERRNO',\n  'NAME',\n  'NAMES',\n  'NATIONAL',\n  'NATURAL',\n  'NCHAR',\n  'NDB',\n  'NDBCLUSTER',\n  'NESTED',\n  'NETWORK_NAMESPACE',\n  'NEVER',\n  'NEW',\n  'NEXT',\n  'NO',\n  'NODEGROUP',\n  'NONE',\n  'NOWAIT',\n  'NO_WAIT',\n  'NO_WRITE_TO_BINLOG',\n  'NULL',\n  'NULLS',\n  'NUMBER',\n  'NUMERIC',\n  'NVARCHAR',\n  'OF',\n  'OFF',\n  'OFFSET',\n  'OJ',\n  'OLD',\n  'ON DELETE',\n  'ON UPDATE',\n  'ONE',\n  'ONLY',\n  'OPEN',\n  'OPTIMIZE',\n  'OPTIMIZER_COSTS',\n  'OPTION',\n  'OPTIONAL',\n  'OPTIONALLY',\n  'OPTIONS',\n  'ORDER',\n  'ORDINALITY',\n  'ORGANIZATION',\n  'OTHERS',\n  'OUT',\n  'OUTER',\n  'OUTFILE',\n  'OVER',\n  'OWNER',\n  'PACK_KEYS',\n  'PAGE',\n  'PARSER',\n  'PARSE_GCOL_EXPR',\n  'PARTIAL',\n  'PARTITION',\n  'PARTITIONING',\n  'PARTITIONS',\n  'PASSWORD',\n  'PASSWORD_LOCK_TIME',\n  'PATH',\n  'PERSIST',\n  '@@PERSIST',\n  'PERSIST_ONLY',\n  '@@PERSIST_ONLY',\n  'PHASE',\n  'PLUGIN',\n  'PLUGINS',\n  'PLUGIN_DIR',\n  'POINT',\n  'POLYGON',\n  'PORT',\n  'PRECEDES',\n  'PRECEDING',\n  'PRECISION',\n  'PRESERVE',\n  'PREV',\n  'PRIMARY',\n  'PRIVILEGES',\n  'PRIVILEGE_CHECKS_USER',\n  'PROCEDURE',\n  'PROCESS',\n  'PROCESSLIST',\n  'PROFILE',\n  'PROFILES',\n  'PROXY',\n  'PURGE',\n  'QUERY',\n  'QUICK',\n  'RANDOM',\n  'RANGE',\n  'READ',\n  'READS',\n  'READ_ONLY',\n  'READ_WRITE',\n  'REAL',\n  'REBUILD',\n  'RECOVER',\n  'RECURSIVE',\n  'REDOFILE',\n  'REDO_BUFFER_SIZE',\n  'REDUNDANT',\n  'REFERENCE',\n  'REFERENCES',\n  'REGISTRATION',\n  'RELAY',\n  'RELAYLOG',\n  'RELAY_LOG_FILE',\n  'RELAY_LOG_POS',\n  'RELAY_THREAD',\n  'RELEASE',\n  'RELOAD',\n  'REMOTE',\n  'REMOVE',\n  'RENAME',\n  'REORGANIZE',\n  'REPAIR',\n  'REPEATABLE',\n  'REPLICA',\n  'REPLICAS',\n  'REPLICATE_DO_DB',\n  'REPLICATE_DO_TABLE',\n  'REPLICATE_IGNORE_DB',\n  'REPLICATE_IGNORE_TABLE',\n  'REPLICATE_REWRITE_DB',\n  'REPLICATE_WILD_DO_TABLE',\n  'REPLICATE_WILD_IGNORE_TABLE',\n  'REPLICATION',\n  'REQUIRE',\n  'REQUIRE_ROW_FORMAT',\n  'RESIGNAL',\n  'RESOURCE',\n  'RESPECT',\n  'RESTORE',\n  'RESTRICT',\n  'RESUME',\n  'RETAIN',\n  'RETURN',\n  'RETURNED_SQLSTATE',\n  'RETURNING',\n  'RETURNS',\n  'REUSE',\n  'ROLE',\n  'ROLLUP',\n  'ROTATE',\n  'ROUTINE',\n  'ROW',\n  'ROWS',\n  'ROW_FORMAT',\n  'RTREE',\n  'SCHEDULE',\n  'SCHEMAS',\n  'SCHEMA_NAME',\n  'SECONDARY',\n  'SECONDARY_ENGINE',\n  'SECONDARY_ENGINE_ATTRIBUTE',\n  'SECONDARY_LOAD',\n  'SECONDARY_UNLOAD',\n  'SECOND_MICROSECOND',\n  'SECURITY',\n  'SENSITIVE',\n  'SEPARATOR',\n  'SERIAL',\n  'SERIALIZABLE',\n  'SERVER',\n  'SESSION',\n  '@@SESSION',\n  'SHARE',\n  'SIGNAL',\n  'SIGNED',\n  'SIMPLE',\n  'SKIP',\n  'SLAVE',\n  'SLOW',\n  'SMALLINT',\n  'SNAPSHOT',\n  'SOCKET',\n  'SOME',\n  'SONAME',\n  'SOUNDS',\n  'SOURCE',\n  'SOURCE_AUTO_POSITION',\n  'SOURCE_BIND',\n  'SOURCE_COMPRESSION_ALGORITHMS',\n  'SOURCE_CONNECT_RETRY',\n  'SOURCE_DELAY',\n  'SOURCE_HEARTBEAT_PERIOD',\n  'SOURCE_HOST',\n  'SOURCE_LOG_FILE',\n  'SOURCE_LOG_POS',\n  'SOURCE_PASSWORD',\n  'SOURCE_PORT',\n  'SOURCE_PUBLIC_KEY_PATH',\n  'SOURCE_RETRY_COUNT',\n  'SOURCE_SSL',\n  'SOURCE_SSL_CA',\n  'SOURCE_SSL_CAPATH',\n  'SOURCE_SSL_CERT',\n  'SOURCE_SSL_CIPHER',\n  'SOURCE_SSL_CRL',\n  'SOURCE_SSL_CRLPATH',\n  'SOURCE_SSL_KEY',\n  'SOURCE_SSL_VERIFY_SERVER_CERT',\n  'SOURCE_TLS_CIPHERSUITES',\n  'SOURCE_TLS_VERSION',\n  'SOURCE_USER',\n  'SOURCE_ZSTD_COMPRESSION_LEVEL',\n  'SPATIAL',\n  'SPECIFIC',\n  'SQL',\n  'SQLEXCEPTION',\n  'SQLSTATE',\n  'SQLWARNING',\n  'SQL_AFTER_GTIDS',\n  'SQL_AFTER_MTS_GAPS',\n  'SQL_BEFORE_GTIDS',\n  'SQL_BIG_RESULT',\n  'SQL_BUFFER_RESULT',\n  'SQL_CACHE',\n  'SQL_CALC_FOUND_ROWS',\n  'SQL_NO_CACHE',\n  'SQL_SMALL_RESULT',\n  'SQL_THREAD',\n  'SQL_TSI_DAY',\n  'SQL_TSI_HOUR',\n  'SQL_TSI_MINUTE',\n  'SQL_TSI_MONTH',\n  'SQL_TSI_QUARTER',\n  'SQL_TSI_SECOND',\n  'SQL_TSI_WEEK',\n  'SQL_TSI_YEAR',\n  'SRID',\n  'SSL',\n  'STACKED',\n  'START',\n  'STARTING',\n  'STARTS',\n  'STATS_AUTO_RECALC',\n  'STATS_PERSISTENT',\n  'STATS_SAMPLE_PAGES',\n  'STATUS',\n  'STOP',\n  'STORAGE',\n  'STORED',\n  'STREAM',\n  'STRING',\n  'SUBCLASS_ORIGIN',\n  'SUBJECT',\n  'SUBPARTITION',\n  'SUBPARTITIONS',\n  'SUPER',\n  'SUSPEND',\n  'SWAPS',\n  'SWITCHES',\n  'SYSTEM',\n  'TABLES',\n  'TABLESPACE',\n  'TABLE_CHECKSUM',\n  'TABLE_NAME',\n  'TEMPORARY',\n  'TEMPTABLE',\n  'TERMINATED',\n  'TEXT',\n  'THAN',\n  'THEN',\n  'THREAD_PRIORITY',\n  'TIES',\n  'TINYBLOB',\n  'TINYINT',\n  'TINYTEXT',\n  'TLS',\n  'TO',\n  'TRAILING',\n  'TRANSACTION',\n  'TRIGGER',\n  'TRIGGERS',\n  'TRUE',\n  'TYPE',\n  'TYPES',\n  'UNBOUNDED',\n  'UNCOMMITTED',\n  'UNDEFINED',\n  'UNDO',\n  'UNDOFILE',\n  'UNDO_BUFFER_SIZE',\n  'UNICODE',\n  'UNINSTALL',\n  'UNIQUE',\n  'UNKNOWN',\n  'UNLOCK',\n  'UNREGISTER',\n  'UNSIGNED',\n  'UNTIL',\n  'UPGRADE',\n  'USAGE',\n  'USER_RESOURCES',\n  'USE_FRM',\n  'VALIDATION',\n  'VALUE',\n  'VARBINARY',\n  'VARCHAR',\n  'VARCHARACTER',\n  'VARIABLES',\n  'VARYING',\n  'VCPU',\n  'VIEW',\n  'VIRTUAL',\n  'VISIBLE',\n  'WAIT',\n  'WARNINGS',\n  'WHILE',\n  'WINDOW',\n  'WITHOUT',\n  'WORK',\n  'WRAPPER',\n  'WRITE',\n  'X509',\n  'XID',\n  'XML',\n  'YEAR_MONTH',\n  'ZEROFILL',\n  'ZONE',\n];\n\n/**\n * Priority 1 (first)\n * keywords that begin a new statement\n * will begin new indented block\n */\n// https://dev.mysql.com/doc/refman/8.0/en/sql-statements.html\nconst reservedCommands = [\n  'ALTER DATABASE',\n  'ALTER EVENT',\n  'ALTER FUNCTION',\n  'ALTER INSTANCE',\n  'ALTER LOGFILE GROUP',\n  'ALTER PROCEDURE',\n  'ALTER RESOURCE GROUP',\n  'ALTER SERVER',\n  'ALTER TABLE',\n  'ALTER TABLESPACE',\n  'ALTER USER',\n  'ALTER VIEW',\n  'ANALYZE TABLE',\n  'BINLOG',\n  'CACHE INDEX',\n  'CALL',\n  'CHANGE MASTER TO',\n  'CHANGE REPLICATION FILTER',\n  'CHANGE REPLICATION SOURCE TO',\n  'CHECK TABLE',\n  'CHECKSUM TABLE',\n  'CLONE',\n  'COMMIT',\n  'CREATE DATABASE',\n  'CREATE EVENT',\n  'CREATE FUNCTION',\n  'CREATE FUNCTION',\n  'CREATE INDEX',\n  'CREATE LOGFILE GROUP',\n  'CREATE PROCEDURE',\n  'CREATE RESOURCE GROUP',\n  'CREATE ROLE',\n  'CREATE SERVER',\n  'CREATE SPATIAL REFERENCE SYSTEM',\n  'CREATE TABLE',\n  'CREATE TABLESPACE',\n  'CREATE TRIGGER',\n  'CREATE USER',\n  'CREATE VIEW',\n  'DEALLOCATE PREPARE',\n  'DELETE',\n  'DESCRIBE',\n  'DO',\n  'DROP DATABASE',\n  'DROP EVENT',\n  'DROP FUNCTION',\n  'DROP FUNCTION',\n  'DROP INDEX',\n  'DROP LOGFILE GROUP',\n  'DROP PROCEDURE',\n  'DROP RESOURCE GROUP',\n  'DROP ROLE',\n  'DROP SERVER',\n  'DROP SPATIAL REFERENCE SYSTEM',\n  'DROP TABLE',\n  'DROP TABLESPACE',\n  'DROP TRIGGER',\n  'DROP USER',\n  'DROP VIEW',\n  'EXECUTE',\n  'EXPLAIN',\n  'FLUSH',\n  'GRANT',\n  'HANDLER',\n  'HELP',\n  'IMPORT TABLE',\n  'INSERT',\n  'INSTALL COMPONENT',\n  'INSTALL PLUGIN',\n  'KILL',\n  'LOAD DATA',\n  'LOAD INDEX INTO CACHE',\n  'LOAD XML',\n  'LOCK INSTANCE FOR BACKUP',\n  'LOCK TABLES',\n  'MASTER_POS_WAIT',\n  'OPTIMIZE TABLE',\n  'PREPARE',\n  'PURGE BINARY LOGS',\n  'RELEASE SAVEPOINT',\n  'RENAME TABLE',\n  'RENAME USER',\n  'REPAIR TABLE',\n  'REPLACE',\n  'RESET',\n  'RESET MASTER',\n  'RESET PERSIST',\n  'RESET REPLICA',\n  'RESET SLAVE',\n  'RESTART',\n  'REVOKE',\n  'ROLLBACK',\n  'ROLLBACK TO SAVEPOINT',\n  'SAVEPOINT',\n  'SELECT',\n  'SET',\n  'SET CHARACTER SET',\n  'SET DEFAULT ROLE',\n  'SET NAMES',\n  'SET PASSWORD',\n  'SET RESOURCE GROUP',\n  'SET ROLE',\n  'SET TRANSACTION',\n  'SHOW',\n  'SHOW BINARY LOGS',\n  'SHOW BINLOG EVENTS',\n  'SHOW CHARACTER SET',\n  'SHOW COLLATION',\n  'SHOW COLUMNS',\n  'SHOW CREATE DATABASE',\n  'SHOW CREATE EVENT',\n  'SHOW CREATE FUNCTION',\n  'SHOW CREATE PROCEDURE',\n  'SHOW CREATE TABLE',\n  'SHOW CREATE TRIGGER',\n  'SHOW CREATE USER',\n  'SHOW CREATE VIEW',\n  'SHOW DATABASES',\n  'SHOW ENGINE',\n  'SHOW ENGINES',\n  'SHOW ERRORS',\n  'SHOW EVENTS',\n  'SHOW FUNCTION CODE',\n  'SHOW FUNCTION STATUS',\n  'SHOW GRANTS',\n  'SHOW INDEX',\n  'SHOW MASTER STATUS',\n  'SHOW OPEN TABLES',\n  'SHOW PLUGINS',\n  'SHOW PRIVILEGES',\n  'SHOW PROCEDURE CODE',\n  'SHOW PROCEDURE STATUS',\n  'SHOW PROCESSLIST',\n  'SHOW PROFILE',\n  'SHOW PROFILES',\n  'SHOW RELAYLOG EVENTS',\n  'SHOW REPLICA STATUS',\n  'SHOW REPLICAS',\n  'SHOW SLAVE',\n  'SHOW SLAVE HOSTS',\n  'SHOW STATUS',\n  'SHOW TABLE STATUS',\n  'SHOW TABLES',\n  'SHOW TRIGGERS',\n  'SHOW VARIABLES',\n  'SHOW WARNINGS',\n  'SHUTDOWN',\n  'SOURCE_POS_WAIT',\n  'START GROUP_REPLICATION',\n  'START REPLICA',\n  'START SLAVE',\n  'START TRANSACTION',\n  'STOP GROUP_REPLICATION',\n  'STOP REPLICA',\n  'STOP SLAVE',\n  'TABLE',\n  'TRUNCATE TABLE',\n  'UNINSTALL COMPONENT',\n  'UNINSTALL PLUGIN',\n  'UNLOCK INSTANCE',\n  'UNLOCK TABLES',\n  'UPDATE',\n  'USE',\n  'VALUES',\n  'WITH',\n  'XA',\n  // flow control\n  // 'IF',\n  'ITERATE',\n  'LEAVE',\n  'LOOP',\n  'REPEAT',\n  'RETURN',\n  'WHILE',\n  // other\n  'ADD',\n  'ALTER COLUMN',\n  'FROM',\n  'GROUP BY',\n  'HAVING',\n  'INSERT INTO',\n  'LIMIT',\n  'OFFSET',\n  'ORDER BY',\n  'WHERE',\n];\n\n/**\n * Priority 2\n * commands that operate on two tables or subqueries\n * two main categories: joins and boolean set operators\n */\nconst reservedBinaryCommands = [\n  // set booleans\n  'INTERSECT',\n  'INTERSECT ALL',\n  'INTERSECT DISTINCT',\n  'UNION',\n  'UNION ALL',\n  'UNION DISTINCT',\n  'EXCEPT',\n  'EXCEPT ALL',\n  'EXCEPT DISTINCT',\n  // joins\n  'JOIN',\n  'INNER JOIN',\n  'LEFT JOIN',\n  'LEFT OUTER JOIN',\n  'RIGHT JOIN',\n  'RIGHT OUTER JOIN',\n  'CROSS JOIN',\n  'NATURAL JOIN',\n  // non-standard joins\n  'STRAIGHT_JOIN',\n  'NATURAL LEFT JOIN',\n  'NATURAL LEFT OUTER JOIN',\n  'NATURAL RIGHT JOIN',\n  'NATURAL RIGHT OUTER JOIN',\n];\n\n/**\n * Priority 3\n * keywords that follow a previous Statement, must be attached to subsequent data\n * can be fully inline or on newline with optional indent\n */\nconst reservedDependentClauses = ['WHEN', 'ELSE', 'ELSEIF'];\n\n// https://dev.mysql.com/doc/refman/8.0/en/\nexport default class MySqlFormatter extends Formatter {\n  static reservedCommands = reservedCommands;\n  static reservedBinaryCommands = reservedBinaryCommands;\n  static reservedDependentClauses = reservedDependentClauses;\n  static reservedJoinConditions = ['ON', 'USING'];\n  static reservedLogicalOperators = ['AND', 'OR', 'XOR'];\n  static reservedKeywords = dedupe([...reservedKeywords, ...reservedFunctions]);\n  static stringTypes: StringPatternType[] = ['``', \"''\", '\"\"'];\n  static blockStart = ['(', 'CASE'];\n  static blockEnd = [')', 'END'];\n  static indexedPlaceholderTypes = ['?'];\n  static namedPlaceholderTypes = [];\n  static lineCommentTypes = ['--', '#'];\n  static specialWordChars = { prefix: '@:' };\n  static operators = [':=', '<<', '>>', '<=>', '&&', '||', '->', '->>'];\n\n  tokenizer() {\n    return new Tokenizer({\n      reservedCommands: MySqlFormatter.reservedCommands,\n      reservedBinaryCommands: MySqlFormatter.reservedBinaryCommands,\n      reservedDependentClauses: MySqlFormatter.reservedDependentClauses,\n      reservedJoinConditions: MySqlFormatter.reservedJoinConditions,\n      reservedLogicalOperators: MySqlFormatter.reservedLogicalOperators,\n      reservedKeywords: MySqlFormatter.reservedKeywords,\n      stringTypes: MySqlFormatter.stringTypes,\n      blockStart: MySqlFormatter.blockStart,\n      blockEnd: MySqlFormatter.blockEnd,\n      indexedPlaceholderTypes: MySqlFormatter.indexedPlaceholderTypes,\n      namedPlaceholderTypes: MySqlFormatter.namedPlaceholderTypes,\n      lineCommentTypes: MySqlFormatter.lineCommentTypes,\n      specialWordChars: MySqlFormatter.specialWordChars,\n      operators: MySqlFormatter.operators,\n    });\n  }\n\n  tokenOverride(token: Token) {\n    // [SET] ( ...\n    if (isToken.SET(token) && this.tokenLookAhead().value === '(') {\n      // This is SET datatype, not SET statement\n      return { type: TokenType.RESERVED_KEYWORD, value: token.value };\n    }\n\n    return token;\n  }\n}\n","import Formatter from '../core/Formatter';\nimport Tokenizer from '../core/Tokenizer';\nimport type { StringPatternType } from '../core/regexFactory';\nimport { dedupe } from '../utils';\n\n// TODO: split this into object with function categories\n/**\n * Priority 5 (last)\n * Full list of reserved functions\n * distinct from Keywords due to interaction with parentheses\n */\n// https://docs.couchbase.com/server/current/n1ql/n1ql-language-reference/functions.html\nconst reservedFunctions = [\n  'ABORT',\n  'ABS',\n  'ACOS',\n  'ADVISOR',\n  'ARRAY_AGG',\n  'ARRAY_AGG',\n  'ARRAY_APPEND',\n  'ARRAY_AVG',\n  'ARRAY_BINARY_SEARCH',\n  'ARRAY_CONCAT',\n  'ARRAY_CONTAINS',\n  'ARRAY_COUNT',\n  'ARRAY_DISTINCT',\n  'ARRAY_EXCEPT',\n  'ARRAY_FLATTEN',\n  'ARRAY_IFNULL',\n  'ARRAY_INSERT',\n  'ARRAY_INTERSECT',\n  'ARRAY_LENGTH',\n  'ARRAY_MAX',\n  'ARRAY_MIN',\n  'ARRAY_MOVE',\n  'ARRAY_POSITION',\n  'ARRAY_PREPEND',\n  'ARRAY_PUT',\n  'ARRAY_RANGE',\n  'ARRAY_REMOVE',\n  'ARRAY_REPEAT',\n  'ARRAY_REPLACE',\n  'ARRAY_REVERSE',\n  'ARRAY_SORT',\n  'ARRAY_STAR',\n  'ARRAY_SUM',\n  'ARRAY_SYMDIFF',\n  'ARRAY_SYMDIFF1',\n  'ARRAY_SYMDIFFN',\n  'ARRAY_UNION',\n  'ASIN',\n  'ATAN',\n  'ATAN2',\n  'AVG',\n  'BASE64',\n  'BASE64_DECODE',\n  'BASE64_ENCODE',\n  'BITAND ',\n  'BITCLEAR ',\n  'BITNOT ',\n  'BITOR ',\n  'BITSET ',\n  'BITSHIFT ',\n  'BITTEST ',\n  'BITXOR ',\n  'CEIL',\n  'CLOCK_LOCAL',\n  'CLOCK_MILLIS',\n  'CLOCK_STR',\n  'CLOCK_TZ',\n  'CLOCK_UTC',\n  'COALESCE',\n  'CONCAT',\n  'CONCAT2',\n  'CONTAINS',\n  'CONTAINS_TOKEN',\n  'CONTAINS_TOKEN_LIKE',\n  'CONTAINS_TOKEN_REGEXP',\n  'COS',\n  'COUNT',\n  'COUNT',\n  'COUNTN',\n  'CUME_DIST',\n  'CURL',\n  'DATE_ADD_MILLIS',\n  'DATE_ADD_STR',\n  'DATE_DIFF_MILLIS',\n  'DATE_DIFF_STR',\n  'DATE_FORMAT_STR',\n  'DATE_PART_MILLIS',\n  'DATE_PART_STR',\n  'DATE_RANGE_MILLIS',\n  'DATE_RANGE_STR',\n  'DATE_TRUNC_MILLIS',\n  'DATE_TRUNC_STR',\n  'DECODE',\n  'DECODE_JSON',\n  'DEGREES',\n  'DENSE_RANK',\n  'DURATION_TO_STR',\n  // 'E',\n  'ENCODED_SIZE',\n  'ENCODE_JSON',\n  'EXP',\n  'FIRST_VALUE',\n  'FLOOR',\n  'GREATEST',\n  'HAS_TOKEN',\n  'IFINF',\n  'IFMISSING',\n  'IFMISSINGORNULL',\n  'IFNAN',\n  'IFNANORINF',\n  'IFNULL',\n  'INITCAP',\n  'ISARRAY',\n  'ISATOM',\n  'ISBITSET',\n  'ISBOOLEAN',\n  'ISNUMBER',\n  'ISOBJECT',\n  'ISSTRING',\n  'LAG',\n  'LAST_VALUE',\n  'LEAD',\n  'LEAST',\n  'LENGTH',\n  'LN',\n  'LOG',\n  'LOWER',\n  'LTRIM',\n  'MAX',\n  'MEAN',\n  'MEDIAN',\n  'META',\n  'MILLIS',\n  'MILLIS_TO_LOCAL',\n  'MILLIS_TO_STR',\n  'MILLIS_TO_TZ',\n  'MILLIS_TO_UTC',\n  'MILLIS_TO_ZONE_NAME',\n  'MIN',\n  'MISSINGIF',\n  'NANIF',\n  'NEGINFIF',\n  'NOW_LOCAL',\n  'NOW_MILLIS',\n  'NOW_STR',\n  'NOW_TZ',\n  'NOW_UTC',\n  'NTH_VALUE',\n  'NTILE',\n  'NULLIF',\n  'NVL',\n  'NVL2',\n  'OBJECT_ADD',\n  'OBJECT_CONCAT',\n  'OBJECT_INNER_PAIRS',\n  'OBJECT_INNER_VALUES',\n  'OBJECT_LENGTH',\n  'OBJECT_NAMES',\n  'OBJECT_PAIRS',\n  'OBJECT_PUT',\n  'OBJECT_REMOVE',\n  'OBJECT_RENAME',\n  'OBJECT_REPLACE',\n  'OBJECT_UNWRAP',\n  'OBJECT_VALUES',\n  'PAIRS',\n  'PERCENT_RANK',\n  'PI',\n  'POLY_LENGTH',\n  'POSINFIF',\n  'POSITION',\n  'POWER',\n  'RADIANS',\n  'RANDOM',\n  'RANK',\n  'RATIO_TO_REPORT',\n  'REGEXP_CONTAINS',\n  'REGEXP_LIKE',\n  'REGEXP_MATCHES',\n  'REGEXP_POSITION',\n  'REGEXP_REPLACE',\n  'REGEXP_SPLIT',\n  'REGEX_CONTAINS',\n  'REGEX_LIKE',\n  'REGEX_MATCHES',\n  'REGEX_POSITION',\n  'REGEX_REPLACE',\n  'REGEX_SPLIT',\n  'REPEAT',\n  'REPLACE',\n  'REVERSE',\n  'ROUND',\n  'ROW_NUMBER',\n  'RTRIM',\n  'SEARCH',\n  'SEARCH_META',\n  'SEARCH_SCORE',\n  'SIGN',\n  'SIN',\n  'SPLIT',\n  'SQRT',\n  'STDDEV',\n  'STDDEV_POP',\n  'STDDEV_SAMP',\n  'STR_TO_DURATION',\n  'STR_TO_MILLIS',\n  'STR_TO_TZ',\n  'STR_TO_UTC',\n  'STR_TO_ZONE_NAME',\n  'SUBSTR',\n  'SUFFIXES',\n  'SUM',\n  'TAN',\n  'TITLE',\n  'TOARRAY',\n  'TOATOM',\n  'TOBOOLEAN',\n  'TOKENS',\n  'TOKENS',\n  'TONUMBER',\n  'TOOBJECT',\n  'TOSTRING',\n  'TRIM',\n  'TRUNC',\n  // 'TYPE', // disabled\n  'UPPER',\n  'UUID',\n  'VARIANCE',\n  'VARIANCE_POP',\n  'VARIANCE_SAMP',\n  'VAR_POP',\n  'VAR_SAMP',\n  'WEEKDAY_MILLIS',\n  'WEEKDAY_STR',\n];\n\n/**\n * Priority 5 (last)\n * Full list of reserved words\n * any words that are in a higher priority are removed\n */\n// https://docs.couchbase.com/server/current/n1ql/n1ql-language-reference/reservedwords.html\nconst reservedKeywords = [\n  'ALL',\n  'ALTER',\n  'ANALYZE',\n  'ANY',\n  'ARRAY',\n  'AS',\n  'ASC',\n  'AT',\n  'BEGIN',\n  'BETWEEN',\n  'BINARY',\n  'BOOLEAN',\n  'BREAK',\n  'BUCKET',\n  'BUILD',\n  'BY',\n  'CALL',\n  'CAST',\n  'CHAR', // verify\n  'CLUSTER',\n  'COLLATE',\n  'COLLECTION',\n  'COMMIT',\n  'COMMITTED',\n  'CONNECT',\n  'CONTINUE',\n  'CORRELATE',\n  'CORRELATED',\n  'COVER',\n  'CREATE',\n  'CURRENT',\n  'DATABASE',\n  'DATASET',\n  'DATASTORE',\n  'DECLARE',\n  'DECREMENT',\n  'DERIVED',\n  'DESC',\n  'DESCRIBE',\n  'DISTINCT',\n  'DO',\n  'DROP',\n  'EACH',\n  'ELEMENT',\n  'EVERY',\n  'EXCLUDE',\n  'EXISTS',\n  'FALSE',\n  'FETCH',\n  'FILTER',\n  'FIRST',\n  'FLATTEN',\n  'FLUSH',\n  'FOLLOWING',\n  'FOR',\n  'FORCE',\n  'FTS',\n  'FUNCTION',\n  'GOLANG',\n  'GROUP',\n  'GROUPS',\n  'GSI',\n  'HASH',\n  'IF',\n  'IGNORE',\n  'ILIKE',\n  'IN',\n  'INCLUDE',\n  'INCREMENT',\n  'INDEX',\n  'INLINE',\n  'INNER',\n  'INTO',\n  'IS',\n  'ISOLATION',\n  'JAVASCRIPT',\n  'KEY',\n  'KEYS',\n  'KEYSPACE',\n  'KNOWN',\n  'LANGUAGE',\n  'LAST',\n  'LEFT',\n  'LETTING',\n  'LEVEL',\n  'LIKE',\n  'LSM',\n  'MAP',\n  'MAPPING',\n  'MATCHED',\n  'MATERIALIZED',\n  'MISSING',\n  'NAMESPACE',\n  'NL',\n  'NO',\n  'NOT',\n  'NULL',\n  'NULLS',\n  'NUMBER',\n  'OBJECT',\n  'OFFSET',\n  'OPTION',\n  'OPTIONS',\n  'ORDER',\n  'OTHERS',\n  'OUTER',\n  'OVER',\n  'PARSE',\n  'PARTITION',\n  'PASSWORD',\n  'PATH',\n  'POOL',\n  'PRECEDING',\n  'PRIMARY',\n  'PRIVATE',\n  'PRIVILEGE',\n  'PROBE',\n  'PROCEDURE',\n  'PUBLIC',\n  'RANGE',\n  'RAW',\n  'REALM',\n  'REDUCE',\n  'RENAME',\n  'RESPECT',\n  'RETURN',\n  'RIGHT',\n  'ROLE',\n  'ROLLBACK',\n  'ROW',\n  'ROWS',\n  'SATISFIES',\n  'SCHEMA',\n  'SCOPE',\n  'SELF',\n  'SEMI',\n  'SOME',\n  'START',\n  'STATISTICS',\n  'STRING',\n  'SYSTEM',\n  'THEN',\n  'TIES',\n  'TO',\n  'TRAN',\n  'TRANSACTION',\n  'TRIGGER',\n  'TRUE',\n  'TRUNCATE',\n  'UNBOUNDED',\n  'UNDER',\n  'UNIQUE',\n  'UNKNOWN',\n  'UNSET',\n  'USE',\n  'USER',\n  'VALIDATE',\n  'VALUE',\n  'VALUED',\n  'VIA',\n  'VIEW',\n  'WHILE',\n  'WINDOW',\n  'WITHIN',\n  'WORK',\n];\n\n/**\n * Priority 1 (first)\n * keywords that begin a new statement\n * will begin new indented block\n */\n// https://docs.couchbase.com/server/current/n1ql/n1ql-language-reference/reservedwords.html\nconst reservedCommands = [\n  'ADVISE',\n  'ALTER INDEX',\n  'BEGIN TRANSACTION',\n  'BUILD INDEX',\n  'COMMIT TRANSACTION',\n  'CREATE COLLECTION',\n  'CREATE FUNCTION',\n  'CREATE INDEX',\n  'CREATE PRIMARY INDEX',\n  'CREATE SCOPE',\n  'CREATE TABLE', // verify\n  'DELETE',\n  'DROP COLLECTION',\n  'DROP FUNCTION',\n  'DROP INDEX',\n  'DROP PRIMARY INDEX',\n  'DROP SCOPE',\n  'EXECUTE',\n  'EXECUTE FUNCTION',\n  'EXPLAIN',\n  'GRANT',\n  'INFER',\n  'INSERT',\n  'MERGE',\n  'PREPARE',\n  'RETURNING',\n  'REVOKE',\n  'ROLLBACK TRANSACTION',\n  'SAVEPOINT',\n  'SELECT',\n  'SET TRANSACTION',\n  'UPDATE',\n  'UPDATE STATISTICS',\n  'UPSERT',\n  // other\n  'DROP TABLE', // verify,\n  'FROM',\n  'GROUP BY',\n  'HAVING',\n  'INSERT INTO',\n  'LET',\n  'LIMIT',\n  'OFFSET',\n  'NEST',\n  'ORDER BY',\n  'SET CURRENT SCHEMA',\n  'SET SCHEMA',\n  'SET',\n  'SHOW',\n  'UNNEST',\n  'USE KEYS',\n  'VALUES',\n  'WHERE',\n  'WITH',\n];\n\n/**\n * Priority 2\n * commands that operate on two tables or subqueries\n * two main categories: joins and boolean set operators\n */\nconst reservedBinaryCommands = [\n  // set booleans\n  'INTERSECT',\n  'INTERSECT ALL',\n  'INTERSECT DISTINCT',\n  'UNION',\n  'UNION ALL',\n  'UNION DISTINCT',\n  'EXCEPT',\n  'EXCEPT ALL',\n  'EXCEPT DISTINCT',\n  'MINUS',\n  'MINUS ALL',\n  'MINUS DISTINCT',\n  // joins\n  'JOIN',\n  'INNER JOIN',\n  'LEFT JOIN',\n  'LEFT OUTER JOIN',\n  'RIGHT JOIN',\n  'RIGHT OUTER JOIN',\n];\n\n/**\n * Priority 3\n * keywords that follow a previous Statement, must be attached to subsequent data\n * can be fully inline or on newline with optional indent\n */\nconst reservedDependentClauses = ['WHEN', 'ELSE'];\n\n// For reference: http://docs.couchbase.com.s3-website-us-west-1.amazonaws.com/server/6.0/n1ql/n1ql-language-reference/index.html\nexport default class N1qlFormatter extends Formatter {\n  static reservedCommands = reservedCommands;\n  static reservedBinaryCommands = reservedBinaryCommands;\n  static reservedDependentClauses = reservedDependentClauses;\n  static reservedJoinConditions = ['ON', 'USING'];\n  static reservedLogicalOperators = ['AND', 'OR', 'XOR'];\n  static reservedKeywords = dedupe([...reservedKeywords, ...reservedFunctions]);\n  static stringTypes: StringPatternType[] = [`\"\"`, \"''\", '``'];\n  static blockStart = ['(', '[', '{', 'CASE'];\n  static blockEnd = [')', ']', '}', 'END'];\n  static namedPlaceholderTypes = ['$'];\n  static lineCommentTypes = ['#', '--'];\n  static operators = ['=='];\n\n  tokenizer() {\n    return new Tokenizer({\n      reservedCommands: N1qlFormatter.reservedCommands,\n      reservedBinaryCommands: N1qlFormatter.reservedBinaryCommands,\n      reservedDependentClauses: N1qlFormatter.reservedDependentClauses,\n      reservedJoinConditions: N1qlFormatter.reservedJoinConditions,\n      reservedLogicalOperators: N1qlFormatter.reservedLogicalOperators,\n      reservedKeywords: N1qlFormatter.reservedKeywords,\n      stringTypes: N1qlFormatter.stringTypes,\n      blockStart: N1qlFormatter.blockStart,\n      blockEnd: N1qlFormatter.blockEnd,\n      namedPlaceholderTypes: N1qlFormatter.namedPlaceholderTypes,\n      lineCommentTypes: N1qlFormatter.lineCommentTypes,\n      operators: N1qlFormatter.operators,\n    });\n  }\n}\n","import Formatter from '../core/Formatter';\nimport Tokenizer from '../core/Tokenizer';\nimport { isToken, Token, TokenType } from '../core/token'; // convert to partial type import in TS 4.5\nimport type { StringPatternType } from '../core/regexFactory';\nimport { dedupe } from '../utils';\n\n/**\n * Priority 5 (last)\n * Full list of reserved words\n * any words that are in a higher priority are removed\n */\nconst reservedKeywords = [\n  // 'A',\n  'ACCESSIBLE',\n  'AGENT',\n  'AGGREGATE',\n  'ALL',\n  'ALTER',\n  'ANY',\n  'ARRAY',\n  'AS',\n  'ASC',\n  'AT',\n  'ATTRIBUTE',\n  'AUTHID',\n  'AVG',\n  'BETWEEN',\n  'BFILE_BASE',\n  'BINARY',\n  'BINARY_INTEGER',\n  'BLOB_BASE',\n  'BLOCK',\n  'BODY',\n  'BOOLEAN',\n  'BOTH',\n  'BOUND',\n  'BREADTH',\n  'BULK',\n  'BY',\n  'BYTE',\n  // 'C',\n  'CALL',\n  'CALLING',\n  'CASCADE',\n  'CAST',\n  'CHAR',\n  'CHARACTER',\n  'CHARSET',\n  'CHARSETFORM',\n  'CHARSETID',\n  'CHAR_BASE',\n  'CHECK',\n  'CLOB_BASE',\n  'CLONE',\n  'CLOSE',\n  'CLUSTER',\n  'CLUSTERS',\n  'COALESCE',\n  'COLAUTH',\n  'COLLECT',\n  'COLUMNS',\n  'COMMENT',\n  'COMMIT',\n  'COMMITTED',\n  'COMPILED',\n  'COMPRESS',\n  'CONNECT',\n  'CONSTANT',\n  'CONSTRUCTOR',\n  'CONTEXT',\n  'CONTINUE',\n  'CONVERT',\n  'COUNT',\n  'CRASH',\n  'CREATE',\n  'CREDENTIAL',\n  'CURRENT',\n  'CURRVAL',\n  'CURSOR',\n  'CUSTOMDATUM',\n  'DANGLING',\n  'DATA',\n  'DATE',\n  'DATE_BASE',\n  'DAY',\n  'DECIMAL',\n  'DEFAULT',\n  'DEFINE',\n  'DEPTH',\n  'DESC',\n  'DETERMINISTIC',\n  'DIRECTORY',\n  'DISTINCT',\n  'DO',\n  'DOUBLE',\n  'DROP',\n  'DURATION',\n  'ELEMENT',\n  'ELSIF',\n  'EMPTY',\n  'ESCAPE',\n  'EXCEPTIONS',\n  'EXCLUSIVE',\n  'EXECUTE',\n  'EXISTS',\n  'EXIT',\n  'EXTENDS',\n  'EXTERNAL',\n  'EXTRACT',\n  'FALSE',\n  'FETCH',\n  'FINAL',\n  'FIRST',\n  'FIXED',\n  'FLOAT',\n  'FOR',\n  'FORALL',\n  'FORCE',\n  'FUNCTION',\n  'GENERAL',\n  'GOTO',\n  'GRANT',\n  'GROUP',\n  'HASH',\n  'HEAP',\n  'HIDDEN',\n  'HOUR',\n  'IDENTIFIED',\n  'IF',\n  'IMMEDIATE',\n  'IN',\n  'INCLUDING',\n  'INDEX',\n  'INDEXES',\n  'INDICATOR',\n  'INDICES',\n  'INFINITE',\n  'INSTANTIABLE',\n  'INT',\n  'INTEGER',\n  'INTERFACE',\n  'INTERVAL',\n  'INTO',\n  'INVALIDATE',\n  'IS',\n  'ISOLATION',\n  'JAVA',\n  'LANGUAGE',\n  'LARGE',\n  'LEADING',\n  'LENGTH',\n  'LEVEL',\n  'LIBRARY',\n  'LIKE',\n  'LIKE2',\n  'LIKE4',\n  'LIKEC',\n  'LIMITED',\n  'LOCAL',\n  'LOCK',\n  'LONG',\n  'MAP',\n  'MAX',\n  'MAXLEN',\n  'MEMBER',\n  'MERGE',\n  'MIN',\n  'MINUTE',\n  'MLSLABEL',\n  'MOD',\n  'MODE',\n  'MONTH',\n  'MULTISET',\n  'NAME',\n  'NAN',\n  'NATIONAL',\n  'NATIVE',\n  'NATURAL',\n  'NATURALN',\n  'NCHAR',\n  'NEW',\n  'NEXTVAL',\n  'NOCOMPRESS',\n  'NOCOPY',\n  'NOT',\n  'NOWAIT',\n  'NULL',\n  'NULLIF',\n  'NUMBER',\n  'NUMBER_BASE',\n  'OBJECT',\n  'OCICOLL',\n  'OCIDATE',\n  'OCIDATETIME',\n  'OCIDURATION',\n  'OCIINTERVAL',\n  'OCILOBLOCATOR',\n  'OCINUMBER',\n  'OCIRAW',\n  'OCIREF',\n  'OCIREFCURSOR',\n  'OCIROWID',\n  'OCISTRING',\n  'OCITYPE',\n  'OF',\n  'OLD',\n  'ON DELETE',\n  'ON UPDATE',\n  'ONLY',\n  'OPAQUE',\n  'OPEN',\n  'OPERATOR',\n  'OPTION',\n  'ORACLE',\n  'ORADATA',\n  'ORDER',\n  'ORGANIZATION',\n  'ORLANY',\n  'ORLVARY',\n  'OTHERS',\n  'OUT',\n  'OVERLAPS',\n  'OVERRIDING',\n  'PACKAGE',\n  'PARALLEL_ENABLE',\n  'PARAMETER',\n  'PARAMETERS',\n  'PARENT',\n  'PARTITION',\n  'PASCAL',\n  'PCTFREE',\n  'PIPE',\n  'PIPELINED',\n  'PLS_INTEGER',\n  'PLUGGABLE',\n  'POSITIVE',\n  'POSITIVEN',\n  'PRAGMA',\n  'PRECISION',\n  'PRIOR',\n  'PRIVATE',\n  'PROCEDURE',\n  'PUBLIC',\n  'RAISE',\n  'RANGE',\n  'RAW',\n  'READ',\n  'REAL',\n  'RECORD',\n  'REF',\n  'REFERENCE',\n  'RELEASE',\n  'RELIES_ON',\n  'REM',\n  'REMAINDER',\n  'RENAME',\n  'RESOURCE',\n  'RESULT',\n  'RESULT_CACHE',\n  'RETURN',\n  'REVERSE',\n  'REVOKE',\n  'ROLLBACK',\n  'ROW',\n  'ROWID',\n  'ROWNUM',\n  'ROWTYPE',\n  'SAMPLE',\n  'SAVE',\n  'SAVEPOINT',\n  'SB1',\n  'SB2',\n  'SB4',\n  'SEARCH',\n  'SECOND',\n  'SEGMENT',\n  'SELF',\n  'SEPARATE',\n  'SEQUENCE',\n  'SERIALIZABLE',\n  'SHARE',\n  'SHORT',\n  'SIZE',\n  'SIZE_T',\n  'SMALLINT',\n  'SOME',\n  'SPACE',\n  'SPARSE',\n  'SQL',\n  'SQLCODE',\n  'SQLDATA',\n  'SQLERRM',\n  'SQLNAME',\n  'SQLSTATE',\n  'STANDARD',\n  'START',\n  'STATIC',\n  'STDDEV',\n  'STORED',\n  'STRING',\n  'STRUCT',\n  'STYLE',\n  'SUBMULTISET',\n  'SUBPARTITION',\n  'SUBSTITUTABLE',\n  'SUBTYPE',\n  'SUCCESSFUL',\n  'SUM',\n  'SYNONYM',\n  'SYSDATE',\n  'TABAUTH',\n  'TABLE',\n  'TDO',\n  'THE',\n  'THEN',\n  'TIME',\n  'TIMESTAMP',\n  'TIMEZONE_ABBR',\n  'TIMEZONE_HOUR',\n  'TIMEZONE_MINUTE',\n  'TIMEZONE_REGION',\n  'TO',\n  'TRAILING',\n  'TRANSACTION',\n  'TRANSACTIONAL',\n  'TRIGGER',\n  'TRUE',\n  'TRUSTED',\n  'TYPE',\n  'UB1',\n  'UB2',\n  'UB4',\n  'UID',\n  'UNDER',\n  'UNIQUE',\n  'UNPLUG',\n  'UNSIGNED',\n  'UNTRUSTED',\n  'USE',\n  'USER',\n  'VALIDATE',\n  'VALIST',\n  'VALUE',\n  'VARCHAR',\n  'VARCHAR2',\n  'VARIABLE',\n  'VARIANCE',\n  'VARRAY',\n  'VARYING',\n  'VIEW',\n  'VIEWS',\n  'VOID',\n  'WHENEVER',\n  'WHILE',\n  'WORK',\n  'WRAPPED',\n  'WRITE',\n  'YEAR',\n  'ZONE',\n];\n\n/**\n * Priority 1 (first)\n * keywords that begin a new statement\n * will begin new indented block\n */\nconst reservedCommands = [\n  'ADD',\n  'ALTER COLUMN',\n  'ALTER TABLE',\n  'BEGIN',\n  'CONNECT BY',\n  'CREATE TABLE', // verify\n  'DROP TABLE', // verify\n  'DECLARE',\n  // 'DELETE FROM', // disabled\n  'DELETE',\n  'END',\n  'EXCEPT',\n  'EXCEPTION',\n  'FETCH FIRST',\n  'FROM',\n  'GROUP BY',\n  'HAVING',\n  'INSERT INTO',\n  'INSERT',\n  'LIMIT',\n  'OFFSET',\n  'LOOP',\n  'MODIFY',\n  'ORDER BY',\n  'RETURNING',\n  'SELECT',\n  'SET CURRENT SCHEMA',\n  'SET SCHEMA',\n  'SET',\n  'START WITH',\n  'UPDATE',\n  'VALUES',\n  'WHERE',\n  'WITH',\n];\n\n/**\n * Priority 2\n * commands that operate on two tables or subqueries\n * two main categories: joins and boolean set operators\n */\nconst reservedBinaryCommands = [\n  // set booleans\n  'INTERSECT',\n  'INTERSECT ALL',\n  'INTERSECT DISTINCT',\n  'UNION',\n  'UNION ALL',\n  'UNION DISTINCT',\n  'EXCEPT',\n  'EXCEPT ALL',\n  'EXCEPT DISTINCT',\n  'MINUS',\n  'MINUS ALL',\n  'MINUS DISTINCT',\n  // joins\n  'JOIN',\n  'INNER JOIN',\n  'LEFT JOIN',\n  'LEFT OUTER JOIN',\n  'RIGHT JOIN',\n  'RIGHT OUTER JOIN',\n  'FULL JOIN',\n  'FULL OUTER JOIN',\n  'CROSS JOIN',\n  'NATURAL JOIN',\n  // apply\n  'CROSS APPLY',\n  'OUTER APPLY',\n];\n\n/**\n * Priority 3\n * keywords that follow a previous Statement, must be attached to subsequent data\n * can be fully inline or on newline with optional indent\n */\nconst reservedDependentClauses = ['WHEN', 'ELSE'];\n\nexport default class PlSqlFormatter extends Formatter {\n  static reservedCommands = reservedCommands;\n  static reservedBinaryCommands = reservedBinaryCommands;\n  static reservedDependentClauses = reservedDependentClauses;\n  static reservedJoinConditions = ['ON', 'USING'];\n  static reservedLogicalOperators = ['AND', 'OR', 'XOR'];\n  static reservedKeywords = dedupe(reservedKeywords);\n  static stringTypes: StringPatternType[] = [`\"\"`, \"N''\", \"''\", '``'];\n  static blockStart = ['(', 'CASE'];\n  static blockEnd = [')', 'END'];\n  static indexedPlaceholderTypes = ['?'];\n  static namedPlaceholderTypes = [':'];\n  static lineCommentTypes = ['--'];\n  static specialWordChars = { any: '_$#.@' };\n  static operators = [\n    '||',\n    '**',\n    ':=',\n    '~=',\n    '^=',\n    '>>',\n    '<<',\n    '=>',\n    //  '..' // breaks operator test, handled by .\n  ];\n\n  tokenizer() {\n    return new Tokenizer({\n      reservedCommands: PlSqlFormatter.reservedCommands,\n      reservedBinaryCommands: PlSqlFormatter.reservedBinaryCommands,\n      reservedDependentClauses: PlSqlFormatter.reservedDependentClauses,\n      reservedJoinConditions: PlSqlFormatter.reservedJoinConditions,\n      reservedLogicalOperators: PlSqlFormatter.reservedLogicalOperators,\n      reservedKeywords: PlSqlFormatter.reservedKeywords,\n      stringTypes: PlSqlFormatter.stringTypes,\n      blockStart: PlSqlFormatter.blockStart,\n      blockEnd: PlSqlFormatter.blockEnd,\n      indexedPlaceholderTypes: PlSqlFormatter.indexedPlaceholderTypes,\n      namedPlaceholderTypes: PlSqlFormatter.namedPlaceholderTypes,\n      lineCommentTypes: PlSqlFormatter.lineCommentTypes,\n      specialWordChars: PlSqlFormatter.specialWordChars,\n      operators: PlSqlFormatter.operators,\n    });\n  }\n\n  tokenOverride(token: Token) {\n    // `table`[.]`column`\n    if (\n      token.value === '.' &&\n      this.tokenLookAhead().value.startsWith('`') &&\n      this.tokenLookBehind().value.endsWith('`')\n    ) {\n      // This is an operator, do not insert spaces\n      return { type: TokenType.OPERATOR, value: token.value };\n    }\n\n    // BY [SET]\n    if (isToken.SET(token) && isToken.BY(this.getPreviousReservedToken())) {\n      return { type: TokenType.RESERVED_KEYWORD, value: token.value };\n    }\n\n    return token;\n  }\n}\n","import Formatter from '../core/Formatter';\nimport Tokenizer from '../core/Tokenizer';\nimport type { StringPatternType } from '../core/regexFactory';\nimport { dedupe } from '../utils';\n\n/**\n * Priority 5 (last)\n * Full list of reserved functions\n * distinct from Keywords due to interaction with parentheses\n */\n// https://www.postgresql.org/docs/14/functions.html\nconst reservedFunctions = {\n  // https://www.postgresql.org/docs/14/functions-math.html\n  math: [\n    'ABS',\n    'ACOS',\n    'ACOSD',\n    'ACOSH',\n    'ASIN',\n    'ASIND',\n    'ASINH',\n    'ATAN',\n    'ATAN2',\n    'ATAN2D',\n    'ATAND',\n    'ATANH',\n    'CBRT',\n    'CEIL',\n    'CEILING',\n    'COS',\n    'COSD',\n    'COSH',\n    'COT',\n    'COTD',\n    'DEGREES',\n    'DIV',\n    'EXP',\n    'FACTORIAL',\n    'FLOOR',\n    'GCD',\n    'LCM',\n    'LN',\n    'LOG',\n    'LOG10',\n    'MIN_SCALE',\n    'MOD',\n    'PI',\n    'POWER',\n    'RADIANS',\n    'RANDOM',\n    'ROUND',\n    'SCALE',\n    'SETSEED',\n    'SIGN',\n    'SIN',\n    'SIND',\n    'SINH',\n    'SQRT',\n    'TAN',\n    'TAND',\n    'TANH',\n    'TRIM_SCALE',\n    'TRUNC',\n    'WIDTH_BUCKET',\n  ],\n  // https://www.postgresql.org/docs/14/functions-string.html\n  string: [\n    'ABS',\n    'ASCII',\n    'BIT_LENGTH',\n    'BTRIM',\n    'CHARACTER_LENGTH',\n    'CHAR_LENGTH',\n    'CHR',\n    'CONCAT',\n    'CONCAT_WS',\n    'FORMAT',\n    'INITCAP',\n    'LEFT',\n    'LENGTH',\n    'LOWER',\n    'LPAD',\n    'LTRIM',\n    'MD5',\n    'NORMALIZE',\n    'OCTET_LENGTH',\n    'OVERLAY',\n    'PARSE_IDENT',\n    'PG_CLIENT_ENCODING',\n    'POSITION',\n    'QUOTE_IDENT',\n    'QUOTE_LITERAL',\n    'QUOTE_NULLABLE',\n    'REGEXP_MATCH',\n    'REGEXP_MATCHES',\n    'REGEXP_REPLACE',\n    'REGEXP_SPLIT_TO_ARRAY',\n    'REGEXP_SPLIT_TO_TABLE',\n    'REPEAT',\n    'REPLACE',\n    'REVERSE',\n    'RIGHT',\n    'RPAD',\n    'RTRIM',\n    'SPLIT_PART',\n    'SPRINTF',\n    'STARTS_WITH',\n    'STRING_AGG',\n    'STRING_TO_ARRAY',\n    'STRING_TO_TABLE',\n    'STRPOS',\n    'SUBSTR',\n    'SUBSTRING',\n    'TO_ASCII',\n    'TO_HEX',\n    'TRANSLATE',\n    'TRIM',\n    'UNISTR',\n    'UPPER',\n  ],\n  // https://www.postgresql.org/docs/14/functions-binarystring.html\n  binary: [\n    'BIT_COUNT',\n    'BIT_LENGTH',\n    'BTRIM',\n    'CONVERT',\n    'CONVERT_FROM',\n    'CONVERT_TO',\n    'DECODE',\n    'ENCODE',\n    'GET_BIT',\n    'GET_BYTE',\n    'LENGTH',\n    'LTRIM',\n    'MD5',\n    'OCTET_LENGTH',\n    'OVERLAY',\n    'POSITION',\n    'RTRIM',\n    'SET_BIT',\n    'SET_BYTE',\n    'SHA224',\n    'SHA256',\n    'SHA384',\n    'SHA512',\n    'STRING_AGG',\n    'SUBSTR',\n    'SUBSTRING',\n    'TRIM',\n  ],\n  // https://www.postgresql.org/docs/14/functions-bitstring.html\n  bitstring: [\n    'BIT_COUNT',\n    'BIT_LENGTH',\n    'GET_BIT',\n    'LENGTH',\n    'OCTET_LENGTH',\n    'OVERLAY',\n    'POSITION',\n    'SET_BIT',\n    'SUBSTRING',\n  ],\n  // https://www.postgresql.org/docs/14/functions-matching.html\n  pattern: [\n    'REGEXP_MATCH',\n    'REGEXP_MATCHES',\n    'REGEXP_REPLACE',\n    'REGEXP_SPLIT_TO_ARRAY',\n    'REGEXP_SPLIT_TO_TABLE',\n  ],\n  // https://www.postgresql.org/docs/14/functions-formatting.html\n  datatype: ['TO_CHAR', 'TO_DATE', 'TO_NUMBER', 'TO_TIMESTAMP'],\n  // https://www.postgresql.org/docs/14/functions-datetime.html\n  datetime: [\n    // 'AGE',\n    'CLOCK_TIMESTAMP',\n    'CURRENT_DATE',\n    'CURRENT_TIME',\n    'CURRENT_TIMESTAMP',\n    'DATE_BIN',\n    'DATE_PART',\n    'DATE_TRUNC',\n    'EXTRACT',\n    'ISFINITE',\n    'JUSTIFY_DAYS',\n    'JUSTIFY_HOURS',\n    'JUSTIFY_INTERVAL',\n    'LOCALTIME',\n    'LOCALTIMESTAMP',\n    'MAKE_DATE',\n    'MAKE_INTERVAL',\n    'MAKE_TIME',\n    'MAKE_TIMESTAMP',\n    'MAKE_TIMESTAMPTZ',\n    'NOW',\n    'PG_SLEEP',\n    'PG_SLEEP_FOR',\n    'PG_SLEEP_UNTIL',\n    'STATEMENT_TIMESTAMP',\n    'TIMEOFDAY',\n    'TO_TIMESTAMP',\n    'TRANSACTION_TIMESTAMP',\n  ],\n  // https://www.postgresql.org/docs/14/functions-enum.html\n  enum: ['ENUM_FIRST', 'ENUM_LAST', 'ENUM_RANGE'],\n  // https://www.postgresql.org/docs/14/functions-geometry.html\n  geometry: [\n    'AREA',\n    'BOUND_BOX',\n    'BOX',\n    'CENTER',\n    'CIRCLE',\n    'DIAGONAL',\n    'DIAMETER',\n    'HEIGHT',\n    'ISCLOSED',\n    'ISOPEN',\n    'LENGTH',\n    'LINE',\n    'LSEG',\n    'NPOINTS',\n    'PATH',\n    'PCLOSE',\n    'POINT',\n    'POLYGON',\n    'POPEN',\n    'RADIUS',\n    'SLOPE',\n    'WIDTH',\n  ],\n  // https://www.postgresql.org/docs/14/functions-net.html\n  network: [\n    'ABBREV',\n    'BROADCAST',\n    'FAMILY',\n    'HOST',\n    'HOSTMASK',\n    'INET_MERGE',\n    'INET_SAME_FAMILY',\n    'MACADDR8_SET7BIT',\n    'MASKLEN',\n    'NETMASK',\n    'NETWORK',\n    'SET_MASKLEN',\n    'TEXT',\n    'TRUNC',\n  ],\n  // https://www.postgresql.org/docs/14/functions-textsearch.html\n  textsearch: [\n    'ARRAY_TO_TSVECTOR',\n    'GET_CURRENT_TS_CONFIG',\n    'JSONB_TO_TSVECTOR',\n    'JSON_TO_TSVECTOR',\n    'LENGTH',\n    'NUMNODE',\n    'PHRASETO_TSQUERY',\n    'PLAINTO_TSQUERY',\n    'QUERYTREE',\n    'SETWEIGHT',\n    'STRIP',\n    'TO_TSQUERY',\n    'TO_TSVECTOR',\n    'TSQUERY_PHRASE',\n    'TSVECTOR_TO_ARRAY',\n    'TS_DEBUG',\n    'TS_DELETE',\n    'TS_FILTER',\n    'TS_HEADLINE',\n    'TS_LEXIZE',\n    'TS_PARSE',\n    'TS_RANK',\n    'TS_RANK_CD',\n    'TS_REWRITE',\n    'TS_STAT',\n    'TS_TOKEN_TYPE',\n    'WEBSEARCH_TO_TSQUERY',\n  ],\n  // https://www.postgresql.org/docs/14/functions-uuid.html\n  uuid: ['UUID'],\n  // https://www.postgresql.org/docs/14/functions-xml.html\n  xml: [\n    'CURSOR_TO_XML',\n    'CURSOR_TO_XMLSCHEMA',\n    'DATABASE_TO_XML',\n    'DATABASE_TO_XMLSCHEMA',\n    'DATABASE_TO_XML_AND_XMLSCHEMA',\n    'NEXTVAL',\n    'QUERY_TO_XML',\n    'QUERY_TO_XMLSCHEMA',\n    'QUERY_TO_XML_AND_XMLSCHEMA',\n    'SCHEMA_TO_XML',\n    'SCHEMA_TO_XMLSCHEMA',\n    'SCHEMA_TO_XML_AND_XMLSCHEMA',\n    'STRING',\n    'TABLE_TO_XML',\n    'TABLE_TO_XMLSCHEMA',\n    'TABLE_TO_XML_AND_XMLSCHEMA',\n    'XMLAGG',\n    'XMLCOMMENT',\n    'XMLCONCAT',\n    'XMLELEMENT',\n    'XMLEXISTS',\n    'XMLFOREST',\n    'XMLPARSE',\n    'XMLPI',\n    'XMLROOT',\n    'XMLSERIALIZE',\n    'XMLTABLE',\n    'XML_IS_WELL_FORMED',\n    'XML_IS_WELL_FORMED_CONTENT',\n    'XML_IS_WELL_FORMED_DOCUMENT',\n    'XPATH',\n    'XPATH_EXISTS',\n  ],\n  // https://www.postgresql.org/docs/14/functions-json.html\n  json: [\n    'ARRAY_TO_JSON',\n    'JSONB_AGG',\n    'JSONB_ARRAY_ELEMENTS',\n    'JSONB_ARRAY_ELEMENTS_TEXT',\n    'JSONB_ARRAY_LENGTH',\n    'JSONB_BUILD_ARRAY',\n    'JSONB_BUILD_OBJECT',\n    'JSONB_EACH',\n    'JSONB_EACH_TEXT',\n    'JSONB_EXTRACT_PATH',\n    'JSONB_EXTRACT_PATH_TEXT',\n    'JSONB_INSERT',\n    'JSONB_OBJECT',\n    'JSONB_OBJECT_AGG',\n    'JSONB_OBJECT_KEYS',\n    'JSONB_PATH_EXISTS',\n    'JSONB_PATH_EXISTS_TZ',\n    'JSONB_PATH_MATCH',\n    'JSONB_PATH_MATCH_TZ',\n    'JSONB_PATH_QUERY',\n    'JSONB_PATH_QUERY_ARRAY',\n    'JSONB_PATH_QUERY_ARRAY_TZ',\n    'JSONB_PATH_QUERY_FIRST',\n    'JSONB_PATH_QUERY_FIRST_TZ',\n    'JSONB_PATH_QUERY_TZ',\n    'JSONB_POPULATE_RECORD',\n    'JSONB_POPULATE_RECORDSET',\n    'JSONB_PRETTY',\n    'JSONB_SET',\n    'JSONB_SET_LAX',\n    'JSONB_STRIP_NULLS',\n    'JSONB_TO_RECORD',\n    'JSONB_TO_RECORDSET',\n    'JSONB_TYPEOF',\n    'JSON_AGG',\n    'JSON_ARRAY_ELEMENTS',\n    'JSON_ARRAY_ELEMENTS_TEXT',\n    'JSON_ARRAY_LENGTH',\n    'JSON_BUILD_ARRAY',\n    'JSON_BUILD_OBJECT',\n    'JSON_EACH',\n    'JSON_EACH_TEXT',\n    'JSON_EXTRACT_PATH',\n    'JSON_EXTRACT_PATH_TEXT',\n    'JSON_OBJECT',\n    'JSON_OBJECT_AGG',\n    'JSON_OBJECT_KEYS',\n    'JSON_POPULATE_RECORD',\n    'JSON_POPULATE_RECORDSET',\n    'JSON_STRIP_NULLS',\n    'JSON_TO_RECORD',\n    'JSON_TO_RECORDSET',\n    'JSON_TYPEOF',\n    'ROW_TO_JSON',\n    'TO_JSON',\n    'TO_JSONB',\n    'TO_TIMESTAMP',\n  ],\n  // https://www.postgresql.org/docs/14/functions-sequence.html\n  sequence: ['CURRVAL', 'LASTVAL', 'NEXTVAL', 'SETVAL'],\n  // https://www.postgresql.org/docs/14/functions-conditional.html\n  conditional: [\n    // 'CASE',\n    'COALESCE',\n    'GREATEST',\n    'LEAST',\n    'NULLIF',\n  ],\n  // https://www.postgresql.org/docs/14/functions-array.html\n  array: [\n    'ARRAY_AGG',\n    'ARRAY_APPEND',\n    'ARRAY_CAT',\n    'ARRAY_DIMS',\n    'ARRAY_FILL',\n    'ARRAY_LENGTH',\n    'ARRAY_LOWER',\n    'ARRAY_NDIMS',\n    'ARRAY_POSITION',\n    'ARRAY_POSITIONS',\n    'ARRAY_PREPEND',\n    'ARRAY_REMOVE',\n    'ARRAY_REPLACE',\n    'ARRAY_TO_STRING',\n    'ARRAY_UPPER',\n    'CARDINALITY',\n    'STRING_TO_ARRAY',\n    'TRIM_ARRAY',\n    'UNNEST',\n  ],\n  // https://www.postgresql.org/docs/14/functions-range.html\n  range: [\n    'ISEMPTY',\n    'LOWER',\n    'LOWER_INC',\n    'LOWER_INF',\n    'MULTIRANGE',\n    'RANGE_MERGE',\n    'UPPER',\n    'UPPER_INC',\n    'UPPER_INF',\n  ],\n  // https://www.postgresql.org/docs/14/functions-aggregate.html\n  aggregate: [\n    'ANY',\n    'ARRAY_AGG',\n    'AVG',\n    'BIT_AND',\n    'BIT_OR',\n    'BIT_XOR',\n    'BOOL_AND',\n    'BOOL_OR',\n    'COALESCE',\n    'CORR',\n    'COUNT',\n    'COVAR_POP',\n    'COVAR_SAMP',\n    'CUME_DIST',\n    'DENSE_RANK',\n    'EVERY',\n    'GROUPING',\n    'JSONB_AGG',\n    'JSONB_OBJECT_AGG',\n    'JSON_AGG',\n    'JSON_OBJECT_AGG',\n    'MAX',\n    'MIN',\n    'MODE',\n    'PERCENTILE_CONT',\n    'PERCENTILE_DISC',\n    'PERCENT_RANK',\n    'RANGE_AGG',\n    'RANGE_INTERSECT_AGG',\n    'RANK',\n    'REGR_AVGX',\n    'REGR_AVGY',\n    'REGR_COUNT',\n    'REGR_INTERCEPT',\n    'REGR_R2',\n    'REGR_SLOPE',\n    'REGR_SXX',\n    'REGR_SXY',\n    'REGR_SYY',\n    'SOME',\n    'STDDEV',\n    'STDDEV_POP',\n    'STDDEV_SAMP',\n    'STRING_AGG',\n    'SUM',\n    'TO_JSON',\n    'TO_JSONB',\n    'VARIANCE',\n    'VAR_POP',\n    'VAR_SAMP',\n    'XMLAGG',\n  ],\n  // https://www.postgresql.org/docs/14/functions-window.html\n  window: [\n    'CUME_DIST',\n    'DENSE_RANK',\n    'FIRST_VALUE',\n    'LAG',\n    'LAST_VALUE',\n    'LEAD',\n    'NTH_VALUE',\n    'NTILE',\n    'PERCENT_RANK',\n    'RANK',\n    'ROW_NUMBER',\n  ],\n  // https://www.postgresql.org/docs/14/functions-srf.html\n  set: ['GENERATE_SERIES', 'GENERATE_SUBSCRIPTS'],\n  // https://www.postgresql.org/docs/14/functions-info.html\n  sysInfo: [\n    'ACLDEFAULT',\n    'ACLEXPLODE',\n    'COL_DESCRIPTION',\n    'CURRENT_CATALOG',\n    'CURRENT_DATABASE',\n    'CURRENT_QUERY',\n    'CURRENT_ROLE',\n    'CURRENT_SCHEMA',\n    'CURRENT_SCHEMAS',\n    'CURRENT_USER',\n    'FORMAT_TYPE',\n    'HAS_ANY_COLUMN_PRIVILEGE',\n    'HAS_COLUMN_PRIVILEGE',\n    'HAS_DATABASE_PRIVILEGE',\n    'HAS_FOREIGN_DATA_WRAPPER_PRIVILEGE',\n    'HAS_FUNCTION_PRIVILEGE',\n    'HAS_LANGUAGE_PRIVILEGE',\n    'HAS_SCHEMA_PRIVILEGE',\n    'HAS_SEQUENCE_PRIVILEGE',\n    'HAS_SERVER_PRIVILEGE',\n    'HAS_TABLESPACE_PRIVILEGE',\n    'HAS_TABLE_PRIVILEGE',\n    'HAS_TYPE_PRIVILEGE',\n    'INET_CLIENT_ADDR',\n    'INET_CLIENT_PORT',\n    'INET_SERVER_ADDR',\n    'INET_SERVER_PORT',\n    'MAKEACLITEM',\n    'OBJ_DESCRIPTION',\n    'PG_BACKEND_PID',\n    'PG_BLOCKING_PIDS',\n    'PG_COLLATION_IS_VISIBLE',\n    'PG_CONF_LOAD_TIME',\n    'PG_CONTROL_CHECKPOINT',\n    'PG_CONTROL_INIT',\n    'PG_CONTROL_SYSTEM',\n    'PG_CONVERSION_IS_VISIBLE',\n    'PG_CURRENT_LOGFILE',\n    'PG_CURRENT_SNAPSHOT',\n    'PG_CURRENT_XACT_ID',\n    'PG_CURRENT_XACT_ID_IF_ASSIGNED',\n    'PG_DESCRIBE_OBJECT',\n    'PG_FUNCTION_IS_VISIBLE',\n    'PG_GET_CATALOG_FOREIGN_KEYS',\n    'PG_GET_CONSTRAINTDEF',\n    'PG_GET_EXPR',\n    'PG_GET_FUNCTIONDEF',\n    'PG_GET_FUNCTION_ARGUMENTS',\n    'PG_GET_FUNCTION_IDENTITY_ARGUMENTS',\n    'PG_GET_FUNCTION_RESULT',\n    'PG_GET_INDEXDEF',\n    'PG_GET_KEYWORDS',\n    'PG_GET_OBJECT_ADDRESS',\n    'PG_GET_OWNED_SEQUENCE',\n    'PG_GET_RULEDEF',\n    'PG_GET_SERIAL_SEQUENCE',\n    'PG_GET_STATISTICSOBJDEF',\n    'PG_GET_TRIGGERDEF',\n    'PG_GET_USERBYID',\n    'PG_GET_VIEWDEF',\n    'PG_HAS_ROLE',\n    'PG_IDENTIFY_OBJECT',\n    'PG_IDENTIFY_OBJECT_AS_ADDRESS',\n    'PG_INDEXAM_HAS_PROPERTY',\n    'PG_INDEX_COLUMN_HAS_PROPERTY',\n    'PG_INDEX_HAS_PROPERTY',\n    'PG_IS_OTHER_TEMP_SCHEMA',\n    'PG_JIT_AVAILABLE',\n    'PG_LAST_COMMITTED_XACT',\n    'PG_LISTENING_CHANNELS',\n    'PG_MY_TEMP_SCHEMA',\n    'PG_NOTIFICATION_QUEUE_USAGE',\n    'PG_OPCLASS_IS_VISIBLE',\n    'PG_OPERATOR_IS_VISIBLE',\n    'PG_OPFAMILY_IS_VISIBLE',\n    'PG_OPTIONS_TO_TABLE',\n    'PG_POSTMASTER_START_TIME',\n    'PG_SAFE_SNAPSHOT_BLOCKING_PIDS',\n    'PG_SNAPSHOT_XIP',\n    'PG_SNAPSHOT_XMAX',\n    'PG_SNAPSHOT_XMIN',\n    'PG_STATISTICS_OBJ_IS_VISIBLE',\n    'PG_TABLESPACE_DATABASES',\n    'PG_TABLESPACE_LOCATION',\n    'PG_TABLE_IS_VISIBLE',\n    'PG_TRIGGER_DEPTH',\n    'PG_TS_CONFIG_IS_VISIBLE',\n    'PG_TS_DICT_IS_VISIBLE',\n    'PG_TS_PARSER_IS_VISIBLE',\n    'PG_TS_TEMPLATE_IS_VISIBLE',\n    'PG_TYPEOF',\n    'PG_TYPE_IS_VISIBLE',\n    'PG_VISIBLE_IN_SNAPSHOT',\n    'PG_XACT_COMMIT_TIMESTAMP',\n    'PG_XACT_COMMIT_TIMESTAMP_ORIGIN',\n    'PG_XACT_STATUS',\n    'PQSERVERVERSION',\n    'ROW_SECURITY_ACTIVE',\n    'SESSION_USER',\n    'SHOBJ_DESCRIPTION',\n    'TO_REGCLASS',\n    'TO_REGCOLLATION',\n    'TO_REGNAMESPACE',\n    'TO_REGOPER',\n    'TO_REGOPERATOR',\n    'TO_REGPROC',\n    'TO_REGPROCEDURE',\n    'TO_REGROLE',\n    'TO_REGTYPE',\n    'TXID_CURRENT',\n    'TXID_CURRENT_IF_ASSIGNED',\n    'TXID_CURRENT_SNAPSHOT',\n    'TXID_SNAPSHOT_XIP',\n    'TXID_SNAPSHOT_XMAX',\n    'TXID_SNAPSHOT_XMIN',\n    'TXID_STATUS',\n    'TXID_VISIBLE_IN_SNAPSHOT',\n    'USER',\n    'VERSION',\n  ],\n  // https://www.postgresql.org/docs/14/functions-admin.html\n  sysAdmin: [\n    'BRIN_DESUMMARIZE_RANGE',\n    'BRIN_SUMMARIZE_NEW_VALUES',\n    'BRIN_SUMMARIZE_RANGE',\n    'CONVERT_FROM',\n    'CURRENT_SETTING',\n    'GIN_CLEAN_PENDING_LIST',\n    'PG_ADVISORY_LOCK',\n    'PG_ADVISORY_LOCK_SHARED',\n    'PG_ADVISORY_UNLOCK',\n    'PG_ADVISORY_UNLOCK_ALL',\n    'PG_ADVISORY_UNLOCK_SHARED',\n    'PG_ADVISORY_XACT_LOCK',\n    'PG_ADVISORY_XACT_LOCK_SHARED',\n    'PG_BACKUP_START_TIME',\n    'PG_CANCEL_BACKEND',\n    'PG_COLLATION_ACTUAL_VERSION',\n    'PG_COLUMN_COMPRESSION',\n    'PG_COLUMN_SIZE',\n    'PG_COPY_LOGICAL_REPLICATION_SLOT',\n    'PG_COPY_PHYSICAL_REPLICATION_SLOT',\n    'PG_CREATE_LOGICAL_REPLICATION_SLOT',\n    'PG_CREATE_PHYSICAL_REPLICATION_SLOT',\n    'PG_CREATE_RESTORE_POINT',\n    'PG_CURRENT_WAL_FLUSH_LSN',\n    'PG_CURRENT_WAL_INSERT_LSN',\n    'PG_CURRENT_WAL_LSN',\n    'PG_DATABASE_SIZE',\n    'PG_DROP_REPLICATION_SLOT',\n    'PG_EXPORT_SNAPSHOT',\n    'PG_FILENODE_RELATION',\n    'PG_GET_WAL_REPLAY_PAUSE_STATE',\n    'PG_IMPORT_SYSTEM_COLLATIONS',\n    'PG_INDEXES_SIZE',\n    'PG_IS_IN_BACKUP',\n    'PG_IS_IN_RECOVERY',\n    'PG_IS_WAL_REPLAY_PAUSED',\n    'PG_LAST_WAL_RECEIVE_LSN',\n    'PG_LAST_WAL_REPLAY_LSN',\n    'PG_LAST_XACT_REPLAY_TIMESTAMP',\n    'PG_LOGICAL_EMIT_MESSAGE',\n    'PG_LOGICAL_SLOT_GET_BINARY_CHANGES',\n    'PG_LOGICAL_SLOT_GET_CHANGES',\n    'PG_LOGICAL_SLOT_PEEK_BINARY_CHANGES',\n    'PG_LOGICAL_SLOT_PEEK_CHANGES',\n    'PG_LOG_BACKEND_MEMORY_CONTEXTS',\n    'PG_LS_ARCHIVE_STATUSDIR',\n    'PG_LS_DIR',\n    'PG_LS_LOGDIR',\n    'PG_LS_TMPDIR',\n    'PG_LS_WALDIR',\n    'PG_PARTITION_ANCESTORS',\n    'PG_PARTITION_ROOT',\n    'PG_PARTITION_TREE',\n    'PG_PROMOTE',\n    'PG_READ_BINARY_FILE',\n    'PG_READ_FILE',\n    'PG_RELATION_FILENODE',\n    'PG_RELATION_FILEPATH',\n    'PG_RELATION_SIZE',\n    'PG_RELOAD_CONF',\n    'PG_REPLICATION_ORIGIN_ADVANCE',\n    'PG_REPLICATION_ORIGIN_CREATE',\n    'PG_REPLICATION_ORIGIN_DROP',\n    'PG_REPLICATION_ORIGIN_OID',\n    'PG_REPLICATION_ORIGIN_PROGRESS',\n    'PG_REPLICATION_ORIGIN_SESSION_IS_SETUP',\n    'PG_REPLICATION_ORIGIN_SESSION_PROGRESS',\n    'PG_REPLICATION_ORIGIN_SESSION_RESET',\n    'PG_REPLICATION_ORIGIN_SESSION_SETUP',\n    'PG_REPLICATION_ORIGIN_XACT_RESET',\n    'PG_REPLICATION_ORIGIN_XACT_SETUP',\n    'PG_REPLICATION_SLOT_ADVANCE',\n    'PG_ROTATE_LOGFILE',\n    'PG_SIZE_BYTES',\n    'PG_SIZE_PRETTY',\n    'PG_START_BACKUP',\n    'PG_STAT_FILE',\n    'PG_STOP_BACKUP',\n    'PG_SWITCH_WAL',\n    'PG_TABLESPACE_SIZE',\n    'PG_TABLE_SIZE',\n    'PG_TERMINATE_BACKEND',\n    'PG_TOTAL_RELATION_SIZE',\n    'PG_TRY_ADVISORY_LOCK',\n    'PG_TRY_ADVISORY_LOCK_SHARED',\n    'PG_TRY_ADVISORY_XACT_LOCK',\n    'PG_TRY_ADVISORY_XACT_LOCK_SHARED',\n    'PG_WALFILE_NAME',\n    'PG_WALFILE_NAME_OFFSET',\n    'PG_WAL_LSN_DIFF',\n    'PG_WAL_REPLAY_PAUSE',\n    'PG_WAL_REPLAY_RESUME',\n    'SET_CONFIG',\n  ],\n  // https://www.postgresql.org/docs/14/functions-trigger.html\n  trigger: [\n    'SUPPRESS_REDUNDANT_UPDATES_TRIGGER',\n    'TSVECTOR_UPDATE_TRIGGER',\n    'TSVECTOR_UPDATE_TRIGGER_COLUMN',\n  ],\n  // https://www.postgresql.org/docs/14/functions-event-triggers.html\n  eventTrigger: [\n    'PG_EVENT_TRIGGER_DDL_COMMANDS',\n    'PG_EVENT_TRIGGER_DROPPED_OBJECTS',\n    'PG_EVENT_TRIGGER_TABLE_REWRITE_OID',\n    'PG_EVENT_TRIGGER_TABLE_REWRITE_REASON',\n    'PG_GET_OBJECT_ADDRESS',\n  ],\n  // https://www.postgresql.org/docs/14/functions-statistics.html\n  stats: ['PG_MCV_LIST_ITEMS'],\n};\n\n/**\n * Priority 5 (last)\n * Full list of reserved words\n * any words that are in a higher priority are removed\n */\n// https://www.postgresql.org/docs/14/sql-keywords-appendix.html\nconst reservedKeywords = [\n  'ABSENT',\n  'ABSOLUTE',\n  'ACCESS',\n  'ACCORDING',\n  'ACTION',\n  'ADA',\n  'ADMIN',\n  'AGGREGATE',\n  'ALL',\n  'ALLOCATE',\n  'ALSO',\n  'ALTER',\n  'ALWAYS',\n  'ANALYSE',\n  'ARE',\n  'ARRAY',\n  'ARRAY_MAX_CARDINALITY',\n  'AS',\n  'ASC',\n  'ASENSITIVE',\n  'ASSERTION',\n  'ASSIGNMENT',\n  'ASYMMETRIC',\n  'AT',\n  'ATOMIC',\n  'ATTACH',\n  'ATTRIBUTE',\n  'ATTRIBUTES',\n  'AUTHORIZATION',\n  'BACKWARD',\n  'BASE64',\n  'BEFORE',\n  'BEGIN_FRAME',\n  'BEGIN_PARTITION',\n  'BERNOULLI',\n  'BETWEEN',\n  'BIGINT',\n  'BINARY',\n  'BIT',\n  'BLOB',\n  'BLOCKED',\n  'BOM',\n  'BOOLEAN',\n  'BOTH',\n  'BREADTH',\n  'BY',\n  'CACHE',\n  'CALLED',\n  'CASCADE',\n  'CASCADED',\n  'CAST',\n  'CATALOG',\n  'CATALOG_NAME',\n  'CHAIN',\n  'CHAINING',\n  'CHAR',\n  'CHARACTER',\n  'CHARACTERISTICS',\n  'CHARACTERS',\n  'CHARACTER_SET_CATALOG',\n  'CHARACTER_SET_NAME',\n  'CHARACTER_SET_SCHEMA',\n  'CHECK',\n  'CLASS',\n  'CLASSIFIER',\n  'CLASS_ORIGIN',\n  'CLOB',\n  'COBOL',\n  'COLLATE',\n  'COLLATION',\n  'COLLATION_CATALOG',\n  'COLLATION_NAME',\n  'COLLATION_SCHEMA',\n  'COLLECT',\n  'COLUMN',\n  'COLUMNS',\n  'COLUMN_NAME',\n  'COMMAND_FUNCTION',\n  'COMMAND_FUNCTION_CODE',\n  'COMMENTS',\n  'COMMITTED',\n  'COMPRESSION',\n  'CONCURRENTLY',\n  'CONDITION',\n  'CONDITIONAL',\n  'CONDITION_NUMBER',\n  'CONFIGURATION',\n  'CONFLICT',\n  'CONNECT',\n  'CONNECTION',\n  'CONNECTION_NAME',\n  'CONSTRAINT',\n  'CONSTRAINTS',\n  'CONSTRAINT_CATALOG',\n  'CONSTRAINT_NAME',\n  'CONSTRAINT_SCHEMA',\n  'CONSTRUCTOR',\n  'CONTAINS',\n  'CONTENT',\n  'CONTINUE',\n  'CONTROL',\n  'CONVERSION',\n  'CORRESPONDING',\n  'COST',\n  'CREATE',\n  'CROSS',\n  'CSV',\n  'CUBE',\n  'CURRENT',\n  'CURRENT_DEFAULT_TRANSFORM_GROUP',\n  'CURRENT_PATH',\n  'CURRENT_ROW',\n  'CURRENT_TRANSFORM_GROUP_FOR_TYPE',\n  'CURSOR',\n  'CURSOR_NAME',\n  'CYCLE',\n  'DATA',\n  'DATABASE',\n  'DATALINK',\n  'DATE',\n  'DATETIME_INTERVAL_CODE',\n  'DATETIME_INTERVAL_PRECISION',\n  'DAY',\n  'DB',\n  'DEC',\n  'DECFLOAT',\n  'DECIMAL',\n  'DEFAULT',\n  'DEFAULTS',\n  'DEFERRABLE',\n  'DEFERRED',\n  'DEFINE',\n  'DEFINED',\n  'DEFINER',\n  'DEGREE',\n  'DELIMITER',\n  'DELIMITERS',\n  'DEPENDS',\n  'DEPTH',\n  'DEREF',\n  'DERIVED',\n  'DESC',\n  'DESCRIBE',\n  'DESCRIPTOR',\n  'DETACH',\n  'DETERMINISTIC',\n  'DIAGNOSTICS',\n  'DICTIONARY',\n  'DISABLE',\n  'DISCONNECT',\n  'DISPATCH',\n  'DISTINCT',\n  'DLNEWCOPY',\n  'DLPREVIOUSCOPY',\n  'DLURLCOMPLETE',\n  'DLURLCOMPLETEONLY',\n  'DLURLCOMPLETEWRITE',\n  'DLURLPATH',\n  'DLURLPATHONLY',\n  'DLURLPATHWRITE',\n  'DLURLSCHEME',\n  'DLURLSERVER',\n  'DLVALUE',\n  'DOCUMENT',\n  'DOMAIN',\n  'DOUBLE',\n  'DROP',\n  'DYNAMIC',\n  'DYNAMIC_FUNCTION',\n  'DYNAMIC_FUNCTION_CODE',\n  'EACH',\n  'ELEMENT',\n  'EMPTY',\n  'ENABLE',\n  'ENCODING',\n  'ENCRYPTED',\n  'END-EXEC',\n  'END_FRAME',\n  'END_PARTITION',\n  'ENFORCED',\n  'ENUM',\n  'EQUALS',\n  'ERROR',\n  'ESCAPE',\n  'EVENT',\n  'EXCEPTION',\n  'EXCLUDE',\n  'EXCLUDING',\n  'EXCLUSIVE',\n  'EXEC',\n  'EXISTS',\n  'EXPRESSION',\n  'EXTENSION',\n  'EXTERNAL',\n  'FALSE',\n  'FILE',\n  'FILTER',\n  'FINAL',\n  'FINALIZE',\n  'FINISH',\n  'FIRST',\n  'FLAG',\n  'FLOAT',\n  'FOLLOWING',\n  'FOR',\n  'FORCE',\n  'FOREIGN',\n  'FORTRAN',\n  'FORWARD',\n  'FOUND',\n  'FRAME_ROW',\n  'FREE',\n  'FREEZE',\n  'FS',\n  'FULFILL',\n  'FULL',\n  'FUNCTION',\n  'FUNCTIONS',\n  'FUSION',\n  'GENERAL',\n  'GENERATED',\n  'GET',\n  'GLOBAL',\n  'GO',\n  'GOTO',\n  'GRANTED',\n  'GROUP',\n  'GROUPS',\n  'HANDLER',\n  'HEADER',\n  'HEX',\n  'HIERARCHY',\n  'HOLD',\n  'HOUR',\n  // 'ID',\n  'IDENTITY',\n  'IF',\n  'IGNORE',\n  'ILIKE',\n  'IMMEDIATE',\n  'IMMEDIATELY',\n  'IMMUTABLE',\n  'IMPLEMENTATION',\n  'IMPLICIT',\n  'IMPORT',\n  'IN',\n  'INCLUDE',\n  'INCLUDING',\n  'INCREMENT',\n  'INDENT',\n  'INDEX',\n  'INDEXES',\n  'INDICATOR',\n  'INHERIT',\n  'INHERITS',\n  'INITIAL',\n  'INITIALLY',\n  'INLINE',\n  'INNER',\n  'INOUT',\n  'INPUT',\n  'INSENSITIVE',\n  'INSTANCE',\n  'INSTANTIABLE',\n  'INSTEAD',\n  'INT',\n  'INTEGER',\n  'INTEGRITY',\n  'INTERSECTION',\n  'INTERVAL',\n  'INTO',\n  'INVOKER',\n  'IS',\n  'ISNULL',\n  'ISOLATION',\n  'JSON',\n  'JSON_ARRAY',\n  'JSON_ARRAYAGG',\n  'JSON_EXISTS',\n  'JSON_OBJECTAGG',\n  'JSON_QUERY',\n  'JSON_TABLE',\n  'JSON_TABLE_PRIMITIVE',\n  'JSON_VALUE',\n  'KEEP',\n  'KEY',\n  'KEYS',\n  'KEY_MEMBER',\n  'KEY_TYPE',\n  'LABEL',\n  'LANGUAGE',\n  'LARGE',\n  'LAST',\n  'LATERAL',\n  'LEADING',\n  'LEAKPROOF',\n  'LEVEL',\n  'LIBRARY',\n  'LIKE',\n  'LIKE_REGEX',\n  'LINK',\n  'LISTAGG',\n  'LOCAL',\n  'LOCATION',\n  'LOCATOR',\n  'LOCKED',\n  'LOGGED',\n  'MAP',\n  'MAPPING',\n  'MATCH',\n  'MATCHED',\n  'MATCHES',\n  'MATCH_NUMBER',\n  'MATCH_RECOGNIZE',\n  'MATERIALIZED',\n  'MAXVALUE',\n  'MEASURES',\n  'MEMBER',\n  'MERGE',\n  'MESSAGE_LENGTH',\n  'MESSAGE_OCTET_LENGTH',\n  'MESSAGE_TEXT',\n  'METHOD',\n  'MINUTE',\n  'MINVALUE',\n  'MODIFIES',\n  'MODULE',\n  'MONTH',\n  'MORE',\n  'MULTISET',\n  'MUMPS',\n  'NAME',\n  'NAMES',\n  'NAMESPACE',\n  'NATIONAL',\n  'NATURAL',\n  'NCHAR',\n  'NCLOB',\n  'NESTED',\n  'NESTING',\n  'NEW',\n  'NEXT',\n  'NFC',\n  'NFD',\n  'NFKC',\n  'NFKD',\n  'NIL',\n  'NO',\n  'NONE',\n  'NORMALIZED',\n  'NOT',\n  'NOTHING',\n  'NOTNULL',\n  'NOWAIT',\n  'NULL',\n  'NULLABLE',\n  'NULLS',\n  'NUMBER',\n  'NUMERIC',\n  'OBJECT',\n  'OCCURRENCES_REGEX',\n  'OCTETS',\n  'OF',\n  'OFF',\n  'OFFSET',\n  'OIDS',\n  'OLD',\n  'OMIT',\n  'ON COMMIT',\n  'ON DELETE',\n  'ON UPDATE',\n  'ONE',\n  'ONLY',\n  'OPEN',\n  'OPERATOR',\n  'OPTION',\n  'OPTIONS',\n  'ORDER',\n  'ORDERING',\n  'ORDINALITY',\n  'OTHERS',\n  'OUT',\n  'OUTER',\n  'OUTPUT',\n  'OVER',\n  'OVERFLOW',\n  'OVERLAPS',\n  'OVERRIDING',\n  'OWNED',\n  'OWNER',\n  'PAD',\n  'PARALLEL',\n  'PARAMETER',\n  'PARAMETER_MODE',\n  'PARAMETER_NAME',\n  'PARAMETER_ORDINAL_POSITION',\n  'PARAMETER_SPECIFIC_CATALOG',\n  'PARAMETER_SPECIFIC_NAME',\n  'PARAMETER_SPECIFIC_SCHEMA',\n  'PARSER',\n  'PARTIAL',\n  'PARTITION',\n  'PASCAL',\n  'PASS',\n  'PASSING',\n  'PASSTHROUGH',\n  'PASSWORD',\n  'PAST',\n  'PATTERN',\n  'PER',\n  'PERCENT',\n  'PERIOD',\n  'PERMISSION',\n  'PERMUTE',\n  'PLACING',\n  'PLAN',\n  'PLANS',\n  'PLI',\n  'POLICY',\n  'PORTION',\n  'POSITION_REGEX',\n  'PRECEDES',\n  'PRECEDING',\n  'PRECISION',\n  'PREPARED',\n  'PRESERVE',\n  'PRIMARY',\n  'PRIOR',\n  'PRIVATE',\n  'PRIVILEGES',\n  'PROCEDURAL',\n  'PROCEDURE',\n  'PROCEDURES',\n  'PROGRAM',\n  'PRUNE',\n  'PTF',\n  'PUBLIC',\n  'PUBLICATION',\n  'QUOTE',\n  'QUOTES',\n  'RANGE',\n  'READ',\n  'READS',\n  'REAL',\n  'REASSIGN',\n  'RECHECK',\n  'RECOVERY',\n  'RECURSIVE',\n  'REF',\n  'REFERENCES',\n  'REFERENCING',\n  'REFRESH',\n  'RELATIVE',\n  'RELEASE',\n  'RENAME',\n  'REPEATABLE',\n  'REPLICA',\n  'REQUIRING',\n  'RESPECT',\n  'RESTART',\n  'RESTORE',\n  'RESTRICT',\n  'RESULT',\n  'RETURN',\n  'RETURNED_CARDINALITY',\n  'RETURNED_LENGTH',\n  'RETURNED_OCTET_LENGTH',\n  'RETURNED_SQLSTATE',\n  'RETURNS',\n  'ROLE',\n  'ROLLUP',\n  'ROUTINE',\n  'ROUTINES',\n  'ROUTINE_CATALOG',\n  'ROUTINE_NAME',\n  'ROUTINE_SCHEMA',\n  'ROW',\n  'ROWS',\n  'ROW_COUNT',\n  'RULE',\n  'RUNNING',\n  'SCALAR',\n  'SCHEMA',\n  'SCHEMAS',\n  'SCHEMA_NAME',\n  'SCOPE',\n  'SCOPE_CATALOG',\n  'SCOPE_NAME',\n  'SCOPE_SCHEMA',\n  'SCROLL',\n  'SEARCH',\n  'SECOND',\n  'SECTION',\n  'SECURITY',\n  'SEEK',\n  'SELECTIVE',\n  'SELF',\n  'SENSITIVE',\n  'SEQUENCE',\n  'SEQUENCES',\n  'SERIALIZABLE',\n  'SERVER',\n  'SERVER_NAME',\n  'SESSION',\n  'SETOF',\n  'SETS',\n  'SHARE',\n  'SIMILAR',\n  'SIMPLE',\n  'SIZE',\n  'SKIP',\n  'SMALLINT',\n  'SNAPSHOT',\n  'SOURCE',\n  'SPACE',\n  'SPECIFIC',\n  'SPECIFICTYPE',\n  'SPECIFIC_NAME',\n  'SQL',\n  'SQLCODE',\n  'SQLERROR',\n  'SQLEXCEPTION',\n  'SQLSTATE',\n  'SQLWARNING',\n  'STABLE',\n  'STANDALONE',\n  'START',\n  'STATE',\n  'STATEMENT',\n  'STATIC',\n  'STATISTICS',\n  'STDIN',\n  'STDOUT',\n  'STORAGE',\n  'STORED',\n  'STRICT',\n  'STRUCTURE',\n  'STYLE',\n  'SUBCLASS_ORIGIN',\n  'SUBMULTISET',\n  'SUBSCRIPTION',\n  'SUBSET',\n  'SUBSTRING_REGEX',\n  'SUCCEEDS',\n  'SUPPORT',\n  'SYMMETRIC',\n  'SYSID',\n  'SYSTEM',\n  'SYSTEM_TIME',\n  'SYSTEM_USER',\n  'TABLE',\n  'TABLES',\n  'TABLESAMPLE',\n  'TABLESPACE',\n  'TABLE_NAME',\n  'TEMP',\n  'TEMPLATE',\n  'TEMPORARY',\n  'THEN',\n  'THROUGH',\n  'TIES',\n  'TIME',\n  'TIMESTAMP',\n  'TIMEZONE_HOUR',\n  'TIMEZONE_MINUTE',\n  'TO',\n  'TOKEN',\n  'TOP_LEVEL_COUNT',\n  'TRAILING',\n  'TRANSACTION',\n  'TRANSACTIONS_COMMITTED',\n  'TRANSACTIONS_ROLLED_BACK',\n  'TRANSACTION_ACTIVE',\n  'TRANSFORM',\n  'TRANSFORMS',\n  'TRANSLATE_REGEX',\n  'TRANSLATION',\n  'TREAT',\n  'TRIGGER',\n  'TRIGGER_CATALOG',\n  'TRIGGER_NAME',\n  'TRIGGER_SCHEMA',\n  'TRUE',\n  'TRUSTED',\n  'TYPE',\n  'TYPES',\n  'UESCAPE',\n  'UNBOUNDED',\n  'UNCOMMITTED',\n  'UNCONDITIONAL',\n  'UNDER',\n  'UNENCRYPTED',\n  'UNIQUE',\n  'UNKNOWN',\n  'UNLINK',\n  'UNLOGGED',\n  'UNMATCHED',\n  'UNNAMED',\n  'UNTIL',\n  'UNTYPED',\n  'URI',\n  'USAGE',\n  'USER_DEFINED_TYPE_CATALOG',\n  'USER_DEFINED_TYPE_CODE',\n  'USER_DEFINED_TYPE_NAME',\n  'USER_DEFINED_TYPE_SCHEMA',\n  'UTF16',\n  'UTF32',\n  'UTF8',\n  'VALID',\n  'VALIDATE',\n  'VALIDATOR',\n  'VALUE',\n  'VALUE_OF',\n  'VARBINARY',\n  'VARCHAR',\n  'VARIADIC',\n  'VARYING',\n  'VERBOSE',\n  'VERSIONING',\n  'VIEW',\n  'VIEWS',\n  'VOLATILE',\n  'WHENEVER',\n  'WHITESPACE',\n  'WINDOW',\n  'WITHIN',\n  'WITHOUT',\n  'WORK',\n  'WRAPPER',\n  'WRITE',\n  'XML',\n  'XMLATTRIBUTES',\n  'XMLBINARY',\n  'XMLCAST',\n  'XMLDECLARATION',\n  'XMLDOCUMENT',\n  'XMLITERATE',\n  'XMLNAMESPACES',\n  'XMLQUERY',\n  'XMLSCHEMA',\n  'XMLTEXT',\n  'XMLVALIDATE',\n  'YEAR',\n  'YES',\n  'ZONE',\n];\n\n/**\n * Priority 1 (first)\n * keywords that begin a new statement\n * will begin new indented block\n */\n// https://www.postgresql.org/docs/14/sql-commands.html\nconst reservedCommands = [\n  'ABORT',\n  'ALTER AGGREGATE',\n  'ALTER COLLATION',\n  'ALTER CONVERSION',\n  'ALTER DATABASE',\n  'ALTER DEFAULT PRIVILEGES',\n  'ALTER DOMAIN',\n  'ALTER EVENT TRIGGER',\n  'ALTER EXTENSION',\n  'ALTER FOREIGN DATA WRAPPER',\n  'ALTER FOREIGN TABLE',\n  'ALTER FUNCTION',\n  'ALTER GROUP',\n  'ALTER INDEX',\n  'ALTER LANGUAGE',\n  'ALTER LARGE OBJECT',\n  'ALTER MATERIALIZED VIEW',\n  'ALTER OPERATOR',\n  'ALTER OPERATOR CLASS',\n  'ALTER OPERATOR FAMILY',\n  'ALTER POLICY',\n  'ALTER PROCEDURE',\n  'ALTER PUBLICATION',\n  'ALTER ROLE',\n  'ALTER ROUTINE',\n  'ALTER RULE',\n  'ALTER SCHEMA',\n  'ALTER SEQUENCE',\n  'ALTER SERVER',\n  'ALTER STATISTICS',\n  'ALTER SUBSCRIPTION',\n  'ALTER SYSTEM',\n  'ALTER TABLE',\n  'ALTER TABLESPACE',\n  'ALTER TEXT SEARCH CONFIGURATION',\n  'ALTER TEXT SEARCH DICTIONARY',\n  'ALTER TEXT SEARCH PARSER',\n  'ALTER TEXT SEARCH TEMPLATE',\n  'ALTER TRIGGER',\n  'ALTER TYPE',\n  'ALTER USER',\n  'ALTER USER MAPPING',\n  'ALTER VIEW',\n  'ANALYZE',\n  'BEGIN',\n  'CALL',\n  'CHECKPOINT',\n  'CLOSE',\n  'CLUSTER',\n  'COMMENT',\n  'COMMIT',\n  'COMMIT PREPARED',\n  'COPY',\n  'CREATE ACCESS METHOD',\n  'CREATE AGGREGATE',\n  'CREATE CAST',\n  'CREATE COLLATION',\n  'CREATE CONVERSION',\n  'CREATE DATABASE',\n  'CREATE DOMAIN',\n  'CREATE EVENT TRIGGER',\n  'CREATE EXTENSION',\n  'CREATE FOREIGN DATA WRAPPER',\n  'CREATE FOREIGN TABLE',\n  'CREATE FUNCTION',\n  'CREATE GROUP',\n  'CREATE INDEX',\n  'CREATE LANGUAGE',\n  'CREATE MATERIALIZED VIEW',\n  'CREATE OPERATOR',\n  'CREATE OPERATOR CLASS',\n  'CREATE OPERATOR FAMILY',\n  'CREATE POLICY',\n  'CREATE PROCEDURE',\n  'CREATE PUBLICATION',\n  'CREATE ROLE',\n  'CREATE RULE',\n  'CREATE SCHEMA',\n  'CREATE SEQUENCE',\n  'CREATE SERVER',\n  'CREATE STATISTICS',\n  'CREATE SUBSCRIPTION',\n  'CREATE TABLE',\n  'CREATE TABLE AS',\n  'CREATE TABLESPACE',\n  'CREATE TEXT SEARCH CONFIGURATION',\n  'CREATE TEXT SEARCH DICTIONARY',\n  'CREATE TEXT SEARCH PARSER',\n  'CREATE TEXT SEARCH TEMPLATE',\n  'CREATE TRANSFORM',\n  'CREATE TRIGGER',\n  'CREATE TYPE',\n  'CREATE USER',\n  'CREATE USER MAPPING',\n  'CREATE VIEW',\n  'DEALLOCATE',\n  'DECLARE',\n  'DELETE',\n  'DISCARD',\n  'DO',\n  'DROP ACCESS METHOD',\n  'DROP AGGREGATE',\n  'DROP CAST',\n  'DROP COLLATION',\n  'DROP CONVERSION',\n  'DROP DATABASE',\n  'DROP DOMAIN',\n  'DROP EVENT TRIGGER',\n  'DROP EXTENSION',\n  'DROP FOREIGN DATA WRAPPER',\n  'DROP FOREIGN TABLE',\n  'DROP FUNCTION',\n  'DROP GROUP',\n  'DROP INDEX',\n  'DROP LANGUAGE',\n  'DROP MATERIALIZED VIEW',\n  'DROP OPERATOR',\n  'DROP OPERATOR CLASS',\n  'DROP OPERATOR FAMILY',\n  'DROP OWNED',\n  'DROP POLICY',\n  'DROP PROCEDURE',\n  'DROP PUBLICATION',\n  'DROP ROLE',\n  'DROP ROUTINE',\n  'DROP RULE',\n  'DROP SCHEMA',\n  'DROP SEQUENCE',\n  'DROP SERVER',\n  'DROP STATISTICS',\n  'DROP SUBSCRIPTION',\n  'DROP TABLE',\n  'DROP TABLESPACE',\n  'DROP TEXT SEARCH CONFIGURATION',\n  'DROP TEXT SEARCH DICTIONARY',\n  'DROP TEXT SEARCH PARSER',\n  'DROP TEXT SEARCH TEMPLATE',\n  'DROP TRANSFORM',\n  'DROP TRIGGER',\n  'DROP TYPE',\n  'DROP USER',\n  'DROP USER MAPPING',\n  'DROP VIEW',\n  'END',\n  'EXECUTE',\n  'EXPLAIN',\n  'FETCH',\n  'GRANT',\n  'IMPORT FOREIGN SCHEMA',\n  'INSERT',\n  'LISTEN',\n  'LOAD',\n  'LOCK',\n  'MOVE',\n  'NOTIFY',\n  'PREPARE',\n  'PREPARE TRANSACTION',\n  'REASSIGN OWNED',\n  'REFRESH MATERIALIZED VIEW',\n  'REINDEX',\n  'RELEASE SAVEPOINT',\n  'RESET',\n  'RETURNING',\n  'REVOKE',\n  'ROLLBACK',\n  'ROLLBACK PREPARED',\n  'ROLLBACK TO SAVEPOINT',\n  'SAVEPOINT',\n  'SECURITY LABEL',\n  'SELECT',\n  'SELECT INTO',\n  'SET',\n  'SET CONSTRAINTS',\n  'SET ROLE',\n  'SET SESSION AUTHORIZATION',\n  'SET TRANSACTION',\n  'SHOW',\n  'START TRANSACTION',\n  'TRUNCATE',\n  'UNLISTEN',\n  'UPDATE',\n  'VACUUM',\n  'VALUES',\n  // other\n  'ADD',\n  'AFTER',\n  'ALTER COLUMN',\n  'INSERT INTO', // verify\n  'SET SCHEMA', // verify\n  'FROM',\n  'GROUP BY',\n  'HAVING',\n  'LIMIT',\n  'OFFSET',\n  'ORDER BY',\n  'WHERE',\n  'WITH',\n];\n\n/**\n * Priority 2\n * commands that operate on two tables or subqueries\n * two main categories: joins and boolean set operators\n */\nconst reservedBinaryCommands = [\n  // set booleans\n  'INTERSECT',\n  'INTERSECT ALL',\n  'INTERSECT DISTINCT',\n  'UNION',\n  'UNION ALL',\n  'UNION DISTINCT',\n  'EXCEPT',\n  'EXCEPT ALL',\n  'EXCEPT DISTINCT',\n  'MINUS',\n  'MINUS ALL',\n  'MINUS DISTINCT',\n  // joins\n  'JOIN',\n  'INNER JOIN',\n  'LEFT JOIN',\n  'LEFT OUTER JOIN',\n  'RIGHT JOIN',\n  'RIGHT OUTER JOIN',\n  'FULL JOIN',\n  'FULL OUTER JOIN',\n  'CROSS JOIN',\n  'NATURAL JOIN',\n];\n\n/**\n * Priority 3\n * keywords that follow a previous Statement, must be attached to subsequent data\n * can be fully inline or on newline with optional indent\n */\nconst reservedDependentClauses = ['WHEN', 'ELSE'];\n\nconst binaryOperators = [\n  '<<',\n  '>>',\n  '||/',\n  '|/',\n  '::',\n  ':=',\n  '->>',\n  '->',\n  '=>',\n  '~~*',\n  '~~',\n  '!~~*',\n  '!~~',\n  '~*',\n  '!~*',\n  '!~',\n  '!!',\n  '||',\n  '@-@',\n  '@@',\n  '##',\n  '<->',\n  '&&',\n  '&<',\n  '&>',\n  '<<|',\n  '&<|',\n  '|>>',\n  '|&>',\n  '<^',\n  '^>',\n  '?#',\n  '?-',\n  '?|',\n  '?-|',\n  '?||',\n  '@>',\n  '<@',\n  '~=',\n  '>>=',\n  '<<=',\n  '@@@',\n];\n\n// https://www.postgresql.org/docs/14/index.html\nexport default class PostgreSqlFormatter extends Formatter {\n  static reservedCommands = reservedCommands;\n  static reservedBinaryCommands = reservedBinaryCommands;\n  static reservedDependentClauses = reservedDependentClauses;\n  static reservedJoinConditions = ['ON', 'USING'];\n  static reservedLogicalOperators = ['AND', 'OR'];\n  static reservedKeywords = dedupe([\n    ...Object.values(reservedFunctions).reduce((acc, arr) => [...acc, ...arr], []),\n    ...reservedKeywords,\n  ]);\n  static stringTypes: StringPatternType[] = [`\"\"`, \"''\", \"U&''\", 'U&\"\"', '$$', '``', \"E''\"];\n  static blockStart = ['(', 'CASE'];\n  static blockEnd = [')', 'END'];\n  static indexedPlaceholderTypes = ['$'];\n  static namedPlaceholderTypes = [':'];\n  static lineCommentTypes = ['--'];\n  static operators = binaryOperators;\n\n  tokenizer() {\n    return new Tokenizer({\n      reservedCommands: PostgreSqlFormatter.reservedCommands,\n      reservedBinaryCommands: PostgreSqlFormatter.reservedBinaryCommands,\n      reservedDependentClauses: PostgreSqlFormatter.reservedDependentClauses,\n      reservedJoinConditions: PostgreSqlFormatter.reservedJoinConditions,\n      reservedLogicalOperators: PostgreSqlFormatter.reservedLogicalOperators,\n      reservedKeywords: PostgreSqlFormatter.reservedKeywords,\n      stringTypes: PostgreSqlFormatter.stringTypes,\n      blockStart: PostgreSqlFormatter.blockStart,\n      blockEnd: PostgreSqlFormatter.blockEnd,\n      indexedPlaceholderTypes: PostgreSqlFormatter.indexedPlaceholderTypes,\n      namedPlaceholderTypes: PostgreSqlFormatter.namedPlaceholderTypes,\n      lineCommentTypes: PostgreSqlFormatter.lineCommentTypes,\n      operators: PostgreSqlFormatter.operators,\n    });\n  }\n}\n","import Formatter from '../core/Formatter';\nimport Tokenizer from '../core/Tokenizer';\nimport type { StringPatternType } from '../core/regexFactory';\nimport { dedupe } from '../utils';\n\n/**\n * Priority 5 (last)\n * Full list of reserved functions\n * distinct from Keywords due to interaction with parentheses\n */\nconst reservedFunctions = {\n  // https://docs.aws.amazon.com/redshift/latest/dg/c_Aggregate_Functions.html\n  aggregate: [\n    'ANY_VALUE',\n    'APPROXIMATE PERCENTILE_DISC',\n    'AVG',\n    'COUNT',\n    'LISTAGG',\n    'MAX',\n    'MEDIAN',\n    'MIN',\n    'PERCENTILE_CONT',\n    'STDDEV_SAMP',\n    'STDDEV_POP',\n    'SUM',\n    'VAR_SAMP',\n    'VAR_POP',\n  ],\n  // https://docs.aws.amazon.com/redshift/latest/dg/c_Array_Functions.html\n  array: [\n    'array',\n    'array_concat',\n    'array_flatten',\n    'get_array_length',\n    'split_to_array',\n    'subarray',\n  ],\n  // https://docs.aws.amazon.com/redshift/latest/dg/c_bitwise_aggregate_functions.html\n  bitwise: ['BIT_AND', 'BIT_OR', 'BOOL_AND', 'BOOL_OR'],\n  // https://docs.aws.amazon.com/redshift/latest/dg/c_conditional_expressions.html\n  conditional: ['CASE', 'COALESCE', 'DECODE', 'GREATEST', 'LEAST', 'NVL', 'NVL2', 'NULLIF'],\n  // https://docs.aws.amazon.com/redshift/latest/dg/Date_functions_header.html\n  dateTime: [\n    'ADD_MONTHS',\n    'AT TIME ZONE',\n    'CONVERT_TIMEZONE',\n    'CURRENT_DATE',\n    'CURRENT_TIME',\n    'CURRENT_TIMESTAMP',\n    'DATE_CMP',\n    'DATE_CMP_TIMESTAMP',\n    'DATE_CMP_TIMESTAMPTZ',\n    'DATE_PART_YEAR',\n    'DATEADD',\n    'DATEDIFF',\n    'DATE_PART',\n    'DATE_TRUNC',\n    'EXTRACT',\n    'GETDATE',\n    'INTERVAL_CMP',\n    'LAST_DAY',\n    'MONTHS_BETWEEN',\n    'NEXT_DAY',\n    'SYSDATE',\n    'TIMEOFDAY',\n    'TIMESTAMP_CMP',\n    'TIMESTAMP_CMP_DATE',\n    'TIMESTAMP_CMP_TIMESTAMPTZ',\n    'TIMESTAMPTZ_CMP',\n    'TIMESTAMPTZ_CMP_DATE',\n    'TIMESTAMPTZ_CMP_TIMESTAMP',\n    'TIMEZONE',\n    'TO_TIMESTAMP',\n    'TRUNC',\n  ],\n  // https://docs.aws.amazon.com/redshift/latest/dg/geospatial-functions.html\n  spatial: [\n    'AddBBox',\n    'DropBBox',\n    'GeometryType',\n    'ST_AddPoint',\n    'ST_Angle',\n    'ST_Area',\n    'ST_AsBinary',\n    'ST_AsEWKB',\n    'ST_AsEWKT',\n    'ST_AsGeoJSON',\n    'ST_AsText',\n    'ST_Azimuth',\n    'ST_Boundary',\n    'ST_Collect',\n    'ST_Contains',\n    'ST_ContainsProperly',\n    'ST_ConvexHull',\n    'ST_CoveredBy',\n    'ST_Covers',\n    'ST_Crosses',\n    'ST_Dimension',\n    'ST_Disjoint',\n    'ST_Distance',\n    'ST_DistanceSphere',\n    'ST_DWithin',\n    'ST_EndPoint',\n    'ST_Envelope',\n    'ST_Equals',\n    'ST_ExteriorRing',\n    'ST_Force2D',\n    'ST_Force3D',\n    'ST_Force3DM',\n    'ST_Force3DZ',\n    'ST_Force4D',\n    'ST_GeometryN',\n    'ST_GeometryType',\n    'ST_GeomFromEWKB',\n    'ST_GeomFromEWKT',\n    'ST_GeomFromText',\n    'ST_GeomFromWKB',\n    'ST_InteriorRingN',\n    'ST_Intersects',\n    'ST_IsPolygonCCW',\n    'ST_IsPolygonCW',\n    'ST_IsClosed',\n    'ST_IsCollection',\n    'ST_IsEmpty',\n    'ST_IsSimple',\n    'ST_IsValid',\n    'ST_Length',\n    'ST_LengthSphere',\n    'ST_Length2D',\n    'ST_LineFromMultiPoint',\n    'ST_LineInterpolatePoint',\n    'ST_M',\n    'ST_MakeEnvelope',\n    'ST_MakeLine',\n    'ST_MakePoint',\n    'ST_MakePolygon',\n    'ST_MemSize',\n    'ST_MMax',\n    'ST_MMin',\n    'ST_Multi',\n    'ST_NDims',\n    'ST_NPoints',\n    'ST_NRings',\n    'ST_NumGeometries',\n    'ST_NumInteriorRings',\n    'ST_NumPoints',\n    'ST_Perimeter',\n    'ST_Perimeter2D',\n    'ST_Point',\n    'ST_PointN',\n    'ST_Points',\n    'ST_Polygon',\n    'ST_RemovePoint',\n    'ST_Reverse',\n    'ST_SetPoint',\n    'ST_SetSRID',\n    'ST_Simplify',\n    'ST_SRID',\n    'ST_StartPoint',\n    'ST_Touches',\n    'ST_Within',\n    'ST_X',\n    'ST_XMax',\n    'ST_XMin',\n    'ST_Y',\n    'ST_YMax',\n    'ST_YMin',\n    'ST_Z',\n    'ST_ZMax',\n    'ST_ZMin',\n    'SupportsBBox',\n  ],\n  // https://docs.aws.amazon.com/redshift/latest/dg/hash-functions.html\n  hash: ['CHECKSUM', 'FUNC_SHA1', 'FNV_HASH', 'MD5', 'SHA', 'SHA1', 'SHA2'],\n  // https://docs.aws.amazon.com/redshift/latest/dg/hyperloglog-functions.html\n  hyperLogLog: ['HLL', 'HLL_CREATE_SKETCH', 'HLL_CARDINALITY', 'HLL_COMBINE'],\n  // https://docs.aws.amazon.com/redshift/latest/dg/json-functions.html\n  json: [\n    'IS_VALID_JSON',\n    'IS_VALID_JSON_ARRAY',\n    'JSON_ARRAY_LENGTH',\n    'JSON_EXTRACT_ARRAY_ELEMENT_TEXT',\n    'JSON_EXTRACT_PATH_TEXT',\n    'JSON_PARSE',\n    'JSON_SERIALIZE',\n  ],\n  // https://docs.aws.amazon.com/redshift/latest/dg/Math_functions.html\n  math: [\n    'ABS',\n    'ACOS',\n    'ASIN',\n    'ATAN',\n    'ATAN2',\n    'CBRT',\n    'CEILING',\n    'CEIL',\n    'COS',\n    'COT',\n    'DEGREES',\n    'DEXP',\n    'DLOG1',\n    'DLOG10',\n    'EXP',\n    'FLOOR',\n    'LN',\n    'LOG',\n    'MOD',\n    'PI',\n    'POWER',\n    'RADIANS',\n    'RANDOM',\n    'ROUND',\n    'SIN',\n    'SIGN',\n    'SQRT',\n    'TAN',\n    'TO_HEX',\n    'TRUNC',\n  ],\n  // https://docs.aws.amazon.com/redshift/latest/dg/ml-function.html\n  machineLearning: ['EXPLAIN_MODEL'],\n  // https://docs.aws.amazon.com/redshift/latest/dg/String_functions_header.html\n  string: [\n    'ASCII',\n    'BPCHARCMP',\n    'BTRIM',\n    'BTTEXT_PATTERN_CMP',\n    'CHAR_LENGTH',\n    'CHARACTER_LENGTH',\n    'CHARINDEX',\n    'CHR',\n    'COLLATE',\n    'CONCAT',\n    'CRC32',\n    'DIFFERENCE',\n    'INITCAP',\n    'LEFT',\n    'RIGHT',\n    'LEN',\n    'LENGTH',\n    'LOWER',\n    'LPAD',\n    'RPAD',\n    'LTRIM',\n    'OCTETINDEX',\n    'OCTET_LENGTH',\n    'POSITION',\n    'QUOTE_IDENT',\n    'QUOTE_LITERAL',\n    'REGEXP_COUNT',\n    'REGEXP_INSTR',\n    'REGEXP_REPLACE',\n    'REGEXP_SUBSTR',\n    'REPEAT',\n    'REPLACE',\n    'REPLICATE',\n    'REVERSE',\n    'RTRIM',\n    'SOUNDEX',\n    'SPLIT_PART',\n    'STRPOS',\n    'STRTOL',\n    'SUBSTRING',\n    'TEXTLEN',\n    'TRANSLATE',\n    'TRIM',\n    'UPPER',\n  ],\n  // https://docs.aws.amazon.com/redshift/latest/dg/c_Type_Info_Functions.html\n  superType: [\n    'decimal_precision',\n    'decimal_scale',\n    'is_array',\n    'is_bigint',\n    'is_boolean',\n    'is_char',\n    'is_decimal',\n    'is_float',\n    'is_integer',\n    'is_object',\n    'is_scalar',\n    'is_smallint',\n    'is_varchar',\n    'json_typeof',\n  ],\n  // https://docs.aws.amazon.com/redshift/latest/dg/c_Window_functions.html\n  window: [\n    'AVG',\n    'COUNT',\n    'CUME_DIST',\n    'DENSE_RANK',\n    'FIRST_VALUE',\n    'LAST_VALUE',\n    'LAG',\n    'LEAD',\n    'LISTAGG',\n    'MAX',\n    'MEDIAN',\n    'MIN',\n    'NTH_VALUE',\n    'NTILE',\n    'PERCENT_RANK',\n    'PERCENTILE_CONT',\n    'PERCENTILE_DISC',\n    'RANK',\n    'RATIO_TO_REPORT',\n    'ROW_NUMBER',\n    'STDDEV_SAMP',\n    'STDDEV_POP',\n    'SUM',\n    'VAR_SAMP',\n    'VAR_POP',\n  ],\n  // https://docs.aws.amazon.com/redshift/latest/dg/r_Data_type_formatting.html\n  dataType: [\n    'CAST',\n    'CONVERT',\n    'TO_CHAR',\n    'TO_DATE',\n    'TO_NUMBER',\n    'TEXT_TO_INT_ALT',\n    'TEXT_TO_NUMERIC_ALT',\n  ],\n  // https://docs.aws.amazon.com/redshift/latest/dg/r_System_administration_functions.html\n  sysAdmin: [\n    'CHANGE_QUERY_PRIORITY',\n    'CHANGE_SESSION_PRIORITY',\n    'CHANGE_USER_PRIORITY',\n    'CURRENT_SETTING',\n    'PG_CANCEL_BACKEND',\n    'PG_TERMINATE_BACKEND',\n    'REBOOT_CLUSTER',\n    'SET_CONFIG',\n  ],\n  // https://docs.aws.amazon.com/redshift/latest/dg/r_System_information_functions.html\n  sysInfo: [\n    'CURRENT_AWS_ACCOUNT',\n    'CURRENT_DATABASE',\n    'CURRENT_NAMESPACE',\n    'CURRENT_SCHEMA',\n    'CURRENT_SCHEMAS',\n    'CURRENT_USER',\n    'CURRENT_USER_ID',\n    'HAS_ASSUMEROLE_PRIVILEGE',\n    'HAS_DATABASE_PRIVILEGE',\n    'HAS_SCHEMA_PRIVILEGE',\n    'HAS_TABLE_PRIVILEGE',\n    'PG_BACKEND_PID',\n    'PG_GET_COLS',\n    'PG_GET_GRANTEE_BY_IAM_ROLE',\n    'PG_GET_IAM_ROLE_BY_USER',\n    'PG_GET_LATE_BINDING_VIEW_COLS',\n    'PG_LAST_COPY_COUNT',\n    'PG_LAST_COPY_ID',\n    'PG_LAST_UNLOAD_ID',\n    'PG_LAST_QUERY_ID',\n    'PG_LAST_UNLOAD_COUNT',\n    'SESSION_USER',\n    'SLICE_NUM',\n    'USER',\n    'VERSION',\n  ],\n};\n\n/**\n * Priority 5 (last)\n * Full list of reserved words\n * any words that are in a higher priority are removed\n */\nconst reservedKeywords = {\n  // https://docs.aws.amazon.com/redshift/latest/dg/r_pg_keywords.html\n  standard: [\n    'AES128',\n    'AES256',\n    'ALL',\n    'ALLOWOVERWRITE',\n    'ANY',\n    'ARRAY',\n    'AS',\n    'ASC',\n    'AUTHORIZATION',\n    'BACKUP',\n    'BETWEEN',\n    'BINARY',\n    'BOTH',\n    'CHECK',\n    'COLUMN',\n    'CONSTRAINT',\n    'CREATE',\n    'CROSS',\n    'DEFAULT',\n    'DEFERRABLE',\n    'DEFLATE',\n    'DEFRAG',\n    'DESC',\n    'DISABLE',\n    'DISTINCT',\n    'DO',\n    'ENABLE',\n    'ENCODE',\n    'ENCRYPT',\n    'ENCRYPTION',\n    'EXPLICIT',\n    'FALSE',\n    'FOR',\n    'FOREIGN',\n    'FREEZE',\n    'FROM',\n    'FULL',\n    'GLOBALDICT256',\n    'GLOBALDICT64K',\n    'GROUP',\n    'IDENTITY',\n    'IGNORE',\n    'ILIKE',\n    'IN',\n    'INITIALLY',\n    'INNER',\n    'INTO',\n    'IS',\n    'ISNULL',\n    'LANGUAGE',\n    'LEADING',\n    'LIKE',\n    'LIMIT',\n    'LOCALTIME',\n    'LOCALTIMESTAMP',\n    'LUN',\n    'LUNS',\n    'MINUS',\n    'NATURAL',\n    'NEW',\n    'NOT',\n    'NOTNULL',\n    'NULL',\n    'NULLS',\n    'OFF',\n    'OFFLINE',\n    'OFFSET',\n    'OID',\n    'OLD',\n    'ONLY',\n    'OPEN',\n    'ORDER',\n    'OUTER',\n    'OVERLAPS',\n    'PARALLEL',\n    'PARTITION',\n    'PERCENT',\n    'PERMISSIONS',\n    'PLACING',\n    'PRIMARY',\n    'RECOVER',\n    'REFERENCES',\n    'REJECTLOG',\n    'RESORT',\n    'RESPECT',\n    'RESTORE',\n    'SIMILAR',\n    'SNAPSHOT',\n    'SOME',\n    'SYSTEM',\n    'TABLE',\n    'TAG',\n    'TDES',\n    'THEN',\n    'TIMESTAMP',\n    'TO',\n    'TOP',\n    'TRAILING',\n    'TRUE',\n    'UNIQUE',\n    'VERBOSE',\n    'WALLET',\n    'WITHOUT',\n  ],\n  // https://docs.aws.amazon.com/redshift/latest/dg/copy-parameters-data-conversion.html\n  dataConversionParams: [\n    'ACCEPTANYDATE',\n    'ACCEPTINVCHARS',\n    'BLANKSASNULL',\n    'DATEFORMAT',\n    'EMPTYASNULL',\n    'ENCODING',\n    'ESCAPE',\n    'EXPLICIT_IDS',\n    'FILLRECORD',\n    'IGNOREBLANKLINES',\n    'IGNOREHEADER',\n    'NULL AS',\n    'REMOVEQUOTES',\n    'ROUNDEC',\n    'TIMEFORMAT',\n    'TRIMBLANKS',\n    'TRUNCATECOLUMNS',\n  ],\n  // https://docs.aws.amazon.com/redshift/latest/dg/copy-parameters-data-load.html\n  dataLoadParams: ['COMPROWS', 'COMPUPDATE', 'MAXERROR', 'NOLOAD', 'STATUPDATE'],\n  // https://docs.aws.amazon.com/redshift/latest/dg/copy-parameters-data-format.html\n  dataFormatParams: [\n    'FORMAT',\n    'CSV',\n    'DELIMITER',\n    'FIXEDWIDTH',\n    'SHAPEFILE',\n    'AVRO',\n    'JSON',\n    'PARQUET',\n    'ORC',\n  ],\n  // https://docs.aws.amazon.com/redshift/latest/dg/copy-parameters-authorization.html\n  copyAuthParams: [\n    'ACCESS_KEY_ID',\n    'CREDENTIALS',\n    'ENCRYPTED',\n    'IAM_ROLE',\n    'MASTER_SYMMETRIC_KEY',\n    'SECRET_ACCESS_KEY',\n    'SESSION_TOKEN',\n  ],\n  // https://docs.aws.amazon.com/redshift/latest/dg/copy-parameters-file-compression.html\n  copyCompressionParams: ['BZIP2', 'GZIP', 'LZOP', 'ZSTD'],\n  // https://docs.aws.amazon.com/redshift/latest/dg/r_COPY-alphabetical-parm-list.html\n  copyMiscParams: ['MANIFEST', 'READRATIO', 'REGION', 'SSH'],\n  // https://docs.aws.amazon.com/redshift/latest/dg/c_Compression_encodings.html\n  compressionEncodings: [\n    'RAW',\n    'AZ64',\n    'BYTEDICT',\n    'DELTA',\n    'DELTA32K',\n    'LZO',\n    'MOSTLY8',\n    'MOSTLY16',\n    'MOSTLY32',\n    'RUNLENGTH',\n    'TEXT255',\n    'TEXT32K',\n  ],\n  misc: [\n    // CREATE EXTERNAL SCHEMA (https://docs.aws.amazon.com/redshift/latest/dg/r_CREATE_EXTERNAL_SCHEMA.html)\n    'CATALOG_ROLE',\n    'SECRET_ARN',\n    'EXTERNAL',\n    'HIVE METASTORE', // https://docs.aws.amazon.com/redshift/latest/dg/c-spectrum-external-schemas.html\n    // https://docs.aws.amazon.com/redshift/latest/dg/c_choosing_dist_sort.html\n    'AUTO',\n    'EVEN',\n    'KEY',\n    'PREDICATE', // ANALYZE | ANALYSE (https://docs.aws.amazon.com/redshift/latest/dg/r_ANALYZE.html)\n    // unknown\n    'COMPRESSION',\n    'DATA CATALOG',\n  ],\n  /**\n   * Other keywords not included:\n   * STL: https://docs.aws.amazon.com/redshift/latest/dg/c_intro_STL_tables.html\n   * SVCS: https://docs.aws.amazon.com/redshift/latest/dg/svcs_views.html\n   * SVL: https://docs.aws.amazon.com/redshift/latest/dg/svl_views.html\n   * SVV: https://docs.aws.amazon.com/redshift/latest/dg/svv_views.html\n   */\n  dataTypes: [\n    'CHAR',\n    'CHARACTER',\n    'NCHAR',\n    'VARCHAR',\n    'CHARACTER VARYING',\n    'NVARCHAR',\n    'BPCHAR',\n    'TEXT',\n  ],\n};\n\n/**\n * Priority 1 (first)\n * keywords that begin a new statement\n * will begin new indented block\n */\n// https://docs.aws.amazon.com/redshift/latest/dg/c_SQL_commands.html\nconst reservedCommands = [\n  'ABORT',\n  'ALTER DATABASE',\n  'ALTER DATASHARE',\n  'ALTER DEFAULT PRIVILEGES',\n  'ALTER GROUP',\n  'ALTER MATERIALIZED VIEW',\n  'ALTER PROCEDURE',\n  'ALTER SCHEMA',\n  'ALTER TABLE',\n  'ALTER TABLE APPEND',\n  'ALTER USER',\n  'ANALYSE',\n  'ANALYZE',\n  'ANALYSE COMPRESSION',\n  'ANALYZE COMPRESSION',\n  'BEGIN',\n  'CALL',\n  'CANCEL',\n  'CLOSE',\n  'COMMENT',\n  'COMMIT',\n  'COPY',\n  'CREATE DATABASE',\n  'CREATE DATASHARE',\n  'CREATE EXTERNAL FUNCTION',\n  'CREATE EXTERNAL SCHEMA',\n  'CREATE EXTERNAL TABLE',\n  'CREATE FUNCTION',\n  'CREATE GROUP',\n  'CREATE LIBRARY',\n  'CREATE MATERIALIZED VIEW',\n  'CREATE MODEL',\n  'CREATE PROCEDURE',\n  'CREATE SCHEMA',\n  'CREATE TABLE',\n  'CREATE TABLE AS',\n  'CREATE USER',\n  'CREATE VIEW',\n  'DEALLOCATE',\n  'DECLARE',\n  'DELETE',\n  'DESC DATASHARE',\n  'DROP DATABASE',\n  'DROP DATASHARE',\n  'DROP FUNCTION',\n  'DROP GROUP',\n  'DROP LIBRARY',\n  'DROP MODEL',\n  'DROP MATERIALIZED VIEW',\n  'DROP PROCEDURE',\n  'DROP SCHEMA',\n  'DROP TABLE',\n  'DROP USER',\n  'DROP VIEW',\n  'DROP',\n  'END',\n  'EXECUTE',\n  'EXPLAIN',\n  'FETCH',\n  'FROM',\n  'GRANT',\n  'HAVING',\n  'INSERT',\n  'LOCK',\n  'PREPARE',\n  'REFRESH MATERIALIZED VIEW',\n  'RESET',\n  'REVOKE',\n  'ROLLBACK',\n  'SELECT',\n  'SELECT INTO',\n  'SET',\n  'SET SESSION AUTHORIZATION',\n  'SET SESSION CHARACTERISTICS',\n  'SHOW',\n  'SHOW EXTERNAL TABLE',\n  'SHOW MODEL',\n  'SHOW DATASHARES',\n  'SHOW PROCEDURE',\n  'SHOW TABLE',\n  'SHOW VIEW',\n  'START TRANSACTION',\n  'TRUNCATE',\n  'UNLOAD',\n  'UPDATE',\n  'VACUUM',\n  'WHERE',\n  'WITH',\n  // other\n  'GROUP BY',\n  'ORDER BY',\n  'LIMIT',\n  'OFFSET',\n  'VALUES',\n  'MODIFY', // verify\n  'INSERT INTO', // verify\n  'ALTER COLUMN', // verify\n  'SET SCHEMA', // verify\n];\n\n/**\n * Priority 2\n * commands that operate on two tables or subqueries\n * two main categories: joins and boolean set operators\n */\nconst reservedBinaryCommands = [\n  // set booleans\n  'INTERSECT',\n  'INTERSECT ALL',\n  'INTERSECT DISTINCT',\n  'UNION',\n  'UNION ALL',\n  'UNION DISTINCT',\n  'EXCEPT',\n  'EXCEPT ALL',\n  'EXCEPT DISTINCT',\n  // joins\n  'JOIN',\n  'INNER JOIN',\n  'LEFT JOIN',\n  'LEFT OUTER JOIN',\n  'RIGHT JOIN',\n  'RIGHT OUTER JOIN',\n  'FULL JOIN',\n  'FULL OUTER JOIN',\n  'CROSS JOIN',\n  'NATURAL JOIN',\n];\n\n/**\n * Priority 3\n * keywords that follow a previous Statement, must be attached to subsequent data\n * can be fully inline or on newline with optional indent\n */\nconst reservedDependentClauses = ['WHEN', 'ELSE'];\n\n// https://docs.aws.amazon.com/redshift/latest/dg/cm_chap_SQLCommandRef.html\nexport default class RedshiftFormatter extends Formatter {\n  static reservedCommands = reservedCommands;\n  static reservedBinaryCommands = reservedBinaryCommands;\n  static reservedDependentClauses = reservedDependentClauses;\n  static reservedJoinConditions = ['ON', 'USING'];\n  static reservedLogicalOperators = ['AND', 'OR'];\n  static reservedKeywords = dedupe([\n    ...Object.values(reservedFunctions).reduce((acc, arr) => [...acc, ...arr], []),\n    ...Object.values(reservedKeywords).reduce((acc, arr) => [...acc, ...arr], []),\n  ]);\n  static stringTypes: StringPatternType[] = [`\"\"`, \"''\", '``'];\n  static blockStart = ['('];\n  static blockEnd = [')'];\n  static indexedPlaceholderTypes = ['?'];\n  static namedPlaceholderTypes = ['@', '#', '$'];\n  static lineCommentTypes = ['--'];\n  static operators = ['|/', '||/', '<<', '>>', '||'];\n\n  tokenizer() {\n    return new Tokenizer({\n      reservedCommands: RedshiftFormatter.reservedCommands,\n      reservedBinaryCommands: RedshiftFormatter.reservedBinaryCommands,\n      reservedDependentClauses: RedshiftFormatter.reservedDependentClauses,\n      reservedJoinConditions: RedshiftFormatter.reservedJoinConditions,\n      reservedLogicalOperators: RedshiftFormatter.reservedLogicalOperators,\n      reservedKeywords: RedshiftFormatter.reservedKeywords,\n      stringTypes: RedshiftFormatter.stringTypes,\n      blockStart: RedshiftFormatter.blockStart,\n      blockEnd: RedshiftFormatter.blockEnd,\n      indexedPlaceholderTypes: RedshiftFormatter.indexedPlaceholderTypes,\n      namedPlaceholderTypes: RedshiftFormatter.namedPlaceholderTypes,\n      lineCommentTypes: RedshiftFormatter.lineCommentTypes,\n      operators: RedshiftFormatter.operators,\n    });\n  }\n}\n","import Formatter from '../core/Formatter';\nimport Tokenizer from '../core/Tokenizer';\nimport { isToken, Token, TokenType } from '../core/token'; // convert to partial type import in TS 4.5\nimport type { StringPatternType } from '../core/regexFactory';\nimport { dedupe } from '../utils';\n\n/**\n * Priority 5 (last)\n * Full list of reserved functions\n * distinct from Keywords due to interaction with parentheses\n */\n// http://spark.apache.org/docs/latest/sql-ref-functions.html\nconst reservedFunctions = {\n  // http://spark.apache.org/docs/latest/sql-ref-functions-builtin.html#aggregate-functions\n  aggregate: [\n    'ANY',\n    'APPROX_COUNT_DISTINCT',\n    'APPROX_PERCENTILE',\n    'AVG',\n    'BIT_AND',\n    'BIT_OR',\n    'BIT_XOR',\n    'BOOL_AND',\n    'BOOL_OR',\n    'COLLECT_LIST',\n    'COLLECT_SET',\n    'CORR',\n    'COUNT',\n    'COUNT',\n    'COUNT',\n    'COUNT_IF',\n    'COUNT_MIN_SKETCH',\n    'COVAR_POP',\n    'COVAR_SAMP',\n    'EVERY',\n    'FIRST',\n    'FIRST_VALUE',\n    'GROUPING',\n    'GROUPING_ID',\n    'KURTOSIS',\n    'LAST',\n    'LAST_VALUE',\n    'MAX',\n    'MAX_BY',\n    'MEAN',\n    'MIN',\n    'MIN_BY',\n    'PERCENTILE',\n    'PERCENTILE',\n    'PERCENTILE_APPROX',\n    'SKEWNESS',\n    'SOME',\n    'STD',\n    'STDDEV',\n    'STDDEV_POP',\n    'STDDEV_SAMP',\n    'SUM',\n    'VAR_POP',\n    'VAR_SAMP',\n    'VARIANCE',\n  ],\n  // http://spark.apache.org/docs/latest/sql-ref-functions-builtin.html#window-functions\n  window: [\n    'CUME_DIST',\n    'DENSE_RANK',\n    'LAG',\n    'LEAD',\n    'NTH_VALUE',\n    'NTILE',\n    'PERCENT_RANK',\n    'RANK',\n    'ROW_NUMBER',\n  ],\n  // http://spark.apache.org/docs/latest/sql-ref-functions-builtin.html#array-functions\n  array: [\n    'ARRAY',\n    'ARRAY_CONTAINS',\n    'ARRAY_DISTINCT',\n    'ARRAY_EXCEPT',\n    'ARRAY_INTERSECT',\n    'ARRAY_JOIN',\n    'ARRAY_MAX',\n    'ARRAY_MIN',\n    'ARRAY_POSITION',\n    'ARRAY_REMOVE',\n    'ARRAY_REPEAT',\n    'ARRAY_UNION',\n    'ARRAYS_OVERLAP',\n    'ARRAYS_ZIP',\n    'FLATTEN',\n    'SEQUENCE',\n    'SHUFFLE',\n    'SLICE',\n    'SORT_ARRAY',\n  ],\n  // http://spark.apache.org/docs/latest/sql-ref-functions-builtin.html#map-functions\n  map: [\n    'ELEMENT_AT',\n    'ELEMENT_AT',\n    'MAP',\n    'MAP_CONCAT',\n    'MAP_ENTRIES',\n    'MAP_FROM_ARRAYS',\n    'MAP_FROM_ENTRIES',\n    'MAP_KEYS',\n    'MAP_VALUES',\n    'STR_TO_MAP',\n  ],\n  // http://spark.apache.org/docs/latest/sql-ref-functions-builtin.html#date-and-timestamp-functions\n  datetime: [\n    'ADD_MONTHS',\n    'CURRENT_DATE',\n    'CURRENT_DATE',\n    'CURRENT_TIMESTAMP',\n    'CURRENT_TIMESTAMP',\n    'CURRENT_TIMEZONE',\n    'DATE_ADD',\n    'DATE_FORMAT',\n    'DATE_FROM_UNIX_DATE',\n    'DATE_PART',\n    'DATE_SUB',\n    'DATE_TRUNC',\n    'DATEDIFF',\n    'DAY',\n    'DAYOFMONTH',\n    'DAYOFWEEK',\n    'DAYOFYEAR',\n    'EXTRACT',\n    'FROM_UNIXTIME',\n    'FROM_UTC_TIMESTAMP',\n    'HOUR',\n    'LAST_DAY',\n    'MAKE_DATE',\n    'MAKE_DT_INTERVAL',\n    'MAKE_INTERVAL',\n    'MAKE_TIMESTAMP',\n    'MAKE_YM_INTERVAL',\n    'MINUTE',\n    'MONTH',\n    'MONTHS_BETWEEN',\n    'NEXT_DAY',\n    'NOW',\n    'QUARTER',\n    'SECOND',\n    'SESSION_WINDOW',\n    'TIMESTAMP_MICROS',\n    'TIMESTAMP_MILLIS',\n    'TIMESTAMP_SECONDS',\n    'TO_DATE',\n    'TO_TIMESTAMP',\n    'TO_UNIX_TIMESTAMP',\n    'TO_UTC_TIMESTAMP',\n    'TRUNC',\n    'UNIX_DATE',\n    'UNIX_MICROS',\n    'UNIX_MILLIS',\n    'UNIX_SECONDS',\n    'UNIX_TIMESTAMP',\n    'WEEKDAY',\n    'WEEKOFYEAR',\n    'WINDOW',\n    'YEAR',\n  ],\n  // http://spark.apache.org/docs/latest/sql-ref-functions-builtin.html#json-functions\n  json: [\n    'FROM_JSON',\n    'GET_JSON_OBJECT',\n    'JSON_ARRAY_LENGTH',\n    'JSON_OBJECT_KEYS',\n    'JSON_TUPLE',\n    'SCHEMA_OF_JSON',\n    'TO_JSON',\n  ],\n  // http://spark.apache.org/docs/latest/api/sql/index.html\n  misc: [\n    'ABS',\n    'ACOS',\n    'ACOSH',\n    'AGGREGATE',\n    'ARRAY_SORT',\n    'ASCII',\n    'ASIN',\n    'ASINH',\n    'ASSERT_TRUE',\n    'ATAN',\n    'ATAN2',\n    'ATANH',\n    'BASE64',\n    'BIGINT',\n    'BIN',\n    'BINARY',\n    'BIT_COUNT',\n    'BIT_GET',\n    'BIT_LENGTH',\n    'BOOLEAN',\n    'BROUND',\n    'BTRIM',\n    'CARDINALITY',\n    'CBRT',\n    'CEIL',\n    'CEILING',\n    'CHAR',\n    'CHAR_LENGTH',\n    'CHARACTER_LENGTH',\n    'CHR',\n    'CONCAT',\n    'CONCAT_WS',\n    'CONV',\n    'COS',\n    'COSH',\n    'COT',\n    'CRC32',\n    'CURRENT_CATALOG',\n    'CURRENT_DATABASE',\n    'CURRENT_USER',\n    'DATE',\n    'DECIMAL',\n    'DEGREES',\n    'DOUBLE',\n    // 'E',\n    'ELT',\n    'EXP',\n    'EXPM1',\n    'FACTORIAL',\n    'FIND_IN_SET',\n    'FLOAT',\n    'FLOOR',\n    'FORALL',\n    'FORMAT_NUMBER',\n    'FORMAT_STRING',\n    'FROM_CSV',\n    'GETBIT',\n    'HASH',\n    'HEX',\n    'HYPOT',\n    'INITCAP',\n    'INLINE',\n    'INLINE_OUTER',\n    'INPUT_FILE_BLOCK_LENGTH',\n    'INPUT_FILE_BLOCK_START',\n    'INPUT_FILE_NAME',\n    'INSTR',\n    'INT',\n    'ISNAN',\n    'ISNOTNULL',\n    'ISNULL',\n    'JAVA_METHOD',\n    'LCASE',\n    'LEFT',\n    'LENGTH',\n    'LEVENSHTEIN',\n    'LN',\n    'LOCATE',\n    'LOG',\n    'LOG10',\n    'LOG1P',\n    'LOG2',\n    'LOWER',\n    'LPAD',\n    'LTRIM',\n    'MAP_FILTER',\n    'MAP_ZIP_WITH',\n    'MD5',\n    'MOD',\n    'MONOTONICALLY_INCREASING_ID',\n    'NAMED_STRUCT',\n    'NANVL',\n    'NEGATIVE',\n    'NVL',\n    'NVL2',\n    'OCTET_LENGTH',\n    'OVERLAY',\n    'PARSE_URL',\n    'PI',\n    'PMOD',\n    'POSEXPLODE',\n    'POSEXPLODE_OUTER',\n    'POSITION',\n    'POSITIVE',\n    'POW',\n    'POWER',\n    'PRINTF',\n    'RADIANS',\n    'RAISE_ERROR',\n    'RAND',\n    'RANDN',\n    'RANDOM',\n    'REFLECT',\n    'REGEXP_EXTRACT',\n    'REGEXP_EXTRACT_ALL',\n    'REGEXP_LIKE',\n    'REGEXP_REPLACE',\n    'REPEAT',\n    'REPLACE',\n    'REVERSE',\n    'RIGHT',\n    'RINT',\n    'ROUND',\n    'RPAD',\n    'RTRIM',\n    'SCHEMA_OF_CSV',\n    'SENTENCES',\n    'SHA',\n    'SHA1',\n    'SHA2',\n    'SHIFTLEFT',\n    'SHIFTRIGHT',\n    'SHIFTRIGHTUNSIGNED',\n    'SIGN',\n    'SIGNUM',\n    'SIN',\n    'SINH',\n    'SMALLINT',\n    'SOUNDEX',\n    'SPACE',\n    'SPARK_PARTITION_ID',\n    'SPLIT',\n    'SQRT',\n    'STACK',\n    'SUBSTR',\n    'SUBSTRING',\n    'SUBSTRING_INDEX',\n    'TAN',\n    'TANH',\n    'TIMESTAMP',\n    'TINYINT',\n    'TO_CSV',\n    'TRANSFORM_KEYS',\n    'TRANSFORM_VALUES',\n    'TRANSLATE',\n    'TRIM',\n    'TRY_ADD',\n    'TRY_DIVIDE',\n    'TYPEOF',\n    'UCASE',\n    'UNBASE64',\n    'UNHEX',\n    'UPPER',\n    'UUID',\n    'VERSION',\n    'WIDTH_BUCKET',\n    'XPATH',\n    'XPATH_BOOLEAN',\n    'XPATH_DOUBLE',\n    'XPATH_FLOAT',\n    'XPATH_INT',\n    'XPATH_LONG',\n    'XPATH_NUMBER',\n    'XPATH_SHORT',\n    'XPATH_STRING',\n    'XXHASH64',\n    'ZIP_WITH',\n  ],\n};\n\n/**\n * Priority 5 (last)\n * Full list of reserved words\n * any words that are in a higher priority are removed\n */\n// https://deepkb.com/CO_000013/en/kb/IMPORT-fbfa59f0-2bf1-31fe-bb7b-0f9efe9932c6/spark-sql-keywords\nconst reservedKeywords = [\n  'ADD',\n  'AFTER',\n  'ALL',\n  'ALTER',\n  'ANALYZE',\n  'AND',\n  'ANTI',\n  'ANY',\n  'ARCHIVE',\n  'ARRAY',\n  'AS',\n  'ASC',\n  'AT',\n  'AUTHORIZATION',\n  'BETWEEN',\n  'BOTH',\n  'BUCKET',\n  'BUCKETS',\n  'BY',\n  'CACHE',\n  'CASCADE',\n  'CAST',\n  'CHANGE',\n  'CHECK',\n  'CLEAR',\n  'CLUSTER',\n  'CLUSTERED',\n  'CODEGEN',\n  'COLLATE',\n  'COLLECTION',\n  'COLUMN',\n  'COLUMNS',\n  'COMMENT',\n  'COMMIT',\n  'COMPACT',\n  'COMPACTIONS',\n  'COMPUTE',\n  'CONCATENATE',\n  'CONSTRAINT',\n  'COST',\n  'CREATE',\n  'CROSS',\n  'CUBE',\n  'CURRENT',\n  'CURRENT_DATE',\n  'CURRENT_TIME',\n  'CURRENT_TIMESTAMP',\n  'CURRENT_USER',\n  'DATA',\n  'DATABASE',\n  'DATABASES',\n  'DAY',\n  'DBPROPERTIES',\n  'DEFINED',\n  'DELETE',\n  'DELIMITED',\n  'DESC',\n  'DESCRIBE',\n  'DFS',\n  'DIRECTORIES',\n  'DIRECTORY',\n  'DISTINCT',\n  'DISTRIBUTE',\n  'DIV',\n  'DROP',\n  'ESCAPE',\n  'ESCAPED',\n  'EXCEPT',\n  'EXCHANGE',\n  'EXISTS',\n  'EXPORT',\n  'EXTENDED',\n  'EXTERNAL',\n  'EXTRACT',\n  'FALSE',\n  'FETCH',\n  'FIELDS',\n  'FILTER',\n  'FILEFORMAT',\n  'FIRST',\n  'FIRST_VALUE',\n  'FOLLOWING',\n  'FOR',\n  'FOREIGN',\n  'FORMAT',\n  'FORMATTED',\n  'FULL',\n  'FUNCTION',\n  'FUNCTIONS',\n  'GLOBAL',\n  'GRANT',\n  'GROUP',\n  'GROUPING',\n  'HOUR',\n  'IF',\n  'IGNORE',\n  'IMPORT',\n  'IN',\n  'INDEX',\n  'INDEXES',\n  'INNER',\n  'INPATH',\n  'INPUTFORMAT',\n  'INTERSECT',\n  'INTERVAL',\n  'INTO',\n  'IS',\n  'ITEMS',\n  'KEYS',\n  'LAST',\n  'LAST_VALUE',\n  'LATERAL',\n  'LAZY',\n  'LEADING',\n  'LEFT',\n  'LIKE',\n  'LINES',\n  'LIST',\n  'LOCAL',\n  'LOCATION',\n  'LOCK',\n  'LOCKS',\n  'LOGICAL',\n  'MACRO',\n  'MAP',\n  'MATCHED',\n  'MERGE',\n  'MINUTE',\n  'MONTH',\n  'MSCK',\n  'NAMESPACE',\n  'NAMESPACES',\n  'NATURAL',\n  'NO',\n  'NOT',\n  'NULL',\n  'NULLS',\n  'OF',\n  'ONLY',\n  'OPTION',\n  'OPTIONS',\n  'OR',\n  'ORDER',\n  'OUT',\n  'OUTER',\n  'OUTPUTFORMAT',\n  'OVER',\n  'OVERLAPS',\n  'OVERLAY',\n  'OVERWRITE',\n  'OWNER',\n  'PARTITION',\n  'PARTITIONED',\n  'PARTITIONS',\n  'PERCENT',\n  'PLACING',\n  'POSITION',\n  'PRECEDING',\n  'PRIMARY',\n  'PRINCIPALS',\n  'PROPERTIES',\n  'PURGE',\n  'QUERY',\n  'RANGE',\n  'RECORDREADER',\n  'RECORDWRITER',\n  'RECOVER',\n  'REDUCE',\n  'REFERENCES',\n  'RENAME',\n  'REPAIR',\n  'REPLACE',\n  'RESPECT',\n  'RESTRICT',\n  'REVOKE',\n  'RIGHT',\n  'RLIKE',\n  'ROLE',\n  'ROLES',\n  'ROLLBACK',\n  'ROLLUP',\n  'ROW',\n  'ROWS',\n  'SCHEMA',\n  'SECOND',\n  'SELECT',\n  'SEMI',\n  'SEPARATED',\n  'SERDE',\n  'SERDEPROPERTIES',\n  'SESSION_USER',\n  'SETS',\n  'SHOW',\n  'SKEWED',\n  'SOME',\n  'SORT',\n  'SORTED',\n  'START',\n  'STATISTICS',\n  'STORED',\n  'STRATIFY',\n  'STRUCT',\n  'SUBSTR',\n  'SUBSTRING',\n  'TABLE',\n  'TABLES',\n  'TBLPROPERTIES',\n  'TEMPORARY',\n  'TERMINATED',\n  'THEN',\n  'TO',\n  'TOUCH',\n  'TRAILING',\n  'TRANSACTION',\n  'TRANSACTIONS',\n  'TRIM',\n  'TRUE',\n  'TRUNCATE',\n  'UNARCHIVE',\n  'UNBOUNDED',\n  'UNCACHE',\n  'UNIQUE',\n  'UNKNOWN',\n  'UNLOCK',\n  'UNSET',\n  'USE',\n  'USER',\n  'VIEW',\n  'WINDOW',\n  'YEAR',\n  // other\n  'ANALYSE',\n  'ARRAY_ZIP',\n  'COALESCE',\n  'CONTAINS',\n  'CONVERT',\n  'CURRENT ROW',\n  'DAYS',\n  'DAY_HOUR',\n  'DAY_MINUTE',\n  'DAY_SECOND',\n  'DECODE',\n  'DEFAULT',\n  'DISTINCTROW',\n  'ENCODE',\n  'EXPLODE',\n  'EXPLODE_OUTER',\n  'FIXED',\n  'GREATEST',\n  'GROUP_CONCAT',\n  'HOURS',\n  'HOUR_MINUTE',\n  'HOUR_SECOND',\n  'IFNULL',\n  'LEAST',\n  'LEVEL',\n  'MINUTE_SECOND',\n  'NULLIF',\n  'OFFSET',\n  'ON DELETE',\n  'ON UPDATE',\n  'OPTIMIZE',\n  'REGEXP',\n  'SEPARATOR',\n  'SIZE',\n  'STRING',\n  'TYPE',\n  'TYPES',\n  'UNSIGNED',\n  'VARIABLES',\n  'YEAR_MONTH',\n];\n\n/**\n * Priority 1 (first)\n * keywords that begin a new statement\n * will begin new indented block\n */\n// http://spark.apache.org/docs/latest/sql-ref-syntax.html\nconst reservedCommands = [\n  // DDL\n  'ALTER COLUMN',\n  'ALTER DATABASE',\n  'ALTER TABLE',\n  'ALTER VIEW',\n  'CREATE DATABASE',\n  'CREATE FUNCTION',\n  'CREATE TABLE',\n  'CREATE VIEW',\n  'DROP DATABASE',\n  'DROP FUNCTION',\n  'DROP TABLE',\n  'DROP VIEW',\n  'REPAIR TABLE',\n  'TRUNCATE TABLE',\n  'USE DATABASE',\n  // DML\n  'INSERT INTO',\n  'INSERT OVERWRITE',\n  'INSERT OVERWRITE DIRECTORY',\n  'LOAD',\n  // Data Retrieval\n  'SELECT',\n  'WITH',\n  'CLUSTER BY',\n  'DISTRIBUTE BY',\n  'PARTITION BY', // verify\n  'GROUP BY',\n  'HAVING',\n  'VALUES',\n  'LIMIT',\n  'OFFSET',\n  'ORDER BY',\n  'SORT BY',\n  'TABLESAMPLE',\n  'WHERE',\n  'PIVOT',\n  'TRANSFORM',\n  'EXPLAIN',\n  // Auxiliary\n  'ADD FILE',\n  'ADD JAR',\n  'ANALYZE TABLE',\n  'CACHE TABLE',\n  'CLEAR CACHE',\n  'DESCRIBE DATABASE',\n  'DESCRIBE FUNCTION',\n  'DESCRIBE QUERY',\n  'DESCRIBE TABLE',\n  'LIST FILE',\n  'LIST JAR',\n  'REFRESH',\n  'REFRESH TABLE',\n  'REFRESH FUNCTION',\n  'RESET',\n  'SET',\n  'SET SCHEMA', // verify\n  'SHOW COLUMNS',\n  'SHOW CREATE TABLE',\n  'SHOW DATABASES',\n  'SHOW FUNCTIONS',\n  'SHOW PARTITIONS',\n  'SHOW TABLE EXTENDED',\n  'SHOW TABLES',\n  'SHOW TBLPROPERTIES',\n  'SHOW VIEWS',\n  'UNCACHE TABLE',\n  // other\n  'FROM',\n  'INSERT',\n  'LATERAL VIEW',\n  'UPDATE',\n  'WINDOW', // verify\n];\n\n/**\n * Priority 2\n * commands that operate on two tables or subqueries\n * two main categories: joins and boolean set operators\n */\nconst reservedBinaryCommands = [\n  // set booleans\n  'INTERSECT',\n  'INTERSECT ALL',\n  'INTERSECT DISTINCT',\n  'UNION',\n  'UNION ALL',\n  'UNION DISTINCT',\n  'EXCEPT',\n  'EXCEPT ALL',\n  'EXCEPT DISTINCT',\n  'MINUS',\n  'MINUS ALL',\n  'MINUS DISTINCT',\n  // joins\n  'JOIN',\n  'INNER JOIN',\n  'LEFT JOIN',\n  'LEFT OUTER JOIN',\n  'RIGHT JOIN',\n  'RIGHT OUTER JOIN',\n  'FULL JOIN',\n  'FULL OUTER JOIN',\n  'CROSS JOIN',\n  'NATURAL JOIN',\n  // apply\n  'CROSS APPLY',\n  'OUTER APPLY',\n  // non-standard-joins\n  'ANTI JOIN',\n  'SEMI JOIN',\n  'LEFT ANTI JOIN',\n  'LEFT SEMI JOIN',\n  'RIGHT OUTER JOIN',\n  'RIGHT SEMI JOIN',\n  'NATURAL ANTI JOIN',\n  'NATURAL FULL OUTER JOIN',\n  'NATURAL INNER JOIN',\n  'NATURAL LEFT ANTI JOIN',\n  'NATURAL LEFT OUTER JOIN',\n  'NATURAL LEFT SEMI JOIN',\n  'NATURAL OUTER JOIN',\n  'NATURAL RIGHT OUTER JOIN',\n  'NATURAL RIGHT SEMI JOIN',\n  'NATURAL SEMI JOIN',\n  'CROSS APPLY',\n  'OUTER APPLY',\n];\n\n/**\n * Priority 3\n * keywords that follow a previous Statement, must be attached to subsequent data\n * can be fully inline or on newline with optional indent\n */\nconst reservedDependentClauses = ['WHEN', 'ELSE'];\n\n// http://spark.apache.org/docs/latest/sql-programming-guide.html\nexport default class SparkSqlFormatter extends Formatter {\n  static reservedCommands = reservedCommands;\n  static reservedBinaryCommands = reservedBinaryCommands;\n  static reservedDependentClauses = reservedDependentClauses;\n  static reservedJoinConditions = ['ON', 'USING'];\n  static reservedLogicalOperators = ['AND', 'OR', 'XOR'];\n  static reservedKeywords = dedupe([\n    ...Object.values(reservedFunctions).reduce((acc, arr) => [...acc, ...arr], []),\n    ...reservedKeywords,\n  ]);\n  static stringTypes: StringPatternType[] = [`\"\"`, \"''\", '``', '{}'];\n  static blockStart = ['(', 'CASE'];\n  static blockEnd = [')', 'END'];\n  static indexedPlaceholderTypes = ['?'];\n  static namedPlaceholderTypes = ['$'];\n  static lineCommentTypes = ['--'];\n  static operators = ['<=>', '&&', '||', '==', '->'];\n\n  tokenizer() {\n    return new Tokenizer({\n      reservedCommands: SparkSqlFormatter.reservedCommands,\n      reservedBinaryCommands: SparkSqlFormatter.reservedBinaryCommands,\n      reservedDependentClauses: SparkSqlFormatter.reservedDependentClauses,\n      reservedJoinConditions: SparkSqlFormatter.reservedJoinConditions,\n      reservedLogicalOperators: SparkSqlFormatter.reservedLogicalOperators,\n      reservedKeywords: SparkSqlFormatter.reservedKeywords,\n      stringTypes: SparkSqlFormatter.stringTypes,\n      blockStart: SparkSqlFormatter.blockStart,\n      blockEnd: SparkSqlFormatter.blockEnd,\n      indexedPlaceholderTypes: SparkSqlFormatter.indexedPlaceholderTypes,\n      namedPlaceholderTypes: SparkSqlFormatter.namedPlaceholderTypes,\n      lineCommentTypes: SparkSqlFormatter.lineCommentTypes,\n      operators: SparkSqlFormatter.operators,\n    });\n  }\n\n  tokenOverride(token: Token) {\n    // [WINDOW](...)\n    if (isToken.WINDOW(token) && this.tokenLookAhead().type === TokenType.BLOCK_START) {\n      // This is a function call, treat it as a reserved word\n      return { type: TokenType.RESERVED_KEYWORD, value: token.value };\n    }\n\n    // .[END]\n    if (isToken.END(token) && this.tokenLookBehind().value === '.') {\n      // This is window().end (or similar) not CASE ... END\n      return { type: TokenType.WORD, value: token.value };\n    }\n\n    // TODO: deprecate this once ITEMS is merged with COLLECTION\n    if (/ITEMS/i.test(token.value) && token.type === TokenType.RESERVED_KEYWORD) {\n      if (\n        !(\n          /COLLECTION/i.test(this.tokenLookBehind().value) &&\n          /TERMINATED/i.test(this.tokenLookAhead().value)\n        )\n      ) {\n        // this is a word and not COLLECTION ITEMS\n        return { type: TokenType.WORD, value: token.value };\n      }\n    }\n\n    return token;\n  }\n}\n","import Formatter from '../core/Formatter';\nimport Tokenizer from '../core/Tokenizer';\nimport type { StringPatternType } from '../core/regexFactory';\nimport { dedupe } from '../utils';\n\n/**\n * Priority 5 (last)\n * Full list of reserved words\n * any words that are in a higher priority are removed\n */\n// https://jakewheat.github.io/sql-overview/sql-2008-foundation-grammar.html#reserved-word\nconst reservedKeywords = [\n  'ABS',\n  'ALL',\n  'ALLOCATE',\n  'ALTER',\n  'ANY',\n  'ARE',\n  'ARRAY',\n  'AS',\n  'ASENSITIVE',\n  'ASYMMETRIC',\n  'AT',\n  'ATOMIC',\n  'AUTHORIZATION',\n  'AVG',\n  'BEGIN',\n  'BETWEEN',\n  'BIGINT',\n  'BINARY',\n  'BLOB',\n  'BOOLEAN',\n  'BOTH',\n  'BY',\n  'CALL',\n  'CALLED',\n  'CARDINALITY',\n  'CASCADED',\n  'CAST',\n  'CEIL',\n  'CEILING',\n  'CHAR',\n  'CHARACTER',\n  'CHARACTER_LENGTH',\n  'CHAR_LENGTH',\n  'CHECK',\n  'CLOB',\n  'CLOSE',\n  'COALESCE',\n  'COLLATE',\n  'COLLECT',\n  'COLUMN',\n  'COMMIT',\n  'CONDITION',\n  'CONNECT',\n  'CONSTRAINT',\n  'CONVERT',\n  'CORR',\n  'CORRESPONDING',\n  'COUNT',\n  'COVAR_POP',\n  'COVAR_SAMP',\n  'CREATE',\n  'CROSS',\n  'CUBE',\n  'CUME_DIST',\n  'CURRENT',\n  'CURRENT_CATALOG',\n  'CURRENT_DATE',\n  'CURRENT_DEFAULT_TRANSFORM_GROUP',\n  'CURRENT_PATH',\n  'CURRENT_ROLE',\n  'CURRENT_SCHEMA',\n  'CURRENT_TIME',\n  'CURRENT_TIMESTAMP',\n  'CURRENT_TRANSFORM_GROUP_FOR_TYPE',\n  'CURRENT_USER',\n  'CURSOR',\n  'CYCLE',\n  'DATE',\n  'DAY',\n  'DEALLOCATE',\n  'DEC',\n  'DECIMAL',\n  'DECLARE',\n  'DEFAULT',\n  'DELETE',\n  'DENSE_RANK',\n  'DEREF',\n  'DESCRIBE',\n  'DETERMINISTIC',\n  'DISCONNECT',\n  'DISTINCT',\n  'DOUBLE',\n  'DROP',\n  'DYNAMIC',\n  'EACH',\n  'ELEMENT',\n  'END-EXEC',\n  'ESCAPE',\n  'EVERY',\n  'EXCEPT',\n  'EXEC',\n  'EXECUTE',\n  'EXISTS',\n  'EXP',\n  'EXTERNAL',\n  'EXTRACT',\n  'FALSE',\n  'FETCH',\n  'FILTER',\n  'FLOAT',\n  'FLOOR',\n  'FOR',\n  'FOREIGN',\n  'FREE',\n  'FROM',\n  'FULL',\n  'FUNCTION',\n  'FUSION',\n  'GET',\n  'GLOBAL',\n  'GRANT',\n  'GROUP',\n  'GROUPING',\n  'HAVING',\n  'HOLD',\n  'HOUR',\n  'IDENTITY',\n  'IN',\n  'INDICATOR',\n  'INNER',\n  'INOUT',\n  'INSENSITIVE',\n  'INSERT',\n  'INT',\n  'INTEGER',\n  'INTERSECT',\n  'INTERSECTION',\n  'INTERVAL',\n  'INTO',\n  'IS',\n  'LANGUAGE',\n  'LARGE',\n  'LATERAL',\n  'LEADING',\n  'LEFT',\n  'LIKE',\n  'LIKE_REGEX',\n  'LN',\n  'LOCAL',\n  'LOCALTIME',\n  'LOCALTIMESTAMP',\n  'LOWER',\n  'MATCH',\n  'MAX',\n  'MEMBER',\n  'MERGE',\n  'METHOD',\n  'MIN',\n  'MINUTE',\n  'MOD',\n  'MODIFIES',\n  'MODULE',\n  'MONTH',\n  'MULTISET',\n  'NATIONAL',\n  'NATURAL',\n  'NCHAR',\n  'NCLOB',\n  'NEW',\n  'NO',\n  'NONE',\n  'NORMALIZE',\n  'NOT',\n  'NULL',\n  'NULLIF',\n  'NUMERIC',\n  'OCCURRENCES_REGEX',\n  'OCTET_LENGTH',\n  'OF',\n  'OLD',\n  'ON DELETE',\n  'ON UPDATE',\n  'ONLY',\n  'OPEN',\n  'ORDER',\n  'OUT',\n  'OUTER',\n  'OVER',\n  'OVERLAPS',\n  'OVERLAY',\n  'PARAMETER',\n  'PARTITION',\n  'PERCENTILE_CONT',\n  'PERCENTILE_DISC',\n  'PERCENT_RANK',\n  'POSITION',\n  'POSITION_REGEX',\n  'POWER',\n  'PRECISION',\n  'PREPARE',\n  'PRIMARY',\n  'PROCEDURE',\n  'RANGE',\n  'RANK',\n  'READS',\n  'REAL',\n  'RECURSIVE',\n  'REF',\n  'REFERENCES',\n  'REFERENCING',\n  'REGR_AVGX',\n  'REGR_AVGY',\n  'REGR_COUNT',\n  'REGR_INTERCEPT',\n  'REGR_R2',\n  'REGR_SLOPE',\n  'REGR_SXX',\n  'REGR_SXY',\n  'REGR_SYY',\n  'RELEASE',\n  'RESULT',\n  'RETURN',\n  'RETURNS',\n  'REVOKE',\n  'RIGHT',\n  'ROLLBACK',\n  'ROLLUP',\n  'ROW',\n  'ROWS',\n  'ROW_NUMBER',\n  'SAVEPOINT',\n  'SCOPE',\n  'SCROLL',\n  'SEARCH',\n  'SECOND',\n  'SELECT',\n  'SENSITIVE',\n  'SESSION_USER',\n  'SET',\n  'SIMILAR',\n  'SMALLINT',\n  'SOME',\n  'SPECIFIC',\n  'SPECIFICTYPE',\n  'SQL',\n  'SQLEXCEPTION',\n  'SQLSTATE',\n  'SQLWARNING',\n  'SQRT',\n  'START',\n  'STATIC',\n  'STDDEV_POP',\n  'STDDEV_SAMP',\n  'SUBMULTISET',\n  'SUBSTRING',\n  'SUBSTRING_REGEX',\n  'SUM',\n  'SYMMETRIC',\n  'SYSTEM',\n  'SYSTEM_USER',\n  'TABLE',\n  'TABLESAMPLE',\n  'THEN',\n  'TIME',\n  'TIMESTAMP',\n  'TIMEZONE_HOUR',\n  'TIMEZONE_MINUTE',\n  'TO',\n  'TRAILING',\n  'TRANSLATE',\n  'TRANSLATE_REGEX',\n  'TRANSLATION',\n  'TREAT',\n  'TRIGGER',\n  'TRIM',\n  'TRUE',\n  'UESCAPE',\n  'UNION',\n  'UNIQUE',\n  'UNKNOWN',\n  'UNNEST',\n  'UPDATE',\n  'UPPER',\n  'USER',\n  'VALUE',\n  'VALUES',\n  'VARBINARY',\n  'VARCHAR',\n  'VARYING',\n  'VAR_POP',\n  'VAR_SAMP',\n  'WHENEVER',\n  'WIDTH_BUCKET',\n  'WINDOW',\n  'WITHIN',\n  'WITHOUT',\n  'YEAR',\n];\n\n/**\n * Priority 1 (first)\n * keywords that begin a new statement\n * will begin new indented block\n */\nconst reservedCommands = [\n  'ADD',\n  'ALTER COLUMN',\n  'ALTER TABLE',\n  'CREATE TABLE',\n  'DROP TABLE',\n  'END',\n  'FETCH FIRST',\n  'FETCH NEXT',\n  'FETCH PRIOR',\n  'FETCH LAST',\n  'FETCH ABSOLUTE',\n  'FETCH RELATIVE',\n  'FROM',\n  'GROUP BY',\n  'HAVING',\n  'INSERT INTO',\n  'LIMIT',\n  'OFFSET',\n  'ORDER BY',\n  'SELECT',\n  'SET SCHEMA',\n  'SET',\n  'UPDATE',\n  'VALUES',\n  'WHERE',\n  'WITH',\n];\n\n/**\n * Priority 2\n * commands that operate on two tables or subqueries\n * two main categories: joins and boolean set operators\n */\nconst reservedBinaryCommands = [\n  // set booleans\n  'INTERSECT',\n  'INTERSECT ALL',\n  'INTERSECT DISTINCT',\n  'UNION',\n  'UNION ALL',\n  'UNION DISTINCT',\n  'EXCEPT',\n  'EXCEPT ALL',\n  'EXCEPT DISTINCT',\n  // joins\n  'JOIN',\n  'INNER JOIN',\n  'LEFT JOIN',\n  'LEFT OUTER JOIN',\n  'RIGHT JOIN',\n  'RIGHT OUTER JOIN',\n  'FULL JOIN',\n  'FULL OUTER JOIN',\n  'CROSS JOIN',\n  'NATURAL JOIN',\n];\n\n/**\n * Priority 3\n * keywords that follow a previous Statement, must be attached to subsequent data\n * can be fully inline or on newline with optional indent\n */\nconst reservedDependentClauses = ['WHEN', 'ELSE'];\n\nexport default class StandardSqlFormatter extends Formatter {\n  static reservedCommands = reservedCommands;\n  static reservedBinaryCommands = reservedBinaryCommands;\n  static reservedDependentClauses = reservedDependentClauses;\n  static reservedJoinConditions = ['ON', 'USING'];\n  static reservedLogicalOperators = ['AND', 'OR'];\n  static reservedKeywords = dedupe(reservedKeywords);\n  static stringTypes: StringPatternType[] = [`\"\"`, \"''\", '``'];\n  static blockStart = ['(', 'CASE'];\n  static blockEnd = [')', 'END'];\n  static indexedPlaceholderTypes = ['?'];\n  static namedPlaceholderTypes = [];\n  static lineCommentTypes = ['--'];\n  static operators = [];\n\n  tokenizer() {\n    return new Tokenizer({\n      reservedCommands: StandardSqlFormatter.reservedCommands,\n      reservedBinaryCommands: StandardSqlFormatter.reservedBinaryCommands,\n      reservedDependentClauses: StandardSqlFormatter.reservedDependentClauses,\n      reservedJoinConditions: StandardSqlFormatter.reservedJoinConditions,\n      reservedLogicalOperators: StandardSqlFormatter.reservedLogicalOperators,\n      reservedKeywords: StandardSqlFormatter.reservedKeywords,\n      stringTypes: StandardSqlFormatter.stringTypes,\n      blockStart: StandardSqlFormatter.blockStart,\n      blockEnd: StandardSqlFormatter.blockEnd,\n      indexedPlaceholderTypes: StandardSqlFormatter.indexedPlaceholderTypes,\n      namedPlaceholderTypes: StandardSqlFormatter.namedPlaceholderTypes,\n      lineCommentTypes: StandardSqlFormatter.lineCommentTypes,\n    });\n  }\n}\n","import Formatter from '../core/Formatter';\nimport Tokenizer from '../core/Tokenizer';\nimport type { StringPatternType } from '../core/regexFactory';\nimport { dedupe } from '../utils';\n\n/**\n * Priority 5 (last)\n * Full list of reserved functions\n * distinct from Keywords due to interaction with parentheses\n */\n// https://docs.microsoft.com/en-us/sql/t-sql/functions/functions?view=sql-server-ver15\nconst reservedFunctions = {\n  aggregate: [\n    'APPROX_COUNT_DISTINCT',\n    'AVG',\n    'CHECKSUM_AGG',\n    'COUNT',\n    'COUNT_BIG',\n    'GROUPING',\n    'GROUPING_ID',\n    'MAX',\n    'MIN',\n    'STDEV',\n    'STDEVP',\n    'SUM',\n    'VAR',\n    'VARP',\n  ],\n  analytic: [\n    'CUME_DIST',\n    'FIRST_VALUE',\n    'LAG',\n    'LAST_VALUE',\n    'LEAD',\n    'PERCENTILE_CONT',\n    'PERCENTILE_DISC',\n    'PERCENT_RANK',\n    'Collation - COLLATIONPROPERTY',\n    'Collation - TERTIARY_WEIGHTS',\n  ],\n  configuration: [\n    '@@DBTS',\n    '@@LANGID',\n    '@@LANGUAGE',\n    '@@LOCK_TIMEOUT',\n    '@@MAX_CONNECTIONS',\n    '@@MAX_PRECISION',\n    '@@NESTLEVEL',\n    '@@OPTIONS',\n    '@@REMSERVER',\n    '@@SERVERNAME',\n    '@@SERVICENAME',\n    '@@SPID',\n    '@@TEXTSIZE',\n    '@@VERSION',\n  ],\n  conversion: ['CAST', 'CONVERT', 'PARSE', 'TRY_CAST', 'TRY_CONVERT', 'TRY_PARSE'],\n  cryptographic: [\n    'ASYMKEY_ID',\n    'ASYMKEYPROPERTY',\n    'CERTPROPERTY',\n    'CERT_ID',\n    'CRYPT_GEN_RANDOM',\n    'DECRYPTBYASYMKEY',\n    'DECRYPTBYCERT',\n    'DECRYPTBYKEY',\n    'DECRYPTBYKEYAUTOASYMKEY',\n    'DECRYPTBYKEYAUTOCERT',\n    'DECRYPTBYPASSPHRASE',\n    'ENCRYPTBYASYMKEY',\n    'ENCRYPTBYCERT',\n    'ENCRYPTBYKEY',\n    'ENCRYPTBYPASSPHRASE',\n    'HASHBYTES',\n    'IS_OBJECTSIGNED',\n    'KEY_GUID',\n    'KEY_ID',\n    'KEY_NAME',\n    'SIGNBYASYMKEY',\n    'SIGNBYCERT',\n    'SYMKEYPROPERTY',\n    'VERIFYSIGNEDBYCERT',\n    'VERIFYSIGNEDBYASYMKEY',\n  ],\n  cursor: ['@@CURSOR_ROWS', '@@FETCH_STATUS', 'CURSOR_STATUS'],\n  dataType: [\n    'DATALENGTH',\n    'IDENT_CURRENT',\n    'IDENT_INCR',\n    'IDENT_SEED',\n    'IDENTITY',\n    'SQL_VARIANT_PROPERTY',\n  ],\n  datetime: [\n    '@@DATEFIRST',\n    'CURRENT_TIMESTAMP',\n    'CURRENT_TIMEZONE',\n    'CURRENT_TIMEZONE_ID',\n    'DATEADD',\n    'DATEDIFF',\n    'DATEDIFF_BIG',\n    'DATEFROMPARTS',\n    'DATENAME',\n    'DATEPART',\n    'DATETIME2FROMPARTS',\n    'DATETIMEFROMPARTS',\n    'DATETIMEOFFSETFROMPARTS',\n    'DAY',\n    'EOMONTH',\n    'GETDATE',\n    'GETUTCDATE',\n    'ISDATE',\n    'MONTH',\n    'SMALLDATETIMEFROMPARTS',\n    'SWITCHOFFSET',\n    'SYSDATETIME',\n    'SYSDATETIMEOFFSET',\n    'SYSUTCDATETIME',\n    'TIMEFROMPARTS',\n    'TODATETIMEOFFSET',\n    'YEAR',\n    'JSON',\n    'ISJSON',\n    'JSON_VALUE',\n    'JSON_QUERY',\n    'JSON_MODIFY',\n  ],\n  mathematical: [\n    'ABS',\n    'ACOS',\n    'ASIN',\n    'ATAN',\n    'ATN2',\n    'CEILING',\n    'COS',\n    'COT',\n    'DEGREES',\n    'EXP',\n    'FLOOR',\n    'LOG',\n    'LOG10',\n    'PI',\n    'POWER',\n    'RADIANS',\n    'RAND',\n    'ROUND',\n    'SIGN',\n    'SIN',\n    'SQRT',\n    'SQUARE',\n    'TAN',\n    'CHOOSE',\n    'GREATEST',\n    'IIF',\n    'LEAST',\n  ],\n  metadata: [\n    '@@PROCID',\n    'APP_NAME',\n    'APPLOCK_MODE',\n    'APPLOCK_TEST',\n    'ASSEMBLYPROPERTY',\n    'COL_LENGTH',\n    'COL_NAME',\n    'COLUMNPROPERTY',\n    'DATABASEPROPERTYEX',\n    'DB_ID',\n    'DB_NAME',\n    'FILE_ID',\n    'FILE_IDEX',\n    'FILE_NAME',\n    'FILEGROUP_ID',\n    'FILEGROUP_NAME',\n    'FILEGROUPPROPERTY',\n    'FILEPROPERTY',\n    'FILEPROPERTYEX',\n    'FULLTEXTCATALOGPROPERTY',\n    'FULLTEXTSERVICEPROPERTY',\n    'INDEX_COL',\n    'INDEXKEY_PROPERTY',\n    'INDEXPROPERTY',\n    'NEXT VALUE FOR',\n    'OBJECT_DEFINITION',\n    'OBJECT_ID',\n    'OBJECT_NAME',\n    'OBJECT_SCHEMA_NAME',\n    'OBJECTPROPERTY',\n    'OBJECTPROPERTYEX',\n    'ORIGINAL_DB_NAME',\n    'PARSENAME',\n    'SCHEMA_ID',\n    'SCHEMA_NAME',\n    'SCOPE_IDENTITY',\n    'SERVERPROPERTY',\n    'STATS_DATE',\n    'TYPE_ID',\n    'TYPE_NAME',\n    'TYPEPROPERTY',\n  ],\n  ranking: ['DENSE_RANK', 'NTILE', 'RANK', 'ROW_NUMBER', 'PUBLISHINGSERVERNAME'],\n  security: [\n    'CERTENCODED',\n    'CERTPRIVATEKEY',\n    'CURRENT_USER',\n    'DATABASE_PRINCIPAL_ID',\n    'HAS_DBACCESS',\n    'HAS_PERMS_BY_NAME',\n    'IS_MEMBER',\n    'IS_ROLEMEMBER',\n    'IS_SRVROLEMEMBER',\n    'LOGINPROPERTY',\n    'ORIGINAL_LOGIN',\n    'PERMISSIONS',\n    'PWDENCRYPT',\n    'PWDCOMPARE',\n    'SESSION_USER',\n    'SESSIONPROPERTY',\n    'SUSER_ID',\n    'SUSER_NAME',\n    'SUSER_SID',\n    'SUSER_SNAME',\n    'SYSTEM_USER',\n    'USER',\n    'USER_ID',\n    'USER_NAME',\n  ],\n  string: [\n    'ASCII',\n    'CHAR',\n    'CHARINDEX',\n    'CONCAT',\n    'CONCAT_WS',\n    'DIFFERENCE',\n    'FORMAT',\n    'LEFT',\n    'LEN',\n    'LOWER',\n    'LTRIM',\n    'NCHAR',\n    'PATINDEX',\n    'QUOTENAME',\n    'REPLACE',\n    'REPLICATE',\n    'REVERSE',\n    'RIGHT',\n    'RTRIM',\n    'SOUNDEX',\n    'SPACE',\n    'STR',\n    'STRING_AGG',\n    'STRING_ESCAPE',\n    'STUFF',\n    'SUBSTRING',\n    'TRANSLATE',\n    'TRIM',\n    'UNICODE',\n    'UPPER',\n  ],\n  system: [\n    '$PARTITION',\n    '@@ERROR',\n    '@@IDENTITY',\n    '@@PACK_RECEIVED',\n    '@@ROWCOUNT',\n    '@@TRANCOUNT',\n    'BINARY_CHECKSUM',\n    'CHECKSUM',\n    'COMPRESS',\n    'CONNECTIONPROPERTY',\n    'CONTEXT_INFO',\n    'CURRENT_REQUEST_ID',\n    'CURRENT_TRANSACTION_ID',\n    'DECOMPRESS',\n    'ERROR_LINE',\n    'ERROR_MESSAGE',\n    'ERROR_NUMBER',\n    'ERROR_PROCEDURE',\n    'ERROR_SEVERITY',\n    'ERROR_STATE',\n    'FORMATMESSAGE',\n    'GET_FILESTREAM_TRANSACTION_CONTEXT',\n    'GETANSINULL',\n    'HOST_ID',\n    'HOST_NAME',\n    'ISNULL',\n    'ISNUMERIC',\n    'MIN_ACTIVE_ROWVERSION',\n    'NEWID',\n    'NEWSEQUENTIALID',\n    'ROWCOUNT_BIG',\n    'SESSION_CONTEXT',\n    'XACT_STATE',\n  ],\n  statistical: [\n    '@@CONNECTIONS',\n    '@@CPU_BUSY',\n    '@@IDLE',\n    '@@IO_BUSY',\n    '@@PACK_SENT',\n    '@@PACKET_ERRORS',\n    '@@TIMETICKS',\n    '@@TOTAL_ERRORS',\n    '@@TOTAL_READ',\n    '@@TOTAL_WRITE',\n    'TEXTPTR',\n    'TEXTVALID',\n  ],\n  trigger: ['COLUMNS_UPDATED', 'EVENTDATA', 'TRIGGER_NESTLEVEL', 'UPDATE'],\n};\n\n// TODO: dedupe these reserved word lists\n// https://docs.microsoft.com/en-us/sql/t-sql/language-elements/reserved-keywords-transact-sql?view=sql-server-ver15\n/**\n * Priority 5 (last)\n * Full list of reserved words\n * any words that are in a higher priority are removed\n */\nconst reservedKeywords = {\n  standard: [\n    'ADD',\n    'ALL',\n    'ALTER',\n    'AND',\n    'ANY',\n    'AS',\n    'ASC',\n    'AUTHORIZATION',\n    'BACKUP',\n    'BEGIN',\n    'BETWEEN',\n    'BREAK',\n    'BROWSE',\n    'BULK',\n    'BY',\n    'CASCADE',\n    'CASE',\n    'CHECK',\n    'CHECKPOINT',\n    'CLOSE',\n    'CLUSTERED',\n    'COALESCE',\n    'COLLATE',\n    'COLUMN',\n    'COMMIT',\n    'COMPUTE',\n    'CONSTRAINT',\n    'CONTAINS',\n    'CONTAINSTABLE',\n    'CONTINUE',\n    'CONVERT',\n    'CREATE',\n    'CROSS',\n    'CURRENT',\n    'CURRENT_DATE',\n    'CURRENT_TIME',\n    'CURRENT_TIMESTAMP',\n    'CURRENT_USER',\n    'CURSOR',\n    'DATABASE',\n    'DBCC',\n    'DEALLOCATE',\n    'DECLARE',\n    'DEFAULT',\n    'DELETE',\n    'DENY',\n    'DESC',\n    'DISK',\n    'DISTINCT',\n    'DISTRIBUTED',\n    'DOUBLE',\n    'DROP',\n    'DUMP',\n    'ERRLVL',\n    'ESCAPE',\n    'EXEC',\n    'EXECUTE',\n    'EXISTS',\n    'EXIT',\n    'EXTERNAL',\n    'FETCH',\n    'FILE',\n    'FILLFACTOR',\n    'FOR',\n    'FOREIGN',\n    'FREETEXT',\n    'FREETEXTTABLE',\n    'FROM',\n    'FULL',\n    'FUNCTION',\n    'GOTO',\n    'GRANT',\n    'GROUP',\n    'HAVING',\n    'HOLDLOCK',\n    'IDENTITY',\n    'IDENTITYCOL',\n    'IDENTITY_INSERT',\n    'IF',\n    'IN',\n    'INDEX',\n    'INNER',\n    'INSERT',\n    'INTERSECT',\n    'INTO',\n    'IS',\n    'JOIN',\n    'KEY',\n    'KILL',\n    'LEFT',\n    'LIKE',\n    'LINENO',\n    'LOAD',\n    'MERGE',\n    'NATIONAL',\n    'NOCHECK',\n    'NONCLUSTERED',\n    'NOT',\n    'NULL',\n    'NULLIF',\n    'OF',\n    'OFF',\n    'OFFSETS',\n    'ON DELETE',\n    'ON UPDATE',\n    'OPEN',\n    'OPENDATASOURCE',\n    'OPENQUERY',\n    'OPENROWSET',\n    'OPENXML',\n    'OPTION',\n    'OR',\n    'ORDER',\n    'OUTER',\n    'OVER',\n    'PERCENT',\n    'PIVOT',\n    'PLAN',\n    'PRECISION',\n    'PRIMARY',\n    'PRINT',\n    'PROC',\n    'PROCEDURE',\n    'PUBLIC',\n    'RAISERROR',\n    'READ',\n    'READTEXT',\n    'RECONFIGURE',\n    'REFERENCES',\n    'REPLICATION',\n    'RESTORE',\n    'RESTRICT',\n    'RETURN',\n    'REVERT',\n    'REVOKE',\n    'RIGHT',\n    'ROLLBACK',\n    'ROWCOUNT',\n    'ROWGUIDCOL',\n    'RULE',\n    'SAVE',\n    'SCHEMA',\n    'SECURITYAUDIT',\n    'SELECT',\n    'SEMANTICKEYPHRASETABLE',\n    'SEMANTICSIMILARITYDETAILSTABLE',\n    'SEMANTICSIMILARITYTABLE',\n    'SESSION_USER',\n    'SET',\n    'SETUSER',\n    'SHUTDOWN',\n    'SOME',\n    'STATISTICS',\n    'SYSTEM_USER',\n    'TABLE',\n    'TABLESAMPLE',\n    'TEXTSIZE',\n    'THEN',\n    'TO',\n    'TOP',\n    'TRAN',\n    'TRANSACTION',\n    'TRIGGER',\n    'TRUNCATE',\n    'TRY_CONVERT',\n    'TSEQUAL',\n    'UNION',\n    'UNIQUE',\n    'UNPIVOT',\n    'UPDATE',\n    'UPDATETEXT',\n    'USE',\n    'USER',\n    'VALUES',\n    'VARYING',\n    'VIEW',\n    'WAITFOR',\n    'WHERE',\n    'WHILE',\n    'WITH',\n    'WITHIN GROUP',\n    'WRITETEXT',\n  ],\n  odbc: [\n    'ABSOLUTE',\n    'ACTION',\n    'ADA',\n    'ADD',\n    'ALL',\n    'ALLOCATE',\n    'ALTER',\n    'AND',\n    'ANY',\n    'ARE',\n    'AS',\n    'ASC',\n    'ASSERTION',\n    'AT',\n    'AUTHORIZATION',\n    'AVG',\n    'BEGIN',\n    'BETWEEN',\n    'BIT',\n    'BIT_LENGTH',\n    'BOTH',\n    'BY',\n    'CASCADE',\n    'CASCADED',\n    'CASE',\n    'CAST',\n    'CATALOG',\n    'CHAR',\n    'CHARACTER',\n    'CHARACTER_LENGTH',\n    'CHAR_LENGTH',\n    'CHECK',\n    'CLOSE',\n    'COALESCE',\n    'COLLATE',\n    'COLLATION',\n    'COLUMN',\n    'COMMIT',\n    'CONNECT',\n    'CONNECTION',\n    'CONSTRAINT',\n    'CONSTRAINTS',\n    'CONTINUE',\n    'CONVERT',\n    'CORRESPONDING',\n    'COUNT',\n    'CREATE',\n    'CROSS',\n    'CURRENT',\n    'CURRENT_DATE',\n    'CURRENT_TIME',\n    'CURRENT_TIMESTAMP',\n    'CURRENT_USER',\n    'CURSOR',\n    'DATE',\n    'DAY',\n    'DEALLOCATE',\n    'DEC',\n    'DECIMAL',\n    'DECLARE',\n    'DEFAULT',\n    'DEFERRABLE',\n    'DEFERRED',\n    'DELETE',\n    'DESC',\n    'DESCRIBE',\n    'DESCRIPTOR',\n    'DIAGNOSTICS',\n    'DISCONNECT',\n    'DISTINCT',\n    'DOMAIN',\n    'DOUBLE',\n    'DROP',\n    'END-EXEC',\n    'ESCAPE',\n    'EXCEPTION',\n    'EXEC',\n    'EXECUTE',\n    'EXISTS',\n    'EXTERNAL',\n    'EXTRACT',\n    'FALSE',\n    'FETCH',\n    'FIRST',\n    'FLOAT',\n    'FOR',\n    'FOREIGN',\n    'FORTRAN',\n    'FOUND',\n    'FROM',\n    'FULL',\n    'GET',\n    'GLOBAL',\n    'GO',\n    'GOTO',\n    'GRANT',\n    'GROUP',\n    'HAVING',\n    'HOUR',\n    'IDENTITY',\n    'IMMEDIATE',\n    'IN',\n    'INCLUDE',\n    'INDEX',\n    'INDICATOR',\n    'INITIALLY',\n    'INNER',\n    'INPUT',\n    'INSENSITIVE',\n    'INSERT',\n    'INT',\n    'INTEGER',\n    'INTERSECT',\n    'INTERVAL',\n    'INTO',\n    'IS',\n    'ISOLATION',\n    'JOIN',\n    'KEY',\n    'LANGUAGE',\n    'LAST',\n    'LEADING',\n    'LEFT',\n    'LEVEL',\n    'LIKE',\n    'LOCAL',\n    'LOWER',\n    'MATCH',\n    'MAX',\n    'MIN',\n    'MINUTE',\n    'MODULE',\n    'MONTH',\n    'NAMES',\n    'NATIONAL',\n    'NATURAL',\n    'NCHAR',\n    'NEXT',\n    'NO',\n    'NONE',\n    'NOT',\n    'NULL',\n    'NULLIF',\n    'NUMERIC',\n    'OCTET_LENGTH',\n    'OF',\n    'ONLY',\n    'OPEN',\n    'OPTION',\n    'OR',\n    'ORDER',\n    'OUTER',\n    'OUTPUT',\n    'OVERLAPS',\n    'PAD',\n    'PARTIAL',\n    'PASCAL',\n    'POSITION',\n    'PRECISION',\n    'PREPARE',\n    'PRESERVE',\n    'PRIMARY',\n    'PRIOR',\n    'PRIVILEGES',\n    'PROCEDURE',\n    'PUBLIC',\n    'READ',\n    'REAL',\n    'REFERENCES',\n    'RELATIVE',\n    'RESTRICT',\n    'REVOKE',\n    'RIGHT',\n    'ROLLBACK',\n    'ROWS',\n    'SCHEMA',\n    'SCROLL',\n    'SECOND',\n    'SECTION',\n    'SELECT',\n    'SESSION',\n    'SESSION_USER',\n    'SET',\n    'SIZE',\n    'SMALLINT',\n    'SOME',\n    'SPACE',\n    'SQL',\n    'SQLCA',\n    'SQLCODE',\n    'SQLERROR',\n    'SQLSTATE',\n    'SQLWARNING',\n    'SUBSTRING',\n    'SUM',\n    'SYSTEM_USER',\n    'TABLE',\n    'TEMPORARY',\n    'TIME',\n    'TIMESTAMP',\n    'TIMEZONE_HOUR',\n    'TIMEZONE_MINUTE',\n    'TO',\n    'TRAILING',\n    'TRANSACTION',\n    'TRANSLATE',\n    'TRANSLATION',\n    'TRIM',\n    'TRUE',\n    'UNION',\n    'UNIQUE',\n    'UNKNOWN',\n    'UPDATE',\n    'UPPER',\n    'USAGE',\n    'USER',\n    'VALUE',\n    'VALUES',\n    'VARCHAR',\n    'VARYING',\n    'VIEW',\n    'WHENEVER',\n    'WHERE',\n    'WITH',\n    'WORK',\n    'WRITE',\n    'YEAR',\n    'ZONE',\n  ],\n  future: [\n    'ABSOLUTE',\n    'ACTION',\n    'ADMIN',\n    'AFTER',\n    'AGGREGATE',\n    'ALIAS',\n    'ALLOCATE',\n    'ARE',\n    'ARRAY',\n    'ASENSITIVE',\n    'ASSERTION',\n    'ASYMMETRIC',\n    'AT',\n    'ATOMIC',\n    'BEFORE',\n    'BINARY',\n    'BIT',\n    'BLOB',\n    'BOOLEAN',\n    'BOTH',\n    'BREADTH',\n    'CALL',\n    'CALLED',\n    'CARDINALITY',\n    'CASCADED',\n    'CAST',\n    'CATALOG',\n    'CHAR',\n    'CHARACTER',\n    'CLASS',\n    'CLOB',\n    'COLLATION',\n    'COLLECT',\n    'COMPLETION',\n    'CONDITION',\n    'CONNECT',\n    'CONNECTION',\n    'CONSTRAINTS',\n    'CONSTRUCTOR',\n    'CORR',\n    'CORRESPONDING',\n    'COVAR_POP',\n    'COVAR_SAMP',\n    'CUBE',\n    'CUME_DIST',\n    'CURRENT_CATALOG',\n    'CURRENT_DEFAULT_TRANSFORM_GROUP',\n    'CURRENT_PATH',\n    'CURRENT_ROLE',\n    'CURRENT_SCHEMA',\n    'CURRENT_TRANSFORM_GROUP_FOR_TYPE',\n    'CYCLE',\n    'DATA',\n    'DATE',\n    'DAY',\n    'DEC',\n    'DECIMAL',\n    'DEFERRABLE',\n    'DEFERRED',\n    'DEPTH',\n    'DEREF',\n    'DESCRIBE',\n    'DESCRIPTOR',\n    'DESTROY',\n    'DESTRUCTOR',\n    'DETERMINISTIC',\n    'DIAGNOSTICS',\n    'DICTIONARY',\n    'DISCONNECT',\n    'DOMAIN',\n    'DYNAMIC',\n    'EACH',\n    'ELEMENT',\n    'END-EXEC',\n    'EQUALS',\n    'EVERY',\n    'FALSE',\n    'FILTER',\n    'FIRST',\n    'FLOAT',\n    'FOUND',\n    'FREE',\n    'FULLTEXTTABLE',\n    'FUSION',\n    'GENERAL',\n    'GET',\n    'GLOBAL',\n    'GO',\n    'GROUPING',\n    'HOLD',\n    'HOST',\n    'HOUR',\n    'IGNORE',\n    'IMMEDIATE',\n    'INDICATOR',\n    'INITIALIZE',\n    'INITIALLY',\n    'INOUT',\n    'INPUT',\n    'INT',\n    'INTEGER',\n    'INTERSECTION',\n    'INTERVAL',\n    'ISOLATION',\n    'ITERATE',\n    'LANGUAGE',\n    'LARGE',\n    'LAST',\n    'LATERAL',\n    'LEADING',\n    'LESS',\n    'LEVEL',\n    'LIKE_REGEX',\n    'LIMIT',\n    'LN',\n    'LOCAL',\n    'LOCALTIME',\n    'LOCALTIMESTAMP',\n    'LOCATOR',\n    'MAP',\n    'MATCH',\n    'MEMBER',\n    'METHOD',\n    'MINUTE',\n    'MOD',\n    'MODIFIES',\n    'MODIFY',\n    'MODULE',\n    'MONTH',\n    'MULTISET',\n    'NAMES',\n    'NATURAL',\n    'NCHAR',\n    'NCLOB',\n    'NEW',\n    'NEXT',\n    'NO',\n    'NONE',\n    'NORMALIZE',\n    'NUMERIC',\n    'OBJECT',\n    'OCCURRENCES_REGEX',\n    'OLD',\n    'ONLY',\n    'OPERATION',\n    'ORDINALITY',\n    'OUT',\n    'OUTPUT',\n    'OVERLAY',\n    'PAD',\n    'PARAMETER',\n    'PARAMETERS',\n    'PARTIAL',\n    'PARTITION',\n    'PATH',\n    'PERCENTILE_CONT',\n    'PERCENTILE_DISC',\n    'PERCENT_RANK',\n    'POSITION_REGEX',\n    'POSTFIX',\n    'PREFIX',\n    'PREORDER',\n    'PREPARE',\n    'PRESERVE',\n    'PRIOR',\n    'PRIVILEGES',\n    'RANGE',\n    'READS',\n    'REAL',\n    'RECURSIVE',\n    'REF',\n    'REFERENCING',\n    'REGR_AVGX',\n    'REGR_AVGY',\n    'REGR_COUNT',\n    'REGR_INTERCEPT',\n    'REGR_R2',\n    'REGR_SLOPE',\n    'REGR_SXX',\n    'REGR_SXY',\n    'REGR_SYY',\n    'RELATIVE',\n    'RELEASE',\n    'RESULT',\n    'RETURNS',\n    'ROLE',\n    'ROLLUP',\n    'ROUTINE',\n    'ROW',\n    'ROWS',\n    'SAVEPOINT',\n    'SCOPE',\n    'SCROLL',\n    'SEARCH',\n    'SECOND',\n    'SECTION',\n    'SENSITIVE',\n    'SEQUENCE',\n    'SESSION',\n    'SETS',\n    'SIMILAR',\n    'SIZE',\n    'SMALLINT',\n    'SPACE',\n    'SPECIFIC',\n    'SPECIFICTYPE',\n    'SQL',\n    'SQLEXCEPTION',\n    'SQLSTATE',\n    'SQLWARNING',\n    'START',\n    'STATE',\n    'STATEMENT',\n    'STATIC',\n    'STDDEV_POP',\n    'STDDEV_SAMP',\n    'STRUCTURE',\n    'SUBMULTISET',\n    'SUBSTRING_REGEX',\n    'SYMMETRIC',\n    'SYSTEM',\n    'TEMPORARY',\n    'TERMINATE',\n    'THAN',\n    'TIME',\n    'TIMESTAMP',\n    'TIMEZONE_HOUR',\n    'TIMEZONE_MINUTE',\n    'TRAILING',\n    'TRANSLATE_REGEX',\n    'TRANSLATION',\n    'TREAT',\n    'TRUE',\n    'UESCAPE',\n    'UNDER',\n    'UNKNOWN',\n    'UNNEST',\n    'USAGE',\n    'USING',\n    'VALUE',\n    'VARCHAR',\n    'VARIABLE',\n    'VAR_POP',\n    'VAR_SAMP',\n    'WHENEVER',\n    'WIDTH_BUCKET',\n    'WINDOW',\n    'WITHIN',\n    'WITHOUT',\n    'WORK',\n    'WRITE',\n    'XMLAGG',\n    'XMLATTRIBUTES',\n    'XMLBINARY',\n    'XMLCAST',\n    'XMLCOMMENT',\n    'XMLCONCAT',\n    'XMLDOCUMENT',\n    'XMLELEMENT',\n    'XMLEXISTS',\n    'XMLFOREST',\n    'XMLITERATE',\n    'XMLNAMESPACES',\n    'XMLPARSE',\n    'XMLPI',\n    'XMLQUERY',\n    'XMLSERIALIZE',\n    'XMLTABLE',\n    'XMLTEXT',\n    'XMLVALIDATE',\n    'YEAR',\n    'ZONE',\n  ],\n};\n\n/**\n * Priority 1 (first)\n * keywords that begin a new statement\n * will begin new indented block\n */\n// https://docs.microsoft.com/en-us/sql/t-sql/statements/statements?view=sql-server-ver15\nconst reservedCommands = [\n  'ADD SENSITIVITY CLASSIFICATION',\n  'ADD SIGNATURE',\n  'AGGREGATE',\n  'ANSI_DEFAULTS',\n  'ANSI_NULLS',\n  'ANSI_NULL_DFLT_OFF',\n  'ANSI_NULL_DFLT_ON',\n  'ANSI_PADDING',\n  'ANSI_WARNINGS',\n  'APPLICATION ROLE',\n  'ARITHABORT',\n  'ARITHIGNORE',\n  'ASSEMBLY',\n  'ASYMMETRIC KEY',\n  'AUTHORIZATION',\n  'AVAILABILITY GROUP',\n  'BACKUP',\n  'BACKUP CERTIFICATE',\n  'BACKUP MASTER KEY',\n  'BACKUP SERVICE MASTER KEY',\n  'BEGIN CONVERSATION TIMER',\n  'BEGIN DIALOG CONVERSATION',\n  'BROKER PRIORITY',\n  'BULK INSERT',\n  'CERTIFICATE',\n  'CLOSE MASTER KEY',\n  'CLOSE SYMMETRIC KEY',\n  'COLLATE',\n  'COLUMN ENCRYPTION KEY',\n  'COLUMN MASTER KEY',\n  'COLUMNSTORE INDEX',\n  'CONCAT_NULL_YIELDS_NULL',\n  'CONTEXT_INFO',\n  'CONTRACT',\n  'CREDENTIAL',\n  'CRYPTOGRAPHIC PROVIDER',\n  'CURSOR_CLOSE_ON_COMMIT',\n  'DATABASE',\n  'DATABASE AUDIT SPECIFICATION',\n  'DATABASE ENCRYPTION KEY',\n  'DATABASE HADR',\n  'DATABASE SCOPED CONFIGURATION',\n  'DATABASE SCOPED CREDENTIAL',\n  'DATABASE SET',\n  'DATEFIRST',\n  'DATEFORMAT',\n  'DEADLOCK_PRIORITY',\n  'DEFAULT',\n  'DELETE',\n  'DENY',\n  'DENY XML',\n  'DISABLE TRIGGER',\n  'ENABLE TRIGGER',\n  'END CONVERSATION',\n  'ENDPOINT',\n  'EVENT NOTIFICATION',\n  'EVENT SESSION',\n  'EXECUTE AS',\n  'EXTERNAL DATA SOURCE',\n  'EXTERNAL FILE FORMAT',\n  'EXTERNAL LANGUAGE',\n  'EXTERNAL LIBRARY',\n  'EXTERNAL RESOURCE POOL',\n  'EXTERNAL TABLE',\n  'FIPS_FLAGGER',\n  'FMTONLY',\n  'FORCEPLAN',\n  'FULLTEXT CATALOG',\n  'FULLTEXT INDEX',\n  'FULLTEXT STOPLIST',\n  'FUNCTION',\n  'GET CONVERSATION GROUP',\n  'GET_TRANSMISSION_STATUS',\n  'GRANT',\n  'GRANT XML',\n  'IDENTITY_INSERT',\n  'IMPLICIT_TRANSACTIONS',\n  'INDEX',\n  'INSERT',\n  'LANGUAGE',\n  'LOCK_TIMEOUT',\n  'LOGIN',\n  'MASTER KEY',\n  'MERGE',\n  'MESSAGE TYPE',\n  'MOVE CONVERSATION',\n  'NOCOUNT',\n  'NOEXEC',\n  'NUMERIC_ROUNDABORT',\n  'OFFSETS',\n  'OPEN MASTER KEY',\n  'OPEN SYMMETRIC KEY',\n  'PARSEONLY',\n  'PARTITION FUNCTION',\n  'PARTITION SCHEME',\n  'PROCEDURE',\n  'QUERY_GOVERNOR_COST_LIMIT',\n  'QUEUE',\n  'QUOTED_IDENTIFIER',\n  'RECEIVE',\n  'REMOTE SERVICE BINDING',\n  'REMOTE_PROC_TRANSACTIONS',\n  'RESOURCE GOVERNOR',\n  'RESOURCE POOL',\n  'RESTORE',\n  'RESTORE FILELISTONLY',\n  'RESTORE HEADERONLY',\n  'RESTORE LABELONLY',\n  'RESTORE MASTER KEY',\n  'RESTORE REWINDONLY',\n  'RESTORE SERVICE MASTER KEY',\n  'RESTORE VERIFYONLY',\n  'REVERT',\n  'REVOKE',\n  'REVOKE XML',\n  'ROLE',\n  'ROUTE',\n  'ROWCOUNT',\n  'RULE',\n  'SCHEMA',\n  'SEARCH PROPERTY LIST',\n  'SECURITY POLICY',\n  'SELECTIVE XML INDEX',\n  'SEND',\n  'SENSITIVITY CLASSIFICATION',\n  'SEQUENCE',\n  'SERVER AUDIT',\n  'SERVER AUDIT SPECIFICATION',\n  'SERVER CONFIGURATION',\n  'SERVER ROLE',\n  'SERVICE',\n  'SERVICE MASTER KEY',\n  'SET',\n  'SETUSER',\n  'SHOWPLAN_ALL',\n  'SHOWPLAN_TEXT',\n  'SHOWPLAN_XML',\n  'SIGNATURE',\n  'SPATIAL INDEX',\n  'STATISTICS',\n  'STATISTICS IO',\n  'STATISTICS PROFILE',\n  'STATISTICS TIME',\n  'STATISTICS XML',\n  'SYMMETRIC KEY',\n  'SYNONYM',\n  'TABLE',\n  'TABLE IDENTITY',\n  'TEXTSIZE',\n  'TRANSACTION ISOLATION LEVEL',\n  'TRIGGER',\n  'TRUNCATE TABLE',\n  'TYPE',\n  'UPDATE',\n  'UPDATE STATISTICS',\n  'USER',\n  'VIEW',\n  'WORKLOAD GROUP',\n  'XACT_ABORT',\n  'XML INDEX',\n  'XML SCHEMA COLLECTION',\n  // other\n  'ALTER COLUMN',\n  'ALTER TABLE',\n  'CREATE TABLE',\n  'FROM',\n  'GROUP BY',\n  'HAVING',\n  'INSERT INTO', // verify\n  'DROP TABLE', // verify\n  'SET SCHEMA', // verify\n  'LIMIT',\n  'OFFSET',\n  'ORDER BY',\n  'SELECT',\n  'VALUES',\n  'WHERE',\n  'WITH',\n];\n\n/**\n * Priority 2\n * commands that operate on two tables or subqueries\n * two main categories: joins and boolean set operators\n */\nconst reservedBinaryCommands = [\n  // set booleans\n  'INTERSECT',\n  'INTERSECT ALL',\n  'INTERSECT DISTINCT',\n  'UNION',\n  'UNION ALL',\n  'UNION DISTINCT',\n  'EXCEPT',\n  'EXCEPT ALL',\n  'EXCEPT DISTINCT',\n  'MINUS',\n  'MINUS ALL',\n  'MINUS DISTINCT',\n  // joins\n  'JOIN',\n  'INNER JOIN',\n  'LEFT JOIN',\n  'LEFT OUTER JOIN',\n  'RIGHT JOIN',\n  'RIGHT OUTER JOIN',\n  'FULL JOIN',\n  'FULL OUTER JOIN',\n  'CROSS JOIN',\n];\n\n/**\n * Priority 3\n * keywords that follow a previous Statement, must be attached to subsequent data\n * can be fully inline or on newline with optional indent\n */\nconst reservedDependentClauses = ['WHEN', 'ELSE'];\n\n// https://docs.microsoft.com/en-us/sql/t-sql/language-reference?view=sql-server-ver15\nexport default class TSqlFormatter extends Formatter {\n  static reservedCommands = reservedCommands;\n  static reservedBinaryCommands = reservedBinaryCommands;\n  static reservedDependentClauses = reservedDependentClauses;\n  static reservedJoinConditions = ['ON', 'USING'];\n  static reservedLogicalOperators = ['AND', 'OR'];\n  static reservedKeywords = dedupe([\n    ...Object.values(reservedFunctions).reduce((acc, arr) => [...acc, ...arr], []),\n    ...Object.values(reservedKeywords).reduce((acc, arr) => [...acc, ...arr], []),\n  ]);\n  static stringTypes: StringPatternType[] = [`\"\"`, \"N''\", \"''\", '[]', '``'];\n  static blockStart = ['(', 'CASE'];\n  static blockEnd = [')', 'END'];\n  static indexedPlaceholderTypes = [];\n  static namedPlaceholderTypes = ['@'];\n  static lineCommentTypes = ['--'];\n  static specialWordChars = { any: '#@' };\n  static operators = ['!<', '!>', '+=', '-=', '*=', '/=', '%=', '|=', '&=', '^=', '::'];\n\n  tokenizer() {\n    return new Tokenizer({\n      reservedCommands: TSqlFormatter.reservedCommands,\n      reservedBinaryCommands: TSqlFormatter.reservedBinaryCommands,\n      reservedDependentClauses: TSqlFormatter.reservedDependentClauses,\n      reservedJoinConditions: TSqlFormatter.reservedJoinConditions,\n      reservedLogicalOperators: TSqlFormatter.reservedLogicalOperators,\n      reservedKeywords: TSqlFormatter.reservedKeywords,\n      stringTypes: TSqlFormatter.stringTypes,\n      blockStart: TSqlFormatter.blockStart,\n      blockEnd: TSqlFormatter.blockEnd,\n      indexedPlaceholderTypes: TSqlFormatter.indexedPlaceholderTypes,\n      namedPlaceholderTypes: TSqlFormatter.namedPlaceholderTypes,\n      lineCommentTypes: TSqlFormatter.lineCommentTypes,\n      specialWordChars: TSqlFormatter.specialWordChars,\n      operators: TSqlFormatter.operators,\n      // TODO: Support for money constants\n    });\n  }\n}\n","import BigQueryFormatter from './languages/bigquery.formatter';\nimport Db2Formatter from './languages/db2.formatter';\nimport HiveFormatter from './languages/hive.formatter';\nimport MariaDbFormatter from './languages/mariadb.formatter';\nimport MySqlFormatter from './languages/mysql.formatter';\nimport N1qlFormatter from './languages/n1ql.formatter';\nimport PlSqlFormatter from './languages/plsql.formatter';\nimport PostgreSqlFormatter from './languages/postgresql.formatter';\nimport RedshiftFormatter from './languages/redshift.formatter';\nimport SparkSqlFormatter from './languages/sparksql.formatter';\nimport StandardSqlFormatter from './languages/standardsql.formatter';\nimport TSqlFormatter from './languages/tsql.formatter';\n\nimport { FormatOptions } from './types';\nimport { isNumber } from './utils';\n\nexport const formatters = {\n  bigquery: BigQueryFormatter,\n  db2: Db2Formatter,\n  hive: HiveFormatter,\n  mariadb: MariaDbFormatter,\n  mysql: MySqlFormatter,\n  n1ql: N1qlFormatter,\n  plsql: PlSqlFormatter,\n  postgresql: PostgreSqlFormatter,\n  redshift: RedshiftFormatter,\n  spark: SparkSqlFormatter,\n  sql: StandardSqlFormatter,\n  tsql: TSqlFormatter,\n};\nexport type SqlLanguage = keyof typeof formatters;\nexport const supportedDialects = Object.keys(formatters);\n\nexport type FormatFnOptions = FormatOptions & { language: SqlLanguage };\n\nconst defaultOptions: FormatFnOptions = {\n  language: 'sql',\n  tabWidth: 2,\n  useTabs: false,\n  keywordCase: 'preserve',\n  indentStyle: 'standard',\n  multilineLists: 'always',\n  logicalOperatorNewline: 'before',\n  aliasAs: 'preserve',\n  tabulateAlias: false,\n  commaPosition: 'after',\n  newlineBeforeOpenParen: true,\n  newlineBeforeCloseParen: true,\n  expressionWidth: 50,\n  linesBetweenQueries: 1,\n  denseOperators: false,\n  newlineBeforeSemicolon: false,\n};\n\n/**\n * Format whitespace in a query to make it easier to read.\n *\n * @param {string} query - input SQL query string\n * @param {FormatOptions} cfg Configuration options (see docs in README)\n * @return {string} formatted query\n */\nexport const format = (query: string, cfg: Partial<FormatFnOptions> = {}): string => {\n  if (typeof query !== 'string') {\n    throw new Error('Invalid query argument. Expected string, instead got ' + typeof query);\n  }\n\n  const options = validateConfig({\n    ...defaultOptions,\n    ...cfg,\n  });\n\n  const Formatter = formatters[options.language];\n  return new Formatter(options).format(query);\n};\n\nexport class ConfigError extends Error {}\n\nfunction validateConfig(cfg: FormatFnOptions): FormatFnOptions {\n  if (!supportedDialects.includes(cfg.language)) {\n    throw new ConfigError(`Unsupported SQL dialect: ${cfg.language}`);\n  }\n\n  if (isNumber(cfg.multilineLists) && cfg.multilineLists <= 0) {\n    throw new ConfigError('multilineLists config must be a positive number.');\n  }\n\n  if (cfg.expressionWidth <= 0) {\n    throw new ConfigError(\n      `expressionWidth config must be positive number. Received ${cfg.expressionWidth} instead.`\n    );\n  }\n\n  if (cfg.commaPosition === 'before' && cfg.useTabs) {\n    throw new ConfigError(\n      'commaPosition: before does not work when tabs are used for indentation.'\n    );\n  }\n\n  return cfg;\n}\n\nexport type FormatFn = typeof format;\n","export const dedupe = (arr: string[]) => [...new Set(arr)];\n\n// Only removes spaces, not newlines\nexport const trimSpacesEnd = (str: string) => str.replace(/[ \\t]+$/u, '');\n\n// Last element from array\nexport const last = <T extends any>(arr: T[]) => arr[arr.length - 1];\n\n// True array is empty, or it's not an array at all\nexport const isEmpty = (arr: any[]) => !Array.isArray(arr) || arr.length === 0;\n\n// Escapes regex special chars\nexport const escapeRegExp = (string: string) => string.replace(/[.*+?^${}()|[\\]\\\\]/gu, '\\\\$&');\n\n// Sorts strings by length, so that longer ones are first\n// Also sorts alphabetically after sorting by length.\nexport const sortByLengthDesc = (strings: string[]) =>\n  strings.sort((a, b) => b.length - a.length || a.localeCompare(b));\n\n/** Get length of longest string in list of strings */\nexport const maxLength = (strings: string[]) =>\n  strings.reduce((max, cur) => Math.max(max, cur.length), 0);\n\nexport const isNumber = (value: any): value is number => typeof value === 'number';\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","export * from './sqlFormatter';\nexport * from './types';\n"],"names":["isCommand","isToken","TokenType","AliasAs","aliasAs","formatter","token","isMissingTableAlias","isMissingSelectColumnAlias","type","WORD","lookBehind","value","prevToken","nextToken","lookAhead","isWithinSelect","END","NUMBER","isEdgeCaseCTE","isEdgeCaseCreateTable","isMissingTypeCastAs","CAST","getPreviousReservedToken","AS","RESERVED_KEYWORD","WITH","TABLE","endsWith","isRemovableNonSelectAs","n","tokenLookBehind","tokenLookAhead","AsTokenFactory","keywordCase","tokens","detectedCase","autoDetectCase","asTokens","filter","upperAsTokens","length","asTokenValue","Indentation","InlineBlock","Params","trimSpacesEnd","isReserved","EOF_TOKEN","formatCommaPositions","formatAliasPositions","toTabularToken","replaceTabularPlaceholders","Formatter","cfg","indentation","indentString","inlineBlock","expressionWidth","params","asTokenFactory","isTabularStyle","repeat","useTabs","tabWidth","Error","query","tokenizer","tokenize","formattedQuery","getFormattedQueryFromTokens","finalQuery","postFormat","replace","trimEnd","tabulateAlias","commaPosition","index","tokenOverride","previousReservedToken","RESERVED_JOIN_CONDITION","indentStyle","RESERVED_COMMAND","previousCommandToken","LINE_COMMENT","formatLineComment","BLOCK_COMMENT","formatBlockComment","currentNewline","checkNewline","formatCommand","RESERVED_BINARY_COMMAND","formatBinaryCommand","RESERVED_DEPENDENT_CLAUSE","formatDependentClause","formatJoinCondition","RESERVED_LOGICAL_OPERATOR","formatLogicalOperator","formatKeyword","BLOCK_START","formatBlockStart","BLOCK_END","formatBlockEnd","PLACEHOLDER","formatPlaceholder","OPERATOR","formatOperator","formatWord","shouldAddBefore","formatWithSpaces","shouldAddAfter","nextTokens","tokensUntilNextCommandOrQueryEnd","some","CASE","multilineLists","inlineWidth","countClauses","tokensString","map","join","whitespaceBefore","count","openBlocks","tail","slice","findIndex","undefined","addNewline","show","indentComment","comment","getIndent","decreaseTopLevel","increaseTopLevel","equalizeWhitespace","isJoin","test","shouldRemove","formatComma","formatQuerySeparator","includes","formatWithoutSpaces","denseOperators","AND","BETWEEN","logicalOperatorNewline","string","preserveWhitespaceFor","_a","newlineBeforeOpenParen","beginIfPossible","isActive","increaseBlockLevel","end","decreaseBlockLevel","getSingleIndent","newlineBeforeCloseParen","get","LIMIT","addSpace","before","after","resetIndentation","newlineBeforeSemicolon","linesBetweenQueries","toUpperCase","toLowerCase","SELECT","last","INDENT_TYPE_TOP_LEVEL","INDENT_TYPE_BLOCK_LEVEL","indent","indentTypes","push","pop","level","isInlineBlock","i","isForbiddenToken","key","regexFactory","escapeRegExp","WHITESPACE_REGEX","NULL_REGEX","Tokenizer","tokenType","input","getTokenOnFirstMatch","regex","REGEX_MAP","specialWordCharsAll","Object","values","specialWordChars","createWordRegex","STRING","createStringRegex","stringTypes","createReservedWordRegex","reservedKeywords","reservedDependentClauses","_b","reservedLogicalOperators","reservedCommands","reservedBinaryCommands","reservedJoinConditions","createOperatorRegex","operators","_c","createParenRegex","blockStart","blockEnd","createLineCommentRegex","lineCommentTypes","EOF","INDEXED_PLACEHOLDER_REGEX","createPlaceholderRegex","indexedPlaceholderTypes","_d","IDENT_NAMED_PLACEHOLDER_REGEX","namedPlaceholderTypes","STRING_NAMED_PLACEHOLDER_REGEX","createStringPattern","getWhitespace","substring","getNextToken","matches","match","previousToken","matchToken","getPlaceholderToken","getReservedWordToken","placeholderTokenRegexMap","parseKey","v","getEscapedPlaceholderKey","quoteChar","reduce","acc","RegExp","reservedTokenList","matchedToken","maxLength","lines","split","newQuery","aliasLines","splitLines","line","precedingText","as","alias","aliasMaxLength","groupCommaDelimitedLines","flatMap","commaLines","formatTabular","formatBefore","groups","group","maxLineLength","trimTrailingCommas","whitespace","removeLastIndent","trimStart","isEmpty","sortByLengthDesc","monadOperators","polyadOperators","c","reservedKeywordsPattern","specialChars","prefixLookBehind","prefix","suffixLookAhead","suffix","unicodeWordChar","any","arrayAccessor","mapAccessor","patterns","t","escapeParen","paren","parens","types","pattern","typesRegex","ZWS","bufferItem","padEnd","padStart","ZWS_REGEX","spaces","testToken","compareToken","BY","FROM","SET","WINDOW","dedupe","reservedFunctions","aead","aggregateAnalytic","aggregate","approximateAggregate","array","bitwise","conversion","date","datetime","debugging","federatedQuery","geography","hash","hll","interval","json","math","navigation","net","numbering","security","statisticalAggregate","time","timestamp","uuid","conditional","legacyAggregate","legacyBitwise","legacyCasting","legacyComparison","legacyDatetime","legacyIp","legacyJson","legacyMath","legacyRegex","legacyString","legacyTableWildcard","legacyUrl","legacyWindow","legacyMisc","other","keywords","datatypes","stringFormat","misc","BigQueryFormatter","fullReservedWords","finalToken","splice","arr","scalar","table","row","olap","standard","onlineUtilies","commands","Db2Formatter","masking","nonReserved","reserved","fileTypes","HiveFormatter","MariaDbFormatter","MySqlFormatter","N1qlFormatter","PlSqlFormatter","startsWith","binary","bitstring","datatype","geometry","network","textsearch","xml","sequence","range","window","set","sysInfo","sysAdmin","trigger","eventTrigger","stats","binaryOperators","PostgreSqlFormatter","dateTime","spatial","hyperLogLog","machineLearning","superType","dataType","dataConversionParams","dataLoadParams","dataFormatParams","copyAuthParams","copyCompressionParams","copyMiscParams","compressionEncodings","dataTypes","RedshiftFormatter","SparkSqlFormatter","StandardSqlFormatter","analytic","configuration","cryptographic","cursor","mathematical","metadata","ranking","system","statistical","odbc","future","TSqlFormatter","isNumber","formatters","bigquery","db2","hive","mariadb","mysql","n1ql","plsql","postgresql","redshift","spark","sql","tsql","supportedDialects","keys","defaultOptions","language","format","options","validateConfig","ConfigError","Set","str","Array","isArray","strings","sort","a","b","localeCompare","max","cur","Math"],"sourceRoot":""} |
\ | No newline at end of file |