@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.
Files changed (68) hide show
  1. package/README.md +289 -1
  2. package/dist/ast/AlterTableQuery.d.ts +32 -0
  3. package/dist/ast/AlterTableQuery.js +60 -0
  4. package/dist/ast/BetweenExpression.d.ts +10 -0
  5. package/dist/ast/BetweenExpression.js +18 -0
  6. package/dist/ast/CastExpression.d.ts +13 -0
  7. package/dist/ast/CastExpression.js +25 -0
  8. package/dist/ast/CollateExpression.d.ts +18 -0
  9. package/dist/ast/CollateExpression.js +30 -0
  10. package/dist/ast/CreateIndexQuery.d.ts +25 -0
  11. package/dist/ast/CreateIndexQuery.js +64 -0
  12. package/dist/ast/CreateTableQuery.d.ts +57 -0
  13. package/dist/ast/CreateTableQuery.js +79 -0
  14. package/dist/ast/CreateViewQuery.d.ts +34 -0
  15. package/dist/ast/CreateViewQuery.js +61 -0
  16. package/dist/ast/CreateVirtualTableQuery.d.ts +32 -0
  17. package/dist/ast/CreateVirtualTableQuery.js +74 -0
  18. package/dist/ast/DeleteQuery.d.ts +17 -0
  19. package/dist/ast/DeleteQuery.js +43 -0
  20. package/dist/ast/DropIndexQuery.d.ts +14 -0
  21. package/dist/ast/DropIndexQuery.js +35 -0
  22. package/dist/ast/DropTableQuery.d.ts +14 -0
  23. package/dist/ast/DropTableQuery.js +35 -0
  24. package/dist/ast/DropViewQuery.d.ts +11 -0
  25. package/dist/ast/DropViewQuery.js +24 -0
  26. package/dist/ast/FunctionExpression.d.ts +21 -0
  27. package/dist/ast/FunctionExpression.js +40 -1
  28. package/dist/ast/FunctionName.d.ts +1 -1
  29. package/dist/ast/FunctionName.js +1 -1
  30. package/dist/ast/InsertQuery.d.ts +24 -1
  31. package/dist/ast/InsertQuery.js +49 -1
  32. package/dist/ast/Operator.d.ts +2 -0
  33. package/dist/ast/Operator.js +3 -1
  34. package/dist/ast/SelectQuery.d.ts +4 -0
  35. package/dist/ast/SelectQuery.js +11 -1
  36. package/dist/ast/SubqueryExpression.d.ts +18 -0
  37. package/dist/ast/SubqueryExpression.js +27 -0
  38. package/dist/ast/UpdateQuery.d.ts +24 -0
  39. package/dist/ast/UpdateQuery.js +51 -0
  40. package/dist/ast/WindowExpression.d.ts +51 -0
  41. package/dist/ast/WindowExpression.js +61 -0
  42. package/dist/ast/WindowSpecification.d.ts +46 -0
  43. package/dist/ast/WindowSpecification.js +60 -0
  44. package/dist/builder/QueryBuilder.d.ts +20 -0
  45. package/dist/builder/QueryBuilder.js +41 -1
  46. package/dist/builder/Shorthand.d.ts +51 -0
  47. package/dist/builder/Shorthand.js +125 -1
  48. package/dist/index.d.ts +17 -1
  49. package/dist/index.js +59 -3
  50. package/dist/renderer/CompactQueryRenderer.d.ts +34 -2
  51. package/dist/renderer/CompactQueryRenderer.js +272 -2
  52. package/dist/renderer/IndentedQueryRenderer.d.ts +34 -2
  53. package/dist/renderer/IndentedQueryRenderer.js +289 -3
  54. package/dist/renderer/QueryRenderer.d.ts +11 -1
  55. package/dist/renderer/QueryRenderer.js +1 -1
  56. package/dist/validate/CommonQueryValidator.d.ts +31 -1
  57. package/dist/validate/CommonQueryValidator.js +253 -4
  58. package/dist/validate/QueryValidator.d.ts +10 -1
  59. package/dist/validate/QueryValidator.js +1 -1
  60. package/dist/validate/SQLiteQueryValidator.d.ts +16 -1
  61. package/dist/validate/SQLiteQueryValidator.js +32 -3
  62. package/dist/visitor/ParamCollector.d.ts +30 -0
  63. package/dist/visitor/ParamCollector.js +109 -2
  64. package/dist/visitor/QueryIdentityTransformer.d.ts +30 -0
  65. package/dist/visitor/QueryIdentityTransformer.js +217 -2
  66. package/dist/visitor/SqlTreeNodeVisitor.d.ts +30 -0
  67. package/dist/visitor/SqlTreeNodeVisitor.js +1 -1
  68. 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
- newQuery['_values'] = this.flatList(node['_values'].map(v => v.accept(this)));
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":"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","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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3FsVHJlZU5vZGVWaXNpdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3Zpc2l0b3IvU3FsVHJlZU5vZGVWaXNpdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHNEQUEwRDtBQUMxRCx3Q0FBcUM7QUFHckMsMENBQW1EO0FBR25ELHNDQUE4RTtBQUk5RSxzQ0FBbUM7QUFDbkMsOENBQXNHO0FBOEJ0RyxNQUFhLDhCQUE4QjtJQUNsQyxNQUFNLENBQUMsT0FBOEIsRUFBRSxDQUFnQjtRQUM1RCxJQUFJLENBQUMsWUFBWSxXQUFJO1lBQ2pCLENBQUMsWUFBWSxnQkFBUztZQUN0QixDQUFDLFlBQVksbUJBQVk7WUFDekIsQ0FBQyxZQUFZLG1CQUFZO1lBQ3pCLENBQUMsWUFBWSxhQUFLLEVBQ3BCLENBQUM7WUFDRCxPQUFPLENBQUMsQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDM0IsQ0FBQzthQUFNLElBQUksQ0FBQyxJQUFJLE9BQU8sQ0FBQyxLQUFLLFFBQVEsSUFBSSxVQUFVLElBQUksQ0FBQyxJQUFJLE9BQU8sSUFBSSxDQUFDLEVBQUUsQ0FBQztZQUN6RSxNQUFNLEtBQUssR0FBRyxJQUFJLGFBQUssQ0FBQyxDQUFDLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUM3QyxPQUFPLEtBQUssQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDL0IsQ0FBQzthQUFNLENBQUM7WUFDTixNQUFNLElBQUksS0FBSyxDQUFDLHVCQUF1QixHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUMvRCxDQUFDO0lBQ0gsQ0FBQztDQUNGO0FBaEJELHdFQWdCQztBQUVELE1BQWEseUJBQXlCO0lBQzdCLE1BQU0sQ0FBQyxPQUE4QixFQUFFLENBQWE7UUFDekQsSUFDRSxDQUFDLFlBQVksZUFBTTtZQUNuQixDQUFDLFlBQVksNEJBQWlCO1lBQzlCLENBQUMsWUFBWSxrQ0FBbUI7WUFDaEMsQ0FBQyxZQUFZLGFBQUssRUFDbEIsQ0FBQztZQUNELE9BQU8sQ0FBQyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUMzQixDQUFDO2FBQU0sSUFBSSxDQUFDLElBQUksT0FBTyxDQUFDLEtBQUssUUFBUSxJQUFJLFVBQVUsSUFBSSxDQUFDLElBQUksT0FBTyxJQUFJLENBQUMsRUFBRSxDQUFDO1lBQ3pFLE1BQU0sS0FBSyxHQUFHLElBQUksYUFBSyxDQUFFLENBQVMsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ3RELE9BQU8sS0FBSyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUMvQixDQUFDO2FBQU0sQ0FBQztZQUNOLE1BQU0sSUFBSSxLQUFLLENBQUMseUJBQXlCLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ2pFLENBQUM7SUFDSCxDQUFDO0NBQ0Y7QUFoQkQsOERBZ0JDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQWxpYXNhYmxlRXhwcmVzc2lvbiB9IGZyb20gXCIuLi9hc3QvQWJzdHJhY3Rpb25zXCI7XG5pbXBvcnQgeyBBbGlhcyB9IGZyb20gXCIuLi9hc3QvQWxpYXNcIjtcbmltcG9ydCB7IEJpbmFyeUV4cHJlc3Npb24gfSBmcm9tIFwiLi4vYXN0L0JpbmFyeUV4cHJlc3Npb25cIjtcbmltcG9ydCB7IENhc2VFeHByZXNzaW9uIH0gZnJvbSBcIi4uL2FzdC9DYXNlRXhwcmVzc2lvblwiO1xuaW1wb3J0IHsgQ29sdW1uLCBDb2x1bW5MaWtlIH0gZnJvbSBcIi4uL2FzdC9Db2x1bW5cIjtcbmltcG9ydCB7IENvbmNhdCB9IGZyb20gXCIuLi9hc3QvQ29uY2F0XCI7XG5pbXBvcnQgeyBFeGlzdHNFeHByZXNzaW9uIH0gZnJvbSBcIi4uL2FzdC9FeGlzdHNFeHByZXNzaW9uXCI7XG5pbXBvcnQgeyBGcm9tTGlrZSwgSnNvbkVhY2hGcm9tLCBTdWJxdWVyeUZyb20sIFRhYmxlRnJvbSB9IGZyb20gXCIuLi9hc3QvRnJvbVwiO1xuaW1wb3J0IHsgRnVuY3Rpb25FeHByZXNzaW9uIH0gZnJvbSBcIi4uL2FzdC9GdW5jdGlvbkV4cHJlc3Npb25cIjtcbmltcG9ydCB7IEluRXhwcmVzc2lvbiB9IGZyb20gXCIuLi9hc3QvSW5FeHByZXNzaW9uXCI7XG5pbXBvcnQgeyBJbnNlcnRRdWVyeSB9IGZyb20gXCIuLi9hc3QvSW5zZXJ0UXVlcnlcIjtcbmltcG9ydCB7IEpvaW4gfSBmcm9tIFwiLi4vYXN0L0pvaW5cIjtcbmltcG9ydCB7IExpdGVyYWxFeHByZXNzaW9uLCBOdWxsTGl0ZXJhbCwgTnVtYmVyTGl0ZXJhbCwgUGFyYW0sIFN0cmluZ0xpdGVyYWwgfSBmcm9tIFwiLi4vYXN0L0xpdGVyYWxzXCI7XG5pbXBvcnQgeyBPcmRlckJ5IH0gZnJvbSBcIi4uL2FzdC9PcmRlckJ5XCI7XG5pbXBvcnQgeyBTZWxlY3RRdWVyeSB9IGZyb20gXCIuLi9hc3QvU2VsZWN0UXVlcnlcIjtcbmltcG9ydCB7IFVuYXJ5RXhwcmVzc2lvbiB9IGZyb20gXCIuLi9hc3QvVW5hcnlFeHByZXNzaW9uXCI7XG5pbXBvcnQgeyBXaXRoIH0gZnJvbSBcIi4uL2FzdC9XaXRoXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU3FsVHJlZU5vZGVWaXNpdG9yPFQ+IHtcbiAgdmlzaXRTZWxlY3RRdWVyeShub2RlOiBTZWxlY3RRdWVyeSk6IFQ7XG4gIHZpc2l0SW5zZXJ0UXVlcnkobm9kZTogSW5zZXJ0UXVlcnkpOiBUO1xuICB2aXNpdFRhYmxlRnJvbShub2RlOiBUYWJsZUZyb20pOiBUO1xuICB2aXNpdFN1YnF1ZXJ5RnJvbShub2RlOiBTdWJxdWVyeUZyb20pOiBUO1xuICB2aXNpdEpzb25FYWNoRnJvbShub2RlOiBKc29uRWFjaEZyb20pOiBUO1xuICB2aXNpdEpvaW5DbGF1c2Uobm9kZTogSm9pbik6IFQ7XG4gIHZpc2l0T3JkZXJCeShub2RlOiBPcmRlckJ5KTogVDtcbiAgdmlzaXRXaXRoQ2xhdXNlKG5vZGU6IFdpdGgpOiBUO1xuICB2aXNpdENvbHVtbihub2RlOiBDb2x1bW4pOiBUO1xuICB2aXNpdEFsaWFzKG5vZGU6IEFsaWFzPGFueT4pOiBUO1xuICB2aXNpdEJpbmFyeUV4cHJlc3Npb24obm9kZTogQmluYXJ5RXhwcmVzc2lvbik6IFQ7XG4gIHZpc2l0VW5hcnlFeHByZXNzaW9uKG5vZGU6IFVuYXJ5RXhwcmVzc2lvbik6IFQ7XG4gIHZpc2l0SW5FeHByZXNzaW9uKG5vZGU6IEluRXhwcmVzc2lvbik6IFQ7XG4gIHZpc2l0Q29uY2F0KG5vZGU6IENvbmNhdCk6IFQ7XG4gIHZpc2l0Q2FzZUV4cHJlc3Npb24obm9kZTogQ2FzZUV4cHJlc3Npb24pOiBUO1xuICB2aXNpdEZ1bmN0aW9uRXhwcmVzc2lvbihub2RlOiBGdW5jdGlvbkV4cHJlc3Npb24pOiBUO1xuICB2aXNpdFBhcmFtRXhwcmVzc2lvbihub2RlOiBQYXJhbSk6IFQ7XG4gIHZpc2l0U3RyaW5nTGl0ZXJhbChub2RlOiBTdHJpbmdMaXRlcmFsKTogVDtcbiAgdmlzaXROdW1iZXJMaXRlcmFsKG5vZGU6IE51bWJlckxpdGVyYWwpOiBUO1xuICB2aXNpdE51bGxMaXRlcmFsKG5vZGU6IE51bGxMaXRlcmFsKTogVDtcbiAgdmlzaXRFeGlzdHNFeHByZXNzaW9uKG5vZGU6IEV4aXN0c0V4cHJlc3Npb24pOiBUO1xufVxuXG5leHBvcnQgY2xhc3MgRnJvbUxpa2VBbmRKb2luVmlzaXRvckFjY2VwdG9yPFQ+IHtcbiAgcHVibGljIGFjY2VwdCh2aXNpdG9yOiBTcWxUcmVlTm9kZVZpc2l0b3I8VD4sIGY6IEZyb21MaWtlfEpvaW4pOiBUIHtcbiAgICBpZiAoZiBpbnN0YW5jZW9mIEpvaW4gfHxcbiAgICAgICAgZiBpbnN0YW5jZW9mIFRhYmxlRnJvbSB8fFxuICAgICAgICBmIGluc3RhbmNlb2YgU3VicXVlcnlGcm9tIHx8XG4gICAgICAgIGYgaW5zdGFuY2VvZiBKc29uRWFjaEZyb20gfHxcbiAgICAgICAgZiBpbnN0YW5jZW9mIEFsaWFzXG4gICAgKSB7XG4gICAgICByZXR1cm4gZi5hY2NlcHQodmlzaXRvcik7XG4gICAgfSBlbHNlIGlmIChmICYmIHR5cGVvZiBmID09PSAnb2JqZWN0JyAmJiAncmVmZXJlbnQnIGluIGYgJiYgJ2FsaWFzJyBpbiBmKSB7XG4gICAgICBjb25zdCBhbGlhcyA9IG5ldyBBbGlhcyhmLnJlZmVyZW50LCBmLmFsaWFzKTtcbiAgICAgIHJldHVybiBhbGlhcy5hY2NlcHQodmlzaXRvcik7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignSW52YWxpZCBGUk9NIGNsYXVzZTogJyArIEpTT04uc3RyaW5naWZ5KGYpKTtcbiAgICB9XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIENvbHVtbkxpa2VWaXNpdG9yQWNjZXB0b3I8VD4ge1xuICBwdWJsaWMgYWNjZXB0KHZpc2l0b3I6IFNxbFRyZWVOb2RlVmlzaXRvcjxUPiwgYzogQ29sdW1uTGlrZSk6IFQge1xuICAgIGlmIChcbiAgICAgIGMgaW5zdGFuY2VvZiBDb2x1bW4gfHxcbiAgICAgIGMgaW5zdGFuY2VvZiBMaXRlcmFsRXhwcmVzc2lvbiB8fFxuICAgICAgYyBpbnN0YW5jZW9mIEFsaWFzYWJsZUV4cHJlc3Npb24gfHxcbiAgICAgIGMgaW5zdGFuY2VvZiBBbGlhc1xuICAgICkge1xuICAgICAgcmV0dXJuIGMuYWNjZXB0KHZpc2l0b3IpO1xuICAgIH0gZWxzZSBpZiAoYyAmJiB0eXBlb2YgYyA9PT0gJ29iamVjdCcgJiYgJ3JlZmVyZW50JyBpbiBjICYmICdhbGlhcycgaW4gYykge1xuICAgICAgY29uc3QgYWxpYXMgPSBuZXcgQWxpYXMoKGMgYXMgYW55KS5yZWZlcmVudCwgYy5hbGlhcyk7XG4gICAgICByZXR1cm4gYWxpYXMuYWNjZXB0KHZpc2l0b3IpO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ0ludmFsaWQgQ09MVU1OIGNsYXVzZTogJyArIEpTT04uc3RyaW5naWZ5KGMpKTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
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.0.0",
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
  }