@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
@@ -23,7 +23,246 @@ class CompactQueryRenderer {
23
23
  if (node['_columns'].length > 0) {
24
24
  parts.push(`(${node['_columns'].map(QueryRenderer_1.quoteIdentifier).join(', ')})`);
25
25
  }
26
- parts.push(`VALUES (${node['_values'].map(v => v.accept(this)).join(', ')})`);
26
+ if (node['_fromSelect']) {
27
+ parts.push(node['_fromSelect'].accept(this));
28
+ }
29
+ else {
30
+ parts.push(`VALUES (${node['_values'].map(v => v.accept(this)).join(', ')})`);
31
+ }
32
+ // ON CONFLICT clause
33
+ if (node['_onConflictColumns'].length > 0) {
34
+ const conflictCols = node['_onConflictColumns'].map(QueryRenderer_1.quoteIdentifier).join(', ');
35
+ if (node['_doNothing']) {
36
+ parts.push(`ON CONFLICT (${conflictCols}) DO NOTHING`);
37
+ }
38
+ else if (node['_doUpdateSets'].length > 0) {
39
+ const setClauses = node['_doUpdateSets'].map(s => `${(0, QueryRenderer_1.quoteIdentifier)(s.column)} = ${s.value.accept(this)}`).join(', ');
40
+ let onConflict = `ON CONFLICT (${conflictCols})`;
41
+ if (node['_onConflictWhere']) {
42
+ onConflict += ` WHERE ${node['_onConflictWhere'].accept(this)}`;
43
+ }
44
+ onConflict += ` DO UPDATE SET ${setClauses}`;
45
+ parts.push(onConflict);
46
+ }
47
+ }
48
+ if (node['_returning'].length > 0) {
49
+ parts.push(`RETURNING ${node['_returning'].map(r => r.accept(this)).join(', ')}`);
50
+ }
51
+ return parts.join(' ');
52
+ }
53
+ visitDeleteQuery(node) {
54
+ const parts = [];
55
+ parts.push('DELETE');
56
+ parts.push(`FROM ${(0, QueryRenderer_1.quoteIdentifier)(node['_tableName'])}`);
57
+ if (node['_where']) {
58
+ parts.push(`WHERE ${node['_where'].accept(this)}`);
59
+ }
60
+ if (node['_returning'].length > 0) {
61
+ parts.push(`RETURNING ${node['_returning'].map(r => r.accept(this)).join(', ')}`);
62
+ }
63
+ return parts.join(' ');
64
+ }
65
+ visitUpdateQuery(node) {
66
+ const parts = [];
67
+ parts.push(`UPDATE ${(0, QueryRenderer_1.quoteIdentifier)(node['_tableName'])}`);
68
+ if (node['_set'].length > 0) {
69
+ const setClauses = node['_set'].map(s => `${(0, QueryRenderer_1.quoteIdentifier)(s.column)} = ${s.value.accept(this)}`).join(', ');
70
+ parts.push(`SET ${setClauses}`);
71
+ }
72
+ if (node['_where']) {
73
+ parts.push(`WHERE ${node['_where'].accept(this)}`);
74
+ }
75
+ if (node['_returning'].length > 0) {
76
+ parts.push(`RETURNING ${node['_returning'].map(r => r.accept(this)).join(', ')}`);
77
+ }
78
+ return parts.join(' ');
79
+ }
80
+ visitDropTableQuery(node) {
81
+ const ifExists = node.hasIfExists ? ' IF EXISTS' : '';
82
+ return `DROP TABLE${ifExists} ${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)}`;
83
+ }
84
+ visitDropIndexQuery(node) {
85
+ const ifExists = node.hasIfExists ? ' IF EXISTS' : '';
86
+ return `DROP INDEX${ifExists} ${(0, QueryRenderer_1.quoteIdentifier)(node.indexName)}`;
87
+ }
88
+ visitDropViewQuery(node) {
89
+ const ifExists = node.hasIfExists ? ' IF EXISTS' : '';
90
+ return `DROP VIEW${ifExists} ${(0, QueryRenderer_1.quoteIdentifier)(node.viewName)}`;
91
+ }
92
+ visitCreateViewQuery(node) {
93
+ const parts = [];
94
+ parts.push('CREATE');
95
+ if (node.isTemporary) {
96
+ parts.push('TEMPORARY');
97
+ }
98
+ parts.push('VIEW');
99
+ if (node.hasIfNotExists) {
100
+ parts.push('IF NOT EXISTS');
101
+ }
102
+ parts.push((0, QueryRenderer_1.quoteIdentifier)(node.viewName));
103
+ if (node.columns.length > 0) {
104
+ parts.push(`(${node.columns.map(QueryRenderer_1.quoteIdentifier).join(', ')})`);
105
+ }
106
+ parts.push('AS');
107
+ if (!node.selectQuery) {
108
+ throw new Error('CreateViewQuery must have a SELECT query');
109
+ }
110
+ parts.push(node.selectQuery.accept(this));
111
+ return parts.join(' ');
112
+ }
113
+ visitCreateIndexQuery(node) {
114
+ const parts = [];
115
+ const unique = node.isUnique ? 'UNIQUE ' : '';
116
+ const ifNotExists = node.hasIfNotExists ? ' IF NOT EXISTS' : '';
117
+ parts.push(`CREATE ${unique}INDEX${ifNotExists} ${(0, QueryRenderer_1.quoteIdentifier)(node.indexName)}`);
118
+ parts.push(`ON ${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)} (${node.columns.map(QueryRenderer_1.quoteIdentifier).join(', ')})`);
119
+ if (node.whereExpression) {
120
+ parts.push(`WHERE ${node.whereExpression.accept(this)}`);
121
+ }
122
+ return parts.join(' ');
123
+ }
124
+ visitAlterTableQuery(node) {
125
+ const op = node.operation;
126
+ if (!op) {
127
+ throw new Error('AlterTableQuery must have an operation');
128
+ }
129
+ switch (op.type) {
130
+ case 'ADD_COLUMN':
131
+ return `ALTER TABLE ${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)} ADD COLUMN ${this.renderColumnDefinition(op.column)}`;
132
+ case 'RENAME_COLUMN':
133
+ return `ALTER TABLE ${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)} RENAME COLUMN ${(0, QueryRenderer_1.quoteIdentifier)(op.oldName)} TO ${(0, QueryRenderer_1.quoteIdentifier)(op.newName)}`;
134
+ case 'DROP_COLUMN':
135
+ return `ALTER TABLE ${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)} DROP COLUMN ${(0, QueryRenderer_1.quoteIdentifier)(op.columnName)}`;
136
+ case 'RENAME_TABLE':
137
+ return `ALTER TABLE ${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)} RENAME TO ${(0, QueryRenderer_1.quoteIdentifier)(op.newTableName)}`;
138
+ }
139
+ }
140
+ visitCreateTableQuery(node) {
141
+ const parts = [];
142
+ const ifNotExists = node.hasIfNotExists ? ' IF NOT EXISTS' : '';
143
+ parts.push(`CREATE TABLE${ifNotExists} ${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)} (`);
144
+ const definitions = [];
145
+ // Column definitions
146
+ for (const col of node.columns) {
147
+ definitions.push(this.renderColumnDefinition(col));
148
+ }
149
+ // Table constraints
150
+ for (const constraint of node.tableConstraints) {
151
+ definitions.push(this.renderTableConstraint(constraint));
152
+ }
153
+ parts.push(definitions.join(', '));
154
+ parts.push(')');
155
+ // Table options
156
+ const options = [];
157
+ if (node.hasWithoutRowid) {
158
+ options.push('WITHOUT ROWID');
159
+ }
160
+ if (node.isStrict) {
161
+ options.push('STRICT');
162
+ }
163
+ if (options.length > 0) {
164
+ parts.push(' ' + options.join(', '));
165
+ }
166
+ return parts.join('');
167
+ }
168
+ visitCreateVirtualTableQuery(node) {
169
+ const ifNotExists = node.hasIfNotExists ? ' IF NOT EXISTS' : '';
170
+ const args = [];
171
+ // Add columns (FTS5 columns don't have types)
172
+ for (const col of node.columns) {
173
+ args.push((0, QueryRenderer_1.quoteIdentifier)(col));
174
+ }
175
+ // Add FTS5 options
176
+ const opts = node.options;
177
+ if (opts.tokenize) {
178
+ args.push(`tokenize = '${opts.tokenize}'`);
179
+ }
180
+ if (opts.content) {
181
+ args.push(`content = '${opts.content}'`);
182
+ }
183
+ if (opts.contentRowid) {
184
+ args.push(`content_rowid = '${opts.contentRowid}'`);
185
+ }
186
+ if (opts.prefix) {
187
+ args.push(`prefix = '${opts.prefix}'`);
188
+ }
189
+ return `CREATE VIRTUAL TABLE${ifNotExists} ${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)} USING ${node.module}(${args.join(', ')})`;
190
+ }
191
+ renderColumnDefinition(col) {
192
+ const parts = [(0, QueryRenderer_1.quoteIdentifier)(col.name), col.type];
193
+ if (col.constraints.primaryKey) {
194
+ parts.push('PRIMARY KEY');
195
+ if (col.constraints.autoIncrement) {
196
+ parts.push('AUTOINCREMENT');
197
+ }
198
+ }
199
+ if (col.constraints.notNull) {
200
+ parts.push('NOT NULL');
201
+ }
202
+ if (col.constraints.unique) {
203
+ parts.push('UNIQUE');
204
+ }
205
+ if (col.constraints.default !== undefined) {
206
+ if (col.constraints.default === null) {
207
+ parts.push('DEFAULT NULL');
208
+ }
209
+ else if (typeof col.constraints.default === 'string') {
210
+ // Check if it's a SQL keyword/function like CURRENT_TIMESTAMP
211
+ const sqlKeywords = ['CURRENT_TIMESTAMP', 'CURRENT_DATE', 'CURRENT_TIME', 'TRUE', 'FALSE'];
212
+ if (sqlKeywords.includes(col.constraints.default.toUpperCase())) {
213
+ parts.push(`DEFAULT ${col.constraints.default}`);
214
+ }
215
+ else {
216
+ parts.push(`DEFAULT '${col.constraints.default.replace(/'/g, "''")}'`);
217
+ }
218
+ }
219
+ else {
220
+ parts.push(`DEFAULT ${col.constraints.default}`);
221
+ }
222
+ }
223
+ if (col.constraints.check) {
224
+ parts.push(`CHECK ${col.constraints.check.accept(this)}`);
225
+ }
226
+ if (col.constraints.references) {
227
+ const ref = col.constraints.references;
228
+ let refStr = `REFERENCES ${(0, QueryRenderer_1.quoteIdentifier)(ref.table)}(${(0, QueryRenderer_1.quoteIdentifier)(ref.column)})`;
229
+ if (ref.onDelete) {
230
+ refStr += ` ON DELETE ${ref.onDelete}`;
231
+ }
232
+ if (ref.onUpdate) {
233
+ refStr += ` ON UPDATE ${ref.onUpdate}`;
234
+ }
235
+ parts.push(refStr);
236
+ }
237
+ return parts.join(' ');
238
+ }
239
+ renderTableConstraint(constraint) {
240
+ const parts = [];
241
+ if (constraint.name) {
242
+ parts.push(`CONSTRAINT ${(0, QueryRenderer_1.quoteIdentifier)(constraint.name)}`);
243
+ }
244
+ switch (constraint.type) {
245
+ case 'PRIMARY KEY':
246
+ parts.push(`PRIMARY KEY (${constraint.columns.map(QueryRenderer_1.quoteIdentifier).join(', ')})`);
247
+ break;
248
+ case 'UNIQUE':
249
+ parts.push(`UNIQUE (${constraint.columns.map(QueryRenderer_1.quoteIdentifier).join(', ')})`);
250
+ break;
251
+ case 'FOREIGN KEY':
252
+ const ref = constraint.references;
253
+ let fkStr = `FOREIGN KEY (${constraint.columns.map(QueryRenderer_1.quoteIdentifier).join(', ')}) REFERENCES ${(0, QueryRenderer_1.quoteIdentifier)(ref.table)}(${(0, QueryRenderer_1.quoteIdentifier)(ref.column)})`;
254
+ if (ref.onDelete) {
255
+ fkStr += ` ON DELETE ${ref.onDelete}`;
256
+ }
257
+ if (ref.onUpdate) {
258
+ fkStr += ` ON UPDATE ${ref.onUpdate}`;
259
+ }
260
+ parts.push(fkStr);
261
+ break;
262
+ case 'CHECK':
263
+ parts.push(`CHECK ${constraint.check.accept(this)}`);
264
+ break;
265
+ }
27
266
  return parts.join(' ');
28
267
  }
29
268
  visitSelectQuery(node) {
@@ -71,6 +310,12 @@ class CompactQueryRenderer {
71
310
  if (node['_union'].length > 0) {
72
311
  parts.push(node['_union'].map(u => `UNION ${u.accept(this)}`).join(' '));
73
312
  }
313
+ if (node['_intersect'].length > 0) {
314
+ parts.push(node['_intersect'].map(i => `INTERSECT ${i.accept(this)}`).join(' '));
315
+ }
316
+ if (node['_except'].length > 0) {
317
+ parts.push(node['_except'].map(e => `EXCEPT ${e.accept(this)}`).join(' '));
318
+ }
74
319
  if (node['_orderBy'].length > 0) {
75
320
  parts.push(`ORDER BY ${node['_orderBy'].map(o => o.accept(this)).join(', ')}`);
76
321
  }
@@ -127,6 +372,10 @@ class CompactQueryRenderer {
127
372
  visitBinaryExpression(node) {
128
373
  return `(${node.left.accept(this)} ${node.operator} ${node.right.accept(this)})`;
129
374
  }
375
+ visitBetweenExpression(node) {
376
+ const not = node.not ? ' NOT' : '';
377
+ return `(${node.operand.accept(this)}${not} BETWEEN ${node.low.accept(this)} AND ${node.high.accept(this)})`;
378
+ }
130
379
  visitUnaryExpression(node) {
131
380
  const operand = node.operand.accept(this);
132
381
  if (node.operator === Operator_1.Operator.IS_NULL || node.operator === Operator_1.Operator.IS_NOT_NULL) {
@@ -167,6 +416,27 @@ class CompactQueryRenderer {
167
416
  parts.push('END');
168
417
  return parts.join(' ');
169
418
  }
419
+ visitCastExpression(node) {
420
+ return `CAST(${node.expression.accept(this)} AS ${node.targetType})`;
421
+ }
422
+ visitCollateExpression(node) {
423
+ return `${node.expression.accept(this)} COLLATE ${node.collation}`;
424
+ }
425
+ visitSubqueryExpression(node) {
426
+ return `(${node.subquery.accept(this)})`;
427
+ }
428
+ visitWindowExpression(node) {
429
+ const fnPart = node.function.accept(this);
430
+ const spec = node.windowSpec;
431
+ const parts = [];
432
+ if (spec.partitionByColumns.length > 0) {
433
+ parts.push(`PARTITION BY ${spec.partitionByColumns.map(c => c.accept(this)).join(', ')}`);
434
+ }
435
+ if (spec.orderByColumns.length > 0) {
436
+ parts.push(`ORDER BY ${spec.orderByColumns.map(o => o.accept(this)).join(', ')}`);
437
+ }
438
+ return `${fnPart} OVER (${parts.join(' ')})`;
439
+ }
170
440
  visitFunctionExpression(node) {
171
441
  const args = node.args.map(a => a.accept(this)).join(', ');
172
442
  const distinctPrefix = node.distinct ? 'DISTINCT ' : '';
@@ -189,4 +459,4 @@ class CompactQueryRenderer {
189
459
  }
190
460
  }
191
461
  exports.CompactQueryRenderer = CompactQueryRenderer;
192
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CompactQueryRenderer.js","sourceRoot":"","sources":["../../src/renderer/CompactQueryRenderer.ts"],"names":[],"mappings":"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","sourcesContent":["import { AliasableExpression } from \"../ast/Abstractions\";\nimport { Alias } from \"../ast/Alias\";\nimport { BinaryExpression } from \"../ast/BinaryExpression\";\nimport { CaseExpression } from \"../ast/CaseExpression\";\nimport { Column } from \"../ast/Column\";\nimport { Concat } from \"../ast/Concat\";\nimport { ExistsExpression } from \"../ast/ExistsExpression\";\nimport { From, JsonEachFrom, SubqueryFrom, TableFrom } from \"../ast/From\";\nimport { FunctionExpression } from \"../ast/FunctionExpression\";\nimport { InExpression } from \"../ast/InExpression\";\nimport { InsertQuery } from \"../ast/InsertQuery\";\nimport { Join } from \"../ast/Join\";\nimport { NullLiteral, NumberLiteral, Param, StringLiteral } from \"../ast/Literals\";\nimport { Operator } from \"../ast/Operator\";\nimport { OrderBy } from \"../ast/OrderBy\";\nimport { SelectQuery } from \"../ast/SelectQuery\";\nimport { UnaryExpression } from \"../ast/UnaryExpression\";\nimport { With } from \"../ast/With\";\nimport { ColumnLikeVisitorAcceptor, FromLikeAndJoinVisitorAcceptor, SqlTreeNodeVisitor } from \"../visitor/SqlTreeNodeVisitor\";\nimport { QueryRenderer, quoteIdentifier } from \"./QueryRenderer\";\n\nexport class CompactQueryRenderer\n  implements QueryRenderer, SqlTreeNodeVisitor<string>\n{\n  protected fromLikeAndJoinAcceptor = new FromLikeAndJoinVisitorAcceptor<void>();\n  protected columnLikeAcceptor = new ColumnLikeVisitorAcceptor<string>();\n\n  public render(node: SelectQuery | InsertQuery): string {\n    return node.accept(this);\n  }\n\n  visitInsertQuery(node: InsertQuery): string {\n    const parts: string[] = [];\n    parts.push(`INSERT${node.isOrReplace() ? ' OR REPLACE' : ''}`);\n    parts.push(`INTO ${quoteIdentifier(node['_tableName'])}`);\n    if (node['_columns'].length > 0) {\n      parts.push(`(${node['_columns'].map(quoteIdentifier).join(', ')})`);\n    }\n    parts.push(`VALUES (${node['_values'].map(v => v.accept(this)).join(', ')})`);\n    return parts.join(' ');\n  }\n\n  visitSelectQuery(node: SelectQuery): string {\n    const parts: string[] = [];\n    if (node['_with'].length > 0) {\n      parts.push(`WITH ${node['_with'].map(w => w.accept(this)).join(', ')}`);\n    }\n    parts.push(`SELECT${node.isDistinct() ? ' DISTINCT' : ''}`);\n    if (node['_columns'].length > 0) {\n      parts.push(node['_columns'].map(c => this.columnLikeAcceptor.accept(this, c)).join(', '));\n    } else {\n      parts.push('*');\n    }\n    if (node['_fromsAndJoins'].length > 0) {\n      let fromsAndJoinsText = '';\n      for (const fromOrJoin of node['_fromsAndJoins']) {\n        if (fromOrJoin instanceof Join) {\n          fromsAndJoinsText += ` ${fromOrJoin.accept(this)}`;\n        } else if (\n          fromOrJoin instanceof Alias ||\n          fromOrJoin instanceof From ||\n          fromOrJoin instanceof TableFrom ||\n          fromOrJoin instanceof SubqueryFrom ||\n          fromOrJoin instanceof JsonEachFrom\n        ) {\n          if (fromsAndJoinsText) {\n            fromsAndJoinsText += `, ${fromOrJoin.accept(this)}`;\n          } else {\n            fromsAndJoinsText += `FROM ${fromOrJoin.accept(this)}`;\n          }\n        }\n      }\n      parts.push(fromsAndJoinsText);\n    }\n    if (node['_where']) {\n      parts.push(`WHERE ${node['_where'].accept(this)}`);\n    }\n    if (node['_groupBy'].length > 0) {\n      parts.push(`GROUP BY ${node['_groupBy'].map(c => c.accept(this)).join(', ')}`);\n    }\n    if (node['_having']) {\n      parts.push(`HAVING ${node['_having'].accept(this)}`);\n    }\n    if (node['_union'].length > 0) {\n      parts.push(node['_union'].map(u => `UNION ${u.accept(this)}`).join(' '));\n    }\n    if (node['_orderBy'].length > 0) {\n      parts.push(`ORDER BY ${node['_orderBy'].map(o => o.accept(this)).join(', ')}`);\n    }\n    if (node['_limit'] !== null && node['_limit'] !== undefined) {\n      parts.push(`LIMIT ${node['_limit']}`);\n      if (node['_offset'] !== null && node['_offset'] !== undefined) {\n        parts.push(`OFFSET ${node['_offset']}`);\n      }\n    }\n    return parts.filter(p => p).join(' ');\n  }\n\n  visitTableFrom(node: TableFrom): string {\n    return `${quoteIdentifier(node.tableName)}`;\n  }\n\n  visitSubqueryFrom(node: SubqueryFrom): string {\n    return `(${node.subquery.accept(this)})`;\n  }\n\n  visitJsonEachFrom(node: JsonEachFrom): string {\n    const expr = node.jsonExpression.accept(this);\n    const path = node.jsonPath ? `, ${node.jsonPath.accept(this)}` : '';\n    return `json_each(${expr}${path})`;\n  }\n\n  visitColumn(node: Column): string {\n    if (node.hasTableName()) {\n      return `${quoteIdentifier(node.tableName as string)}.${quoteIdentifier(node.columnName)}`;\n    } else {\n      return `${quoteIdentifier(node.columnName)}`;\n    }\n  }\n\n  visitAlias(node: Alias<From|AliasableExpression>): string {\n    const isSubquery = node.referent instanceof SubqueryFrom || node.referent instanceof SelectQuery;\n    const renderedReferent = node.referent.accept(this);\n    const renderedAliasName = quoteIdentifier(node.alias as string);\n    if (node.referent instanceof From) {\n      return `${renderedReferent} ${renderedAliasName}`;\n    } else if (isSubquery) {\n      return `(${renderedReferent}) AS ${renderedAliasName}`;\n    } else {\n      return `${renderedReferent} AS ${renderedAliasName}`;\n    }\n  }\n\n  visitJoinClause(node: Join): string {\n    return `${node.type} JOIN ${quoteIdentifier(node.tableName)} ${quoteIdentifier(node.alias)} ON ${node.on.accept(this)}`;\n  }\n\n  visitOrderBy(node: OrderBy): string {\n    return `${node.column.accept(this)} ${node.direction}`;\n  }\n\n  visitWithClause(node: With): string {\n    return `${quoteIdentifier(node.name)} AS (${node.query.accept(this)})`;\n  }\n\n  visitBinaryExpression(node: BinaryExpression): string {\n    return `(${node.left.accept(this)} ${node.operator} ${node.right.accept(this)})`;\n  }\n\n  visitUnaryExpression(node: UnaryExpression): string {\n    const operand = node.operand.accept(this);\n    if (node.operator === Operator.IS_NULL || node.operator === Operator.IS_NOT_NULL) {\n      return `(${operand} ${node.operator})`;\n    } else if (node.operator === 'NOT') {\n      return `(NOT ${operand})`;\n    } else {\n      return `(${node.operator}${operand})`;\n    }\n  }\n\n  visitInExpression(node: InExpression): string {\n    const leftStr = node.left.length > 1\n      ? `(${node.left.map(l => l.accept(this)).join(', ')})`\n      : node.left[0].accept(this);\n    const not = node.not ? ' NOT' : '';\n    let right: string;\n    if (node.values instanceof SelectQuery) {\n      right = `(${node.values.accept(this)})`;\n    } else {\n      right = `(${node.values.map(set =>\n        set.length > 1 ? `(${set.map(v => v.accept(this)).join(', ')})` : set[0].accept(this)\n      ).join(', ')})`;\n    }\n    return `(${leftStr}${not} IN ${right})`;\n  }\n\n  visitConcat(node: Concat): string {\n    return `(${node.expressions.map(e => e.accept(this)).join(' || ')})`;\n  }\n\n  visitCaseExpression(node: CaseExpression): string {\n    const parts: string[] = ['CASE'];\n    for (const c of node.cases) {\n      parts.push(`WHEN ${c.when.accept(this)} THEN ${c.then.accept(this)}`);\n    }\n    if (node.else) {\n      parts.push(`ELSE ${node.else.accept(this)}`);\n    }\n    parts.push('END');\n    return parts.join(' ');\n  }\n\n  visitFunctionExpression(node: FunctionExpression): string {\n    const args = node.args.map(a => a.accept(this)).join(', ');\n    const distinctPrefix = node.distinct ? 'DISTINCT ' : '';\n    return `${node.name}(${distinctPrefix}${args})`;\n  }\n\n  visitParamExpression(_node: Param): string {\n    return '?';\n  }\n\n  visitStringLiteral(node: StringLiteral): string {\n    return `'${node.value.replace(/'/g, \"''\")}'`;\n  }\n\n  visitNumberLiteral(node: NumberLiteral): string {\n    return node.value.toString();\n  }\n\n  visitNullLiteral(_node: NullLiteral): string {\n    return 'NULL';\n  }\n\n  visitExistsExpression(node: ExistsExpression): string {\n    return `EXISTS (${node.subquery.accept(this)})`;\n  }\n}\n"]}
462
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CompactQueryRenderer.js","sourceRoot":"","sources":["../../src/renderer/CompactQueryRenderer.ts"],"names":[],"mappings":"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","sourcesContent":["import { AliasableExpression } from \"../ast/Abstractions\";\nimport { Alias } from \"../ast/Alias\";\nimport { 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 } 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, 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 { NullLiteral, NumberLiteral, Param, StringLiteral } from \"../ast/Literals\";\nimport { Operator } from \"../ast/Operator\";\nimport { OrderBy } from \"../ast/OrderBy\";\nimport { SelectQuery } from \"../ast/SelectQuery\";\nimport { UnaryExpression } from \"../ast/UnaryExpression\";\nimport { With } from \"../ast/With\";\nimport { ColumnLikeVisitorAcceptor, FromLikeAndJoinVisitorAcceptor, SqlTreeNodeVisitor } from \"../visitor/SqlTreeNodeVisitor\";\nimport { QueryRenderer, RenderableQuery, quoteIdentifier } from \"./QueryRenderer\";\n\nexport class CompactQueryRenderer\n  implements QueryRenderer, SqlTreeNodeVisitor<string>\n{\n  protected fromLikeAndJoinAcceptor = new FromLikeAndJoinVisitorAcceptor<void>();\n  protected columnLikeAcceptor = new ColumnLikeVisitorAcceptor<string>();\n\n  public render(node: RenderableQuery): string {\n    return node.accept(this);\n  }\n\n  visitInsertQuery(node: InsertQuery): string {\n    const parts: string[] = [];\n    parts.push(`INSERT${node.isOrReplace() ? ' OR REPLACE' : ''}`);\n    parts.push(`INTO ${quoteIdentifier(node['_tableName'])}`);\n    if (node['_columns'].length > 0) {\n      parts.push(`(${node['_columns'].map(quoteIdentifier).join(', ')})`);\n    }\n    if (node['_fromSelect']) {\n      parts.push(node['_fromSelect'].accept(this));\n    } else {\n      parts.push(`VALUES (${node['_values'].map(v => v.accept(this)).join(', ')})`);\n    }\n    // ON CONFLICT clause\n    if (node['_onConflictColumns'].length > 0) {\n      const conflictCols = node['_onConflictColumns'].map(quoteIdentifier).join(', ');\n      if (node['_doNothing']) {\n        parts.push(`ON CONFLICT (${conflictCols}) DO NOTHING`);\n      } else if (node['_doUpdateSets'].length > 0) {\n        const setClauses = node['_doUpdateSets'].map(s =>\n          `${quoteIdentifier(s.column)} = ${s.value.accept(this)}`\n        ).join(', ');\n        let onConflict = `ON CONFLICT (${conflictCols})`;\n        if (node['_onConflictWhere']) {\n          onConflict += ` WHERE ${node['_onConflictWhere'].accept(this)}`;\n        }\n        onConflict += ` DO UPDATE SET ${setClauses}`;\n        parts.push(onConflict);\n      }\n    }\n    if (node['_returning'].length > 0) {\n      parts.push(`RETURNING ${node['_returning'].map(r => r.accept(this)).join(', ')}`);\n    }\n    return parts.join(' ');\n  }\n\n  visitDeleteQuery(node: DeleteQuery): string {\n    const parts: string[] = [];\n    parts.push('DELETE');\n    parts.push(`FROM ${quoteIdentifier(node['_tableName'])}`);\n    if (node['_where']) {\n      parts.push(`WHERE ${node['_where'].accept(this)}`);\n    }\n    if (node['_returning'].length > 0) {\n      parts.push(`RETURNING ${node['_returning'].map(r => r.accept(this)).join(', ')}`);\n    }\n    return parts.join(' ');\n  }\n\n  visitUpdateQuery(node: UpdateQuery): string {\n    const parts: string[] = [];\n    parts.push(`UPDATE ${quoteIdentifier(node['_tableName'])}`);\n    if (node['_set'].length > 0) {\n      const setClauses = node['_set'].map(s =>\n        `${quoteIdentifier(s.column)} = ${s.value.accept(this)}`\n      ).join(', ');\n      parts.push(`SET ${setClauses}`);\n    }\n    if (node['_where']) {\n      parts.push(`WHERE ${node['_where'].accept(this)}`);\n    }\n    if (node['_returning'].length > 0) {\n      parts.push(`RETURNING ${node['_returning'].map(r => r.accept(this)).join(', ')}`);\n    }\n    return parts.join(' ');\n  }\n\n  visitDropTableQuery(node: DropTableQuery): string {\n    const ifExists = node.hasIfExists ? ' IF EXISTS' : '';\n    return `DROP TABLE${ifExists} ${quoteIdentifier(node.tableName)}`;\n  }\n\n  visitDropIndexQuery(node: DropIndexQuery): string {\n    const ifExists = node.hasIfExists ? ' IF EXISTS' : '';\n    return `DROP INDEX${ifExists} ${quoteIdentifier(node.indexName)}`;\n  }\n\n  visitDropViewQuery(node: DropViewQuery): string {\n    const ifExists = node.hasIfExists ? ' IF EXISTS' : '';\n    return `DROP VIEW${ifExists} ${quoteIdentifier(node.viewName)}`;\n  }\n\n  visitCreateViewQuery(node: CreateViewQuery): string {\n    const parts: string[] = [];\n\n    parts.push('CREATE');\n    if (node.isTemporary) {\n      parts.push('TEMPORARY');\n    }\n    parts.push('VIEW');\n    if (node.hasIfNotExists) {\n      parts.push('IF NOT EXISTS');\n    }\n    parts.push(quoteIdentifier(node.viewName));\n\n    if (node.columns.length > 0) {\n      parts.push(`(${node.columns.map(quoteIdentifier).join(', ')})`);\n    }\n\n    parts.push('AS');\n\n    if (!node.selectQuery) {\n      throw new Error('CreateViewQuery must have a SELECT query');\n    }\n    parts.push(node.selectQuery.accept(this));\n\n    return parts.join(' ');\n  }\n\n  visitCreateIndexQuery(node: CreateIndexQuery): string {\n    const parts: string[] = [];\n    const unique = node.isUnique ? 'UNIQUE ' : '';\n    const ifNotExists = node.hasIfNotExists ? ' IF NOT EXISTS' : '';\n\n    parts.push(`CREATE ${unique}INDEX${ifNotExists} ${quoteIdentifier(node.indexName)}`);\n    parts.push(`ON ${quoteIdentifier(node.tableName)} (${node.columns.map(quoteIdentifier).join(', ')})`);\n\n    if (node.whereExpression) {\n      parts.push(`WHERE ${node.whereExpression.accept(this)}`);\n    }\n\n    return parts.join(' ');\n  }\n\n  visitAlterTableQuery(node: AlterTableQuery): string {\n    const op = node.operation;\n    if (!op) {\n      throw new Error('AlterTableQuery must have an operation');\n    }\n\n    switch (op.type) {\n      case 'ADD_COLUMN':\n        return `ALTER TABLE ${quoteIdentifier(node.tableName)} ADD COLUMN ${this.renderColumnDefinition(op.column)}`;\n      case 'RENAME_COLUMN':\n        return `ALTER TABLE ${quoteIdentifier(node.tableName)} RENAME COLUMN ${quoteIdentifier(op.oldName)} TO ${quoteIdentifier(op.newName)}`;\n      case 'DROP_COLUMN':\n        return `ALTER TABLE ${quoteIdentifier(node.tableName)} DROP COLUMN ${quoteIdentifier(op.columnName)}`;\n      case 'RENAME_TABLE':\n        return `ALTER TABLE ${quoteIdentifier(node.tableName)} RENAME TO ${quoteIdentifier(op.newTableName)}`;\n    }\n  }\n\n  visitCreateTableQuery(node: CreateTableQuery): string {\n    const parts: string[] = [];\n    const ifNotExists = node.hasIfNotExists ? ' IF NOT EXISTS' : '';\n    parts.push(`CREATE TABLE${ifNotExists} ${quoteIdentifier(node.tableName)} (`);\n\n    const definitions: string[] = [];\n\n    // Column definitions\n    for (const col of node.columns) {\n      definitions.push(this.renderColumnDefinition(col));\n    }\n\n    // Table constraints\n    for (const constraint of node.tableConstraints) {\n      definitions.push(this.renderTableConstraint(constraint));\n    }\n\n    parts.push(definitions.join(', '));\n    parts.push(')');\n\n    // Table options\n    const options: string[] = [];\n    if (node.hasWithoutRowid) {\n      options.push('WITHOUT ROWID');\n    }\n    if (node.isStrict) {\n      options.push('STRICT');\n    }\n    if (options.length > 0) {\n      parts.push(' ' + options.join(', '));\n    }\n\n    return parts.join('');\n  }\n\n  visitCreateVirtualTableQuery(node: CreateVirtualTableQuery): string {\n    const ifNotExists = node.hasIfNotExists ? ' IF NOT EXISTS' : '';\n    const args: string[] = [];\n\n    // Add columns (FTS5 columns don't have types)\n    for (const col of node.columns) {\n      args.push(quoteIdentifier(col));\n    }\n\n    // Add FTS5 options\n    const opts = node.options;\n    if (opts.tokenize) {\n      args.push(`tokenize = '${opts.tokenize}'`);\n    }\n    if (opts.content) {\n      args.push(`content = '${opts.content}'`);\n    }\n    if (opts.contentRowid) {\n      args.push(`content_rowid = '${opts.contentRowid}'`);\n    }\n    if (opts.prefix) {\n      args.push(`prefix = '${opts.prefix}'`);\n    }\n\n    return `CREATE VIRTUAL TABLE${ifNotExists} ${quoteIdentifier(node.tableName)} USING ${node.module}(${args.join(', ')})`;\n  }\n\n  protected renderColumnDefinition(col: ColumnDefinition): string {\n    const parts: string[] = [quoteIdentifier(col.name), col.type];\n\n    if (col.constraints.primaryKey) {\n      parts.push('PRIMARY KEY');\n      if (col.constraints.autoIncrement) {\n        parts.push('AUTOINCREMENT');\n      }\n    }\n    if (col.constraints.notNull) {\n      parts.push('NOT NULL');\n    }\n    if (col.constraints.unique) {\n      parts.push('UNIQUE');\n    }\n    if (col.constraints.default !== undefined) {\n      if (col.constraints.default === null) {\n        parts.push('DEFAULT NULL');\n      } else if (typeof col.constraints.default === 'string') {\n        // Check if it's a SQL keyword/function like CURRENT_TIMESTAMP\n        const sqlKeywords = ['CURRENT_TIMESTAMP', 'CURRENT_DATE', 'CURRENT_TIME', 'TRUE', 'FALSE'];\n        if (sqlKeywords.includes(col.constraints.default.toUpperCase())) {\n          parts.push(`DEFAULT ${col.constraints.default}`);\n        } else {\n          parts.push(`DEFAULT '${col.constraints.default.replace(/'/g, \"''\")}'`);\n        }\n      } else {\n        parts.push(`DEFAULT ${col.constraints.default}`);\n      }\n    }\n    if (col.constraints.check) {\n      parts.push(`CHECK ${col.constraints.check.accept(this)}`);\n    }\n    if (col.constraints.references) {\n      const ref = col.constraints.references;\n      let refStr = `REFERENCES ${quoteIdentifier(ref.table)}(${quoteIdentifier(ref.column)})`;\n      if (ref.onDelete) {\n        refStr += ` ON DELETE ${ref.onDelete}`;\n      }\n      if (ref.onUpdate) {\n        refStr += ` ON UPDATE ${ref.onUpdate}`;\n      }\n      parts.push(refStr);\n    }\n\n    return parts.join(' ');\n  }\n\n  protected renderTableConstraint(constraint: TableConstraint): string {\n    const parts: string[] = [];\n\n    if (constraint.name) {\n      parts.push(`CONSTRAINT ${quoteIdentifier(constraint.name)}`);\n    }\n\n    switch (constraint.type) {\n      case 'PRIMARY KEY':\n        parts.push(`PRIMARY KEY (${constraint.columns!.map(quoteIdentifier).join(', ')})`);\n        break;\n      case 'UNIQUE':\n        parts.push(`UNIQUE (${constraint.columns!.map(quoteIdentifier).join(', ')})`);\n        break;\n      case 'FOREIGN KEY':\n        const ref = constraint.references!;\n        let fkStr = `FOREIGN KEY (${constraint.columns!.map(quoteIdentifier).join(', ')}) REFERENCES ${quoteIdentifier(ref.table)}(${quoteIdentifier(ref.column)})`;\n        if (ref.onDelete) {\n          fkStr += ` ON DELETE ${ref.onDelete}`;\n        }\n        if (ref.onUpdate) {\n          fkStr += ` ON UPDATE ${ref.onUpdate}`;\n        }\n        parts.push(fkStr);\n        break;\n      case 'CHECK':\n        parts.push(`CHECK ${constraint.check!.accept(this)}`);\n        break;\n    }\n\n    return parts.join(' ');\n  }\n\n  visitSelectQuery(node: SelectQuery): string {\n    const parts: string[] = [];\n    if (node['_with'].length > 0) {\n      parts.push(`WITH ${node['_with'].map(w => w.accept(this)).join(', ')}`);\n    }\n    parts.push(`SELECT${node.isDistinct() ? ' DISTINCT' : ''}`);\n    if (node['_columns'].length > 0) {\n      parts.push(node['_columns'].map(c => this.columnLikeAcceptor.accept(this, c)).join(', '));\n    } else {\n      parts.push('*');\n    }\n    if (node['_fromsAndJoins'].length > 0) {\n      let fromsAndJoinsText = '';\n      for (const fromOrJoin of node['_fromsAndJoins']) {\n        if (fromOrJoin instanceof Join) {\n          fromsAndJoinsText += ` ${fromOrJoin.accept(this)}`;\n        } else if (\n          fromOrJoin instanceof Alias ||\n          fromOrJoin instanceof From ||\n          fromOrJoin instanceof TableFrom ||\n          fromOrJoin instanceof SubqueryFrom ||\n          fromOrJoin instanceof JsonEachFrom\n        ) {\n          if (fromsAndJoinsText) {\n            fromsAndJoinsText += `, ${fromOrJoin.accept(this)}`;\n          } else {\n            fromsAndJoinsText += `FROM ${fromOrJoin.accept(this)}`;\n          }\n        }\n      }\n      parts.push(fromsAndJoinsText);\n    }\n    if (node['_where']) {\n      parts.push(`WHERE ${node['_where'].accept(this)}`);\n    }\n    if (node['_groupBy'].length > 0) {\n      parts.push(`GROUP BY ${node['_groupBy'].map(c => c.accept(this)).join(', ')}`);\n    }\n    if (node['_having']) {\n      parts.push(`HAVING ${node['_having'].accept(this)}`);\n    }\n    if (node['_union'].length > 0) {\n      parts.push(node['_union'].map(u => `UNION ${u.accept(this)}`).join(' '));\n    }\n    if (node['_intersect'].length > 0) {\n      parts.push(node['_intersect'].map(i => `INTERSECT ${i.accept(this)}`).join(' '));\n    }\n    if (node['_except'].length > 0) {\n      parts.push(node['_except'].map(e => `EXCEPT ${e.accept(this)}`).join(' '));\n    }\n    if (node['_orderBy'].length > 0) {\n      parts.push(`ORDER BY ${node['_orderBy'].map(o => o.accept(this)).join(', ')}`);\n    }\n    if (node['_limit'] !== null && node['_limit'] !== undefined) {\n      parts.push(`LIMIT ${node['_limit']}`);\n      if (node['_offset'] !== null && node['_offset'] !== undefined) {\n        parts.push(`OFFSET ${node['_offset']}`);\n      }\n    }\n    return parts.filter(p => p).join(' ');\n  }\n\n  visitTableFrom(node: TableFrom): string {\n    return `${quoteIdentifier(node.tableName)}`;\n  }\n\n  visitSubqueryFrom(node: SubqueryFrom): string {\n    return `(${node.subquery.accept(this)})`;\n  }\n\n  visitJsonEachFrom(node: JsonEachFrom): string {\n    const expr = node.jsonExpression.accept(this);\n    const path = node.jsonPath ? `, ${node.jsonPath.accept(this)}` : '';\n    return `json_each(${expr}${path})`;\n  }\n\n  visitColumn(node: Column): string {\n    if (node.hasTableName()) {\n      return `${quoteIdentifier(node.tableName as string)}.${quoteIdentifier(node.columnName)}`;\n    } else {\n      return `${quoteIdentifier(node.columnName)}`;\n    }\n  }\n\n  visitAlias(node: Alias<From|AliasableExpression>): string {\n    const isSubquery = node.referent instanceof SubqueryFrom || node.referent instanceof SelectQuery;\n    const renderedReferent = node.referent.accept(this);\n    const renderedAliasName = quoteIdentifier(node.alias as string);\n    if (node.referent instanceof From) {\n      return `${renderedReferent} ${renderedAliasName}`;\n    } else if (isSubquery) {\n      return `(${renderedReferent}) AS ${renderedAliasName}`;\n    } else {\n      return `${renderedReferent} AS ${renderedAliasName}`;\n    }\n  }\n\n  visitJoinClause(node: Join): string {\n    return `${node.type} JOIN ${quoteIdentifier(node.tableName)} ${quoteIdentifier(node.alias)} ON ${node.on.accept(this)}`;\n  }\n\n  visitOrderBy(node: OrderBy): string {\n    return `${node.column.accept(this)} ${node.direction}`;\n  }\n\n  visitWithClause(node: With): string {\n    return `${quoteIdentifier(node.name)} AS (${node.query.accept(this)})`;\n  }\n\n  visitBinaryExpression(node: BinaryExpression): string {\n    return `(${node.left.accept(this)} ${node.operator} ${node.right.accept(this)})`;\n  }\n\n  visitBetweenExpression(node: BetweenExpression): string {\n    const not = node.not ? ' NOT' : '';\n    return `(${node.operand.accept(this)}${not} BETWEEN ${node.low.accept(this)} AND ${node.high.accept(this)})`;\n  }\n\n  visitUnaryExpression(node: UnaryExpression): string {\n    const operand = node.operand.accept(this);\n    if (node.operator === Operator.IS_NULL || node.operator === Operator.IS_NOT_NULL) {\n      return `(${operand} ${node.operator})`;\n    } else if (node.operator === 'NOT') {\n      return `(NOT ${operand})`;\n    } else {\n      return `(${node.operator}${operand})`;\n    }\n  }\n\n  visitInExpression(node: InExpression): string {\n    const leftStr = node.left.length > 1\n      ? `(${node.left.map(l => l.accept(this)).join(', ')})`\n      : node.left[0].accept(this);\n    const not = node.not ? ' NOT' : '';\n    let right: string;\n    if (node.values instanceof SelectQuery) {\n      right = `(${node.values.accept(this)})`;\n    } else {\n      right = `(${node.values.map(set =>\n        set.length > 1 ? `(${set.map(v => v.accept(this)).join(', ')})` : set[0].accept(this)\n      ).join(', ')})`;\n    }\n    return `(${leftStr}${not} IN ${right})`;\n  }\n\n  visitConcat(node: Concat): string {\n    return `(${node.expressions.map(e => e.accept(this)).join(' || ')})`;\n  }\n\n  visitCaseExpression(node: CaseExpression): string {\n    const parts: string[] = ['CASE'];\n    for (const c of node.cases) {\n      parts.push(`WHEN ${c.when.accept(this)} THEN ${c.then.accept(this)}`);\n    }\n    if (node.else) {\n      parts.push(`ELSE ${node.else.accept(this)}`);\n    }\n    parts.push('END');\n    return parts.join(' ');\n  }\n\n  visitCastExpression(node: CastExpression): string {\n    return `CAST(${node.expression.accept(this)} AS ${node.targetType})`;\n  }\n\n  visitCollateExpression(node: CollateExpression): string {\n    return `${node.expression.accept(this)} COLLATE ${node.collation}`;\n  }\n\n  visitSubqueryExpression(node: SubqueryExpression): string {\n    return `(${node.subquery.accept(this)})`;\n  }\n\n  visitWindowExpression(node: WindowExpression): string {\n    const fnPart = node.function.accept(this);\n    const spec = node.windowSpec;\n\n    const parts: string[] = [];\n    if (spec.partitionByColumns.length > 0) {\n      parts.push(`PARTITION BY ${spec.partitionByColumns.map(c => c.accept(this)).join(', ')}`);\n    }\n    if (spec.orderByColumns.length > 0) {\n      parts.push(`ORDER BY ${spec.orderByColumns.map(o => o.accept(this)).join(', ')}`);\n    }\n\n    return `${fnPart} OVER (${parts.join(' ')})`;\n  }\n\n  visitFunctionExpression(node: FunctionExpression): string {\n    const args = node.args.map(a => a.accept(this)).join(', ');\n    const distinctPrefix = node.distinct ? 'DISTINCT ' : '';\n    return `${node.name}(${distinctPrefix}${args})`;\n  }\n\n  visitParamExpression(_node: Param): string {\n    return '?';\n  }\n\n  visitStringLiteral(node: StringLiteral): string {\n    return `'${node.value.replace(/'/g, \"''\")}'`;\n  }\n\n  visitNumberLiteral(node: NumberLiteral): string {\n    return node.value.toString();\n  }\n\n  visitNullLiteral(_node: NullLiteral): string {\n    return 'NULL';\n  }\n\n  visitExistsExpression(node: ExistsExpression): string {\n    return `EXISTS (${node.subquery.accept(this)})`;\n  }\n}\n"]}
@@ -1,14 +1,29 @@
1
1
  import { AliasableExpression } from "../ast/Abstractions";
2
2
  import { Alias } from "../ast/Alias";
3
+ import { AlterTableQuery } from "../ast/AlterTableQuery";
4
+ import { BetweenExpression } from "../ast/BetweenExpression";
3
5
  import { BinaryExpression } from "../ast/BinaryExpression";
4
6
  import { CaseExpression } from "../ast/CaseExpression";
7
+ import { CastExpression } from "../ast/CastExpression";
8
+ import { CollateExpression } from "../ast/CollateExpression";
9
+ import { SubqueryExpression } from "../ast/SubqueryExpression";
10
+ import { WindowExpression } from "../ast/WindowExpression";
5
11
  import { Column } from "../ast/Column";
6
12
  import { Concat } from "../ast/Concat";
13
+ import { CreateIndexQuery } from "../ast/CreateIndexQuery";
14
+ import { CreateTableQuery, ColumnDefinition, TableConstraint } from "../ast/CreateTableQuery";
15
+ import { CreateVirtualTableQuery } from "../ast/CreateVirtualTableQuery";
16
+ import { CreateViewQuery } from "../ast/CreateViewQuery";
17
+ import { DeleteQuery } from "../ast/DeleteQuery";
18
+ import { DropIndexQuery } from "../ast/DropIndexQuery";
19
+ import { DropTableQuery } from "../ast/DropTableQuery";
20
+ import { DropViewQuery } from "../ast/DropViewQuery";
7
21
  import { ExistsExpression } from "../ast/ExistsExpression";
8
22
  import { From, JsonEachFrom, SubqueryFrom, TableFrom } from "../ast/From";
9
23
  import { FunctionExpression } from "../ast/FunctionExpression";
10
24
  import { InExpression } from "../ast/InExpression";
11
25
  import { InsertQuery } from "../ast/InsertQuery";
26
+ import { UpdateQuery } from "../ast/UpdateQuery";
12
27
  import { Join } from "../ast/Join";
13
28
  import { NullLiteral, NumberLiteral, Param, StringLiteral } from "../ast/Literals";
14
29
  import { OrderBy } from "../ast/OrderBy";
@@ -16,18 +31,30 @@ import { SelectQuery } from "../ast/SelectQuery";
16
31
  import { UnaryExpression } from "../ast/UnaryExpression";
17
32
  import { With } from "../ast/With";
18
33
  import { ColumnLikeVisitorAcceptor, FromLikeAndJoinVisitorAcceptor, SqlTreeNodeVisitor } from "../visitor/SqlTreeNodeVisitor";
19
- import { QueryRenderer } from "./QueryRenderer";
34
+ import { QueryRenderer, RenderableQuery } from "./QueryRenderer";
20
35
  export declare class IndentedQueryRenderer implements QueryRenderer, SqlTreeNodeVisitor<string> {
21
36
  protected fromLikeAndJoinAcceptor: FromLikeAndJoinVisitorAcceptor<string>;
22
37
  protected columnLikeAcceptor: ColumnLikeVisitorAcceptor<string>;
23
38
  private readonly spacesPerLevel;
24
39
  private indentationLevel;
25
40
  constructor(spacesPerLevel: number);
26
- render(node: SelectQuery | InsertQuery): string;
41
+ render(node: RenderableQuery): string;
27
42
  private getIndent;
28
43
  private indent;
29
44
  private dedent;
30
45
  visitInsertQuery(node: InsertQuery): string;
46
+ visitDeleteQuery(node: DeleteQuery): string;
47
+ visitUpdateQuery(node: UpdateQuery): string;
48
+ visitDropTableQuery(node: DropTableQuery): string;
49
+ visitDropIndexQuery(node: DropIndexQuery): string;
50
+ visitDropViewQuery(node: DropViewQuery): string;
51
+ visitCreateViewQuery(node: CreateViewQuery): string;
52
+ visitCreateIndexQuery(node: CreateIndexQuery): string;
53
+ visitAlterTableQuery(node: AlterTableQuery): string;
54
+ visitCreateTableQuery(node: CreateTableQuery): string;
55
+ visitCreateVirtualTableQuery(node: CreateVirtualTableQuery): string;
56
+ protected renderColumnDefinition(col: ColumnDefinition): string;
57
+ protected renderTableConstraint(constraint: TableConstraint): string;
31
58
  visitSelectQuery(node: SelectQuery): string;
32
59
  visitTableFrom(node: TableFrom): string;
33
60
  visitSubqueryFrom(node: SubqueryFrom): string;
@@ -38,10 +65,15 @@ export declare class IndentedQueryRenderer implements QueryRenderer, SqlTreeNode
38
65
  visitOrderBy(node: OrderBy): string;
39
66
  visitWithClause(node: With): string;
40
67
  visitBinaryExpression(node: BinaryExpression): string;
68
+ visitBetweenExpression(node: BetweenExpression): string;
41
69
  visitUnaryExpression(node: UnaryExpression): string;
42
70
  visitInExpression(node: InExpression): string;
43
71
  visitConcat(node: Concat): string;
44
72
  visitCaseExpression(node: CaseExpression): string;
73
+ visitCastExpression(node: CastExpression): string;
74
+ visitCollateExpression(node: CollateExpression): string;
75
+ visitSubqueryExpression(node: SubqueryExpression): string;
76
+ visitWindowExpression(node: WindowExpression): string;
45
77
  visitFunctionExpression(node: FunctionExpression): string;
46
78
  visitParamExpression(_node: Param): string;
47
79
  visitStringLiteral(node: StringLiteral): string;