@shaxpir/squilt 1.0.0 → 1.1.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.
- package/README.md +289 -1
- package/dist/ast/AlterTableQuery.d.ts +32 -0
- package/dist/ast/AlterTableQuery.js +60 -0
- package/dist/ast/BetweenExpression.d.ts +10 -0
- package/dist/ast/BetweenExpression.js +18 -0
- package/dist/ast/CastExpression.d.ts +13 -0
- package/dist/ast/CastExpression.js +25 -0
- package/dist/ast/CollateExpression.d.ts +18 -0
- package/dist/ast/CollateExpression.js +30 -0
- package/dist/ast/CreateIndexQuery.d.ts +25 -0
- package/dist/ast/CreateIndexQuery.js +64 -0
- package/dist/ast/CreateTableQuery.d.ts +57 -0
- package/dist/ast/CreateTableQuery.js +79 -0
- package/dist/ast/CreateViewQuery.d.ts +34 -0
- package/dist/ast/CreateViewQuery.js +61 -0
- package/dist/ast/CreateVirtualTableQuery.d.ts +32 -0
- package/dist/ast/CreateVirtualTableQuery.js +74 -0
- package/dist/ast/DeleteQuery.d.ts +17 -0
- package/dist/ast/DeleteQuery.js +43 -0
- package/dist/ast/DropIndexQuery.d.ts +14 -0
- package/dist/ast/DropIndexQuery.js +35 -0
- package/dist/ast/DropTableQuery.d.ts +14 -0
- package/dist/ast/DropTableQuery.js +35 -0
- package/dist/ast/DropViewQuery.d.ts +11 -0
- package/dist/ast/DropViewQuery.js +24 -0
- package/dist/ast/FunctionExpression.d.ts +21 -0
- package/dist/ast/FunctionExpression.js +40 -1
- package/dist/ast/FunctionName.d.ts +1 -1
- package/dist/ast/FunctionName.js +1 -1
- package/dist/ast/InsertQuery.d.ts +24 -1
- package/dist/ast/InsertQuery.js +49 -1
- package/dist/ast/Operator.d.ts +2 -0
- package/dist/ast/Operator.js +3 -1
- package/dist/ast/SelectQuery.d.ts +4 -0
- package/dist/ast/SelectQuery.js +11 -1
- package/dist/ast/SubqueryExpression.d.ts +18 -0
- package/dist/ast/SubqueryExpression.js +27 -0
- package/dist/ast/UpdateQuery.d.ts +24 -0
- package/dist/ast/UpdateQuery.js +51 -0
- package/dist/ast/WindowExpression.d.ts +51 -0
- package/dist/ast/WindowExpression.js +61 -0
- package/dist/ast/WindowSpecification.d.ts +46 -0
- package/dist/ast/WindowSpecification.js +60 -0
- package/dist/builder/QueryBuilder.d.ts +20 -0
- package/dist/builder/QueryBuilder.js +41 -1
- package/dist/builder/Shorthand.d.ts +51 -0
- package/dist/builder/Shorthand.js +125 -1
- package/dist/index.d.ts +17 -1
- package/dist/index.js +59 -3
- package/dist/renderer/CompactQueryRenderer.d.ts +34 -2
- package/dist/renderer/CompactQueryRenderer.js +272 -2
- package/dist/renderer/IndentedQueryRenderer.d.ts +34 -2
- package/dist/renderer/IndentedQueryRenderer.js +289 -3
- package/dist/renderer/QueryRenderer.d.ts +11 -1
- package/dist/renderer/QueryRenderer.js +1 -1
- package/dist/validate/CommonQueryValidator.d.ts +31 -1
- package/dist/validate/CommonQueryValidator.js +253 -4
- package/dist/validate/QueryValidator.d.ts +10 -1
- package/dist/validate/QueryValidator.js +1 -1
- package/dist/validate/SQLiteQueryValidator.d.ts +16 -1
- package/dist/validate/SQLiteQueryValidator.js +32 -3
- package/dist/visitor/ParamCollector.d.ts +30 -0
- package/dist/visitor/ParamCollector.js +109 -2
- package/dist/visitor/QueryIdentityTransformer.d.ts +30 -0
- package/dist/visitor/QueryIdentityTransformer.js +217 -2
- package/dist/visitor/SqlTreeNodeVisitor.d.ts +30 -0
- package/dist/visitor/SqlTreeNodeVisitor.js +1 -1
- package/package.json +4 -1
|
@@ -2,15 +2,31 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.QueryIdentityTransformer = void 0;
|
|
4
4
|
const Alias_1 = require("../ast/Alias");
|
|
5
|
+
const AlterTableQuery_1 = require("../ast/AlterTableQuery");
|
|
6
|
+
const BetweenExpression_1 = require("../ast/BetweenExpression");
|
|
5
7
|
const BinaryExpression_1 = require("../ast/BinaryExpression");
|
|
6
8
|
const CaseExpression_1 = require("../ast/CaseExpression");
|
|
9
|
+
const CastExpression_1 = require("../ast/CastExpression");
|
|
10
|
+
const CollateExpression_1 = require("../ast/CollateExpression");
|
|
11
|
+
const SubqueryExpression_1 = require("../ast/SubqueryExpression");
|
|
12
|
+
const WindowExpression_1 = require("../ast/WindowExpression");
|
|
13
|
+
const WindowSpecification_1 = require("../ast/WindowSpecification");
|
|
7
14
|
const Column_1 = require("../ast/Column");
|
|
8
15
|
const Concat_1 = require("../ast/Concat");
|
|
16
|
+
const CreateIndexQuery_1 = require("../ast/CreateIndexQuery");
|
|
17
|
+
const CreateTableQuery_1 = require("../ast/CreateTableQuery");
|
|
18
|
+
const CreateVirtualTableQuery_1 = require("../ast/CreateVirtualTableQuery");
|
|
19
|
+
const CreateViewQuery_1 = require("../ast/CreateViewQuery");
|
|
20
|
+
const DeleteQuery_1 = require("../ast/DeleteQuery");
|
|
21
|
+
const DropIndexQuery_1 = require("../ast/DropIndexQuery");
|
|
22
|
+
const DropTableQuery_1 = require("../ast/DropTableQuery");
|
|
23
|
+
const DropViewQuery_1 = require("../ast/DropViewQuery");
|
|
9
24
|
const ExistsExpression_1 = require("../ast/ExistsExpression");
|
|
10
25
|
const From_1 = require("../ast/From");
|
|
11
26
|
const FunctionExpression_1 = require("../ast/FunctionExpression");
|
|
12
27
|
const InExpression_1 = require("../ast/InExpression");
|
|
13
28
|
const InsertQuery_1 = require("../ast/InsertQuery");
|
|
29
|
+
const UpdateQuery_1 = require("../ast/UpdateQuery");
|
|
14
30
|
const Join_1 = require("../ast/Join");
|
|
15
31
|
const Literals_1 = require("../ast/Literals");
|
|
16
32
|
const OrderBy_1 = require("../ast/OrderBy");
|
|
@@ -69,6 +85,8 @@ class QueryIdentityTransformer {
|
|
|
69
85
|
if (node['_having'])
|
|
70
86
|
newQuery['_having'] = this.expectSingle(node['_having'].accept(this), 'HAVING');
|
|
71
87
|
newQuery['_union'] = this.flatList(node['_union'].map(u => u.accept(this)));
|
|
88
|
+
newQuery['_intersect'] = this.flatList(node['_intersect'].map(i => i.accept(this)));
|
|
89
|
+
newQuery['_except'] = this.flatList(node['_except'].map(e => e.accept(this)));
|
|
72
90
|
newQuery['_orderBy'] = this.flatList(node['_orderBy'].map(o => o.accept(this)));
|
|
73
91
|
newQuery['_offset'] = node['_offset'];
|
|
74
92
|
newQuery['_limit'] = node['_limit'];
|
|
@@ -78,7 +96,181 @@ class QueryIdentityTransformer {
|
|
|
78
96
|
const newQuery = new InsertQuery_1.InsertQuery(node['_tableName']);
|
|
79
97
|
newQuery['_orReplace'] = node['_orReplace'];
|
|
80
98
|
newQuery['_columns'] = [...node['_columns']]; // Strings, reuse
|
|
81
|
-
|
|
99
|
+
if (node['_fromSelect']) {
|
|
100
|
+
newQuery['_fromSelect'] = this.expectSingle(node['_fromSelect'].accept(this), 'fromSelect');
|
|
101
|
+
}
|
|
102
|
+
else {
|
|
103
|
+
newQuery['_values'] = this.flatList(node['_values'].map(v => v.accept(this)));
|
|
104
|
+
}
|
|
105
|
+
// Transform ON CONFLICT clause
|
|
106
|
+
newQuery['_onConflictColumns'] = [...node['_onConflictColumns']];
|
|
107
|
+
newQuery['_doNothing'] = node['_doNothing'];
|
|
108
|
+
newQuery['_doUpdateSets'] = node['_doUpdateSets'].map(s => ({
|
|
109
|
+
column: s.column,
|
|
110
|
+
value: this.expectSingle(s.value.accept(this), 'DO UPDATE value')
|
|
111
|
+
}));
|
|
112
|
+
if (node['_onConflictWhere']) {
|
|
113
|
+
newQuery['_onConflictWhere'] = this.expectSingle(node['_onConflictWhere'].accept(this), 'ON CONFLICT WHERE');
|
|
114
|
+
}
|
|
115
|
+
newQuery['_returning'] = this.flatList(node['_returning'].map(r => r.accept(this)));
|
|
116
|
+
return newQuery;
|
|
117
|
+
}
|
|
118
|
+
visitDeleteQuery(node) {
|
|
119
|
+
const newQuery = new DeleteQuery_1.DeleteQuery(node['_tableName']);
|
|
120
|
+
if (node['_where']) {
|
|
121
|
+
newQuery['_where'] = this.expectSingle(node['_where'].accept(this), 'WHERE');
|
|
122
|
+
}
|
|
123
|
+
newQuery['_returning'] = this.flatList(node['_returning'].map(r => r.accept(this)));
|
|
124
|
+
return newQuery;
|
|
125
|
+
}
|
|
126
|
+
visitUpdateQuery(node) {
|
|
127
|
+
const newQuery = new UpdateQuery_1.UpdateQuery(node['_tableName']);
|
|
128
|
+
node['_set'].forEach(s => {
|
|
129
|
+
newQuery.set(s.column, this.expectSingle(s.value.accept(this), 'SET value'));
|
|
130
|
+
});
|
|
131
|
+
if (node['_where']) {
|
|
132
|
+
newQuery['_where'] = this.expectSingle(node['_where'].accept(this), 'WHERE');
|
|
133
|
+
}
|
|
134
|
+
newQuery['_returning'] = this.flatList(node['_returning'].map(r => r.accept(this)));
|
|
135
|
+
return newQuery;
|
|
136
|
+
}
|
|
137
|
+
visitDropTableQuery(node) {
|
|
138
|
+
const newQuery = new DropTableQuery_1.DropTableQuery(node.tableName);
|
|
139
|
+
if (node.hasIfExists) {
|
|
140
|
+
newQuery.ifExists();
|
|
141
|
+
}
|
|
142
|
+
return newQuery;
|
|
143
|
+
}
|
|
144
|
+
visitDropIndexQuery(node) {
|
|
145
|
+
const newQuery = new DropIndexQuery_1.DropIndexQuery(node.indexName);
|
|
146
|
+
if (node.hasIfExists) {
|
|
147
|
+
newQuery.ifExists();
|
|
148
|
+
}
|
|
149
|
+
return newQuery;
|
|
150
|
+
}
|
|
151
|
+
visitDropViewQuery(node) {
|
|
152
|
+
const newQuery = new DropViewQuery_1.DropViewQuery(node.viewName);
|
|
153
|
+
if (node.hasIfExists) {
|
|
154
|
+
newQuery.ifExists();
|
|
155
|
+
}
|
|
156
|
+
return newQuery;
|
|
157
|
+
}
|
|
158
|
+
visitCreateViewQuery(node) {
|
|
159
|
+
const newQuery = new CreateViewQuery_1.CreateViewQuery(node.viewName);
|
|
160
|
+
if (node.columns.length > 0) {
|
|
161
|
+
newQuery.withColumns(...node.columns);
|
|
162
|
+
}
|
|
163
|
+
if (node.isTemporary) {
|
|
164
|
+
newQuery.temporary();
|
|
165
|
+
}
|
|
166
|
+
if (node.hasIfNotExists) {
|
|
167
|
+
newQuery.ifNotExists();
|
|
168
|
+
}
|
|
169
|
+
if (node.selectQuery) {
|
|
170
|
+
newQuery.as(this.expectSingle(node.selectQuery.accept(this), 'SELECT'));
|
|
171
|
+
}
|
|
172
|
+
return newQuery;
|
|
173
|
+
}
|
|
174
|
+
visitCreateIndexQuery(node) {
|
|
175
|
+
const newQuery = new CreateIndexQuery_1.CreateIndexQuery(node.indexName);
|
|
176
|
+
newQuery.on(node.tableName, [...node.columns]);
|
|
177
|
+
if (node.isUnique) {
|
|
178
|
+
newQuery.unique();
|
|
179
|
+
}
|
|
180
|
+
if (node.hasIfNotExists) {
|
|
181
|
+
newQuery.ifNotExists();
|
|
182
|
+
}
|
|
183
|
+
if (node.whereExpression) {
|
|
184
|
+
newQuery.where(this.expectSingle(node.whereExpression.accept(this), 'WHERE'));
|
|
185
|
+
}
|
|
186
|
+
return newQuery;
|
|
187
|
+
}
|
|
188
|
+
visitAlterTableQuery(node) {
|
|
189
|
+
const newQuery = new AlterTableQuery_1.AlterTableQuery(node.tableName);
|
|
190
|
+
const op = node.operation;
|
|
191
|
+
if (op) {
|
|
192
|
+
switch (op.type) {
|
|
193
|
+
case 'ADD_COLUMN':
|
|
194
|
+
const newConstraints = { ...op.column.constraints };
|
|
195
|
+
if (op.column.constraints.check) {
|
|
196
|
+
newConstraints.check = this.expectSingle(op.column.constraints.check.accept(this), 'check constraint');
|
|
197
|
+
}
|
|
198
|
+
newQuery.addColumn(op.column.name, op.column.type, newConstraints);
|
|
199
|
+
break;
|
|
200
|
+
case 'RENAME_COLUMN':
|
|
201
|
+
newQuery.renameColumn(op.oldName, op.newName);
|
|
202
|
+
break;
|
|
203
|
+
case 'DROP_COLUMN':
|
|
204
|
+
newQuery.dropColumn(op.columnName);
|
|
205
|
+
break;
|
|
206
|
+
case 'RENAME_TABLE':
|
|
207
|
+
newQuery.renameTo(op.newTableName);
|
|
208
|
+
break;
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
return newQuery;
|
|
212
|
+
}
|
|
213
|
+
visitCreateTableQuery(node) {
|
|
214
|
+
const newQuery = new CreateTableQuery_1.CreateTableQuery(node.tableName);
|
|
215
|
+
// Copy columns with transformed check constraints
|
|
216
|
+
for (const col of node.columns) {
|
|
217
|
+
const newConstraints = { ...col.constraints };
|
|
218
|
+
if (col.constraints.check) {
|
|
219
|
+
newConstraints.check = this.expectSingle(col.constraints.check.accept(this), 'check constraint');
|
|
220
|
+
}
|
|
221
|
+
newQuery.column(col.name, col.type, newConstraints);
|
|
222
|
+
}
|
|
223
|
+
// Copy table constraints with transformed check expressions
|
|
224
|
+
for (const constraint of node.tableConstraints) {
|
|
225
|
+
switch (constraint.type) {
|
|
226
|
+
case 'PRIMARY KEY':
|
|
227
|
+
newQuery.primaryKey(...constraint.columns);
|
|
228
|
+
break;
|
|
229
|
+
case 'UNIQUE':
|
|
230
|
+
newQuery.unique(...constraint.columns);
|
|
231
|
+
break;
|
|
232
|
+
case 'FOREIGN KEY':
|
|
233
|
+
newQuery.foreignKey(constraint.columns, constraint.references);
|
|
234
|
+
break;
|
|
235
|
+
case 'CHECK':
|
|
236
|
+
const checkExpr = this.expectSingle(constraint.check.accept(this), 'table check constraint');
|
|
237
|
+
newQuery.check(checkExpr, constraint.name);
|
|
238
|
+
break;
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
if (node.hasIfNotExists) {
|
|
242
|
+
newQuery.ifNotExists();
|
|
243
|
+
}
|
|
244
|
+
if (node.hasWithoutRowid) {
|
|
245
|
+
newQuery.withoutRowid();
|
|
246
|
+
}
|
|
247
|
+
if (node.isStrict) {
|
|
248
|
+
newQuery.strict();
|
|
249
|
+
}
|
|
250
|
+
return newQuery;
|
|
251
|
+
}
|
|
252
|
+
visitCreateVirtualTableQuery(node) {
|
|
253
|
+
const newQuery = new CreateVirtualTableQuery_1.CreateVirtualTableQuery(node.tableName, node.module);
|
|
254
|
+
// Copy columns
|
|
255
|
+
for (const col of node.columns) {
|
|
256
|
+
newQuery.column(col);
|
|
257
|
+
}
|
|
258
|
+
// Copy options
|
|
259
|
+
if (node.options.tokenize) {
|
|
260
|
+
newQuery.tokenize(node.options.tokenize);
|
|
261
|
+
}
|
|
262
|
+
if (node.options.content) {
|
|
263
|
+
newQuery.content(node.options.content);
|
|
264
|
+
}
|
|
265
|
+
if (node.options.contentRowid) {
|
|
266
|
+
newQuery.contentRowid(node.options.contentRowid);
|
|
267
|
+
}
|
|
268
|
+
if (node.options.prefix) {
|
|
269
|
+
newQuery.prefix(node.options.prefix);
|
|
270
|
+
}
|
|
271
|
+
if (node.hasIfNotExists) {
|
|
272
|
+
newQuery.ifNotExists();
|
|
273
|
+
}
|
|
82
274
|
return newQuery;
|
|
83
275
|
}
|
|
84
276
|
visitTableFrom(node) {
|
|
@@ -110,6 +302,9 @@ class QueryIdentityTransformer {
|
|
|
110
302
|
visitBinaryExpression(node) {
|
|
111
303
|
return new BinaryExpression_1.BinaryExpression(this.expectSingle(node.left.accept(this), 'left'), node.operator, this.expectSingle(node.right.accept(this), 'right'));
|
|
112
304
|
}
|
|
305
|
+
visitBetweenExpression(node) {
|
|
306
|
+
return new BetweenExpression_1.BetweenExpression(this.expectSingle(node.operand.accept(this), 'operand'), this.expectSingle(node.low.accept(this), 'low'), this.expectSingle(node.high.accept(this), 'high'), node.not);
|
|
307
|
+
}
|
|
113
308
|
visitUnaryExpression(node) {
|
|
114
309
|
return new UnaryExpression_1.UnaryExpression(node.operator, this.expectSingle(node.operand.accept(this), 'operand'));
|
|
115
310
|
}
|
|
@@ -168,6 +363,26 @@ class QueryIdentityTransformer {
|
|
|
168
363
|
visitExistsExpression(node) {
|
|
169
364
|
return new ExistsExpression_1.ExistsExpression(this.expectSingle(node.subquery.accept(this), 'subquery'));
|
|
170
365
|
}
|
|
366
|
+
visitCastExpression(node) {
|
|
367
|
+
return new CastExpression_1.CastExpression(this.expectSingle(node.expression.accept(this), 'cast expression'), node.targetType);
|
|
368
|
+
}
|
|
369
|
+
visitCollateExpression(node) {
|
|
370
|
+
return new CollateExpression_1.CollateExpression(this.expectSingle(node.expression.accept(this), 'collate expression'), node.collation);
|
|
371
|
+
}
|
|
372
|
+
visitSubqueryExpression(node) {
|
|
373
|
+
return new SubqueryExpression_1.SubqueryExpression(this.expectSingle(node.subquery.accept(this), 'subquery'));
|
|
374
|
+
}
|
|
375
|
+
visitWindowExpression(node) {
|
|
376
|
+
const newFn = this.expectSingle(node.function.accept(this), 'window function');
|
|
377
|
+
const newWindowSpec = new WindowSpecification_1.WindowSpecification();
|
|
378
|
+
if (node.windowSpec.partitionByColumns.length > 0) {
|
|
379
|
+
newWindowSpec.setPartitionBy(this.flatList(node.windowSpec.partitionByColumns.map(c => c.accept(this))));
|
|
380
|
+
}
|
|
381
|
+
if (node.windowSpec.orderByColumns.length > 0) {
|
|
382
|
+
newWindowSpec.setOrderBy(this.flatList(node.windowSpec.orderByColumns.map(o => o.accept(this))));
|
|
383
|
+
}
|
|
384
|
+
return new WindowExpression_1.WindowExpression(newFn, newWindowSpec);
|
|
385
|
+
}
|
|
171
386
|
}
|
|
172
387
|
exports.QueryIdentityTransformer = QueryIdentityTransformer;
|
|
173
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"QueryIdentityTransformer.js","sourceRoot":"","sources":["../../src/visitor/QueryIdentityTransformer.ts"],"names":[],"mappings":"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","sourcesContent":["import { Aliasable, AliasableExpression, Expression, SqlTreeNode } from \"../ast/Abstractions\";\nimport { Alias } from \"../ast/Alias\";\nimport { BinaryExpression } from \"../ast/BinaryExpression\";\nimport { CaseExpression, CaseItem } from \"../ast/CaseExpression\";\nimport { Column, ColumnLike } from \"../ast/Column\";\nimport { Concat } from \"../ast/Concat\";\nimport { ExistsExpression } from \"../ast/ExistsExpression\";\nimport { From, FromLike, JsonEachFrom, SubqueryFrom, TableFrom } from \"../ast/From\";\nimport { FunctionExpression } from \"../ast/FunctionExpression\";\nimport { FunctionName } from \"../ast/FunctionName\";\nimport { InExpression } from \"../ast/InExpression\";\nimport { InsertQuery } from \"../ast/InsertQuery\";\nimport { Join, JoinType } from \"../ast/Join\";\nimport { NullLiteral, NumberLiteral, Param, StringLiteral } from \"../ast/Literals\";\nimport { Operator } from \"../ast/Operator\";\nimport { OrderBy, OrderByDirection } from \"../ast/OrderBy\";\nimport { SelectQuery } from \"../ast/SelectQuery\";\nimport { UnaryExpression } from \"../ast/UnaryExpression\";\nimport { With } from \"../ast/With\";\nimport { SqlTreeNodeTransformer } from \"./SqlTreeNodeTransformer\";\n\nexport class QueryIdentityTransformer implements SqlTreeNodeTransformer {\n  public transform(node: SqlTreeNode): SqlTreeNode {\n    const result = node.accept(this);\n    if (Array.isArray(result)) {\n      throw new Error('Top-level transformation must return a single SqlTreeNode');\n    }\n    return result;\n  }\n\n  protected expectSingle<T extends SqlTreeNode>(result: SqlTreeNode | SqlTreeNode[], typeName: string): T {\n    if (Array.isArray(result)) {\n      throw new Error(`Unexpected array in single-node context for ${typeName}`);\n    }\n    return result as T;\n  }\n\n  protected flatList(results: (SqlTreeNode | SqlTreeNode[])[]): SqlTreeNode[] {\n    return results.flatMap(r => Array.isArray(r) ? r : [r]);\n  }\n\n  protected flatList2D(results: (SqlTreeNode | SqlTreeNode[])[][]): SqlTreeNode[][] {\n    return results.map(set => this.flatList(set));\n  }\n\n  visitSelectQuery(node: SelectQuery): SqlTreeNode | SqlTreeNode[] {\n    const newQuery = new SelectQuery();\n    newQuery['_distinct'] = node['_distinct'];\n    newQuery['_with'] = this.flatList(node['_with'].map(w => w.accept(this))) as With[];\n    newQuery['_fromsAndJoins'] = node['_fromsAndJoins'].map(fj => {\n      if (fj && typeof fj === 'object' && 'referent' in fj && 'alias' in fj) {\n        return new Alias(this.expectSingle(fj.referent.accept(this), 'referent') as From, fj.alias);\n      } else if (fj && typeof fj === 'object' && 'accept' in fj) {\n        return this.expectSingle((fj as any).accept(this), 'from/join');\n      } else {\n        throw new Error('Invalid from/join object');\n      }\n    }) as (FromLike | Join)[];\n    newQuery['_columns'] = node['_columns'].map(c => {\n      if (c && typeof c === 'object' && 'referent' in c && 'alias' in c) {\n        return new Alias(this.expectSingle(c.referent.accept(this), 'referent') as AliasableExpression, c.alias);\n      } else if (c && typeof c === 'object' && 'accept' in c) {\n        return this.expectSingle((c as any).accept(this), 'column');\n      } else {\n        throw new Error('Invalid column object');\n      }\n    }) as ColumnLike[];\n    if (node['_where']) newQuery['_where'] = this.expectSingle(node['_where'].accept(this), 'WHERE') as Expression;\n    newQuery['_groupBy'] = this.flatList(node['_groupBy'].map(g => g.accept(this))) as Column[];\n    if (node['_having']) newQuery['_having'] = this.expectSingle(node['_having'].accept(this), 'HAVING') as Expression;\n    newQuery['_union'] = this.flatList(node['_union'].map(u => u.accept(this))) as SelectQuery[];\n    newQuery['_orderBy'] = this.flatList(node['_orderBy'].map(o => o.accept(this))) as OrderBy[];\n    newQuery['_offset'] = node['_offset'];\n    newQuery['_limit'] = node['_limit'];\n    return newQuery;\n  }\n\n  visitInsertQuery(node: InsertQuery): SqlTreeNode | SqlTreeNode[] {\n    const newQuery = new InsertQuery(node['_tableName']);\n    newQuery['_orReplace'] = node['_orReplace'];\n    newQuery['_columns'] = [...node['_columns']]; // Strings, reuse\n    newQuery['_values'] = this.flatList(node['_values'].map(v => v.accept(this))) as Expression[];\n    return newQuery;\n  }\n\n  visitTableFrom(node: TableFrom): SqlTreeNode | SqlTreeNode[] {\n    return new TableFrom(node.tableName);\n  }\n\n  visitSubqueryFrom(node: SubqueryFrom): SqlTreeNode | SqlTreeNode[] {\n    return new SubqueryFrom(this.expectSingle(node.subquery.accept(this), 'subquery') as SelectQuery);\n  }\n\n  visitJsonEachFrom(node: JsonEachFrom): SqlTreeNode | SqlTreeNode[] {\n    const newJsonExpr = this.expectSingle(node.jsonExpression.accept(this), 'jsonExpression') as Expression;\n    const newJsonPath = node.jsonPath ? this.expectSingle(node.jsonPath.accept(this), 'jsonPath') as Expression : undefined;\n    return new JsonEachFrom(newJsonExpr, newJsonPath);\n  }\n\n  visitColumn(node: Column): SqlTreeNode | SqlTreeNode[] {\n    return new Column(node.hasTableName() ? node.tableName! : node.columnName, node.hasTableName() ? node.columnName : undefined);\n  }\n\n  visitAlias<T extends Aliasable>(node: Alias<T>): SqlTreeNode | SqlTreeNode[] {\n    return new Alias(this.expectSingle(node.referent.accept(this), 'referent') as T, node.alias);\n  }\n\n  visitJoinClause(node: Join): SqlTreeNode | SqlTreeNode[] {\n    return new Join(node.type, node.tableName, node.alias, this.expectSingle(node.on.accept(this), 'on') as Expression);\n  }\n\n  visitOrderBy(node: OrderBy): SqlTreeNode | SqlTreeNode[] {\n    return new OrderBy(this.expectSingle(node.column.accept(this), 'column') as Expression, node.direction);\n  }\n\n  visitWithClause(node: With): SqlTreeNode | SqlTreeNode[] {\n    return new With(node.name, this.expectSingle(node.query.accept(this), 'query') as SelectQuery);\n  }\n\n  visitBinaryExpression(node: BinaryExpression): SqlTreeNode | SqlTreeNode[] {\n    return new BinaryExpression(\n      this.expectSingle(node.left.accept(this), 'left') as Expression,\n      node.operator,\n      this.expectSingle(node.right.accept(this), 'right') as Expression\n    );\n  }\n\n  visitUnaryExpression(node: UnaryExpression): SqlTreeNode | SqlTreeNode[] {\n    return new UnaryExpression(node.operator, this.expectSingle(node.operand.accept(this), 'operand') as Expression);\n  }\n\n  visitInExpression(node: InExpression): SqlTreeNode | SqlTreeNode[] {\n    const newLeft = this.flatList(node.left.map(l => l.accept(this))) as Expression[];\n    let newValues: Expression[][] | SelectQuery;\n    if (node.values instanceof SelectQuery) {\n      newValues = this.expectSingle(node.values.accept(this), 'values subquery') as SelectQuery;\n    } else {\n      const newSets: Expression[][] = [];\n      for (const set of node.values) {\n        const transformedSetParts: (Expression | Expression[])[] = set.map(v => v.accept(this));\n        if (set.length > 1 && transformedSetParts.some(Array.isArray)) {\n          throw new Error('Array replacement not allowed in multi-column tuple position');\n        }\n        if (set.length === 1 && Array.isArray(transformedSetParts[0])) {\n          // Single-column splice: add as separate sets\n          transformedSetParts[0].forEach(r => newSets.push([r]));\n        } else {\n          // Normal or multi-column (no arrays)\n          newSets.push(transformedSetParts as Expression[]);\n        }\n      }\n      newValues = newSets;\n    }\n    return new InExpression(newLeft, newValues, node.not);\n  }\n\n  visitConcat(node: Concat): SqlTreeNode | SqlTreeNode[] {\n    return new Concat(...(this.flatList(node.expressions.map(e => e.accept(this))) as Expression[]));\n  }\n\n  visitCaseExpression(node: CaseExpression): SqlTreeNode | SqlTreeNode[] {\n    const newCases: CaseItem[] = node.cases.map(c => ({\n      when: this.expectSingle(c.when.accept(this), 'when') as Expression,\n      then: this.expectSingle(c.then.accept(this), 'then') as Expression\n    }));\n    const newElse = node.else ? this.expectSingle(node.else.accept(this), 'else') as Expression : undefined;\n    return new CaseExpression(newCases, newElse);\n  }\n\n  visitFunctionExpression(node: FunctionExpression): SqlTreeNode | SqlTreeNode[] {\n    return new FunctionExpression(node.name as FunctionName, this.flatList(node.args.map(a => a.accept(this))) as Expression[]);\n  }\n\n  visitParamExpression(node: Param): SqlTreeNode | SqlTreeNode[] {\n    return new Param(node.paramName);\n  }\n\n  visitStringLiteral(node: StringLiteral): SqlTreeNode | SqlTreeNode[] {\n    return new StringLiteral(node.value);\n  }\n\n  visitNumberLiteral(node: NumberLiteral): SqlTreeNode | SqlTreeNode[] {\n    return new NumberLiteral(node.value);\n  }\n\n  visitNullLiteral(node: NullLiteral): SqlTreeNode | SqlTreeNode[] {\n    return NullLiteral.INSTANCE;\n  }\n\n  visitExistsExpression(node: ExistsExpression): SqlTreeNode | SqlTreeNode[] {\n    return new ExistsExpression(this.expectSingle(node.subquery.accept(this), 'subquery') as SelectQuery);\n  }\n}\n"]}
|
|
388
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"QueryIdentityTransformer.js","sourceRoot":"","sources":["../../src/visitor/QueryIdentityTransformer.ts"],"names":[],"mappings":";;;AACA,wCAAqC;AACrC,4DAAyD;AACzD,gEAA6D;AAC7D,8DAA2D;AAC3D,0DAAiE;AACjE,0DAAuD;AACvD,gEAA6D;AAC7D,kEAA+D;AAC/D,8DAA2D;AAC3D,oEAAiE;AACjE,0CAAmD;AACnD,0CAAuC;AACvC,8DAA2D;AAC3D,8DAA8F;AAC9F,4EAAyE;AACzE,4DAAyD;AACzD,oDAAiD;AACjD,0DAAuD;AACvD,0DAAuD;AACvD,wDAAqD;AACrD,8DAA2D;AAC3D,sCAAoF;AACpF,kEAA+D;AAE/D,sDAAmD;AACnD,oDAAkE;AAClE,oDAA4D;AAC5D,sCAA6C;AAC7C,8CAAmF;AAEnF,4CAA2D;AAC3D,oDAAiD;AACjD,4DAAyD;AACzD,sCAAmC;AAGnC,MAAa,wBAAwB;IAC5B,SAAS,CAAC,IAAiB;QAChC,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACjC,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;YAC1B,MAAM,IAAI,KAAK,CAAC,2DAA2D,CAAC,CAAC;QAC/E,CAAC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;IAES,YAAY,CAAwB,MAAmC,EAAE,QAAgB;QACjG,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;YAC1B,MAAM,IAAI,KAAK,CAAC,+CAA+C,QAAQ,EAAE,CAAC,CAAC;QAC7E,CAAC;QACD,OAAO,MAAW,CAAC;IACrB,CAAC;IAES,QAAQ,CAAC,OAAwC;QACzD,OAAO,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC1D,CAAC;IAES,UAAU,CAAC,OAA0C;QAC7D,OAAO,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC;IAChD,CAAC;IAED,gBAAgB,CAAC,IAAiB;QAChC,MAAM,QAAQ,GAAG,IAAI,yBAAW,EAAE,CAAC;QACnC,QAAQ,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC;QAC1C,QAAQ,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAW,CAAC;QACpF,QAAQ,CAAC,gBAAgB,CAAC,GAAG,IAAI,CAAC,gBAAgB,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE;YAC3D,IAAI,EAAE,IAAI,OAAO,EAAE,KAAK,QAAQ,IAAI,UAAU,IAAI,EAAE,IAAI,OAAO,IAAI,EAAE,EAAE,CAAC;gBACtE,OAAO,IAAI,aAAK,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,UAAU,CAAS,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC;YAC9F,CAAC;iBAAM,IAAI,EAAE,IAAI,OAAO,EAAE,KAAK,QAAQ,IAAI,QAAQ,IAAI,EAAE,EAAE,CAAC;gBAC1D,OAAO,IAAI,CAAC,YAAY,CAAE,EAAU,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,WAAW,CAAC,CAAC;YAClE,CAAC;iBAAM,CAAC;gBACN,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;YAC9C,CAAC;QACH,CAAC,CAAwB,CAAC;QAC1B,QAAQ,CAAC,UAAU,CAAC,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;YAC9C,IAAI,CAAC,IAAI,OAAO,CAAC,KAAK,QAAQ,IAAI,UAAU,IAAI,CAAC,IAAI,OAAO,IAAI,CAAC,EAAE,CAAC;gBAClE,OAAO,IAAI,aAAK,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,UAAU,CAAwB,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC;YAC3G,CAAC;iBAAM,IAAI,CAAC,IAAI,OAAO,CAAC,KAAK,QAAQ,IAAI,QAAQ,IAAI,CAAC,EAAE,CAAC;gBACvD,OAAO,IAAI,CAAC,YAAY,CAAE,CAAS,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,QAAQ,CAAC,CAAC;YAC9D,CAAC;iBAAM,CAAC;gBACN,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;YAC3C,CAAC;QACH,CAAC,CAAiB,CAAC;QACnB,IAAI,IAAI,CAAC,QAAQ,CAAC;YAAE,QAAQ,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,OAAO,CAAe,CAAC;QAC/G,QAAQ,CAAC,UAAU,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAa,CAAC;QAC5F,IAAI,IAAI,CAAC,SAAS,CAAC;YAAE,QAAQ,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,QAAQ,CAAe,CAAC;QACnH,QAAQ,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAkB,CAAC;QAC7F,QAAQ,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAkB,CAAC;QACrG,QAAQ,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAkB,CAAC;QAC/F,QAAQ,CAAC,UAAU,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAc,CAAC;QAC7F,QAAQ,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC;QACtC,QAAQ,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC;QACpC,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,gBAAgB,CAAC,IAAiB;QAChC,MAAM,QAAQ,GAAG,IAAI,yBAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;QACrD,QAAQ,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC;QAC5C,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,iBAAiB;QAC/D,IAAI,IAAI,CAAC,aAAa,CAAC,EAAE,CAAC;YACxB,QAAQ,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,YAAY,CAAgB,CAAC;QAC7G,CAAC;aAAM,CAAC;YACN,QAAQ,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAiB,CAAC;QAChG,CAAC;QACD,+BAA+B;QAC/B,QAAQ,CAAC,oBAAoB,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,oBAAoB,CAAC,CAAC,CAAC;QACjE,QAAQ,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC;QAC5C,QAAQ,CAAC,eAAe,CAAC,GAAG,IAAI,CAAC,eAAe,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;YAC1D,MAAM,EAAE,CAAC,CAAC,MAAM;YAChB,KAAK,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,iBAAiB,CAAe;SAChF,CAAC,CAAsB,CAAC;QACzB,IAAI,IAAI,CAAC,kBAAkB,CAAC,EAAE,CAAC;YAC7B,QAAQ,CAAC,kBAAkB,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,mBAAmB,CAAe,CAAC;QAC7H,CAAC;QACD,QAAQ,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAA0B,CAAC;QAC7G,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,gBAAgB,CAAC,IAAiB;QAChC,MAAM,QAAQ,GAAG,IAAI,yBAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;QACrD,IAAI,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;YACnB,QAAQ,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,OAAO,CAAe,CAAC;QAC7F,CAAC;QACD,QAAQ,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAA0B,CAAC;QAC7G,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,gBAAgB,CAAC,IAAiB;QAChC,MAAM,QAAQ,GAAG,IAAI,yBAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;QACrD,IAAI,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;YACvB,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,WAAW,CAAe,CAAC,CAAC;QAC7F,CAAC,CAAC,CAAC;QACH,IAAI,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;YACnB,QAAQ,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,OAAO,CAAe,CAAC;QAC7F,CAAC;QACD,QAAQ,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAA0B,CAAC;QAC7G,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,mBAAmB,CAAC,IAAoB;QACtC,MAAM,QAAQ,GAAG,IAAI,+BAAc,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACpD,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,QAAQ,CAAC,QAAQ,EAAE,CAAC;QACtB,CAAC;QACD,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,mBAAmB,CAAC,IAAoB;QACtC,MAAM,QAAQ,GAAG,IAAI,+BAAc,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACpD,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,QAAQ,CAAC,QAAQ,EAAE,CAAC;QACtB,CAAC;QACD,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,kBAAkB,CAAC,IAAmB;QACpC,MAAM,QAAQ,GAAG,IAAI,6BAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAClD,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,QAAQ,CAAC,QAAQ,EAAE,CAAC;QACtB,CAAC;QACD,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,oBAAoB,CAAC,IAAqB;QACxC,MAAM,QAAQ,GAAG,IAAI,iCAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAEpD,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC5B,QAAQ,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC;QACxC,CAAC;QACD,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,QAAQ,CAAC,SAAS,EAAE,CAAC;QACvB,CAAC;QACD,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACxB,QAAQ,CAAC,WAAW,EAAE,CAAC;QACzB,CAAC;QACD,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,QAAQ,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,QAAQ,CAAgB,CAAC,CAAC;QACzF,CAAC;QAED,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,qBAAqB,CAAC,IAAsB;QAC1C,MAAM,QAAQ,GAAG,IAAI,mCAAgB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACtD,QAAQ,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;QAE/C,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClB,QAAQ,CAAC,MAAM,EAAE,CAAC;QACpB,CAAC;QACD,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACxB,QAAQ,CAAC,WAAW,EAAE,CAAC;QACzB,CAAC;QACD,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YACzB,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,OAAO,CAAe,CAAC,CAAC;QAC9F,CAAC;QAED,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,oBAAoB,CAAC,IAAqB;QACxC,MAAM,QAAQ,GAAG,IAAI,iCAAe,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACrD,MAAM,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC;QAE1B,IAAI,EAAE,EAAE,CAAC;YACP,QAAQ,EAAE,CAAC,IAAI,EAAE,CAAC;gBAChB,KAAK,YAAY;oBACf,MAAM,cAAc,GAAG,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC;oBACpD,IAAI,EAAE,CAAC,MAAM,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;wBAChC,cAAc,CAAC,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,MAAM,CAAC,WAAW,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,kBAAkB,CAAe,CAAC;oBACvH,CAAC;oBACD,QAAQ,CAAC,SAAS,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE,cAAc,CAAC,CAAC;oBACnE,MAAM;gBACR,KAAK,eAAe;oBAClB,QAAQ,CAAC,YAAY,CAAC,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC;oBAC9C,MAAM;gBACR,KAAK,aAAa;oBAChB,QAAQ,CAAC,UAAU,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC;oBACnC,MAAM;gBACR,KAAK,cAAc;oBACjB,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC;oBACnC,MAAM;YACV,CAAC;QACH,CAAC;QAED,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,qBAAqB,CAAC,IAAsB;QAC1C,MAAM,QAAQ,GAAG,IAAI,mCAAgB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAEtD,kDAAkD;QAClD,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YAC/B,MAAM,cAAc,GAAG,EAAE,GAAG,GAAG,CAAC,WAAW,EAAE,CAAC;YAC9C,IAAI,GAAG,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;gBAC1B,cAAc,CAAC,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,WAAW,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,kBAAkB,CAAe,CAAC;YACjH,CAAC;YACD,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,EAAE,GAAG,CAAC,IAAI,EAAE,cAAc,CAAC,CAAC;QACtD,CAAC;QAED,4DAA4D;QAC5D,KAAK,MAAM,UAAU,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC/C,QAAQ,UAAU,CAAC,IAAI,EAAE,CAAC;gBACxB,KAAK,aAAa;oBAChB,QAAQ,CAAC,UAAU,CAAC,GAAG,UAAU,CAAC,OAAQ,CAAC,CAAC;oBAC5C,MAAM;gBACR,KAAK,QAAQ;oBACX,QAAQ,CAAC,MAAM,CAAC,GAAG,UAAU,CAAC,OAAQ,CAAC,CAAC;oBACxC,MAAM;gBACR,KAAK,aAAa;oBAChB,QAAQ,CAAC,UAAU,CAAC,UAAU,CAAC,OAAQ,EAAE,UAAU,CAAC,UAAW,CAAC,CAAC;oBACjE,MAAM;gBACR,KAAK,OAAO;oBACV,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,KAAM,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,wBAAwB,CAAe,CAAC;oBAC5G,QAAQ,CAAC,KAAK,CAAC,SAAS,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC;oBAC3C,MAAM;YACV,CAAC;QACH,CAAC;QAED,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACxB,QAAQ,CAAC,WAAW,EAAE,CAAC;QACzB,CAAC;QACD,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YACzB,QAAQ,CAAC,YAAY,EAAE,CAAC;QAC1B,CAAC;QACD,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClB,QAAQ,CAAC,MAAM,EAAE,CAAC;QACpB,CAAC;QAED,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,4BAA4B,CAAC,IAA6B;QACxD,MAAM,QAAQ,GAAG,IAAI,iDAAuB,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QAE1E,eAAe;QACf,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YAC/B,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QACvB,CAAC;QAED,eAAe;QACf,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;YAC1B,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;QAC3C,CAAC;QACD,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;YACzB,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QACzC,CAAC;QACD,IAAI,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC;YAC9B,QAAQ,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;QACnD,CAAC;QACD,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;YACxB,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QACvC,CAAC;QAED,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACxB,QAAQ,CAAC,WAAW,EAAE,CAAC;QACzB,CAAC;QAED,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,cAAc,CAAC,IAAe;QAC5B,OAAO,IAAI,gBAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACvC,CAAC;IAED,iBAAiB,CAAC,IAAkB;QAClC,OAAO,IAAI,mBAAY,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,UAAU,CAAgB,CAAC,CAAC;IACpG,CAAC;IAED,iBAAiB,CAAC,IAAkB;QAClC,MAAM,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,gBAAgB,CAAe,CAAC;QACxG,MAAM,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,UAAU,CAAe,CAAC,CAAC,CAAC,SAAS,CAAC;QACxH,OAAO,IAAI,mBAAY,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC;IACpD,CAAC;IAED,WAAW,CAAC,IAAY;QACtB,OAAO,IAAI,eAAM,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,SAAU,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;IAChI,CAAC;IAED,UAAU,CAAsB,IAAc;QAC5C,OAAO,IAAI,aAAK,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,UAAU,CAAM,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;IAC/F,CAAC;IAED,eAAe,CAAC,IAAU;QACxB,OAAO,IAAI,WAAI,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,IAAI,CAAe,CAAC,CAAC;IACtH,CAAC;IAED,YAAY,CAAC,IAAa;QACxB,OAAO,IAAI,iBAAO,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,QAAQ,CAAe,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;IAC1G,CAAC;IAED,eAAe,CAAC,IAAU;QACxB,OAAO,IAAI,WAAI,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,OAAO,CAAgB,CAAC,CAAC;IACjG,CAAC;IAED,qBAAqB,CAAC,IAAsB;QAC1C,OAAO,IAAI,mCAAgB,CACzB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,MAAM,CAAe,EAC/D,IAAI,CAAC,QAAQ,EACb,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,OAAO,CAAe,CAClE,CAAC;IACJ,CAAC;IAED,sBAAsB,CAAC,IAAuB;QAC5C,OAAO,IAAI,qCAAiB,CAC1B,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,SAAS,CAAe,EACrE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,KAAK,CAAe,EAC7D,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,MAAM,CAAe,EAC/D,IAAI,CAAC,GAAG,CACT,CAAC;IACJ,CAAC;IAED,oBAAoB,CAAC,IAAqB;QACxC,OAAO,IAAI,iCAAe,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,SAAS,CAAe,CAAC,CAAC;IACnH,CAAC;IAED,iBAAiB,CAAC,IAAkB;QAClC,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAiB,CAAC;QAClF,IAAI,SAAuC,CAAC;QAC5C,IAAI,IAAI,CAAC,MAAM,YAAY,yBAAW,EAAE,CAAC;YACvC,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,iBAAiB,CAAgB,CAAC;QAC5F,CAAC;aAAM,CAAC;YACN,MAAM,OAAO,GAAmB,EAAE,CAAC;YACnC,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;gBAC9B,MAAM,mBAAmB,GAAkC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;gBACxF,IAAI,GAAG,CAAC,MAAM,GAAG,CAAC,IAAI,mBAAmB,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC;oBAC9D,MAAM,IAAI,KAAK,CAAC,8DAA8D,CAAC,CAAC;gBAClF,CAAC;gBACD,IAAI,GAAG,CAAC,MAAM,KAAK,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;oBAC9D,6CAA6C;oBAC7C,mBAAmB,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBACzD,CAAC;qBAAM,CAAC;oBACN,qCAAqC;oBACrC,OAAO,CAAC,IAAI,CAAC,mBAAmC,CAAC,CAAC;gBACpD,CAAC;YACH,CAAC;YACD,SAAS,GAAG,OAAO,CAAC;QACtB,CAAC;QACD,OAAO,IAAI,2BAAY,CAAC,OAAO,EAAE,SAAS,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;IACxD,CAAC;IAED,WAAW,CAAC,IAAY;QACtB,OAAO,IAAI,eAAM,CAAC,GAAI,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAkB,CAAC,CAAC;IACnG,CAAC;IAED,mBAAmB,CAAC,IAAoB;QACtC,MAAM,QAAQ,GAAe,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;YAChD,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,MAAM,CAAe;YAClE,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,MAAM,CAAe;SACnE,CAAC,CAAC,CAAC;QACJ,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,MAAM,CAAe,CAAC,CAAC,CAAC,SAAS,CAAC;QACxG,OAAO,IAAI,+BAAc,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;IAC/C,CAAC;IAED,uBAAuB,CAAC,IAAwB;QAC9C,OAAO,IAAI,uCAAkB,CAAC,IAAI,CAAC,IAAoB,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAiB,CAAC,CAAC;IAC9H,CAAC;IAED,oBAAoB,CAAC,IAAW;QAC9B,OAAO,IAAI,gBAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACnC,CAAC;IAED,kBAAkB,CAAC,IAAmB;QACpC,OAAO,IAAI,wBAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACvC,CAAC;IAED,kBAAkB,CAAC,IAAmB;QACpC,OAAO,IAAI,wBAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACvC,CAAC;IAED,gBAAgB,CAAC,IAAiB;QAChC,OAAO,sBAAW,CAAC,QAAQ,CAAC;IAC9B,CAAC;IAED,qBAAqB,CAAC,IAAsB;QAC1C,OAAO,IAAI,mCAAgB,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,UAAU,CAAgB,CAAC,CAAC;IACxG,CAAC;IAED,mBAAmB,CAAC,IAAoB;QACtC,OAAO,IAAI,+BAAc,CACvB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,iBAAiB,CAAe,EAChF,IAAI,CAAC,UAAU,CAChB,CAAC;IACJ,CAAC;IAED,sBAAsB,CAAC,IAAuB;QAC5C,OAAO,IAAI,qCAAiB,CAC1B,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,oBAAoB,CAAe,EACnF,IAAI,CAAC,SAAS,CACf,CAAC;IACJ,CAAC;IAED,uBAAuB,CAAC,IAAwB;QAC9C,OAAO,IAAI,uCAAkB,CAC3B,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,UAAU,CAAgB,CACzE,CAAC;IACJ,CAAC;IAED,qBAAqB,CAAC,IAAsB;QAC1C,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,iBAAiB,CAAuB,CAAC;QAErG,MAAM,aAAa,GAAG,IAAI,yCAAmB,EAAE,CAAC;QAChD,IAAI,IAAI,CAAC,UAAU,CAAC,kBAAkB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAClD,aAAa,CAAC,cAAc,CAC1B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAiB,CAC3F,CAAC;QACJ,CAAC;QACD,IAAI,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC9C,aAAa,CAAC,UAAU,CACtB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAc,CACpF,CAAC;QACJ,CAAC;QAED,OAAO,IAAI,mCAAgB,CAAC,KAAK,EAAE,aAAa,CAAC,CAAC;IACpD,CAAC;CACF;AAjaD,4DAiaC","sourcesContent":["import { Aliasable, AliasableExpression, Expression, SqlTreeNode } from \"../ast/Abstractions\";\nimport { Alias } from \"../ast/Alias\";\nimport { AlterTableQuery } from \"../ast/AlterTableQuery\";\nimport { BetweenExpression } from \"../ast/BetweenExpression\";\nimport { BinaryExpression } from \"../ast/BinaryExpression\";\nimport { CaseExpression, CaseItem } from \"../ast/CaseExpression\";\nimport { CastExpression } from \"../ast/CastExpression\";\nimport { CollateExpression } from \"../ast/CollateExpression\";\nimport { SubqueryExpression } from \"../ast/SubqueryExpression\";\nimport { WindowExpression } from \"../ast/WindowExpression\";\nimport { WindowSpecification } from \"../ast/WindowSpecification\";\nimport { Column, ColumnLike } from \"../ast/Column\";\nimport { Concat } from \"../ast/Concat\";\nimport { CreateIndexQuery } from \"../ast/CreateIndexQuery\";\nimport { CreateTableQuery, ColumnDefinition, TableConstraint } from \"../ast/CreateTableQuery\";\nimport { CreateVirtualTableQuery } from \"../ast/CreateVirtualTableQuery\";\nimport { CreateViewQuery } from \"../ast/CreateViewQuery\";\nimport { DeleteQuery } from \"../ast/DeleteQuery\";\nimport { DropIndexQuery } from \"../ast/DropIndexQuery\";\nimport { DropTableQuery } from \"../ast/DropTableQuery\";\nimport { DropViewQuery } from \"../ast/DropViewQuery\";\nimport { ExistsExpression } from \"../ast/ExistsExpression\";\nimport { From, FromLike, JsonEachFrom, SubqueryFrom, TableFrom } from \"../ast/From\";\nimport { FunctionExpression } from \"../ast/FunctionExpression\";\nimport { FunctionName } from \"../ast/FunctionName\";\nimport { InExpression } from \"../ast/InExpression\";\nimport { InsertQuery, UpsertSetClause } from \"../ast/InsertQuery\";\nimport { UpdateQuery, SetClause } from \"../ast/UpdateQuery\";\nimport { Join, JoinType } from \"../ast/Join\";\nimport { NullLiteral, NumberLiteral, Param, StringLiteral } from \"../ast/Literals\";\nimport { Operator } from \"../ast/Operator\";\nimport { OrderBy, OrderByDirection } from \"../ast/OrderBy\";\nimport { SelectQuery } from \"../ast/SelectQuery\";\nimport { UnaryExpression } from \"../ast/UnaryExpression\";\nimport { With } from \"../ast/With\";\nimport { SqlTreeNodeTransformer } from \"./SqlTreeNodeTransformer\";\n\nexport class QueryIdentityTransformer implements SqlTreeNodeTransformer {\n  public transform(node: SqlTreeNode): SqlTreeNode {\n    const result = node.accept(this);\n    if (Array.isArray(result)) {\n      throw new Error('Top-level transformation must return a single SqlTreeNode');\n    }\n    return result;\n  }\n\n  protected expectSingle<T extends SqlTreeNode>(result: SqlTreeNode | SqlTreeNode[], typeName: string): T {\n    if (Array.isArray(result)) {\n      throw new Error(`Unexpected array in single-node context for ${typeName}`);\n    }\n    return result as T;\n  }\n\n  protected flatList(results: (SqlTreeNode | SqlTreeNode[])[]): SqlTreeNode[] {\n    return results.flatMap(r => Array.isArray(r) ? r : [r]);\n  }\n\n  protected flatList2D(results: (SqlTreeNode | SqlTreeNode[])[][]): SqlTreeNode[][] {\n    return results.map(set => this.flatList(set));\n  }\n\n  visitSelectQuery(node: SelectQuery): SqlTreeNode | SqlTreeNode[] {\n    const newQuery = new SelectQuery();\n    newQuery['_distinct'] = node['_distinct'];\n    newQuery['_with'] = this.flatList(node['_with'].map(w => w.accept(this))) as With[];\n    newQuery['_fromsAndJoins'] = node['_fromsAndJoins'].map(fj => {\n      if (fj && typeof fj === 'object' && 'referent' in fj && 'alias' in fj) {\n        return new Alias(this.expectSingle(fj.referent.accept(this), 'referent') as From, fj.alias);\n      } else if (fj && typeof fj === 'object' && 'accept' in fj) {\n        return this.expectSingle((fj as any).accept(this), 'from/join');\n      } else {\n        throw new Error('Invalid from/join object');\n      }\n    }) as (FromLike | Join)[];\n    newQuery['_columns'] = node['_columns'].map(c => {\n      if (c && typeof c === 'object' && 'referent' in c && 'alias' in c) {\n        return new Alias(this.expectSingle(c.referent.accept(this), 'referent') as AliasableExpression, c.alias);\n      } else if (c && typeof c === 'object' && 'accept' in c) {\n        return this.expectSingle((c as any).accept(this), 'column');\n      } else {\n        throw new Error('Invalid column object');\n      }\n    }) as ColumnLike[];\n    if (node['_where']) newQuery['_where'] = this.expectSingle(node['_where'].accept(this), 'WHERE') as Expression;\n    newQuery['_groupBy'] = this.flatList(node['_groupBy'].map(g => g.accept(this))) as Column[];\n    if (node['_having']) newQuery['_having'] = this.expectSingle(node['_having'].accept(this), 'HAVING') as Expression;\n    newQuery['_union'] = this.flatList(node['_union'].map(u => u.accept(this))) as SelectQuery[];\n    newQuery['_intersect'] = this.flatList(node['_intersect'].map(i => i.accept(this))) as SelectQuery[];\n    newQuery['_except'] = this.flatList(node['_except'].map(e => e.accept(this))) as SelectQuery[];\n    newQuery['_orderBy'] = this.flatList(node['_orderBy'].map(o => o.accept(this))) as OrderBy[];\n    newQuery['_offset'] = node['_offset'];\n    newQuery['_limit'] = node['_limit'];\n    return newQuery;\n  }\n\n  visitInsertQuery(node: InsertQuery): SqlTreeNode | SqlTreeNode[] {\n    const newQuery = new InsertQuery(node['_tableName']);\n    newQuery['_orReplace'] = node['_orReplace'];\n    newQuery['_columns'] = [...node['_columns']]; // Strings, reuse\n    if (node['_fromSelect']) {\n      newQuery['_fromSelect'] = this.expectSingle(node['_fromSelect'].accept(this), 'fromSelect') as SelectQuery;\n    } else {\n      newQuery['_values'] = this.flatList(node['_values'].map(v => v.accept(this))) as Expression[];\n    }\n    // Transform ON CONFLICT clause\n    newQuery['_onConflictColumns'] = [...node['_onConflictColumns']];\n    newQuery['_doNothing'] = node['_doNothing'];\n    newQuery['_doUpdateSets'] = node['_doUpdateSets'].map(s => ({\n      column: s.column,\n      value: this.expectSingle(s.value.accept(this), 'DO UPDATE value') as Expression\n    })) as UpsertSetClause[];\n    if (node['_onConflictWhere']) {\n      newQuery['_onConflictWhere'] = this.expectSingle(node['_onConflictWhere'].accept(this), 'ON CONFLICT WHERE') as Expression;\n    }\n    newQuery['_returning'] = this.flatList(node['_returning'].map(r => r.accept(this))) as AliasableExpression[];\n    return newQuery;\n  }\n\n  visitDeleteQuery(node: DeleteQuery): SqlTreeNode | SqlTreeNode[] {\n    const newQuery = new DeleteQuery(node['_tableName']);\n    if (node['_where']) {\n      newQuery['_where'] = this.expectSingle(node['_where'].accept(this), 'WHERE') as Expression;\n    }\n    newQuery['_returning'] = this.flatList(node['_returning'].map(r => r.accept(this))) as AliasableExpression[];\n    return newQuery;\n  }\n\n  visitUpdateQuery(node: UpdateQuery): SqlTreeNode | SqlTreeNode[] {\n    const newQuery = new UpdateQuery(node['_tableName']);\n    node['_set'].forEach(s => {\n      newQuery.set(s.column, this.expectSingle(s.value.accept(this), 'SET value') as Expression);\n    });\n    if (node['_where']) {\n      newQuery['_where'] = this.expectSingle(node['_where'].accept(this), 'WHERE') as Expression;\n    }\n    newQuery['_returning'] = this.flatList(node['_returning'].map(r => r.accept(this))) as AliasableExpression[];\n    return newQuery;\n  }\n\n  visitDropTableQuery(node: DropTableQuery): SqlTreeNode | SqlTreeNode[] {\n    const newQuery = new DropTableQuery(node.tableName);\n    if (node.hasIfExists) {\n      newQuery.ifExists();\n    }\n    return newQuery;\n  }\n\n  visitDropIndexQuery(node: DropIndexQuery): SqlTreeNode | SqlTreeNode[] {\n    const newQuery = new DropIndexQuery(node.indexName);\n    if (node.hasIfExists) {\n      newQuery.ifExists();\n    }\n    return newQuery;\n  }\n\n  visitDropViewQuery(node: DropViewQuery): SqlTreeNode | SqlTreeNode[] {\n    const newQuery = new DropViewQuery(node.viewName);\n    if (node.hasIfExists) {\n      newQuery.ifExists();\n    }\n    return newQuery;\n  }\n\n  visitCreateViewQuery(node: CreateViewQuery): SqlTreeNode | SqlTreeNode[] {\n    const newQuery = new CreateViewQuery(node.viewName);\n\n    if (node.columns.length > 0) {\n      newQuery.withColumns(...node.columns);\n    }\n    if (node.isTemporary) {\n      newQuery.temporary();\n    }\n    if (node.hasIfNotExists) {\n      newQuery.ifNotExists();\n    }\n    if (node.selectQuery) {\n      newQuery.as(this.expectSingle(node.selectQuery.accept(this), 'SELECT') as SelectQuery);\n    }\n\n    return newQuery;\n  }\n\n  visitCreateIndexQuery(node: CreateIndexQuery): SqlTreeNode | SqlTreeNode[] {\n    const newQuery = new CreateIndexQuery(node.indexName);\n    newQuery.on(node.tableName, [...node.columns]);\n\n    if (node.isUnique) {\n      newQuery.unique();\n    }\n    if (node.hasIfNotExists) {\n      newQuery.ifNotExists();\n    }\n    if (node.whereExpression) {\n      newQuery.where(this.expectSingle(node.whereExpression.accept(this), 'WHERE') as Expression);\n    }\n\n    return newQuery;\n  }\n\n  visitAlterTableQuery(node: AlterTableQuery): SqlTreeNode | SqlTreeNode[] {\n    const newQuery = new AlterTableQuery(node.tableName);\n    const op = node.operation;\n\n    if (op) {\n      switch (op.type) {\n        case 'ADD_COLUMN':\n          const newConstraints = { ...op.column.constraints };\n          if (op.column.constraints.check) {\n            newConstraints.check = this.expectSingle(op.column.constraints.check.accept(this), 'check constraint') as Expression;\n          }\n          newQuery.addColumn(op.column.name, op.column.type, newConstraints);\n          break;\n        case 'RENAME_COLUMN':\n          newQuery.renameColumn(op.oldName, op.newName);\n          break;\n        case 'DROP_COLUMN':\n          newQuery.dropColumn(op.columnName);\n          break;\n        case 'RENAME_TABLE':\n          newQuery.renameTo(op.newTableName);\n          break;\n      }\n    }\n\n    return newQuery;\n  }\n\n  visitCreateTableQuery(node: CreateTableQuery): SqlTreeNode | SqlTreeNode[] {\n    const newQuery = new CreateTableQuery(node.tableName);\n\n    // Copy columns with transformed check constraints\n    for (const col of node.columns) {\n      const newConstraints = { ...col.constraints };\n      if (col.constraints.check) {\n        newConstraints.check = this.expectSingle(col.constraints.check.accept(this), 'check constraint') as Expression;\n      }\n      newQuery.column(col.name, col.type, newConstraints);\n    }\n\n    // Copy table constraints with transformed check expressions\n    for (const constraint of node.tableConstraints) {\n      switch (constraint.type) {\n        case 'PRIMARY KEY':\n          newQuery.primaryKey(...constraint.columns!);\n          break;\n        case 'UNIQUE':\n          newQuery.unique(...constraint.columns!);\n          break;\n        case 'FOREIGN KEY':\n          newQuery.foreignKey(constraint.columns!, constraint.references!);\n          break;\n        case 'CHECK':\n          const checkExpr = this.expectSingle(constraint.check!.accept(this), 'table check constraint') as Expression;\n          newQuery.check(checkExpr, constraint.name);\n          break;\n      }\n    }\n\n    if (node.hasIfNotExists) {\n      newQuery.ifNotExists();\n    }\n    if (node.hasWithoutRowid) {\n      newQuery.withoutRowid();\n    }\n    if (node.isStrict) {\n      newQuery.strict();\n    }\n\n    return newQuery;\n  }\n\n  visitCreateVirtualTableQuery(node: CreateVirtualTableQuery): SqlTreeNode | SqlTreeNode[] {\n    const newQuery = new CreateVirtualTableQuery(node.tableName, node.module);\n\n    // Copy columns\n    for (const col of node.columns) {\n      newQuery.column(col);\n    }\n\n    // Copy options\n    if (node.options.tokenize) {\n      newQuery.tokenize(node.options.tokenize);\n    }\n    if (node.options.content) {\n      newQuery.content(node.options.content);\n    }\n    if (node.options.contentRowid) {\n      newQuery.contentRowid(node.options.contentRowid);\n    }\n    if (node.options.prefix) {\n      newQuery.prefix(node.options.prefix);\n    }\n\n    if (node.hasIfNotExists) {\n      newQuery.ifNotExists();\n    }\n\n    return newQuery;\n  }\n\n  visitTableFrom(node: TableFrom): SqlTreeNode | SqlTreeNode[] {\n    return new TableFrom(node.tableName);\n  }\n\n  visitSubqueryFrom(node: SubqueryFrom): SqlTreeNode | SqlTreeNode[] {\n    return new SubqueryFrom(this.expectSingle(node.subquery.accept(this), 'subquery') as SelectQuery);\n  }\n\n  visitJsonEachFrom(node: JsonEachFrom): SqlTreeNode | SqlTreeNode[] {\n    const newJsonExpr = this.expectSingle(node.jsonExpression.accept(this), 'jsonExpression') as Expression;\n    const newJsonPath = node.jsonPath ? this.expectSingle(node.jsonPath.accept(this), 'jsonPath') as Expression : undefined;\n    return new JsonEachFrom(newJsonExpr, newJsonPath);\n  }\n\n  visitColumn(node: Column): SqlTreeNode | SqlTreeNode[] {\n    return new Column(node.hasTableName() ? node.tableName! : node.columnName, node.hasTableName() ? node.columnName : undefined);\n  }\n\n  visitAlias<T extends Aliasable>(node: Alias<T>): SqlTreeNode | SqlTreeNode[] {\n    return new Alias(this.expectSingle(node.referent.accept(this), 'referent') as T, node.alias);\n  }\n\n  visitJoinClause(node: Join): SqlTreeNode | SqlTreeNode[] {\n    return new Join(node.type, node.tableName, node.alias, this.expectSingle(node.on.accept(this), 'on') as Expression);\n  }\n\n  visitOrderBy(node: OrderBy): SqlTreeNode | SqlTreeNode[] {\n    return new OrderBy(this.expectSingle(node.column.accept(this), 'column') as Expression, node.direction);\n  }\n\n  visitWithClause(node: With): SqlTreeNode | SqlTreeNode[] {\n    return new With(node.name, this.expectSingle(node.query.accept(this), 'query') as SelectQuery);\n  }\n\n  visitBinaryExpression(node: BinaryExpression): SqlTreeNode | SqlTreeNode[] {\n    return new BinaryExpression(\n      this.expectSingle(node.left.accept(this), 'left') as Expression,\n      node.operator,\n      this.expectSingle(node.right.accept(this), 'right') as Expression\n    );\n  }\n\n  visitBetweenExpression(node: BetweenExpression): SqlTreeNode | SqlTreeNode[] {\n    return new BetweenExpression(\n      this.expectSingle(node.operand.accept(this), 'operand') as Expression,\n      this.expectSingle(node.low.accept(this), 'low') as Expression,\n      this.expectSingle(node.high.accept(this), 'high') as Expression,\n      node.not\n    );\n  }\n\n  visitUnaryExpression(node: UnaryExpression): SqlTreeNode | SqlTreeNode[] {\n    return new UnaryExpression(node.operator, this.expectSingle(node.operand.accept(this), 'operand') as Expression);\n  }\n\n  visitInExpression(node: InExpression): SqlTreeNode | SqlTreeNode[] {\n    const newLeft = this.flatList(node.left.map(l => l.accept(this))) as Expression[];\n    let newValues: Expression[][] | SelectQuery;\n    if (node.values instanceof SelectQuery) {\n      newValues = this.expectSingle(node.values.accept(this), 'values subquery') as SelectQuery;\n    } else {\n      const newSets: Expression[][] = [];\n      for (const set of node.values) {\n        const transformedSetParts: (Expression | Expression[])[] = set.map(v => v.accept(this));\n        if (set.length > 1 && transformedSetParts.some(Array.isArray)) {\n          throw new Error('Array replacement not allowed in multi-column tuple position');\n        }\n        if (set.length === 1 && Array.isArray(transformedSetParts[0])) {\n          // Single-column splice: add as separate sets\n          transformedSetParts[0].forEach(r => newSets.push([r]));\n        } else {\n          // Normal or multi-column (no arrays)\n          newSets.push(transformedSetParts as Expression[]);\n        }\n      }\n      newValues = newSets;\n    }\n    return new InExpression(newLeft, newValues, node.not);\n  }\n\n  visitConcat(node: Concat): SqlTreeNode | SqlTreeNode[] {\n    return new Concat(...(this.flatList(node.expressions.map(e => e.accept(this))) as Expression[]));\n  }\n\n  visitCaseExpression(node: CaseExpression): SqlTreeNode | SqlTreeNode[] {\n    const newCases: CaseItem[] = node.cases.map(c => ({\n      when: this.expectSingle(c.when.accept(this), 'when') as Expression,\n      then: this.expectSingle(c.then.accept(this), 'then') as Expression\n    }));\n    const newElse = node.else ? this.expectSingle(node.else.accept(this), 'else') as Expression : undefined;\n    return new CaseExpression(newCases, newElse);\n  }\n\n  visitFunctionExpression(node: FunctionExpression): SqlTreeNode | SqlTreeNode[] {\n    return new FunctionExpression(node.name as FunctionName, this.flatList(node.args.map(a => a.accept(this))) as Expression[]);\n  }\n\n  visitParamExpression(node: Param): SqlTreeNode | SqlTreeNode[] {\n    return new Param(node.paramName);\n  }\n\n  visitStringLiteral(node: StringLiteral): SqlTreeNode | SqlTreeNode[] {\n    return new StringLiteral(node.value);\n  }\n\n  visitNumberLiteral(node: NumberLiteral): SqlTreeNode | SqlTreeNode[] {\n    return new NumberLiteral(node.value);\n  }\n\n  visitNullLiteral(node: NullLiteral): SqlTreeNode | SqlTreeNode[] {\n    return NullLiteral.INSTANCE;\n  }\n\n  visitExistsExpression(node: ExistsExpression): SqlTreeNode | SqlTreeNode[] {\n    return new ExistsExpression(this.expectSingle(node.subquery.accept(this), 'subquery') as SelectQuery);\n  }\n\n  visitCastExpression(node: CastExpression): SqlTreeNode | SqlTreeNode[] {\n    return new CastExpression(\n      this.expectSingle(node.expression.accept(this), 'cast expression') as Expression,\n      node.targetType\n    );\n  }\n\n  visitCollateExpression(node: CollateExpression): SqlTreeNode | SqlTreeNode[] {\n    return new CollateExpression(\n      this.expectSingle(node.expression.accept(this), 'collate expression') as Expression,\n      node.collation\n    );\n  }\n\n  visitSubqueryExpression(node: SubqueryExpression): SqlTreeNode | SqlTreeNode[] {\n    return new SubqueryExpression(\n      this.expectSingle(node.subquery.accept(this), 'subquery') as SelectQuery\n    );\n  }\n\n  visitWindowExpression(node: WindowExpression): SqlTreeNode | SqlTreeNode[] {\n    const newFn = this.expectSingle(node.function.accept(this), 'window function') as FunctionExpression;\n\n    const newWindowSpec = new WindowSpecification();\n    if (node.windowSpec.partitionByColumns.length > 0) {\n      newWindowSpec.setPartitionBy(\n        this.flatList(node.windowSpec.partitionByColumns.map(c => c.accept(this))) as Expression[]\n      );\n    }\n    if (node.windowSpec.orderByColumns.length > 0) {\n      newWindowSpec.setOrderBy(\n        this.flatList(node.windowSpec.orderByColumns.map(o => o.accept(this))) as OrderBy[]\n      );\n    }\n\n    return new WindowExpression(newFn, newWindowSpec);\n  }\n}\n"]}
|
|
@@ -1,13 +1,28 @@
|
|
|
1
1
|
import { Alias } from "../ast/Alias";
|
|
2
|
+
import { AlterTableQuery } from "../ast/AlterTableQuery";
|
|
3
|
+
import { BetweenExpression } from "../ast/BetweenExpression";
|
|
2
4
|
import { BinaryExpression } from "../ast/BinaryExpression";
|
|
3
5
|
import { CaseExpression } from "../ast/CaseExpression";
|
|
6
|
+
import { CastExpression } from "../ast/CastExpression";
|
|
7
|
+
import { CollateExpression } from "../ast/CollateExpression";
|
|
8
|
+
import { SubqueryExpression } from "../ast/SubqueryExpression";
|
|
9
|
+
import { WindowExpression } from "../ast/WindowExpression";
|
|
4
10
|
import { Column, ColumnLike } from "../ast/Column";
|
|
5
11
|
import { Concat } from "../ast/Concat";
|
|
12
|
+
import { CreateIndexQuery } from "../ast/CreateIndexQuery";
|
|
13
|
+
import { CreateTableQuery } from "../ast/CreateTableQuery";
|
|
14
|
+
import { CreateVirtualTableQuery } from "../ast/CreateVirtualTableQuery";
|
|
15
|
+
import { CreateViewQuery } from "../ast/CreateViewQuery";
|
|
16
|
+
import { DeleteQuery } from "../ast/DeleteQuery";
|
|
17
|
+
import { DropIndexQuery } from "../ast/DropIndexQuery";
|
|
18
|
+
import { DropTableQuery } from "../ast/DropTableQuery";
|
|
19
|
+
import { DropViewQuery } from "../ast/DropViewQuery";
|
|
6
20
|
import { ExistsExpression } from "../ast/ExistsExpression";
|
|
7
21
|
import { FromLike, JsonEachFrom, SubqueryFrom, TableFrom } from "../ast/From";
|
|
8
22
|
import { FunctionExpression } from "../ast/FunctionExpression";
|
|
9
23
|
import { InExpression } from "../ast/InExpression";
|
|
10
24
|
import { InsertQuery } from "../ast/InsertQuery";
|
|
25
|
+
import { UpdateQuery } from "../ast/UpdateQuery";
|
|
11
26
|
import { Join } from "../ast/Join";
|
|
12
27
|
import { NullLiteral, NumberLiteral, Param, StringLiteral } from "../ast/Literals";
|
|
13
28
|
import { OrderBy } from "../ast/OrderBy";
|
|
@@ -17,6 +32,16 @@ import { With } from "../ast/With";
|
|
|
17
32
|
export interface SqlTreeNodeVisitor<T> {
|
|
18
33
|
visitSelectQuery(node: SelectQuery): T;
|
|
19
34
|
visitInsertQuery(node: InsertQuery): T;
|
|
35
|
+
visitDeleteQuery(node: DeleteQuery): T;
|
|
36
|
+
visitUpdateQuery(node: UpdateQuery): T;
|
|
37
|
+
visitCreateTableQuery(node: CreateTableQuery): T;
|
|
38
|
+
visitCreateVirtualTableQuery(node: CreateVirtualTableQuery): T;
|
|
39
|
+
visitCreateIndexQuery(node: CreateIndexQuery): T;
|
|
40
|
+
visitCreateViewQuery(node: CreateViewQuery): T;
|
|
41
|
+
visitAlterTableQuery(node: AlterTableQuery): T;
|
|
42
|
+
visitDropTableQuery(node: DropTableQuery): T;
|
|
43
|
+
visitDropIndexQuery(node: DropIndexQuery): T;
|
|
44
|
+
visitDropViewQuery(node: DropViewQuery): T;
|
|
20
45
|
visitTableFrom(node: TableFrom): T;
|
|
21
46
|
visitSubqueryFrom(node: SubqueryFrom): T;
|
|
22
47
|
visitJsonEachFrom(node: JsonEachFrom): T;
|
|
@@ -26,10 +51,15 @@ export interface SqlTreeNodeVisitor<T> {
|
|
|
26
51
|
visitColumn(node: Column): T;
|
|
27
52
|
visitAlias(node: Alias<any>): T;
|
|
28
53
|
visitBinaryExpression(node: BinaryExpression): T;
|
|
54
|
+
visitBetweenExpression(node: BetweenExpression): T;
|
|
29
55
|
visitUnaryExpression(node: UnaryExpression): T;
|
|
30
56
|
visitInExpression(node: InExpression): T;
|
|
31
57
|
visitConcat(node: Concat): T;
|
|
32
58
|
visitCaseExpression(node: CaseExpression): T;
|
|
59
|
+
visitCastExpression(node: CastExpression): T;
|
|
60
|
+
visitCollateExpression(node: CollateExpression): T;
|
|
61
|
+
visitSubqueryExpression(node: SubqueryExpression): T;
|
|
62
|
+
visitWindowExpression(node: WindowExpression): T;
|
|
33
63
|
visitFunctionExpression(node: FunctionExpression): T;
|
|
34
64
|
visitParamExpression(node: Param): T;
|
|
35
65
|
visitStringLiteral(node: StringLiteral): T;
|
|
@@ -44,4 +44,4 @@ class ColumnLikeVisitorAcceptor {
|
|
|
44
44
|
}
|
|
45
45
|
}
|
|
46
46
|
exports.ColumnLikeVisitorAcceptor = ColumnLikeVisitorAcceptor;
|
|
47
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SqlTreeNodeVisitor.js","sourceRoot":"","sources":["../../src/visitor/SqlTreeNodeVisitor.ts"],"names":[],"mappings":";;;AAAA,sDAA0D;AAC1D,wCAAqC;AASrC,0CAAmD;AAWnD,sCAA8E;AAK9E,sCAAmC;AACnC,8CAAsG;AA6CtG,MAAa,8BAA8B;IAClC,MAAM,CAAC,OAA8B,EAAE,CAAgB;QAC5D,IAAI,CAAC,YAAY,WAAI;YACjB,CAAC,YAAY,gBAAS;YACtB,CAAC,YAAY,mBAAY;YACzB,CAAC,YAAY,mBAAY;YACzB,CAAC,YAAY,aAAK,EACpB,CAAC;YACD,OAAO,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QAC3B,CAAC;aAAM,IAAI,CAAC,IAAI,OAAO,CAAC,KAAK,QAAQ,IAAI,UAAU,IAAI,CAAC,IAAI,OAAO,IAAI,CAAC,EAAE,CAAC;YACzE,MAAM,KAAK,GAAG,IAAI,aAAK,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC;YAC7C,OAAO,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QAC/B,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,KAAK,CAAC,uBAAuB,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;QAC/D,CAAC;IACH,CAAC;CACF;AAhBD,wEAgBC;AAED,MAAa,yBAAyB;IAC7B,MAAM,CAAC,OAA8B,EAAE,CAAa;QACzD,IACE,CAAC,YAAY,eAAM;YACnB,CAAC,YAAY,4BAAiB;YAC9B,CAAC,YAAY,kCAAmB;YAChC,CAAC,YAAY,aAAK,EAClB,CAAC;YACD,OAAO,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QAC3B,CAAC;aAAM,IAAI,CAAC,IAAI,OAAO,CAAC,KAAK,QAAQ,IAAI,UAAU,IAAI,CAAC,IAAI,OAAO,IAAI,CAAC,EAAE,CAAC;YACzE,MAAM,KAAK,GAAG,IAAI,aAAK,CAAE,CAAS,CAAC,QAAQ,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC;YACtD,OAAO,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QAC/B,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,KAAK,CAAC,yBAAyB,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;QACjE,CAAC;IACH,CAAC;CACF;AAhBD,8DAgBC","sourcesContent":["import { AliasableExpression } from \"../ast/Abstractions\";\nimport { Alias } from \"../ast/Alias\";\nimport { AlterTableQuery } from \"../ast/AlterTableQuery\";\nimport { BetweenExpression } from \"../ast/BetweenExpression\";\nimport { BinaryExpression } from \"../ast/BinaryExpression\";\nimport { CaseExpression } from \"../ast/CaseExpression\";\nimport { CastExpression } from \"../ast/CastExpression\";\nimport { CollateExpression } from \"../ast/CollateExpression\";\nimport { SubqueryExpression } from \"../ast/SubqueryExpression\";\nimport { WindowExpression } from \"../ast/WindowExpression\";\nimport { Column, ColumnLike } from \"../ast/Column\";\nimport { Concat } from \"../ast/Concat\";\nimport { CreateIndexQuery } from \"../ast/CreateIndexQuery\";\nimport { CreateTableQuery } from \"../ast/CreateTableQuery\";\nimport { CreateVirtualTableQuery } from \"../ast/CreateVirtualTableQuery\";\nimport { CreateViewQuery } from \"../ast/CreateViewQuery\";\nimport { DeleteQuery } from \"../ast/DeleteQuery\";\nimport { DropIndexQuery } from \"../ast/DropIndexQuery\";\nimport { DropTableQuery } from \"../ast/DropTableQuery\";\nimport { DropViewQuery } from \"../ast/DropViewQuery\";\nimport { ExistsExpression } from \"../ast/ExistsExpression\";\nimport { FromLike, JsonEachFrom, SubqueryFrom, TableFrom } from \"../ast/From\";\nimport { FunctionExpression } from \"../ast/FunctionExpression\";\nimport { InExpression } from \"../ast/InExpression\";\nimport { InsertQuery } from \"../ast/InsertQuery\";\nimport { UpdateQuery } from \"../ast/UpdateQuery\";\nimport { Join } from \"../ast/Join\";\nimport { LiteralExpression, NullLiteral, NumberLiteral, Param, StringLiteral } from \"../ast/Literals\";\nimport { OrderBy } from \"../ast/OrderBy\";\nimport { SelectQuery } from \"../ast/SelectQuery\";\nimport { UnaryExpression } from \"../ast/UnaryExpression\";\nimport { With } from \"../ast/With\";\n\nexport interface SqlTreeNodeVisitor<T> {\n  visitSelectQuery(node: SelectQuery): T;\n  visitInsertQuery(node: InsertQuery): T;\n  visitDeleteQuery(node: DeleteQuery): T;\n  visitUpdateQuery(node: UpdateQuery): T;\n  visitCreateTableQuery(node: CreateTableQuery): T;\n  visitCreateVirtualTableQuery(node: CreateVirtualTableQuery): T;\n  visitCreateIndexQuery(node: CreateIndexQuery): T;\n  visitCreateViewQuery(node: CreateViewQuery): T;\n  visitAlterTableQuery(node: AlterTableQuery): T;\n  visitDropTableQuery(node: DropTableQuery): T;\n  visitDropIndexQuery(node: DropIndexQuery): T;\n  visitDropViewQuery(node: DropViewQuery): T;\n  visitTableFrom(node: TableFrom): T;\n  visitSubqueryFrom(node: SubqueryFrom): T;\n  visitJsonEachFrom(node: JsonEachFrom): T;\n  visitJoinClause(node: Join): T;\n  visitOrderBy(node: OrderBy): T;\n  visitWithClause(node: With): T;\n  visitColumn(node: Column): T;\n  visitAlias(node: Alias<any>): T;\n  visitBinaryExpression(node: BinaryExpression): T;\n  visitBetweenExpression(node: BetweenExpression): T;\n  visitUnaryExpression(node: UnaryExpression): T;\n  visitInExpression(node: InExpression): T;\n  visitConcat(node: Concat): T;\n  visitCaseExpression(node: CaseExpression): T;\n  visitCastExpression(node: CastExpression): T;\n  visitCollateExpression(node: CollateExpression): T;\n  visitSubqueryExpression(node: SubqueryExpression): T;\n  visitWindowExpression(node: WindowExpression): T;\n  visitFunctionExpression(node: FunctionExpression): T;\n  visitParamExpression(node: Param): T;\n  visitStringLiteral(node: StringLiteral): T;\n  visitNumberLiteral(node: NumberLiteral): T;\n  visitNullLiteral(node: NullLiteral): T;\n  visitExistsExpression(node: ExistsExpression): T;\n}\n\nexport class FromLikeAndJoinVisitorAcceptor<T> {\n  public accept(visitor: SqlTreeNodeVisitor<T>, f: FromLike|Join): T {\n    if (f instanceof Join ||\n        f instanceof TableFrom ||\n        f instanceof SubqueryFrom ||\n        f instanceof JsonEachFrom ||\n        f instanceof Alias\n    ) {\n      return f.accept(visitor);\n    } else if (f && typeof f === 'object' && 'referent' in f && 'alias' in f) {\n      const alias = new Alias(f.referent, f.alias);\n      return alias.accept(visitor);\n    } else {\n      throw new Error('Invalid FROM clause: ' + JSON.stringify(f));\n    }\n  }\n}\n\nexport class ColumnLikeVisitorAcceptor<T> {\n  public accept(visitor: SqlTreeNodeVisitor<T>, c: ColumnLike): T {\n    if (\n      c instanceof Column ||\n      c instanceof LiteralExpression ||\n      c instanceof AliasableExpression ||\n      c instanceof Alias\n    ) {\n      return c.accept(visitor);\n    } else if (c && typeof c === 'object' && 'referent' in c && 'alias' in c) {\n      const alias = new Alias((c as any).referent, c.alias);\n      return alias.accept(visitor);\n    } else {\n      throw new Error('Invalid COLUMN clause: ' + JSON.stringify(c));\n    }\n  }\n}\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@shaxpir/squilt",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.1.0",
|
|
4
4
|
"description": "A lightweight, zero-dependency TypeScript library for building SQL queries through a fluent AST API",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"types": "dist/index.d.ts",
|
|
@@ -32,5 +32,8 @@
|
|
|
32
32
|
"jest": "^29.7.0",
|
|
33
33
|
"ts-jest": "^29.2.5",
|
|
34
34
|
"typescript": "^5.7.2"
|
|
35
|
+
},
|
|
36
|
+
"dependencies": {
|
|
37
|
+
"@shaxpir/squilt": "^1.0.0"
|
|
35
38
|
}
|
|
36
39
|
}
|