@shaxpir/squilt 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (69) hide show
  1. package/LICENSE +201 -0
  2. package/README.md +133 -0
  3. package/dist/ast/Abstractions.d.ts +14 -0
  4. package/dist/ast/Abstractions.js +11 -0
  5. package/dist/ast/Alias.d.ts +11 -0
  6. package/dist/ast/Alias.js +23 -0
  7. package/dist/ast/BinaryExpression.d.ts +13 -0
  8. package/dist/ast/BinaryExpression.js +26 -0
  9. package/dist/ast/CaseExpression.d.ts +14 -0
  10. package/dist/ast/CaseExpression.js +22 -0
  11. package/dist/ast/Column.d.ts +17 -0
  12. package/dist/ast/Column.js +38 -0
  13. package/dist/ast/Concat.d.ts +8 -0
  14. package/dist/ast/Concat.js +19 -0
  15. package/dist/ast/ExistsExpression.d.ts +9 -0
  16. package/dist/ast/ExistsExpression.js +18 -0
  17. package/dist/ast/From.d.ts +33 -0
  18. package/dist/ast/From.js +60 -0
  19. package/dist/ast/FunctionExpression.d.ts +13 -0
  20. package/dist/ast/FunctionExpression.js +27 -0
  21. package/dist/ast/FunctionName.d.ts +1 -0
  22. package/dist/ast/FunctionName.js +3 -0
  23. package/dist/ast/InExpression.d.ts +13 -0
  24. package/dist/ast/InExpression.js +35 -0
  25. package/dist/ast/InsertQuery.d.ts +17 -0
  26. package/dist/ast/InsertQuery.js +42 -0
  27. package/dist/ast/Join.d.ts +21 -0
  28. package/dist/ast/Join.js +37 -0
  29. package/dist/ast/Literals.d.ts +31 -0
  30. package/dist/ast/Literals.js +65 -0
  31. package/dist/ast/Operator.d.ts +18 -0
  32. package/dist/ast/Operator.js +23 -0
  33. package/dist/ast/OrderBy.d.ts +14 -0
  34. package/dist/ast/OrderBy.js +25 -0
  35. package/dist/ast/SelectQuery.d.ts +39 -0
  36. package/dist/ast/SelectQuery.js +109 -0
  37. package/dist/ast/UnaryExpression.d.ts +11 -0
  38. package/dist/ast/UnaryExpression.js +22 -0
  39. package/dist/ast/With.d.ts +11 -0
  40. package/dist/ast/With.js +21 -0
  41. package/dist/builder/QueryBuilder.d.ts +8 -0
  42. package/dist/builder/QueryBuilder.js +20 -0
  43. package/dist/builder/Shorthand.d.ts +77 -0
  44. package/dist/builder/Shorthand.js +375 -0
  45. package/dist/index.d.ts +32 -0
  46. package/dist/index.js +133 -0
  47. package/dist/renderer/CompactQueryRenderer.d.ts +45 -0
  48. package/dist/renderer/CompactQueryRenderer.js +192 -0
  49. package/dist/renderer/IndentedQueryRenderer.d.ts +51 -0
  50. package/dist/renderer/IndentedQueryRenderer.js +230 -0
  51. package/dist/renderer/QueryRenderer.d.ts +8 -0
  52. package/dist/renderer/QueryRenderer.js +77 -0
  53. package/dist/validate/CommonQueryValidator.d.ts +50 -0
  54. package/dist/validate/CommonQueryValidator.js +262 -0
  55. package/dist/validate/QueryValidator.d.ts +6 -0
  56. package/dist/validate/QueryValidator.js +3 -0
  57. package/dist/validate/SQLiteQueryValidator.d.ts +27 -0
  58. package/dist/validate/SQLiteQueryValidator.js +96 -0
  59. package/dist/visitor/ParamCollector.d.ts +46 -0
  60. package/dist/visitor/ParamCollector.js +129 -0
  61. package/dist/visitor/QueryIdentityTransformer.d.ts +45 -0
  62. package/dist/visitor/QueryIdentityTransformer.js +173 -0
  63. package/dist/visitor/QueryParamRewriteTransformer.d.ts +11 -0
  64. package/dist/visitor/QueryParamRewriteTransformer.js +26 -0
  65. package/dist/visitor/SqlTreeNodeTransformer.d.ts +5 -0
  66. package/dist/visitor/SqlTreeNodeTransformer.js +3 -0
  67. package/dist/visitor/SqlTreeNodeVisitor.d.ts +45 -0
  68. package/dist/visitor/SqlTreeNodeVisitor.js +47 -0
  69. package/package.json +36 -0
@@ -0,0 +1,45 @@
1
+ import { AliasableExpression } from "../ast/Abstractions";
2
+ import { Alias } from "../ast/Alias";
3
+ import { BinaryExpression } from "../ast/BinaryExpression";
4
+ import { CaseExpression } from "../ast/CaseExpression";
5
+ import { Column } from "../ast/Column";
6
+ import { Concat } from "../ast/Concat";
7
+ import { ExistsExpression } from "../ast/ExistsExpression";
8
+ import { From, JsonEachFrom, SubqueryFrom, TableFrom } from "../ast/From";
9
+ import { FunctionExpression } from "../ast/FunctionExpression";
10
+ import { InExpression } from "../ast/InExpression";
11
+ import { InsertQuery } from "../ast/InsertQuery";
12
+ import { Join } from "../ast/Join";
13
+ import { NullLiteral, NumberLiteral, Param, StringLiteral } from "../ast/Literals";
14
+ import { OrderBy } from "../ast/OrderBy";
15
+ import { SelectQuery } from "../ast/SelectQuery";
16
+ import { UnaryExpression } from "../ast/UnaryExpression";
17
+ import { With } from "../ast/With";
18
+ import { ColumnLikeVisitorAcceptor, FromLikeAndJoinVisitorAcceptor, SqlTreeNodeVisitor } from "../visitor/SqlTreeNodeVisitor";
19
+ import { QueryRenderer } from "./QueryRenderer";
20
+ export declare class CompactQueryRenderer implements QueryRenderer, SqlTreeNodeVisitor<string> {
21
+ protected fromLikeAndJoinAcceptor: FromLikeAndJoinVisitorAcceptor<void>;
22
+ protected columnLikeAcceptor: ColumnLikeVisitorAcceptor<string>;
23
+ render(node: SelectQuery | InsertQuery): string;
24
+ visitInsertQuery(node: InsertQuery): string;
25
+ visitSelectQuery(node: SelectQuery): string;
26
+ visitTableFrom(node: TableFrom): string;
27
+ visitSubqueryFrom(node: SubqueryFrom): string;
28
+ visitJsonEachFrom(node: JsonEachFrom): string;
29
+ visitColumn(node: Column): string;
30
+ visitAlias(node: Alias<From | AliasableExpression>): string;
31
+ visitJoinClause(node: Join): string;
32
+ visitOrderBy(node: OrderBy): string;
33
+ visitWithClause(node: With): string;
34
+ visitBinaryExpression(node: BinaryExpression): string;
35
+ visitUnaryExpression(node: UnaryExpression): string;
36
+ visitInExpression(node: InExpression): string;
37
+ visitConcat(node: Concat): string;
38
+ visitCaseExpression(node: CaseExpression): string;
39
+ visitFunctionExpression(node: FunctionExpression): string;
40
+ visitParamExpression(_node: Param): string;
41
+ visitStringLiteral(node: StringLiteral): string;
42
+ visitNumberLiteral(node: NumberLiteral): string;
43
+ visitNullLiteral(_node: NullLiteral): string;
44
+ visitExistsExpression(node: ExistsExpression): string;
45
+ }
@@ -0,0 +1,192 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.CompactQueryRenderer = void 0;
4
+ const Alias_1 = require("../ast/Alias");
5
+ const From_1 = require("../ast/From");
6
+ const Join_1 = require("../ast/Join");
7
+ const Operator_1 = require("../ast/Operator");
8
+ const SelectQuery_1 = require("../ast/SelectQuery");
9
+ const SqlTreeNodeVisitor_1 = require("../visitor/SqlTreeNodeVisitor");
10
+ const QueryRenderer_1 = require("./QueryRenderer");
11
+ class CompactQueryRenderer {
12
+ constructor() {
13
+ this.fromLikeAndJoinAcceptor = new SqlTreeNodeVisitor_1.FromLikeAndJoinVisitorAcceptor();
14
+ this.columnLikeAcceptor = new SqlTreeNodeVisitor_1.ColumnLikeVisitorAcceptor();
15
+ }
16
+ render(node) {
17
+ return node.accept(this);
18
+ }
19
+ visitInsertQuery(node) {
20
+ const parts = [];
21
+ parts.push(`INSERT${node.isOrReplace() ? ' OR REPLACE' : ''}`);
22
+ parts.push(`INTO ${(0, QueryRenderer_1.quoteIdentifier)(node['_tableName'])}`);
23
+ if (node['_columns'].length > 0) {
24
+ parts.push(`(${node['_columns'].map(QueryRenderer_1.quoteIdentifier).join(', ')})`);
25
+ }
26
+ parts.push(`VALUES (${node['_values'].map(v => v.accept(this)).join(', ')})`);
27
+ return parts.join(' ');
28
+ }
29
+ visitSelectQuery(node) {
30
+ const parts = [];
31
+ if (node['_with'].length > 0) {
32
+ parts.push(`WITH ${node['_with'].map(w => w.accept(this)).join(', ')}`);
33
+ }
34
+ parts.push(`SELECT${node.isDistinct() ? ' DISTINCT' : ''}`);
35
+ if (node['_columns'].length > 0) {
36
+ parts.push(node['_columns'].map(c => this.columnLikeAcceptor.accept(this, c)).join(', '));
37
+ }
38
+ else {
39
+ parts.push('*');
40
+ }
41
+ if (node['_fromsAndJoins'].length > 0) {
42
+ let fromsAndJoinsText = '';
43
+ for (const fromOrJoin of node['_fromsAndJoins']) {
44
+ if (fromOrJoin instanceof Join_1.Join) {
45
+ fromsAndJoinsText += ` ${fromOrJoin.accept(this)}`;
46
+ }
47
+ else if (fromOrJoin instanceof Alias_1.Alias ||
48
+ fromOrJoin instanceof From_1.From ||
49
+ fromOrJoin instanceof From_1.TableFrom ||
50
+ fromOrJoin instanceof From_1.SubqueryFrom ||
51
+ fromOrJoin instanceof From_1.JsonEachFrom) {
52
+ if (fromsAndJoinsText) {
53
+ fromsAndJoinsText += `, ${fromOrJoin.accept(this)}`;
54
+ }
55
+ else {
56
+ fromsAndJoinsText += `FROM ${fromOrJoin.accept(this)}`;
57
+ }
58
+ }
59
+ }
60
+ parts.push(fromsAndJoinsText);
61
+ }
62
+ if (node['_where']) {
63
+ parts.push(`WHERE ${node['_where'].accept(this)}`);
64
+ }
65
+ if (node['_groupBy'].length > 0) {
66
+ parts.push(`GROUP BY ${node['_groupBy'].map(c => c.accept(this)).join(', ')}`);
67
+ }
68
+ if (node['_having']) {
69
+ parts.push(`HAVING ${node['_having'].accept(this)}`);
70
+ }
71
+ if (node['_union'].length > 0) {
72
+ parts.push(node['_union'].map(u => `UNION ${u.accept(this)}`).join(' '));
73
+ }
74
+ if (node['_orderBy'].length > 0) {
75
+ parts.push(`ORDER BY ${node['_orderBy'].map(o => o.accept(this)).join(', ')}`);
76
+ }
77
+ if (node['_limit'] !== null && node['_limit'] !== undefined) {
78
+ parts.push(`LIMIT ${node['_limit']}`);
79
+ if (node['_offset'] !== null && node['_offset'] !== undefined) {
80
+ parts.push(`OFFSET ${node['_offset']}`);
81
+ }
82
+ }
83
+ return parts.filter(p => p).join(' ');
84
+ }
85
+ visitTableFrom(node) {
86
+ return `${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)}`;
87
+ }
88
+ visitSubqueryFrom(node) {
89
+ return `(${node.subquery.accept(this)})`;
90
+ }
91
+ visitJsonEachFrom(node) {
92
+ const expr = node.jsonExpression.accept(this);
93
+ const path = node.jsonPath ? `, ${node.jsonPath.accept(this)}` : '';
94
+ return `json_each(${expr}${path})`;
95
+ }
96
+ visitColumn(node) {
97
+ if (node.hasTableName()) {
98
+ return `${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)}.${(0, QueryRenderer_1.quoteIdentifier)(node.columnName)}`;
99
+ }
100
+ else {
101
+ return `${(0, QueryRenderer_1.quoteIdentifier)(node.columnName)}`;
102
+ }
103
+ }
104
+ visitAlias(node) {
105
+ const isSubquery = node.referent instanceof From_1.SubqueryFrom || node.referent instanceof SelectQuery_1.SelectQuery;
106
+ const renderedReferent = node.referent.accept(this);
107
+ const renderedAliasName = (0, QueryRenderer_1.quoteIdentifier)(node.alias);
108
+ if (node.referent instanceof From_1.From) {
109
+ return `${renderedReferent} ${renderedAliasName}`;
110
+ }
111
+ else if (isSubquery) {
112
+ return `(${renderedReferent}) AS ${renderedAliasName}`;
113
+ }
114
+ else {
115
+ return `${renderedReferent} AS ${renderedAliasName}`;
116
+ }
117
+ }
118
+ visitJoinClause(node) {
119
+ return `${node.type} JOIN ${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)} ${(0, QueryRenderer_1.quoteIdentifier)(node.alias)} ON ${node.on.accept(this)}`;
120
+ }
121
+ visitOrderBy(node) {
122
+ return `${node.column.accept(this)} ${node.direction}`;
123
+ }
124
+ visitWithClause(node) {
125
+ return `${(0, QueryRenderer_1.quoteIdentifier)(node.name)} AS (${node.query.accept(this)})`;
126
+ }
127
+ visitBinaryExpression(node) {
128
+ return `(${node.left.accept(this)} ${node.operator} ${node.right.accept(this)})`;
129
+ }
130
+ visitUnaryExpression(node) {
131
+ const operand = node.operand.accept(this);
132
+ if (node.operator === Operator_1.Operator.IS_NULL || node.operator === Operator_1.Operator.IS_NOT_NULL) {
133
+ return `(${operand} ${node.operator})`;
134
+ }
135
+ else if (node.operator === 'NOT') {
136
+ return `(NOT ${operand})`;
137
+ }
138
+ else {
139
+ return `(${node.operator}${operand})`;
140
+ }
141
+ }
142
+ visitInExpression(node) {
143
+ const leftStr = node.left.length > 1
144
+ ? `(${node.left.map(l => l.accept(this)).join(', ')})`
145
+ : node.left[0].accept(this);
146
+ const not = node.not ? ' NOT' : '';
147
+ let right;
148
+ if (node.values instanceof SelectQuery_1.SelectQuery) {
149
+ right = `(${node.values.accept(this)})`;
150
+ }
151
+ else {
152
+ right = `(${node.values.map(set => set.length > 1 ? `(${set.map(v => v.accept(this)).join(', ')})` : set[0].accept(this)).join(', ')})`;
153
+ }
154
+ return `(${leftStr}${not} IN ${right})`;
155
+ }
156
+ visitConcat(node) {
157
+ return `(${node.expressions.map(e => e.accept(this)).join(' || ')})`;
158
+ }
159
+ visitCaseExpression(node) {
160
+ const parts = ['CASE'];
161
+ for (const c of node.cases) {
162
+ parts.push(`WHEN ${c.when.accept(this)} THEN ${c.then.accept(this)}`);
163
+ }
164
+ if (node.else) {
165
+ parts.push(`ELSE ${node.else.accept(this)}`);
166
+ }
167
+ parts.push('END');
168
+ return parts.join(' ');
169
+ }
170
+ visitFunctionExpression(node) {
171
+ const args = node.args.map(a => a.accept(this)).join(', ');
172
+ const distinctPrefix = node.distinct ? 'DISTINCT ' : '';
173
+ return `${node.name}(${distinctPrefix}${args})`;
174
+ }
175
+ visitParamExpression(_node) {
176
+ return '?';
177
+ }
178
+ visitStringLiteral(node) {
179
+ return `'${node.value.replace(/'/g, "''")}'`;
180
+ }
181
+ visitNumberLiteral(node) {
182
+ return node.value.toString();
183
+ }
184
+ visitNullLiteral(_node) {
185
+ return 'NULL';
186
+ }
187
+ visitExistsExpression(node) {
188
+ return `EXISTS (${node.subquery.accept(this)})`;
189
+ }
190
+ }
191
+ exports.CompactQueryRenderer = CompactQueryRenderer;
192
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CompactQueryRenderer.js","sourceRoot":"","sources":["../../src/renderer/CompactQueryRenderer.ts"],"names":[],"mappings":"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","sourcesContent":["import { AliasableExpression } from \"../ast/Abstractions\";\nimport { Alias } from \"../ast/Alias\";\nimport { BinaryExpression } from \"../ast/BinaryExpression\";\nimport { CaseExpression } from \"../ast/CaseExpression\";\nimport { Column } from \"../ast/Column\";\nimport { Concat } from \"../ast/Concat\";\nimport { ExistsExpression } from \"../ast/ExistsExpression\";\nimport { From, JsonEachFrom, SubqueryFrom, TableFrom } from \"../ast/From\";\nimport { FunctionExpression } from \"../ast/FunctionExpression\";\nimport { InExpression } from \"../ast/InExpression\";\nimport { InsertQuery } from \"../ast/InsertQuery\";\nimport { Join } from \"../ast/Join\";\nimport { NullLiteral, NumberLiteral, Param, StringLiteral } from \"../ast/Literals\";\nimport { Operator } from \"../ast/Operator\";\nimport { OrderBy } from \"../ast/OrderBy\";\nimport { SelectQuery } from \"../ast/SelectQuery\";\nimport { UnaryExpression } from \"../ast/UnaryExpression\";\nimport { With } from \"../ast/With\";\nimport { ColumnLikeVisitorAcceptor, FromLikeAndJoinVisitorAcceptor, SqlTreeNodeVisitor } from \"../visitor/SqlTreeNodeVisitor\";\nimport { QueryRenderer, quoteIdentifier } from \"./QueryRenderer\";\n\nexport class CompactQueryRenderer\n  implements QueryRenderer, SqlTreeNodeVisitor<string>\n{\n  protected fromLikeAndJoinAcceptor = new FromLikeAndJoinVisitorAcceptor<void>();\n  protected columnLikeAcceptor = new ColumnLikeVisitorAcceptor<string>();\n\n  public render(node: SelectQuery | InsertQuery): string {\n    return node.accept(this);\n  }\n\n  visitInsertQuery(node: InsertQuery): string {\n    const parts: string[] = [];\n    parts.push(`INSERT${node.isOrReplace() ? ' OR REPLACE' : ''}`);\n    parts.push(`INTO ${quoteIdentifier(node['_tableName'])}`);\n    if (node['_columns'].length > 0) {\n      parts.push(`(${node['_columns'].map(quoteIdentifier).join(', ')})`);\n    }\n    parts.push(`VALUES (${node['_values'].map(v => v.accept(this)).join(', ')})`);\n    return parts.join(' ');\n  }\n\n  visitSelectQuery(node: SelectQuery): string {\n    const parts: string[] = [];\n    if (node['_with'].length > 0) {\n      parts.push(`WITH ${node['_with'].map(w => w.accept(this)).join(', ')}`);\n    }\n    parts.push(`SELECT${node.isDistinct() ? ' DISTINCT' : ''}`);\n    if (node['_columns'].length > 0) {\n      parts.push(node['_columns'].map(c => this.columnLikeAcceptor.accept(this, c)).join(', '));\n    } else {\n      parts.push('*');\n    }\n    if (node['_fromsAndJoins'].length > 0) {\n      let fromsAndJoinsText = '';\n      for (const fromOrJoin of node['_fromsAndJoins']) {\n        if (fromOrJoin instanceof Join) {\n          fromsAndJoinsText += ` ${fromOrJoin.accept(this)}`;\n        } else if (\n          fromOrJoin instanceof Alias ||\n          fromOrJoin instanceof From ||\n          fromOrJoin instanceof TableFrom ||\n          fromOrJoin instanceof SubqueryFrom ||\n          fromOrJoin instanceof JsonEachFrom\n        ) {\n          if (fromsAndJoinsText) {\n            fromsAndJoinsText += `, ${fromOrJoin.accept(this)}`;\n          } else {\n            fromsAndJoinsText += `FROM ${fromOrJoin.accept(this)}`;\n          }\n        }\n      }\n      parts.push(fromsAndJoinsText);\n    }\n    if (node['_where']) {\n      parts.push(`WHERE ${node['_where'].accept(this)}`);\n    }\n    if (node['_groupBy'].length > 0) {\n      parts.push(`GROUP BY ${node['_groupBy'].map(c => c.accept(this)).join(', ')}`);\n    }\n    if (node['_having']) {\n      parts.push(`HAVING ${node['_having'].accept(this)}`);\n    }\n    if (node['_union'].length > 0) {\n      parts.push(node['_union'].map(u => `UNION ${u.accept(this)}`).join(' '));\n    }\n    if (node['_orderBy'].length > 0) {\n      parts.push(`ORDER BY ${node['_orderBy'].map(o => o.accept(this)).join(', ')}`);\n    }\n    if (node['_limit'] !== null && node['_limit'] !== undefined) {\n      parts.push(`LIMIT ${node['_limit']}`);\n      if (node['_offset'] !== null && node['_offset'] !== undefined) {\n        parts.push(`OFFSET ${node['_offset']}`);\n      }\n    }\n    return parts.filter(p => p).join(' ');\n  }\n\n  visitTableFrom(node: TableFrom): string {\n    return `${quoteIdentifier(node.tableName)}`;\n  }\n\n  visitSubqueryFrom(node: SubqueryFrom): string {\n    return `(${node.subquery.accept(this)})`;\n  }\n\n  visitJsonEachFrom(node: JsonEachFrom): string {\n    const expr = node.jsonExpression.accept(this);\n    const path = node.jsonPath ? `, ${node.jsonPath.accept(this)}` : '';\n    return `json_each(${expr}${path})`;\n  }\n\n  visitColumn(node: Column): string {\n    if (node.hasTableName()) {\n      return `${quoteIdentifier(node.tableName as string)}.${quoteIdentifier(node.columnName)}`;\n    } else {\n      return `${quoteIdentifier(node.columnName)}`;\n    }\n  }\n\n  visitAlias(node: Alias<From|AliasableExpression>): string {\n    const isSubquery = node.referent instanceof SubqueryFrom || node.referent instanceof SelectQuery;\n    const renderedReferent = node.referent.accept(this);\n    const renderedAliasName = quoteIdentifier(node.alias as string);\n    if (node.referent instanceof From) {\n      return `${renderedReferent} ${renderedAliasName}`;\n    } else if (isSubquery) {\n      return `(${renderedReferent}) AS ${renderedAliasName}`;\n    } else {\n      return `${renderedReferent} AS ${renderedAliasName}`;\n    }\n  }\n\n  visitJoinClause(node: Join): string {\n    return `${node.type} JOIN ${quoteIdentifier(node.tableName)} ${quoteIdentifier(node.alias)} ON ${node.on.accept(this)}`;\n  }\n\n  visitOrderBy(node: OrderBy): string {\n    return `${node.column.accept(this)} ${node.direction}`;\n  }\n\n  visitWithClause(node: With): string {\n    return `${quoteIdentifier(node.name)} AS (${node.query.accept(this)})`;\n  }\n\n  visitBinaryExpression(node: BinaryExpression): string {\n    return `(${node.left.accept(this)} ${node.operator} ${node.right.accept(this)})`;\n  }\n\n  visitUnaryExpression(node: UnaryExpression): string {\n    const operand = node.operand.accept(this);\n    if (node.operator === Operator.IS_NULL || node.operator === Operator.IS_NOT_NULL) {\n      return `(${operand} ${node.operator})`;\n    } else if (node.operator === 'NOT') {\n      return `(NOT ${operand})`;\n    } else {\n      return `(${node.operator}${operand})`;\n    }\n  }\n\n  visitInExpression(node: InExpression): string {\n    const leftStr = node.left.length > 1\n      ? `(${node.left.map(l => l.accept(this)).join(', ')})`\n      : node.left[0].accept(this);\n    const not = node.not ? ' NOT' : '';\n    let right: string;\n    if (node.values instanceof SelectQuery) {\n      right = `(${node.values.accept(this)})`;\n    } else {\n      right = `(${node.values.map(set =>\n        set.length > 1 ? `(${set.map(v => v.accept(this)).join(', ')})` : set[0].accept(this)\n      ).join(', ')})`;\n    }\n    return `(${leftStr}${not} IN ${right})`;\n  }\n\n  visitConcat(node: Concat): string {\n    return `(${node.expressions.map(e => e.accept(this)).join(' || ')})`;\n  }\n\n  visitCaseExpression(node: CaseExpression): string {\n    const parts: string[] = ['CASE'];\n    for (const c of node.cases) {\n      parts.push(`WHEN ${c.when.accept(this)} THEN ${c.then.accept(this)}`);\n    }\n    if (node.else) {\n      parts.push(`ELSE ${node.else.accept(this)}`);\n    }\n    parts.push('END');\n    return parts.join(' ');\n  }\n\n  visitFunctionExpression(node: FunctionExpression): string {\n    const args = node.args.map(a => a.accept(this)).join(', ');\n    const distinctPrefix = node.distinct ? 'DISTINCT ' : '';\n    return `${node.name}(${distinctPrefix}${args})`;\n  }\n\n  visitParamExpression(_node: Param): string {\n    return '?';\n  }\n\n  visitStringLiteral(node: StringLiteral): string {\n    return `'${node.value.replace(/'/g, \"''\")}'`;\n  }\n\n  visitNumberLiteral(node: NumberLiteral): string {\n    return node.value.toString();\n  }\n\n  visitNullLiteral(_node: NullLiteral): string {\n    return 'NULL';\n  }\n\n  visitExistsExpression(node: ExistsExpression): string {\n    return `EXISTS (${node.subquery.accept(this)})`;\n  }\n}\n"]}
@@ -0,0 +1,51 @@
1
+ import { AliasableExpression } from "../ast/Abstractions";
2
+ import { Alias } from "../ast/Alias";
3
+ import { BinaryExpression } from "../ast/BinaryExpression";
4
+ import { CaseExpression } from "../ast/CaseExpression";
5
+ import { Column } from "../ast/Column";
6
+ import { Concat } from "../ast/Concat";
7
+ import { ExistsExpression } from "../ast/ExistsExpression";
8
+ import { From, JsonEachFrom, SubqueryFrom, TableFrom } from "../ast/From";
9
+ import { FunctionExpression } from "../ast/FunctionExpression";
10
+ import { InExpression } from "../ast/InExpression";
11
+ import { InsertQuery } from "../ast/InsertQuery";
12
+ import { Join } from "../ast/Join";
13
+ import { NullLiteral, NumberLiteral, Param, StringLiteral } from "../ast/Literals";
14
+ import { OrderBy } from "../ast/OrderBy";
15
+ import { SelectQuery } from "../ast/SelectQuery";
16
+ import { UnaryExpression } from "../ast/UnaryExpression";
17
+ import { With } from "../ast/With";
18
+ import { ColumnLikeVisitorAcceptor, FromLikeAndJoinVisitorAcceptor, SqlTreeNodeVisitor } from "../visitor/SqlTreeNodeVisitor";
19
+ import { QueryRenderer } from "./QueryRenderer";
20
+ export declare class IndentedQueryRenderer implements QueryRenderer, SqlTreeNodeVisitor<string> {
21
+ protected fromLikeAndJoinAcceptor: FromLikeAndJoinVisitorAcceptor<string>;
22
+ protected columnLikeAcceptor: ColumnLikeVisitorAcceptor<string>;
23
+ private readonly spacesPerLevel;
24
+ private indentationLevel;
25
+ constructor(spacesPerLevel: number);
26
+ render(node: SelectQuery | InsertQuery): string;
27
+ private getIndent;
28
+ private indent;
29
+ private dedent;
30
+ visitInsertQuery(node: InsertQuery): string;
31
+ visitSelectQuery(node: SelectQuery): string;
32
+ visitTableFrom(node: TableFrom): string;
33
+ visitSubqueryFrom(node: SubqueryFrom): string;
34
+ visitJsonEachFrom(node: JsonEachFrom): string;
35
+ visitColumn(node: Column): string;
36
+ visitAlias(node: Alias<From | AliasableExpression>): string;
37
+ visitJoinClause(node: Join): string;
38
+ visitOrderBy(node: OrderBy): string;
39
+ visitWithClause(node: With): string;
40
+ visitBinaryExpression(node: BinaryExpression): string;
41
+ visitUnaryExpression(node: UnaryExpression): string;
42
+ visitInExpression(node: InExpression): string;
43
+ visitConcat(node: Concat): string;
44
+ visitCaseExpression(node: CaseExpression): string;
45
+ visitFunctionExpression(node: FunctionExpression): string;
46
+ visitParamExpression(_node: Param): string;
47
+ visitStringLiteral(node: StringLiteral): string;
48
+ visitNumberLiteral(node: NumberLiteral): string;
49
+ visitNullLiteral(_node: NullLiteral): string;
50
+ visitExistsExpression(node: ExistsExpression): string;
51
+ }
@@ -0,0 +1,230 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.IndentedQueryRenderer = void 0;
4
+ const Alias_1 = require("../ast/Alias");
5
+ const From_1 = require("../ast/From");
6
+ const Join_1 = require("../ast/Join");
7
+ const Operator_1 = require("../ast/Operator");
8
+ const SelectQuery_1 = require("../ast/SelectQuery");
9
+ const SqlTreeNodeVisitor_1 = require("../visitor/SqlTreeNodeVisitor");
10
+ const QueryRenderer_1 = require("./QueryRenderer");
11
+ class IndentedQueryRenderer {
12
+ constructor(spacesPerLevel) {
13
+ this.fromLikeAndJoinAcceptor = new SqlTreeNodeVisitor_1.FromLikeAndJoinVisitorAcceptor();
14
+ this.columnLikeAcceptor = new SqlTreeNodeVisitor_1.ColumnLikeVisitorAcceptor();
15
+ this.indentationLevel = -1;
16
+ if (!Number.isInteger(spacesPerLevel) || spacesPerLevel <= 0) {
17
+ throw new Error('spacesPerLevel must be a positive integer');
18
+ }
19
+ this.spacesPerLevel = spacesPerLevel;
20
+ }
21
+ render(node) {
22
+ return node.accept(this);
23
+ }
24
+ getIndent() {
25
+ return ' '.repeat(this.indentationLevel * this.spacesPerLevel);
26
+ }
27
+ indent() {
28
+ this.indentationLevel++;
29
+ }
30
+ dedent() {
31
+ this.indentationLevel--;
32
+ }
33
+ visitInsertQuery(node) {
34
+ this.indent();
35
+ const parts = [];
36
+ parts.push(`${this.getIndent()}INSERT${node.isOrReplace() ? ' OR REPLACE' : ''}`);
37
+ parts.push(`${this.getIndent()}INTO ${(0, QueryRenderer_1.quoteIdentifier)(node['_tableName'])}`);
38
+ if (node['_columns'].length > 0) {
39
+ parts.push(`${this.getIndent()}(${node['_columns'].map(QueryRenderer_1.quoteIdentifier).join(', ')})`);
40
+ }
41
+ parts.push(`${this.getIndent()}VALUES`);
42
+ parts.push(`${this.getIndent()}(${node['_values'].map(v => v.accept(this)).join(', ')})`);
43
+ this.dedent();
44
+ return parts.join('\n');
45
+ }
46
+ visitSelectQuery(node) {
47
+ const parts = [];
48
+ if (node['_with'].length > 0) {
49
+ this.indent();
50
+ parts.push('WITH');
51
+ parts.push(node['_with'].map(w => w.accept(this)).join(',\n'));
52
+ this.dedent();
53
+ }
54
+ this.indent();
55
+ parts.push(`${this.getIndent()}SELECT${node.isDistinct() ? ' DISTINCT' : ''}`);
56
+ if (node['_columns'].length > 0) {
57
+ parts.push(node['_columns'].map(c => `${this.getIndent()} ${this.columnLikeAcceptor.accept(this, c)}`).join(',\n'));
58
+ }
59
+ else {
60
+ parts.push(`${this.getIndent()} *`);
61
+ }
62
+ if (node['_fromsAndJoins'].length > 0) {
63
+ let fromsAndJoinsText = '';
64
+ for (const fromOrJoin of node['_fromsAndJoins']) {
65
+ if (fromOrJoin instanceof Join_1.Join) {
66
+ fromsAndJoinsText += `\n${this.getIndent()}${fromOrJoin.accept(this)}`;
67
+ }
68
+ else if (fromOrJoin instanceof Alias_1.Alias ||
69
+ fromOrJoin instanceof From_1.From ||
70
+ fromOrJoin instanceof From_1.TableFrom ||
71
+ fromOrJoin instanceof From_1.SubqueryFrom ||
72
+ fromOrJoin instanceof From_1.JsonEachFrom) {
73
+ if (fromsAndJoinsText) {
74
+ fromsAndJoinsText += `,\n${this.getIndent()}${fromOrJoin.accept(this)}`;
75
+ }
76
+ else {
77
+ fromsAndJoinsText += `${this.getIndent()}FROM ${fromOrJoin.accept(this)}`;
78
+ }
79
+ }
80
+ }
81
+ parts.push(fromsAndJoinsText);
82
+ }
83
+ if (node['_where']) {
84
+ parts.push(`${this.getIndent()}WHERE ${node['_where'].accept(this)}`);
85
+ }
86
+ if (node['_groupBy'].length > 0) {
87
+ parts.push(`${this.getIndent()}GROUP BY ${node['_groupBy'].map(c => c.accept(this)).join(', ')}`);
88
+ }
89
+ if (node['_having']) {
90
+ parts.push(`${this.getIndent()}HAVING ${node['_having'].accept(this)}`);
91
+ }
92
+ if (node['_union'].length > 0) {
93
+ parts.push(node['_union'].map(u => `${this.getIndent()}UNION\n${u.accept(this)}`).join('\n'));
94
+ }
95
+ if (node['_orderBy'].length > 0) {
96
+ parts.push(`${this.getIndent()}ORDER BY ${node['_orderBy'].map(o => o.accept(this)).join(', ')}`);
97
+ }
98
+ if (node['_limit'] !== null && node['_limit'] !== undefined) {
99
+ parts.push(`${this.getIndent()}LIMIT ${node['_limit']}`);
100
+ if (node['_offset'] !== null && node['_offset'] !== undefined) {
101
+ parts.push(`${this.getIndent()}OFFSET ${node['_offset']}`);
102
+ }
103
+ }
104
+ this.dedent();
105
+ return parts.filter(p => p).join('\n');
106
+ }
107
+ visitTableFrom(node) {
108
+ return `${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)}`;
109
+ }
110
+ visitSubqueryFrom(node) {
111
+ this.indent();
112
+ const result = `(\n${node.subquery.accept(this)}\n${this.getIndent()})`;
113
+ this.dedent();
114
+ return result;
115
+ }
116
+ visitJsonEachFrom(node) {
117
+ const expr = node.jsonExpression.accept(this);
118
+ const path = node.jsonPath ? `, ${node.jsonPath.accept(this)}` : '';
119
+ return `json_each(${expr}${path})`;
120
+ }
121
+ visitColumn(node) {
122
+ if (node.hasTableName()) {
123
+ return `${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)}.${(0, QueryRenderer_1.quoteIdentifier)(node.columnName)}`;
124
+ }
125
+ else {
126
+ return `${(0, QueryRenderer_1.quoteIdentifier)(node.columnName)}`;
127
+ }
128
+ }
129
+ visitAlias(node) {
130
+ const renderedAliasName = (0, QueryRenderer_1.quoteIdentifier)(node.alias);
131
+ if (node.referent instanceof From_1.From) {
132
+ return `${node.referent.accept(this)} ${renderedAliasName}`;
133
+ }
134
+ else if (node.referent instanceof From_1.SubqueryFrom ||
135
+ node.referent instanceof SelectQuery_1.SelectQuery) {
136
+ this.indent();
137
+ const renderedSubquery = `${node.referent.accept(this)}\n`;
138
+ const result = `(\n${renderedSubquery}${this.getIndent()}) AS ${renderedAliasName}`;
139
+ this.dedent();
140
+ return result;
141
+ }
142
+ else {
143
+ return `${node.referent.accept(this)} AS ${renderedAliasName}`;
144
+ }
145
+ }
146
+ visitJoinClause(node) {
147
+ return `${node.type} JOIN ${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)} ${(0, QueryRenderer_1.quoteIdentifier)(node.alias)} ON ${node.on.accept(this)}`;
148
+ }
149
+ visitOrderBy(node) {
150
+ return `${node.column.accept(this)} ${node.direction}`;
151
+ }
152
+ visitWithClause(node) {
153
+ this.indent();
154
+ const result = `${this.getIndent()}${(0, QueryRenderer_1.quoteIdentifier)(node.name)} AS (\n${node.query.accept(this)}\n${this.getIndent()})`;
155
+ this.dedent();
156
+ return result;
157
+ }
158
+ visitBinaryExpression(node) {
159
+ return `(${node.left.accept(this)} ${node.operator} ${node.right.accept(this)})`;
160
+ }
161
+ visitUnaryExpression(node) {
162
+ const operand = node.operand.accept(this);
163
+ if (node.operator === Operator_1.Operator.IS_NULL || node.operator === Operator_1.Operator.IS_NOT_NULL) {
164
+ return `(${operand} ${node.operator})`;
165
+ }
166
+ else if (node.operator === 'NOT') {
167
+ return `(NOT ${operand})`;
168
+ }
169
+ else {
170
+ return `(${node.operator}${operand})`;
171
+ }
172
+ }
173
+ visitInExpression(node) {
174
+ const leftStr = node.left.length > 1
175
+ ? `(${node.left.map(l => l.accept(this)).join(', ')})`
176
+ : node.left[0].accept(this);
177
+ const not = node.not ? ' NOT' : '';
178
+ let right;
179
+ if (node.values instanceof SelectQuery_1.SelectQuery) {
180
+ right = `(\n${node.values.accept(this)}\n${this.getIndent()})`;
181
+ }
182
+ else {
183
+ right = `(${node.values.map(set => set.length > 1 ? `(${set.map(v => v.accept(this)).join(', ')})` : set[0].accept(this)).join(', ')})`;
184
+ }
185
+ return `(${leftStr}${not} IN ${right})`;
186
+ }
187
+ visitConcat(node) {
188
+ return `(${node.expressions.map(e => e.accept(this)).join(' || ')})`;
189
+ }
190
+ visitCaseExpression(node) {
191
+ const parts = [`${this.getIndent()}CASE`];
192
+ this.indent();
193
+ for (const c of node.cases) {
194
+ this.indent();
195
+ parts.push(`${this.getIndent()}WHEN ${c.when.accept(this)} THEN ${c.then.accept(this)}`);
196
+ this.dedent();
197
+ }
198
+ if (node.else) {
199
+ this.indent();
200
+ parts.push(`${this.getIndent()}ELSE ${node.else.accept(this)}`);
201
+ this.dedent();
202
+ }
203
+ parts.push(`${this.getIndent()}END`);
204
+ this.dedent();
205
+ return parts.join('\n');
206
+ }
207
+ visitFunctionExpression(node) {
208
+ const args = node.args.map(a => a.accept(this)).join(', ');
209
+ const distinctPrefix = node.distinct ? 'DISTINCT ' : '';
210
+ return `${node.name}(${distinctPrefix}${args})`;
211
+ }
212
+ visitParamExpression(_node) {
213
+ return '?';
214
+ }
215
+ visitStringLiteral(node) {
216
+ return `'${node.value.replace(/'/g, "''")}'`;
217
+ }
218
+ visitNumberLiteral(node) {
219
+ return node.value.toString();
220
+ }
221
+ visitNullLiteral(_node) {
222
+ return 'NULL';
223
+ }
224
+ visitExistsExpression(node) {
225
+ const subquerySql = node.subquery.accept(this);
226
+ return `EXISTS (\n${subquerySql}\n${this.getIndent()})`;
227
+ }
228
+ }
229
+ exports.IndentedQueryRenderer = IndentedQueryRenderer;
230
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"IndentedQueryRenderer.js","sourceRoot":"","sources":["../../src/renderer/IndentedQueryRenderer.ts"],"names":[],"mappings":";;;AACA,wCAAqC;AAMrC,sCAA0E;AAI1E,sCAAmC;AAEnC,8CAA2C;AAE3C,oDAAiD;AAGjD,sEAA8H;AAC9H,mDAAiE;AAEjE,MAAa,qBAAqB;IAShC,YAAmB,cAAsB;QAN/B,4BAAuB,GAAG,IAAI,mDAA8B,EAAU,CAAC;QACvE,uBAAkB,GAAG,IAAI,8CAAyB,EAAU,CAAC;QAG/D,qBAAgB,GAAW,CAAC,CAAC,CAAC;QAGpC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,cAAc,CAAC,IAAI,cAAc,IAAI,CAAC,EAAE,CAAC;YAC7D,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;QAC/D,CAAC;QACD,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC;IACvC,CAAC;IAEM,MAAM,CAAC,IAA+B;QAC3C,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAC3B,CAAC;IAEO,SAAS;QACf,OAAO,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC;IACjE,CAAC;IAEO,MAAM;QACZ,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAEO,MAAM;QACZ,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAED,gBAAgB,CAAC,IAAiB;QAChC,IAAI,CAAC,MAAM,EAAE,CAAC;QACd,MAAM,KAAK,GAAa,EAAE,CAAC;QAC3B,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,SAAS,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QAClF,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,QAAQ,IAAA,+BAAe,EAAC,IAAI,CAAC,YAAY,CAAC,CAAC,EAAE,CAAC,CAAC;QAC7E,IAAI,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAChC,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,IAAI,IAAI,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,+BAAe,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACzF,CAAC;QACD,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;QACxC,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,IAAI,IAAI,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC1F,IAAI,CAAC,MAAM,EAAE,CAAC;QACd,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1B,CAAC;IAED,gBAAgB,CAAC,IAAiB;QAChC,MAAM,KAAK,GAAa,EAAE,CAAC;QAC3B,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC7B,IAAI,CAAC,MAAM,EAAE,CAAC;YACd,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACnB,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;YAC/D,IAAI,CAAC,MAAM,EAAE,CAAC;QAChB,CAAC;QACD,IAAI,CAAC,MAAM,EAAE,CAAC;QACd,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,SAAS,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QAC/E,IAAI,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAChC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,KAAK,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;QACvH,CAAC;aAAM,CAAC;YACN,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;QACvC,CAAC;QACD,IAAI,IAAI,CAAC,gBAAgB,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACtC,IAAI,iBAAiB,GAAG,EAAE,CAAC;YAC3B,KAAK,MAAM,UAAU,IAAI,IAAI,CAAC,gBAAgB,CAAC,EAAE,CAAC;gBAChD,IAAI,UAAU,YAAY,WAAI,EAAE,CAAC;oBAC/B,iBAAiB,IAAI,KAAK,IAAI,CAAC,SAAS,EAAE,GAAG,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC;gBACzE,CAAC;qBAAM,IACL,UAAU,YAAY,aAAK;oBAC3B,UAAU,YAAY,WAAI;oBAC1B,UAAU,YAAY,gBAAS;oBAC/B,UAAU,YAAY,mBAAY;oBAClC,UAAU,YAAY,mBAAY,EAClC,CAAC;oBACD,IAAI,iBAAiB,EAAE,CAAC;wBACtB,iBAAiB,IAAI,MAAM,IAAI,CAAC,SAAS,EAAE,GAAG,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC;oBAC1E,CAAC;yBAAM,CAAC;wBACN,iBAAiB,IAAI,GAAG,IAAI,CAAC,SAAS,EAAE,QAAQ,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC;oBAC5E,CAAC;gBACH,CAAC;YACH,CAAC;YACD,KAAK,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;QAChC,CAAC;QACD,IAAI,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;YACnB,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,SAAS,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACxE,CAAC;QACD,IAAI,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAChC,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,YAAY,IAAI,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACpG,CAAC;QACD,IAAI,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC;YACpB,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,UAAU,IAAI,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAC1E,CAAC;QACD,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC9B,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QAChG,CAAC;QACD,IAAI,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAChC,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,YAAY,IAAI,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACpG,CAAC;QACD,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,SAAS,EAAE,CAAC;YAC5D,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,SAAS,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;YACzD,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,IAAI,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,SAAS,EAAE,CAAC;gBAC9D,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,UAAU,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;YAC7D,CAAC;QACH,CAAC;QACD,IAAI,CAAC,MAAM,EAAE,CAAC;QACd,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACzC,CAAC;IAED,cAAc,CAAC,IAAe;QAC5B,OAAO,GAAG,IAAA,+BAAe,EAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC;IAC9C,CAAC;IAED,iBAAiB,CAAC,IAAkB;QAClC,IAAI,CAAC,MAAM,EAAE,CAAC;QACd,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,SAAS,EAAE,GAAG,CAAC;QACxE,IAAI,CAAC,MAAM,EAAE,CAAC;QACd,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,iBAAiB,CAAC,IAAkB;QAClC,MAAM,IAAI,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAC9C,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACpE,OAAO,aAAa,IAAI,GAAG,IAAI,GAAG,CAAC;IACrC,CAAC;IAED,WAAW,CAAC,IAAY;QACtB,IAAI,IAAI,CAAC,YAAY,EAAE,EAAE,CAAC;YACxB,OAAO,GAAG,IAAA,+BAAe,EAAC,IAAI,CAAC,SAAmB,CAAC,IAAI,IAAA,+BAAe,EAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;QAC5F,CAAC;aAAM,CAAC;YACN,OAAO,GAAG,IAAA,+BAAe,EAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;QAC/C,CAAC;IACH,CAAC;IAED,UAAU,CAAC,IAAqC;QAC9C,MAAM,iBAAiB,GAAG,IAAA,+BAAe,EAAC,IAAI,CAAC,KAAe,CAAC,CAAC;QAChE,IAAI,IAAI,CAAC,QAAQ,YAAY,WAAI,EAAE,CAAC;YAClC,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,iBAAiB,EAAE,CAAC;QAC9D,CAAC;aAAM,IACL,IAAI,CAAC,QAAQ,YAAY,mBAAY;YACrC,IAAI,CAAC,QAAQ,YAAY,yBAAW,EACpC,CAAC;YACD,IAAI,CAAC,MAAM,EAAE,CAAC;YACd,MAAM,gBAAgB,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC;YAC3D,MAAM,MAAM,GAAG,MAAM,gBAAgB,GAAG,IAAI,CAAC,SAAS,EAAE,QAAQ,iBAAiB,EAAE,CAAC;YACpF,IAAI,CAAC,MAAM,EAAE,CAAC;YACd,OAAO,MAAM,CAAC;QAChB,CAAC;aAAM,CAAC;YACN,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,iBAAiB,EAAE,CAAC;QACjE,CAAC;IACH,CAAC;IAED,eAAe,CAAC,IAAU;QACxB,OAAO,GAAG,IAAI,CAAC,IAAI,SAAS,IAAA,+BAAe,EAAC,IAAI,CAAC,SAAS,CAAC,IAAI,IAAA,+BAAe,EAAC,IAAI,CAAC,KAAK,CAAC,OAAO,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC;IAC1H,CAAC;IAED,YAAY,CAAC,IAAa;QACxB,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;IACzD,CAAC;IAED,eAAe,CAAC,IAAU;QACxB,IAAI,CAAC,MAAM,EAAE,CAAC;QACd,MAAM,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,EAAE,GAAG,IAAA,+BAAe,EAAC,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,SAAS,EAAE,GAAG,CAAC;QACzH,IAAI,CAAC,MAAM,EAAE,CAAC;QACd,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,qBAAqB,CAAC,IAAsB;QAC1C,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC;IACnF,CAAC;IAED,oBAAoB,CAAC,IAAqB;QACxC,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAC1C,IAAI,IAAI,CAAC,QAAQ,KAAK,mBAAQ,CAAC,OAAO,IAAI,IAAI,CAAC,QAAQ,KAAK,mBAAQ,CAAC,WAAW,EAAE,CAAC;YACjF,OAAO,IAAI,OAAO,IAAI,IAAI,CAAC,QAAQ,GAAG,CAAC;QACzC,CAAC;aAAM,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK,EAAE,CAAC;YACnC,OAAO,QAAQ,OAAO,GAAG,CAAC;QAC5B,CAAC;aAAM,CAAC;YACN,OAAO,IAAI,IAAI,CAAC,QAAQ,GAAG,OAAO,GAAG,CAAC;QACxC,CAAC;IACH,CAAC;IAED,iBAAiB,CAAC,IAAkB;QAClC,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC;YAClC,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG;YACtD,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAC9B,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC;QACnC,IAAI,KAAa,CAAC;QAClB,IAAI,IAAI,CAAC,MAAM,YAAY,yBAAW,EAAE,CAAC;YACvC,KAAK,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,SAAS,EAAE,GAAG,CAAC;QACjE,CAAC;aAAM,CAAC;YACN,KAAK,GAAG,IAAI,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAChC,GAAG,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CACtF,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC;QAClB,CAAC;QACD,OAAO,IAAI,OAAO,GAAG,GAAG,OAAO,KAAK,GAAG,CAAC;IAC1C,CAAC;IAED,WAAW,CAAC,IAAY;QACtB,OAAO,IAAI,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC;IACvE,CAAC;IAED,mBAAmB,CAAC,IAAoB;QACtC,MAAM,KAAK,GAAa,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;QACpD,IAAI,CAAC,MAAM,EAAE,CAAC;QACd,KAAK,MAAM,CAAC,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YAC3B,IAAI,CAAC,MAAM,EAAE,CAAC;YACd,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACzF,IAAI,CAAC,MAAM,EAAE,CAAC;QAChB,CAAC;QACD,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;YACd,IAAI,CAAC,MAAM,EAAE,CAAC;YACd,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,QAAQ,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YAChE,IAAI,CAAC,MAAM,EAAE,CAAC;QAChB,CAAC;QACD,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;QACrC,IAAI,CAAC,MAAM,EAAE,CAAC;QACd,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1B,CAAC;IAED,uBAAuB,CAAC,IAAwB;QAC9C,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC3D,MAAM,cAAc,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,CAAC;QACxD,OAAO,GAAG,IAAI,CAAC,IAAI,IAAI,cAAc,GAAG,IAAI,GAAG,CAAC;IAClD,CAAC;IAED,oBAAoB,CAAC,KAAY;QAC/B,OAAO,GAAG,CAAC;IACb,CAAC;IAED,kBAAkB,CAAC,IAAmB;QACpC,OAAO,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,GAAG,CAAC;IAC/C,CAAC;IAED,kBAAkB,CAAC,IAAmB;QACpC,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;IAC/B,CAAC;IAED,gBAAgB,CAAC,KAAkB;QACjC,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,qBAAqB,CAAC,IAAsB;QAC1C,MAAM,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAC/C,OAAO,aAAa,WAAW,KAAK,IAAI,CAAC,SAAS,EAAE,GAAG,CAAC;IAC1D,CAAC;CACF;AApPD,sDAoPC","sourcesContent":["import { AliasableExpression } from \"../ast/Abstractions\";\nimport { Alias } from \"../ast/Alias\";\nimport { BinaryExpression } from \"../ast/BinaryExpression\";\nimport { CaseExpression } from \"../ast/CaseExpression\";\nimport { Column } from \"../ast/Column\";\nimport { Concat } from \"../ast/Concat\";\nimport { ExistsExpression } from \"../ast/ExistsExpression\";\nimport { From, JsonEachFrom, SubqueryFrom, TableFrom } from \"../ast/From\";\nimport { FunctionExpression } from \"../ast/FunctionExpression\";\nimport { InExpression } from \"../ast/InExpression\";\nimport { InsertQuery } from \"../ast/InsertQuery\";\nimport { Join } from \"../ast/Join\";\nimport { NullLiteral, NumberLiteral, Param, StringLiteral } from \"../ast/Literals\";\nimport { Operator } from \"../ast/Operator\";\nimport { OrderBy } from \"../ast/OrderBy\";\nimport { SelectQuery } from \"../ast/SelectQuery\";\nimport { UnaryExpression } from \"../ast/UnaryExpression\";\nimport { With } from \"../ast/With\";\nimport { ColumnLikeVisitorAcceptor, FromLikeAndJoinVisitorAcceptor, SqlTreeNodeVisitor } from \"../visitor/SqlTreeNodeVisitor\";\nimport { QueryRenderer, quoteIdentifier } from \"./QueryRenderer\";\n\nexport class IndentedQueryRenderer\n  implements QueryRenderer, SqlTreeNodeVisitor<string>\n{\n  protected fromLikeAndJoinAcceptor = new FromLikeAndJoinVisitorAcceptor<string>();\n  protected columnLikeAcceptor = new ColumnLikeVisitorAcceptor<string>();\n\n  private readonly spacesPerLevel: number;\n  private indentationLevel: number = -1;\n\n  public constructor(spacesPerLevel: number) {\n    if (!Number.isInteger(spacesPerLevel) || spacesPerLevel <= 0) {\n      throw new Error('spacesPerLevel must be a positive integer');\n    }\n    this.spacesPerLevel = spacesPerLevel;\n  }\n\n  public render(node: SelectQuery | InsertQuery): string {\n    return node.accept(this);\n  }\n\n  private getIndent(): string {\n    return ' '.repeat(this.indentationLevel * this.spacesPerLevel);\n  }\n\n  private indent(): void {\n    this.indentationLevel++;\n  }\n\n  private dedent(): void {\n    this.indentationLevel--;\n  }\n\n  visitInsertQuery(node: InsertQuery): string {\n    this.indent();\n    const parts: string[] = [];\n    parts.push(`${this.getIndent()}INSERT${node.isOrReplace() ? ' OR REPLACE' : ''}`);\n    parts.push(`${this.getIndent()}INTO ${quoteIdentifier(node['_tableName'])}`);\n    if (node['_columns'].length > 0) {\n      parts.push(`${this.getIndent()}(${node['_columns'].map(quoteIdentifier).join(', ')})`);\n    }\n    parts.push(`${this.getIndent()}VALUES`);\n    parts.push(`${this.getIndent()}(${node['_values'].map(v => v.accept(this)).join(', ')})`);\n    this.dedent();\n    return parts.join('\\n');\n  }\n\n  visitSelectQuery(node: SelectQuery): string {\n    const parts: string[] = [];\n    if (node['_with'].length > 0) {\n      this.indent();\n      parts.push('WITH');\n      parts.push(node['_with'].map(w => w.accept(this)).join(',\\n'));\n      this.dedent();\n    }\n    this.indent();\n    parts.push(`${this.getIndent()}SELECT${node.isDistinct() ? ' DISTINCT' : ''}`);\n    if (node['_columns'].length > 0) {\n      parts.push(node['_columns'].map(c => `${this.getIndent()}  ${this.columnLikeAcceptor.accept(this, c)}`).join(',\\n'));\n    } else {\n      parts.push(`${this.getIndent()}  *`);\n    }\n    if (node['_fromsAndJoins'].length > 0) {\n      let fromsAndJoinsText = '';\n      for (const fromOrJoin of node['_fromsAndJoins']) {\n        if (fromOrJoin instanceof Join) {\n          fromsAndJoinsText += `\\n${this.getIndent()}${fromOrJoin.accept(this)}`;\n        } else if (\n          fromOrJoin instanceof Alias ||\n          fromOrJoin instanceof From ||\n          fromOrJoin instanceof TableFrom ||\n          fromOrJoin instanceof SubqueryFrom ||\n          fromOrJoin instanceof JsonEachFrom\n        ) {\n          if (fromsAndJoinsText) {\n            fromsAndJoinsText += `,\\n${this.getIndent()}${fromOrJoin.accept(this)}`;\n          } else {\n            fromsAndJoinsText += `${this.getIndent()}FROM ${fromOrJoin.accept(this)}`;\n          }\n        }\n      }\n      parts.push(fromsAndJoinsText);\n    }\n    if (node['_where']) {\n      parts.push(`${this.getIndent()}WHERE ${node['_where'].accept(this)}`);\n    }\n    if (node['_groupBy'].length > 0) {\n      parts.push(`${this.getIndent()}GROUP BY ${node['_groupBy'].map(c => c.accept(this)).join(', ')}`);\n    }\n    if (node['_having']) {\n      parts.push(`${this.getIndent()}HAVING ${node['_having'].accept(this)}`);\n    }\n    if (node['_union'].length > 0) {\n      parts.push(node['_union'].map(u => `${this.getIndent()}UNION\\n${u.accept(this)}`).join('\\n'));\n    }\n    if (node['_orderBy'].length > 0) {\n      parts.push(`${this.getIndent()}ORDER BY ${node['_orderBy'].map(o => o.accept(this)).join(', ')}`);\n    }\n    if (node['_limit'] !== null && node['_limit'] !== undefined) {\n      parts.push(`${this.getIndent()}LIMIT ${node['_limit']}`);\n      if (node['_offset'] !== null && node['_offset'] !== undefined) {\n        parts.push(`${this.getIndent()}OFFSET ${node['_offset']}`);\n      }\n    }\n    this.dedent();\n    return parts.filter(p => p).join('\\n');\n  }\n\n  visitTableFrom(node: TableFrom): string {\n    return `${quoteIdentifier(node.tableName)}`;\n  }\n\n  visitSubqueryFrom(node: SubqueryFrom): string {\n    this.indent();\n    const result = `(\\n${node.subquery.accept(this)}\\n${this.getIndent()})`;\n    this.dedent();\n    return result;\n  }\n\n  visitJsonEachFrom(node: JsonEachFrom): string {\n    const expr = node.jsonExpression.accept(this);\n    const path = node.jsonPath ? `, ${node.jsonPath.accept(this)}` : '';\n    return `json_each(${expr}${path})`;\n  }\n\n  visitColumn(node: Column): string {\n    if (node.hasTableName()) {\n      return `${quoteIdentifier(node.tableName as string)}.${quoteIdentifier(node.columnName)}`;\n    } else {\n      return `${quoteIdentifier(node.columnName)}`;\n    }\n  }\n\n  visitAlias(node: Alias<From|AliasableExpression>): string {\n    const renderedAliasName = quoteIdentifier(node.alias as string);\n    if (node.referent instanceof From) {\n      return `${node.referent.accept(this)} ${renderedAliasName}`;\n    } else if (\n      node.referent instanceof SubqueryFrom ||\n      node.referent instanceof SelectQuery\n    ) {\n      this.indent();\n      const renderedSubquery = `${node.referent.accept(this)}\\n`;\n      const result = `(\\n${renderedSubquery}${this.getIndent()}) AS ${renderedAliasName}`;\n      this.dedent();\n      return result;\n    } else {\n      return `${node.referent.accept(this)} AS ${renderedAliasName}`;\n    }\n  }\n\n  visitJoinClause(node: Join): string {\n    return `${node.type} JOIN ${quoteIdentifier(node.tableName)} ${quoteIdentifier(node.alias)} ON ${node.on.accept(this)}`;\n  }\n\n  visitOrderBy(node: OrderBy): string {\n    return `${node.column.accept(this)} ${node.direction}`;\n  }\n\n  visitWithClause(node: With): string {\n    this.indent();\n    const result = `${this.getIndent()}${quoteIdentifier(node.name)} AS (\\n${node.query.accept(this)}\\n${this.getIndent()})`;\n    this.dedent();\n    return result;\n  }\n\n  visitBinaryExpression(node: BinaryExpression): string {\n    return `(${node.left.accept(this)} ${node.operator} ${node.right.accept(this)})`;\n  }\n\n  visitUnaryExpression(node: UnaryExpression): string {\n    const operand = node.operand.accept(this);\n    if (node.operator === Operator.IS_NULL || node.operator === Operator.IS_NOT_NULL) {\n      return `(${operand} ${node.operator})`;\n    } else if (node.operator === 'NOT') {\n      return `(NOT ${operand})`;\n    } else {\n      return `(${node.operator}${operand})`;\n    }\n  }\n\n  visitInExpression(node: InExpression): string {\n    const leftStr = node.left.length > 1\n      ? `(${node.left.map(l => l.accept(this)).join(', ')})`\n      : node.left[0].accept(this);\n    const not = node.not ? ' NOT' : '';\n    let right: string;\n    if (node.values instanceof SelectQuery) {\n      right = `(\\n${node.values.accept(this)}\\n${this.getIndent()})`;\n    } else {\n      right = `(${node.values.map(set =>\n        set.length > 1 ? `(${set.map(v => v.accept(this)).join(', ')})` : set[0].accept(this)\n      ).join(', ')})`;\n    }\n    return `(${leftStr}${not} IN ${right})`;\n  }\n\n  visitConcat(node: Concat): string {\n    return `(${node.expressions.map(e => e.accept(this)).join(' || ')})`;\n  }\n\n  visitCaseExpression(node: CaseExpression): string {\n    const parts: string[] = [`${this.getIndent()}CASE`];\n    this.indent();\n    for (const c of node.cases) {\n      this.indent();\n      parts.push(`${this.getIndent()}WHEN ${c.when.accept(this)} THEN ${c.then.accept(this)}`);\n      this.dedent();\n    }\n    if (node.else) {\n      this.indent();\n      parts.push(`${this.getIndent()}ELSE ${node.else.accept(this)}`);\n      this.dedent();\n    }\n    parts.push(`${this.getIndent()}END`);\n    this.dedent();\n    return parts.join('\\n');\n  }\n\n  visitFunctionExpression(node: FunctionExpression): string {\n    const args = node.args.map(a => a.accept(this)).join(', ');\n    const distinctPrefix = node.distinct ? 'DISTINCT ' : '';\n    return `${node.name}(${distinctPrefix}${args})`;\n  }\n\n  visitParamExpression(_node: Param): string {\n    return '?';\n  }\n\n  visitStringLiteral(node: StringLiteral): string {\n    return `'${node.value.replace(/'/g, \"''\")}'`;\n  }\n\n  visitNumberLiteral(node: NumberLiteral): string {\n    return node.value.toString();\n  }\n\n  visitNullLiteral(_node: NullLiteral): string {\n    return 'NULL';\n  }\n\n  visitExistsExpression(node: ExistsExpression): string {\n    const subquerySql = node.subquery.accept(this);\n    return `EXISTS (\\n${subquerySql}\\n${this.getIndent()})`;\n  }\n}\n"]}
@@ -0,0 +1,8 @@
1
+ import { InsertQuery } from "../ast/InsertQuery";
2
+ import { SelectQuery } from "../ast/SelectQuery";
3
+ import { SqlTreeNodeVisitor } from "../visitor/SqlTreeNodeVisitor";
4
+ export declare function quoteIdentifier(identifier: string): string;
5
+ export interface QueryRenderer extends SqlTreeNodeVisitor<string> {
6
+ render(node: SelectQuery | InsertQuery): string;
7
+ }
8
+ export declare function shouldQuoteIdentifier(identifier: string): boolean;