@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
@@ -38,11 +38,266 @@ class IndentedQueryRenderer {
38
38
  if (node['_columns'].length > 0) {
39
39
  parts.push(`${this.getIndent()}(${node['_columns'].map(QueryRenderer_1.quoteIdentifier).join(', ')})`);
40
40
  }
41
- parts.push(`${this.getIndent()}VALUES`);
42
- parts.push(`${this.getIndent()}(${node['_values'].map(v => v.accept(this)).join(', ')})`);
41
+ if (node['_fromSelect']) {
42
+ parts.push(node['_fromSelect'].accept(this));
43
+ }
44
+ else {
45
+ parts.push(`${this.getIndent()}VALUES`);
46
+ parts.push(`${this.getIndent()}(${node['_values'].map(v => v.accept(this)).join(', ')})`);
47
+ }
48
+ // ON CONFLICT clause
49
+ if (node['_onConflictColumns'].length > 0) {
50
+ const conflictCols = node['_onConflictColumns'].map(QueryRenderer_1.quoteIdentifier).join(', ');
51
+ if (node['_doNothing']) {
52
+ parts.push(`${this.getIndent()}ON CONFLICT (${conflictCols}) DO NOTHING`);
53
+ }
54
+ else if (node['_doUpdateSets'].length > 0) {
55
+ let onConflictLine = `${this.getIndent()}ON CONFLICT (${conflictCols})`;
56
+ if (node['_onConflictWhere']) {
57
+ onConflictLine += ` WHERE ${node['_onConflictWhere'].accept(this)}`;
58
+ }
59
+ parts.push(onConflictLine);
60
+ const setClauses = node['_doUpdateSets'].map(s => `${(0, QueryRenderer_1.quoteIdentifier)(s.column)} = ${s.value.accept(this)}`).join(', ');
61
+ parts.push(`${this.getIndent()}DO UPDATE SET ${setClauses}`);
62
+ }
63
+ }
64
+ if (node['_returning'].length > 0) {
65
+ parts.push(`${this.getIndent()}RETURNING ${node['_returning'].map(r => r.accept(this)).join(', ')}`);
66
+ }
67
+ this.dedent();
68
+ return parts.join('\n');
69
+ }
70
+ visitDeleteQuery(node) {
71
+ this.indent();
72
+ const parts = [];
73
+ parts.push(`${this.getIndent()}DELETE`);
74
+ parts.push(`${this.getIndent()}FROM ${(0, QueryRenderer_1.quoteIdentifier)(node['_tableName'])}`);
75
+ if (node['_where']) {
76
+ parts.push(`${this.getIndent()}WHERE ${node['_where'].accept(this)}`);
77
+ }
78
+ if (node['_returning'].length > 0) {
79
+ parts.push(`${this.getIndent()}RETURNING ${node['_returning'].map(r => r.accept(this)).join(', ')}`);
80
+ }
81
+ this.dedent();
82
+ return parts.join('\n');
83
+ }
84
+ visitUpdateQuery(node) {
85
+ this.indent();
86
+ const parts = [];
87
+ parts.push(`${this.getIndent()}UPDATE ${(0, QueryRenderer_1.quoteIdentifier)(node['_tableName'])}`);
88
+ if (node['_set'].length > 0) {
89
+ const setClauses = node['_set'].map(s => `${(0, QueryRenderer_1.quoteIdentifier)(s.column)} = ${s.value.accept(this)}`).join(', ');
90
+ parts.push(`${this.getIndent()}SET ${setClauses}`);
91
+ }
92
+ if (node['_where']) {
93
+ parts.push(`${this.getIndent()}WHERE ${node['_where'].accept(this)}`);
94
+ }
95
+ if (node['_returning'].length > 0) {
96
+ parts.push(`${this.getIndent()}RETURNING ${node['_returning'].map(r => r.accept(this)).join(', ')}`);
97
+ }
43
98
  this.dedent();
44
99
  return parts.join('\n');
45
100
  }
101
+ visitDropTableQuery(node) {
102
+ const ifExists = node.hasIfExists ? ' IF EXISTS' : '';
103
+ return `DROP TABLE${ifExists} ${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)}`;
104
+ }
105
+ visitDropIndexQuery(node) {
106
+ const ifExists = node.hasIfExists ? ' IF EXISTS' : '';
107
+ return `DROP INDEX${ifExists} ${(0, QueryRenderer_1.quoteIdentifier)(node.indexName)}`;
108
+ }
109
+ visitDropViewQuery(node) {
110
+ const ifExists = node.hasIfExists ? ' IF EXISTS' : '';
111
+ return `DROP VIEW${ifExists} ${(0, QueryRenderer_1.quoteIdentifier)(node.viewName)}`;
112
+ }
113
+ visitCreateViewQuery(node) {
114
+ const parts = [];
115
+ parts.push('CREATE');
116
+ if (node.isTemporary) {
117
+ parts.push('TEMPORARY');
118
+ }
119
+ parts.push('VIEW');
120
+ if (node.hasIfNotExists) {
121
+ parts.push('IF NOT EXISTS');
122
+ }
123
+ parts.push((0, QueryRenderer_1.quoteIdentifier)(node.viewName));
124
+ if (node.columns.length > 0) {
125
+ parts.push(`(${node.columns.map(QueryRenderer_1.quoteIdentifier).join(', ')})`);
126
+ }
127
+ parts.push('AS');
128
+ if (!node.selectQuery) {
129
+ throw new Error('CreateViewQuery must have a SELECT query');
130
+ }
131
+ parts.push(node.selectQuery.accept(this));
132
+ return parts.join(' ');
133
+ }
134
+ visitCreateIndexQuery(node) {
135
+ const unique = node.isUnique ? 'UNIQUE ' : '';
136
+ const ifNotExists = node.hasIfNotExists ? ' IF NOT EXISTS' : '';
137
+ let sql = `CREATE ${unique}INDEX${ifNotExists} ${(0, QueryRenderer_1.quoteIdentifier)(node.indexName)} ON ${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)} (${node.columns.map(QueryRenderer_1.quoteIdentifier).join(', ')})`;
138
+ if (node.whereExpression) {
139
+ sql += ` WHERE ${node.whereExpression.accept(this)}`;
140
+ }
141
+ return sql;
142
+ }
143
+ visitAlterTableQuery(node) {
144
+ const op = node.operation;
145
+ if (!op) {
146
+ throw new Error('AlterTableQuery must have an operation');
147
+ }
148
+ switch (op.type) {
149
+ case 'ADD_COLUMN':
150
+ return `ALTER TABLE ${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)} ADD COLUMN ${this.renderColumnDefinition(op.column)}`;
151
+ case 'RENAME_COLUMN':
152
+ return `ALTER TABLE ${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)} RENAME COLUMN ${(0, QueryRenderer_1.quoteIdentifier)(op.oldName)} TO ${(0, QueryRenderer_1.quoteIdentifier)(op.newName)}`;
153
+ case 'DROP_COLUMN':
154
+ return `ALTER TABLE ${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)} DROP COLUMN ${(0, QueryRenderer_1.quoteIdentifier)(op.columnName)}`;
155
+ case 'RENAME_TABLE':
156
+ return `ALTER TABLE ${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)} RENAME TO ${(0, QueryRenderer_1.quoteIdentifier)(op.newTableName)}`;
157
+ }
158
+ }
159
+ visitCreateTableQuery(node) {
160
+ this.indent();
161
+ const parts = [];
162
+ const ifNotExists = node.hasIfNotExists ? ' IF NOT EXISTS' : '';
163
+ parts.push(`${this.getIndent()}CREATE TABLE${ifNotExists} ${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)} (`);
164
+ this.indent();
165
+ const definitions = [];
166
+ // Column definitions
167
+ for (const col of node.columns) {
168
+ definitions.push(`${this.getIndent()}${this.renderColumnDefinition(col)}`);
169
+ }
170
+ // Table constraints
171
+ for (const constraint of node.tableConstraints) {
172
+ definitions.push(`${this.getIndent()}${this.renderTableConstraint(constraint)}`);
173
+ }
174
+ parts.push(definitions.join(',\n'));
175
+ this.dedent();
176
+ // Table options
177
+ const options = [];
178
+ if (node.hasWithoutRowid) {
179
+ options.push('WITHOUT ROWID');
180
+ }
181
+ if (node.isStrict) {
182
+ options.push('STRICT');
183
+ }
184
+ if (options.length > 0) {
185
+ parts.push(`${this.getIndent()}) ${options.join(', ')}`);
186
+ }
187
+ else {
188
+ parts.push(`${this.getIndent()})`);
189
+ }
190
+ this.dedent();
191
+ return parts.join('\n');
192
+ }
193
+ visitCreateVirtualTableQuery(node) {
194
+ this.indent();
195
+ const parts = [];
196
+ const ifNotExists = node.hasIfNotExists ? ' IF NOT EXISTS' : '';
197
+ parts.push(`${this.getIndent()}CREATE VIRTUAL TABLE${ifNotExists} ${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)} USING ${node.module}(`);
198
+ this.indent();
199
+ const args = [];
200
+ // Add columns (FTS5 columns don't have types)
201
+ for (const col of node.columns) {
202
+ args.push(`${this.getIndent()}${(0, QueryRenderer_1.quoteIdentifier)(col)}`);
203
+ }
204
+ // Add FTS5 options
205
+ const opts = node.options;
206
+ if (opts.tokenize) {
207
+ args.push(`${this.getIndent()}tokenize = '${opts.tokenize}'`);
208
+ }
209
+ if (opts.content) {
210
+ args.push(`${this.getIndent()}content = '${opts.content}'`);
211
+ }
212
+ if (opts.contentRowid) {
213
+ args.push(`${this.getIndent()}content_rowid = '${opts.contentRowid}'`);
214
+ }
215
+ if (opts.prefix) {
216
+ args.push(`${this.getIndent()}prefix = '${opts.prefix}'`);
217
+ }
218
+ parts.push(args.join(',\n'));
219
+ this.dedent();
220
+ parts.push(`${this.getIndent()})`);
221
+ this.dedent();
222
+ return parts.join('\n');
223
+ }
224
+ renderColumnDefinition(col) {
225
+ const parts = [(0, QueryRenderer_1.quoteIdentifier)(col.name), col.type];
226
+ if (col.constraints.primaryKey) {
227
+ parts.push('PRIMARY KEY');
228
+ if (col.constraints.autoIncrement) {
229
+ parts.push('AUTOINCREMENT');
230
+ }
231
+ }
232
+ if (col.constraints.notNull) {
233
+ parts.push('NOT NULL');
234
+ }
235
+ if (col.constraints.unique) {
236
+ parts.push('UNIQUE');
237
+ }
238
+ if (col.constraints.default !== undefined) {
239
+ if (col.constraints.default === null) {
240
+ parts.push('DEFAULT NULL');
241
+ }
242
+ else if (typeof col.constraints.default === 'string') {
243
+ // Check if it's a SQL keyword/function like CURRENT_TIMESTAMP
244
+ const sqlKeywords = ['CURRENT_TIMESTAMP', 'CURRENT_DATE', 'CURRENT_TIME', 'TRUE', 'FALSE'];
245
+ if (sqlKeywords.includes(col.constraints.default.toUpperCase())) {
246
+ parts.push(`DEFAULT ${col.constraints.default}`);
247
+ }
248
+ else {
249
+ parts.push(`DEFAULT '${col.constraints.default.replace(/'/g, "''")}'`);
250
+ }
251
+ }
252
+ else {
253
+ parts.push(`DEFAULT ${col.constraints.default}`);
254
+ }
255
+ }
256
+ if (col.constraints.check) {
257
+ parts.push(`CHECK ${col.constraints.check.accept(this)}`);
258
+ }
259
+ if (col.constraints.references) {
260
+ const ref = col.constraints.references;
261
+ let refStr = `REFERENCES ${(0, QueryRenderer_1.quoteIdentifier)(ref.table)}(${(0, QueryRenderer_1.quoteIdentifier)(ref.column)})`;
262
+ if (ref.onDelete) {
263
+ refStr += ` ON DELETE ${ref.onDelete}`;
264
+ }
265
+ if (ref.onUpdate) {
266
+ refStr += ` ON UPDATE ${ref.onUpdate}`;
267
+ }
268
+ parts.push(refStr);
269
+ }
270
+ return parts.join(' ');
271
+ }
272
+ renderTableConstraint(constraint) {
273
+ const parts = [];
274
+ if (constraint.name) {
275
+ parts.push(`CONSTRAINT ${(0, QueryRenderer_1.quoteIdentifier)(constraint.name)}`);
276
+ }
277
+ switch (constraint.type) {
278
+ case 'PRIMARY KEY':
279
+ parts.push(`PRIMARY KEY (${constraint.columns.map(QueryRenderer_1.quoteIdentifier).join(', ')})`);
280
+ break;
281
+ case 'UNIQUE':
282
+ parts.push(`UNIQUE (${constraint.columns.map(QueryRenderer_1.quoteIdentifier).join(', ')})`);
283
+ break;
284
+ case 'FOREIGN KEY':
285
+ const ref = constraint.references;
286
+ let fkStr = `FOREIGN KEY (${constraint.columns.map(QueryRenderer_1.quoteIdentifier).join(', ')}) REFERENCES ${(0, QueryRenderer_1.quoteIdentifier)(ref.table)}(${(0, QueryRenderer_1.quoteIdentifier)(ref.column)})`;
287
+ if (ref.onDelete) {
288
+ fkStr += ` ON DELETE ${ref.onDelete}`;
289
+ }
290
+ if (ref.onUpdate) {
291
+ fkStr += ` ON UPDATE ${ref.onUpdate}`;
292
+ }
293
+ parts.push(fkStr);
294
+ break;
295
+ case 'CHECK':
296
+ parts.push(`CHECK ${constraint.check.accept(this)}`);
297
+ break;
298
+ }
299
+ return parts.join(' ');
300
+ }
46
301
  visitSelectQuery(node) {
47
302
  const parts = [];
48
303
  if (node['_with'].length > 0) {
@@ -92,6 +347,12 @@ class IndentedQueryRenderer {
92
347
  if (node['_union'].length > 0) {
93
348
  parts.push(node['_union'].map(u => `${this.getIndent()}UNION\n${u.accept(this)}`).join('\n'));
94
349
  }
350
+ if (node['_intersect'].length > 0) {
351
+ parts.push(node['_intersect'].map(i => `${this.getIndent()}INTERSECT\n${i.accept(this)}`).join('\n'));
352
+ }
353
+ if (node['_except'].length > 0) {
354
+ parts.push(node['_except'].map(e => `${this.getIndent()}EXCEPT\n${e.accept(this)}`).join('\n'));
355
+ }
95
356
  if (node['_orderBy'].length > 0) {
96
357
  parts.push(`${this.getIndent()}ORDER BY ${node['_orderBy'].map(o => o.accept(this)).join(', ')}`);
97
358
  }
@@ -158,6 +419,10 @@ class IndentedQueryRenderer {
158
419
  visitBinaryExpression(node) {
159
420
  return `(${node.left.accept(this)} ${node.operator} ${node.right.accept(this)})`;
160
421
  }
422
+ visitBetweenExpression(node) {
423
+ const not = node.not ? ' NOT' : '';
424
+ return `(${node.operand.accept(this)}${not} BETWEEN ${node.low.accept(this)} AND ${node.high.accept(this)})`;
425
+ }
161
426
  visitUnaryExpression(node) {
162
427
  const operand = node.operand.accept(this);
163
428
  if (node.operator === Operator_1.Operator.IS_NULL || node.operator === Operator_1.Operator.IS_NOT_NULL) {
@@ -204,6 +469,27 @@ class IndentedQueryRenderer {
204
469
  this.dedent();
205
470
  return parts.join('\n');
206
471
  }
472
+ visitCastExpression(node) {
473
+ return `CAST(${node.expression.accept(this)} AS ${node.targetType})`;
474
+ }
475
+ visitCollateExpression(node) {
476
+ return `${node.expression.accept(this)} COLLATE ${node.collation}`;
477
+ }
478
+ visitSubqueryExpression(node) {
479
+ return `(${node.subquery.accept(this)})`;
480
+ }
481
+ visitWindowExpression(node) {
482
+ const fnPart = node.function.accept(this);
483
+ const spec = node.windowSpec;
484
+ const parts = [];
485
+ if (spec.partitionByColumns.length > 0) {
486
+ parts.push(`PARTITION BY ${spec.partitionByColumns.map(c => c.accept(this)).join(', ')}`);
487
+ }
488
+ if (spec.orderByColumns.length > 0) {
489
+ parts.push(`ORDER BY ${spec.orderByColumns.map(o => o.accept(this)).join(', ')}`);
490
+ }
491
+ return `${fnPart} OVER (${parts.join(' ')})`;
492
+ }
207
493
  visitFunctionExpression(node) {
208
494
  const args = node.args.map(a => a.accept(this)).join(', ');
209
495
  const distinctPrefix = node.distinct ? 'DISTINCT ' : '';
@@ -227,4 +513,4 @@ class IndentedQueryRenderer {
227
513
  }
228
514
  }
229
515
  exports.IndentedQueryRenderer = IndentedQueryRenderer;
230
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"IndentedQueryRenderer.js","sourceRoot":"","sources":["../../src/renderer/IndentedQueryRenderer.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 IndentedQueryRenderer\n  implements QueryRenderer, SqlTreeNodeVisitor<string>\n{\n  protected fromLikeAndJoinAcceptor = new FromLikeAndJoinVisitorAcceptor<string>();\n  protected columnLikeAcceptor = new ColumnLikeVisitorAcceptor<string>();\n\n  private readonly spacesPerLevel: number;\n  private indentationLevel: number = -1;\n\n  public constructor(spacesPerLevel: number) {\n    if (!Number.isInteger(spacesPerLevel) || spacesPerLevel <= 0) {\n      throw new Error('spacesPerLevel must be a positive integer');\n    }\n    this.spacesPerLevel = spacesPerLevel;\n  }\n\n  public render(node: SelectQuery | InsertQuery): string {\n    return node.accept(this);\n  }\n\n  private getIndent(): string {\n    return ' '.repeat(this.indentationLevel * this.spacesPerLevel);\n  }\n\n  private indent(): void {\n    this.indentationLevel++;\n  }\n\n  private dedent(): void {\n    this.indentationLevel--;\n  }\n\n  visitInsertQuery(node: InsertQuery): string {\n    this.indent();\n    const parts: string[] = [];\n    parts.push(`${this.getIndent()}INSERT${node.isOrReplace() ? ' OR REPLACE' : ''}`);\n    parts.push(`${this.getIndent()}INTO ${quoteIdentifier(node['_tableName'])}`);\n    if (node['_columns'].length > 0) {\n      parts.push(`${this.getIndent()}(${node['_columns'].map(quoteIdentifier).join(', ')})`);\n    }\n    parts.push(`${this.getIndent()}VALUES`);\n    parts.push(`${this.getIndent()}(${node['_values'].map(v => v.accept(this)).join(', ')})`);\n    this.dedent();\n    return parts.join('\\n');\n  }\n\n  visitSelectQuery(node: SelectQuery): string {\n    const parts: string[] = [];\n    if (node['_with'].length > 0) {\n      this.indent();\n      parts.push('WITH');\n      parts.push(node['_with'].map(w => w.accept(this)).join(',\\n'));\n      this.dedent();\n    }\n    this.indent();\n    parts.push(`${this.getIndent()}SELECT${node.isDistinct() ? ' DISTINCT' : ''}`);\n    if (node['_columns'].length > 0) {\n      parts.push(node['_columns'].map(c => `${this.getIndent()}  ${this.columnLikeAcceptor.accept(this, c)}`).join(',\\n'));\n    } else {\n      parts.push(`${this.getIndent()}  *`);\n    }\n    if (node['_fromsAndJoins'].length > 0) {\n      let fromsAndJoinsText = '';\n      for (const fromOrJoin of node['_fromsAndJoins']) {\n        if (fromOrJoin instanceof Join) {\n          fromsAndJoinsText += `\\n${this.getIndent()}${fromOrJoin.accept(this)}`;\n        } else if (\n          fromOrJoin instanceof Alias ||\n          fromOrJoin instanceof From ||\n          fromOrJoin instanceof TableFrom ||\n          fromOrJoin instanceof SubqueryFrom ||\n          fromOrJoin instanceof JsonEachFrom\n        ) {\n          if (fromsAndJoinsText) {\n            fromsAndJoinsText += `,\\n${this.getIndent()}${fromOrJoin.accept(this)}`;\n          } else {\n            fromsAndJoinsText += `${this.getIndent()}FROM ${fromOrJoin.accept(this)}`;\n          }\n        }\n      }\n      parts.push(fromsAndJoinsText);\n    }\n    if (node['_where']) {\n      parts.push(`${this.getIndent()}WHERE ${node['_where'].accept(this)}`);\n    }\n    if (node['_groupBy'].length > 0) {\n      parts.push(`${this.getIndent()}GROUP BY ${node['_groupBy'].map(c => c.accept(this)).join(', ')}`);\n    }\n    if (node['_having']) {\n      parts.push(`${this.getIndent()}HAVING ${node['_having'].accept(this)}`);\n    }\n    if (node['_union'].length > 0) {\n      parts.push(node['_union'].map(u => `${this.getIndent()}UNION\\n${u.accept(this)}`).join('\\n'));\n    }\n    if (node['_orderBy'].length > 0) {\n      parts.push(`${this.getIndent()}ORDER BY ${node['_orderBy'].map(o => o.accept(this)).join(', ')}`);\n    }\n    if (node['_limit'] !== null && node['_limit'] !== undefined) {\n      parts.push(`${this.getIndent()}LIMIT ${node['_limit']}`);\n      if (node['_offset'] !== null && node['_offset'] !== undefined) {\n        parts.push(`${this.getIndent()}OFFSET ${node['_offset']}`);\n      }\n    }\n    this.dedent();\n    return parts.filter(p => p).join('\\n');\n  }\n\n  visitTableFrom(node: TableFrom): string {\n    return `${quoteIdentifier(node.tableName)}`;\n  }\n\n  visitSubqueryFrom(node: SubqueryFrom): string {\n    this.indent();\n    const result = `(\\n${node.subquery.accept(this)}\\n${this.getIndent()})`;\n    this.dedent();\n    return result;\n  }\n\n  visitJsonEachFrom(node: JsonEachFrom): string {\n    const expr = node.jsonExpression.accept(this);\n    const path = node.jsonPath ? `, ${node.jsonPath.accept(this)}` : '';\n    return `json_each(${expr}${path})`;\n  }\n\n  visitColumn(node: Column): string {\n    if (node.hasTableName()) {\n      return `${quoteIdentifier(node.tableName as string)}.${quoteIdentifier(node.columnName)}`;\n    } else {\n      return `${quoteIdentifier(node.columnName)}`;\n    }\n  }\n\n  visitAlias(node: Alias<From|AliasableExpression>): string {\n    const renderedAliasName = quoteIdentifier(node.alias as string);\n    if (node.referent instanceof From) {\n      return `${node.referent.accept(this)} ${renderedAliasName}`;\n    } else if (\n      node.referent instanceof SubqueryFrom ||\n      node.referent instanceof SelectQuery\n    ) {\n      this.indent();\n      const renderedSubquery = `${node.referent.accept(this)}\\n`;\n      const result = `(\\n${renderedSubquery}${this.getIndent()}) AS ${renderedAliasName}`;\n      this.dedent();\n      return result;\n    } else {\n      return `${node.referent.accept(this)} AS ${renderedAliasName}`;\n    }\n  }\n\n  visitJoinClause(node: Join): string {\n    return `${node.type} JOIN ${quoteIdentifier(node.tableName)} ${quoteIdentifier(node.alias)} ON ${node.on.accept(this)}`;\n  }\n\n  visitOrderBy(node: OrderBy): string {\n    return `${node.column.accept(this)} ${node.direction}`;\n  }\n\n  visitWithClause(node: With): string {\n    this.indent();\n    const result = `${this.getIndent()}${quoteIdentifier(node.name)} AS (\\n${node.query.accept(this)}\\n${this.getIndent()})`;\n    this.dedent();\n    return result;\n  }\n\n  visitBinaryExpression(node: BinaryExpression): string {\n    return `(${node.left.accept(this)} ${node.operator} ${node.right.accept(this)})`;\n  }\n\n  visitUnaryExpression(node: UnaryExpression): string {\n    const operand = node.operand.accept(this);\n    if (node.operator === Operator.IS_NULL || node.operator === Operator.IS_NOT_NULL) {\n      return `(${operand} ${node.operator})`;\n    } else if (node.operator === 'NOT') {\n      return `(NOT ${operand})`;\n    } else {\n      return `(${node.operator}${operand})`;\n    }\n  }\n\n  visitInExpression(node: InExpression): string {\n    const leftStr = node.left.length > 1\n      ? `(${node.left.map(l => l.accept(this)).join(', ')})`\n      : node.left[0].accept(this);\n    const not = node.not ? ' NOT' : '';\n    let right: string;\n    if (node.values instanceof SelectQuery) {\n      right = `(\\n${node.values.accept(this)}\\n${this.getIndent()})`;\n    } else {\n      right = `(${node.values.map(set =>\n        set.length > 1 ? `(${set.map(v => v.accept(this)).join(', ')})` : set[0].accept(this)\n      ).join(', ')})`;\n    }\n    return `(${leftStr}${not} IN ${right})`;\n  }\n\n  visitConcat(node: Concat): string {\n    return `(${node.expressions.map(e => e.accept(this)).join(' || ')})`;\n  }\n\n  visitCaseExpression(node: CaseExpression): string {\n    const parts: string[] = [`${this.getIndent()}CASE`];\n    this.indent();\n    for (const c of node.cases) {\n      this.indent();\n      parts.push(`${this.getIndent()}WHEN ${c.when.accept(this)} THEN ${c.then.accept(this)}`);\n      this.dedent();\n    }\n    if (node.else) {\n      this.indent();\n      parts.push(`${this.getIndent()}ELSE ${node.else.accept(this)}`);\n      this.dedent();\n    }\n    parts.push(`${this.getIndent()}END`);\n    this.dedent();\n    return parts.join('\\n');\n  }\n\n  visitFunctionExpression(node: FunctionExpression): string {\n    const args = node.args.map(a => a.accept(this)).join(', ');\n    const distinctPrefix = node.distinct ? 'DISTINCT ' : '';\n    return `${node.name}(${distinctPrefix}${args})`;\n  }\n\n  visitParamExpression(_node: Param): string {\n    return '?';\n  }\n\n  visitStringLiteral(node: StringLiteral): string {\n    return `'${node.value.replace(/'/g, \"''\")}'`;\n  }\n\n  visitNumberLiteral(node: NumberLiteral): string {\n    return node.value.toString();\n  }\n\n  visitNullLiteral(_node: NullLiteral): string {\n    return 'NULL';\n  }\n\n  visitExistsExpression(node: ExistsExpression): string {\n    const subquerySql = node.subquery.accept(this);\n    return `EXISTS (\\n${subquerySql}\\n${this.getIndent()})`;\n  }\n}\n"]}
516
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"IndentedQueryRenderer.js","sourceRoot":"","sources":["../../src/renderer/IndentedQueryRenderer.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 IndentedQueryRenderer\n  implements QueryRenderer, SqlTreeNodeVisitor<string>\n{\n  protected fromLikeAndJoinAcceptor = new FromLikeAndJoinVisitorAcceptor<string>();\n  protected columnLikeAcceptor = new ColumnLikeVisitorAcceptor<string>();\n\n  private readonly spacesPerLevel: number;\n  private indentationLevel: number = -1;\n\n  public constructor(spacesPerLevel: number) {\n    if (!Number.isInteger(spacesPerLevel) || spacesPerLevel <= 0) {\n      throw new Error('spacesPerLevel must be a positive integer');\n    }\n    this.spacesPerLevel = spacesPerLevel;\n  }\n\n  public render(node: RenderableQuery): string {\n    return node.accept(this);\n  }\n\n  private getIndent(): string {\n    return ' '.repeat(this.indentationLevel * this.spacesPerLevel);\n  }\n\n  private indent(): void {\n    this.indentationLevel++;\n  }\n\n  private dedent(): void {\n    this.indentationLevel--;\n  }\n\n  visitInsertQuery(node: InsertQuery): string {\n    this.indent();\n    const parts: string[] = [];\n    parts.push(`${this.getIndent()}INSERT${node.isOrReplace() ? ' OR REPLACE' : ''}`);\n    parts.push(`${this.getIndent()}INTO ${quoteIdentifier(node['_tableName'])}`);\n    if (node['_columns'].length > 0) {\n      parts.push(`${this.getIndent()}(${node['_columns'].map(quoteIdentifier).join(', ')})`);\n    }\n    if (node['_fromSelect']) {\n      parts.push(node['_fromSelect'].accept(this));\n    } else {\n      parts.push(`${this.getIndent()}VALUES`);\n      parts.push(`${this.getIndent()}(${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(`${this.getIndent()}ON CONFLICT (${conflictCols}) DO NOTHING`);\n      } else if (node['_doUpdateSets'].length > 0) {\n        let onConflictLine = `${this.getIndent()}ON CONFLICT (${conflictCols})`;\n        if (node['_onConflictWhere']) {\n          onConflictLine += ` WHERE ${node['_onConflictWhere'].accept(this)}`;\n        }\n        parts.push(onConflictLine);\n        const setClauses = node['_doUpdateSets'].map(s =>\n          `${quoteIdentifier(s.column)} = ${s.value.accept(this)}`\n        ).join(', ');\n        parts.push(`${this.getIndent()}DO UPDATE SET ${setClauses}`);\n      }\n    }\n    if (node['_returning'].length > 0) {\n      parts.push(`${this.getIndent()}RETURNING ${node['_returning'].map(r => r.accept(this)).join(', ')}`);\n    }\n    this.dedent();\n    return parts.join('\\n');\n  }\n\n  visitDeleteQuery(node: DeleteQuery): string {\n    this.indent();\n    const parts: string[] = [];\n    parts.push(`${this.getIndent()}DELETE`);\n    parts.push(`${this.getIndent()}FROM ${quoteIdentifier(node['_tableName'])}`);\n    if (node['_where']) {\n      parts.push(`${this.getIndent()}WHERE ${node['_where'].accept(this)}`);\n    }\n    if (node['_returning'].length > 0) {\n      parts.push(`${this.getIndent()}RETURNING ${node['_returning'].map(r => r.accept(this)).join(', ')}`);\n    }\n    this.dedent();\n    return parts.join('\\n');\n  }\n\n  visitUpdateQuery(node: UpdateQuery): string {\n    this.indent();\n    const parts: string[] = [];\n    parts.push(`${this.getIndent()}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(`${this.getIndent()}SET ${setClauses}`);\n    }\n    if (node['_where']) {\n      parts.push(`${this.getIndent()}WHERE ${node['_where'].accept(this)}`);\n    }\n    if (node['_returning'].length > 0) {\n      parts.push(`${this.getIndent()}RETURNING ${node['_returning'].map(r => r.accept(this)).join(', ')}`);\n    }\n    this.dedent();\n    return parts.join('\\n');\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 unique = node.isUnique ? 'UNIQUE ' : '';\n    const ifNotExists = node.hasIfNotExists ? ' IF NOT EXISTS' : '';\n\n    let sql = `CREATE ${unique}INDEX${ifNotExists} ${quoteIdentifier(node.indexName)} ON ${quoteIdentifier(node.tableName)} (${node.columns.map(quoteIdentifier).join(', ')})`;\n\n    if (node.whereExpression) {\n      sql += ` WHERE ${node.whereExpression.accept(this)}`;\n    }\n\n    return sql;\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    this.indent();\n    const parts: string[] = [];\n    const ifNotExists = node.hasIfNotExists ? ' IF NOT EXISTS' : '';\n    parts.push(`${this.getIndent()}CREATE TABLE${ifNotExists} ${quoteIdentifier(node.tableName)} (`);\n\n    this.indent();\n    const definitions: string[] = [];\n\n    // Column definitions\n    for (const col of node.columns) {\n      definitions.push(`${this.getIndent()}${this.renderColumnDefinition(col)}`);\n    }\n\n    // Table constraints\n    for (const constraint of node.tableConstraints) {\n      definitions.push(`${this.getIndent()}${this.renderTableConstraint(constraint)}`);\n    }\n\n    parts.push(definitions.join(',\\n'));\n    this.dedent();\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\n    if (options.length > 0) {\n      parts.push(`${this.getIndent()}) ${options.join(', ')}`);\n    } else {\n      parts.push(`${this.getIndent()})`);\n    }\n\n    this.dedent();\n    return parts.join('\\n');\n  }\n\n  visitCreateVirtualTableQuery(node: CreateVirtualTableQuery): string {\n    this.indent();\n    const parts: string[] = [];\n    const ifNotExists = node.hasIfNotExists ? ' IF NOT EXISTS' : '';\n    parts.push(`${this.getIndent()}CREATE VIRTUAL TABLE${ifNotExists} ${quoteIdentifier(node.tableName)} USING ${node.module}(`);\n\n    this.indent();\n    const args: string[] = [];\n\n    // Add columns (FTS5 columns don't have types)\n    for (const col of node.columns) {\n      args.push(`${this.getIndent()}${quoteIdentifier(col)}`);\n    }\n\n    // Add FTS5 options\n    const opts = node.options;\n    if (opts.tokenize) {\n      args.push(`${this.getIndent()}tokenize = '${opts.tokenize}'`);\n    }\n    if (opts.content) {\n      args.push(`${this.getIndent()}content = '${opts.content}'`);\n    }\n    if (opts.contentRowid) {\n      args.push(`${this.getIndent()}content_rowid = '${opts.contentRowid}'`);\n    }\n    if (opts.prefix) {\n      args.push(`${this.getIndent()}prefix = '${opts.prefix}'`);\n    }\n\n    parts.push(args.join(',\\n'));\n    this.dedent();\n    parts.push(`${this.getIndent()})`);\n    this.dedent();\n\n    return parts.join('\\n');\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      this.indent();\n      parts.push('WITH');\n      parts.push(node['_with'].map(w => w.accept(this)).join(',\\n'));\n      this.dedent();\n    }\n    this.indent();\n    parts.push(`${this.getIndent()}SELECT${node.isDistinct() ? ' DISTINCT' : ''}`);\n    if (node['_columns'].length > 0) {\n      parts.push(node['_columns'].map(c => `${this.getIndent()}  ${this.columnLikeAcceptor.accept(this, c)}`).join(',\\n'));\n    } else {\n      parts.push(`${this.getIndent()}  *`);\n    }\n    if (node['_fromsAndJoins'].length > 0) {\n      let fromsAndJoinsText = '';\n      for (const fromOrJoin of node['_fromsAndJoins']) {\n        if (fromOrJoin instanceof Join) {\n          fromsAndJoinsText += `\\n${this.getIndent()}${fromOrJoin.accept(this)}`;\n        } else if (\n          fromOrJoin instanceof Alias ||\n          fromOrJoin instanceof From ||\n          fromOrJoin instanceof TableFrom ||\n          fromOrJoin instanceof SubqueryFrom ||\n          fromOrJoin instanceof JsonEachFrom\n        ) {\n          if (fromsAndJoinsText) {\n            fromsAndJoinsText += `,\\n${this.getIndent()}${fromOrJoin.accept(this)}`;\n          } else {\n            fromsAndJoinsText += `${this.getIndent()}FROM ${fromOrJoin.accept(this)}`;\n          }\n        }\n      }\n      parts.push(fromsAndJoinsText);\n    }\n    if (node['_where']) {\n      parts.push(`${this.getIndent()}WHERE ${node['_where'].accept(this)}`);\n    }\n    if (node['_groupBy'].length > 0) {\n      parts.push(`${this.getIndent()}GROUP BY ${node['_groupBy'].map(c => c.accept(this)).join(', ')}`);\n    }\n    if (node['_having']) {\n      parts.push(`${this.getIndent()}HAVING ${node['_having'].accept(this)}`);\n    }\n    if (node['_union'].length > 0) {\n      parts.push(node['_union'].map(u => `${this.getIndent()}UNION\\n${u.accept(this)}`).join('\\n'));\n    }\n    if (node['_intersect'].length > 0) {\n      parts.push(node['_intersect'].map(i => `${this.getIndent()}INTERSECT\\n${i.accept(this)}`).join('\\n'));\n    }\n    if (node['_except'].length > 0) {\n      parts.push(node['_except'].map(e => `${this.getIndent()}EXCEPT\\n${e.accept(this)}`).join('\\n'));\n    }\n    if (node['_orderBy'].length > 0) {\n      parts.push(`${this.getIndent()}ORDER BY ${node['_orderBy'].map(o => o.accept(this)).join(', ')}`);\n    }\n    if (node['_limit'] !== null && node['_limit'] !== undefined) {\n      parts.push(`${this.getIndent()}LIMIT ${node['_limit']}`);\n      if (node['_offset'] !== null && node['_offset'] !== undefined) {\n        parts.push(`${this.getIndent()}OFFSET ${node['_offset']}`);\n      }\n    }\n    this.dedent();\n    return parts.filter(p => p).join('\\n');\n  }\n\n  visitTableFrom(node: TableFrom): string {\n    return `${quoteIdentifier(node.tableName)}`;\n  }\n\n  visitSubqueryFrom(node: SubqueryFrom): string {\n    this.indent();\n    const result = `(\\n${node.subquery.accept(this)}\\n${this.getIndent()})`;\n    this.dedent();\n    return result;\n  }\n\n  visitJsonEachFrom(node: JsonEachFrom): string {\n    const expr = node.jsonExpression.accept(this);\n    const path = node.jsonPath ? `, ${node.jsonPath.accept(this)}` : '';\n    return `json_each(${expr}${path})`;\n  }\n\n  visitColumn(node: Column): string {\n    if (node.hasTableName()) {\n      return `${quoteIdentifier(node.tableName as string)}.${quoteIdentifier(node.columnName)}`;\n    } else {\n      return `${quoteIdentifier(node.columnName)}`;\n    }\n  }\n\n  visitAlias(node: Alias<From|AliasableExpression>): string {\n    const renderedAliasName = quoteIdentifier(node.alias as string);\n    if (node.referent instanceof From) {\n      return `${node.referent.accept(this)} ${renderedAliasName}`;\n    } else if (\n      node.referent instanceof SubqueryFrom ||\n      node.referent instanceof SelectQuery\n    ) {\n      this.indent();\n      const renderedSubquery = `${node.referent.accept(this)}\\n`;\n      const result = `(\\n${renderedSubquery}${this.getIndent()}) AS ${renderedAliasName}`;\n      this.dedent();\n      return result;\n    } else {\n      return `${node.referent.accept(this)} AS ${renderedAliasName}`;\n    }\n  }\n\n  visitJoinClause(node: Join): string {\n    return `${node.type} JOIN ${quoteIdentifier(node.tableName)} ${quoteIdentifier(node.alias)} ON ${node.on.accept(this)}`;\n  }\n\n  visitOrderBy(node: OrderBy): string {\n    return `${node.column.accept(this)} ${node.direction}`;\n  }\n\n  visitWithClause(node: With): string {\n    this.indent();\n    const result = `${this.getIndent()}${quoteIdentifier(node.name)} AS (\\n${node.query.accept(this)}\\n${this.getIndent()})`;\n    this.dedent();\n    return result;\n  }\n\n  visitBinaryExpression(node: BinaryExpression): string {\n    return `(${node.left.accept(this)} ${node.operator} ${node.right.accept(this)})`;\n  }\n\n  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 = `(\\n${node.values.accept(this)}\\n${this.getIndent()})`;\n    } else {\n      right = `(${node.values.map(set =>\n        set.length > 1 ? `(${set.map(v => v.accept(this)).join(', ')})` : set[0].accept(this)\n      ).join(', ')})`;\n    }\n    return `(${leftStr}${not} IN ${right})`;\n  }\n\n  visitConcat(node: Concat): string {\n    return `(${node.expressions.map(e => e.accept(this)).join(' || ')})`;\n  }\n\n  visitCaseExpression(node: CaseExpression): string {\n    const parts: string[] = [`${this.getIndent()}CASE`];\n    this.indent();\n    for (const c of node.cases) {\n      this.indent();\n      parts.push(`${this.getIndent()}WHEN ${c.when.accept(this)} THEN ${c.then.accept(this)}`);\n      this.dedent();\n    }\n    if (node.else) {\n      this.indent();\n      parts.push(`${this.getIndent()}ELSE ${node.else.accept(this)}`);\n      this.dedent();\n    }\n    parts.push(`${this.getIndent()}END`);\n    this.dedent();\n    return parts.join('\\n');\n  }\n\n  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    const subquerySql = node.subquery.accept(this);\n    return `EXISTS (\\n${subquerySql}\\n${this.getIndent()})`;\n  }\n}\n"]}
@@ -1,8 +1,18 @@
1
+ import { AlterTableQuery } from "../ast/AlterTableQuery";
2
+ import { CreateIndexQuery } from "../ast/CreateIndexQuery";
3
+ import { CreateTableQuery } from "../ast/CreateTableQuery";
4
+ import { CreateViewQuery } from "../ast/CreateViewQuery";
5
+ import { DeleteQuery } from "../ast/DeleteQuery";
6
+ import { DropIndexQuery } from "../ast/DropIndexQuery";
7
+ import { DropTableQuery } from "../ast/DropTableQuery";
8
+ import { DropViewQuery } from "../ast/DropViewQuery";
1
9
  import { InsertQuery } from "../ast/InsertQuery";
10
+ import { UpdateQuery } from "../ast/UpdateQuery";
2
11
  import { SelectQuery } from "../ast/SelectQuery";
3
12
  import { SqlTreeNodeVisitor } from "../visitor/SqlTreeNodeVisitor";
4
13
  export declare function quoteIdentifier(identifier: string): string;
14
+ export type RenderableQuery = SelectQuery | InsertQuery | UpdateQuery | DeleteQuery | CreateTableQuery | CreateIndexQuery | CreateViewQuery | AlterTableQuery | DropTableQuery | DropIndexQuery | DropViewQuery;
5
15
  export interface QueryRenderer extends SqlTreeNodeVisitor<string> {
6
- render(node: SelectQuery | InsertQuery): string;
16
+ render(node: RenderableQuery): string;
7
17
  }
8
18
  export declare function shouldQuoteIdentifier(identifier: string): boolean;
@@ -74,4 +74,4 @@ function shouldQuoteIdentifier(identifier) {
74
74
  // No quotes needed for simple, lowercase, non-reserved identifiers
75
75
  return false;
76
76
  }
77
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"QueryRenderer.js","sourceRoot":"","sources":["../../src/renderer/QueryRenderer.ts"],"names":[],"mappings":"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","sourcesContent":["import { InsertQuery } from \"../ast/InsertQuery\";\nimport { SelectQuery } from \"../ast/SelectQuery\";\nimport { SqlTreeNodeVisitor } from \"../visitor/SqlTreeNodeVisitor\";\n\n\n// Comprehensive list of SQLite reserved keywords (case-insensitive)\nconst RESERVED_KEYWORDS = new Set([\n  'ABORT', 'ACTION', 'ADD', 'AFTER', 'ALL', 'ALTER', 'ALWAYS', 'ANALYZE', 'AND',\n  'AS', 'ASC', 'ATTACH', 'AUTOINCREMENT', 'BEFORE', 'BEGIN', 'BETWEEN', 'BY',\n  'CASCADE', 'CASE', 'CAST', 'CHECK', 'COLLATE', 'COLUMN', 'COMMIT', 'CONFLICT',\n  'CONSTRAINT', 'CREATE', 'CROSS', 'CURRENT', 'CURRENT_DATE', 'CURRENT_TIME',\n  'CURRENT_TIMESTAMP', 'DATABASE', 'DEFAULT', 'DEFERRED', 'DEFERRABLE', 'DELETE',\n  'DESC', 'DETACH', 'DISTINCT', 'DO', 'DROP', 'EACH', 'ELSE', 'END', 'ESCAPE',\n  'EXCEPT', 'EXCLUDE', 'EXCLUSIVE', 'EXISTS', 'EXPLAIN', 'FAIL', 'FILTER', 'FIRST',\n  'FOLLOWING', 'FOR', 'FOREIGN', 'FROM', 'FULL', 'GENERATED', 'GLOB', 'GROUP',\n  'GROUPS', 'HAVING', 'IF', 'IGNORE', 'IMMEDIATE', 'IN', 'INDEX', 'INDEXED',\n  'INITIALLY', 'INNER', 'INSERT', 'INSTEAD', 'INTERSECT', 'INTO', 'IS', 'ISNULL',\n  'JOIN', 'KEY', 'LAST', 'LEFT', 'LIKE', 'LIMIT', 'MATCH', 'MATERIALIZED', 'NATURAL',\n  'NO', 'NOT', 'NOTHING', 'NOTNULL', 'NULL', 'NULLS', 'OF', 'OFFSET', 'ON', 'OR',\n  'ORDER', 'OTHERS', 'OUTER', 'OVER', 'PARTITION', 'PLAN', 'PRAGMA', 'PRECEDING',\n  'PRIMARY', 'QUERY', 'RAISE', 'RANGE', 'RECURSIVE', 'REFERENCES', 'REGEXP',\n  'REINDEX', 'RELEASE', 'RENAME', 'REPLACE', 'RESTRICT', 'RETURNING', 'RIGHT',\n  'ROLLBACK', 'ROW', 'ROWS', 'SAVEPOINT', 'SELECT', 'SET', 'TABLE', 'TEMP',\n  'TEMPORARY', 'THEN', 'TIES', 'TO', 'TRANSACTION', 'TRIGGER', 'UNBOUNDED',\n  'UNION', 'UNIQUE', 'UPDATE', 'USING', 'VACUUM', 'VALUES', 'VIEW', 'VIRTUAL',\n  'WHEN', 'WHERE', 'WINDOW', 'WITH', 'WITHOUT'\n]);\n\n// Utility function to quote identifiers, escaping inner quotes\nexport function quoteIdentifier(identifier: string): string {\n  if (identifier === '*') {\n    return identifier; // Do not quote '*'\n  }\n\n  // Handle database-qualified identifiers (e.g., \"database.table\")\n  if (identifier.includes('.')) {\n    const parts = identifier.split('.');\n    if (parts.length === 2) {\n      // Quote each part individually if needed (except for asterisk), then join with dot\n      const quotedParts = parts.map(part => {\n        if (part === '*') {\n          return part; // Don't quote asterisk\n        }\n        return shouldQuoteIdentifier(part) ? `\"${part.replace(/\"/g, '\"\"')}\"` : part;\n      });\n      return quotedParts.join('.');\n    }\n  }\n\n  if (shouldQuoteIdentifier(identifier)) {\n    // Escape double-quotes by doubling them (e.g., \" becomes \"\")\n    const escaped = identifier.replace(/\"/g, '\"\"');\n    return `\"${escaped}\"`;\n  }\n  return identifier; // Return unquoted if no quoting is needed\n}\n\nexport interface QueryRenderer extends SqlTreeNodeVisitor<string> {\n  render(node: SelectQuery | InsertQuery): string;\n}\n\nexport function shouldQuoteIdentifier(identifier: string): boolean {\n  // Check for empty or invalid input\n  if (!identifier || identifier.trim() === '') {\n    return true; // Empty or invalid identifiers should be quoted to avoid errors\n  }\n\n  // Check if the identifier is a reserved keyword (case-insensitive)\n  if (RESERVED_KEYWORDS.has(identifier.toUpperCase())) {\n      return true;\n  }\n\n  // Check if the identifier contains special characters or spaces\n  // Valid unquoted identifiers: letters, digits, underscores; must not start with a digit\n  const validIdentifierPattern = /^[a-zA-Z_][a-zA-Z0-9_]*$/;\n  if (!validIdentifierPattern.test(identifier)) {\n      return true;\n  }\n\n  // Check for case sensitivity (if identifier has uppercase letters)\n  // SQLite is case-insensitive by default, but quoting preserves case\n  const hasUpperCase = /[A-Z]/.test(identifier);\n  if (hasUpperCase) {\n      return true; // Quote if case sensitivity is desired\n  }\n\n  // No quotes needed for simple, lowercase, non-reserved identifiers\n  return false;\n}\n"]}
77
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"QueryRenderer.js","sourceRoot":"","sources":["../../src/renderer/QueryRenderer.ts"],"names":[],"mappings":"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","sourcesContent":["import { AlterTableQuery } from \"../ast/AlterTableQuery\";\nimport { CreateIndexQuery } from \"../ast/CreateIndexQuery\";\nimport { CreateTableQuery } from \"../ast/CreateTableQuery\";\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 { InsertQuery } from \"../ast/InsertQuery\";\nimport { UpdateQuery } from \"../ast/UpdateQuery\";\nimport { SelectQuery } from \"../ast/SelectQuery\";\nimport { SqlTreeNodeVisitor } from \"../visitor/SqlTreeNodeVisitor\";\n\n\n// Comprehensive list of SQLite reserved keywords (case-insensitive)\nconst RESERVED_KEYWORDS = new Set([\n  'ABORT', 'ACTION', 'ADD', 'AFTER', 'ALL', 'ALTER', 'ALWAYS', 'ANALYZE', 'AND',\n  'AS', 'ASC', 'ATTACH', 'AUTOINCREMENT', 'BEFORE', 'BEGIN', 'BETWEEN', 'BY',\n  'CASCADE', 'CASE', 'CAST', 'CHECK', 'COLLATE', 'COLUMN', 'COMMIT', 'CONFLICT',\n  'CONSTRAINT', 'CREATE', 'CROSS', 'CURRENT', 'CURRENT_DATE', 'CURRENT_TIME',\n  'CURRENT_TIMESTAMP', 'DATABASE', 'DEFAULT', 'DEFERRED', 'DEFERRABLE', 'DELETE',\n  'DESC', 'DETACH', 'DISTINCT', 'DO', 'DROP', 'EACH', 'ELSE', 'END', 'ESCAPE',\n  'EXCEPT', 'EXCLUDE', 'EXCLUSIVE', 'EXISTS', 'EXPLAIN', 'FAIL', 'FILTER', 'FIRST',\n  'FOLLOWING', 'FOR', 'FOREIGN', 'FROM', 'FULL', 'GENERATED', 'GLOB', 'GROUP',\n  'GROUPS', 'HAVING', 'IF', 'IGNORE', 'IMMEDIATE', 'IN', 'INDEX', 'INDEXED',\n  'INITIALLY', 'INNER', 'INSERT', 'INSTEAD', 'INTERSECT', 'INTO', 'IS', 'ISNULL',\n  'JOIN', 'KEY', 'LAST', 'LEFT', 'LIKE', 'LIMIT', 'MATCH', 'MATERIALIZED', 'NATURAL',\n  'NO', 'NOT', 'NOTHING', 'NOTNULL', 'NULL', 'NULLS', 'OF', 'OFFSET', 'ON', 'OR',\n  'ORDER', 'OTHERS', 'OUTER', 'OVER', 'PARTITION', 'PLAN', 'PRAGMA', 'PRECEDING',\n  'PRIMARY', 'QUERY', 'RAISE', 'RANGE', 'RECURSIVE', 'REFERENCES', 'REGEXP',\n  'REINDEX', 'RELEASE', 'RENAME', 'REPLACE', 'RESTRICT', 'RETURNING', 'RIGHT',\n  'ROLLBACK', 'ROW', 'ROWS', 'SAVEPOINT', 'SELECT', 'SET', 'TABLE', 'TEMP',\n  'TEMPORARY', 'THEN', 'TIES', 'TO', 'TRANSACTION', 'TRIGGER', 'UNBOUNDED',\n  'UNION', 'UNIQUE', 'UPDATE', 'USING', 'VACUUM', 'VALUES', 'VIEW', 'VIRTUAL',\n  'WHEN', 'WHERE', 'WINDOW', 'WITH', 'WITHOUT'\n]);\n\n// Utility function to quote identifiers, escaping inner quotes\nexport function quoteIdentifier(identifier: string): string {\n  if (identifier === '*') {\n    return identifier; // Do not quote '*'\n  }\n\n  // Handle database-qualified identifiers (e.g., \"database.table\")\n  if (identifier.includes('.')) {\n    const parts = identifier.split('.');\n    if (parts.length === 2) {\n      // Quote each part individually if needed (except for asterisk), then join with dot\n      const quotedParts = parts.map(part => {\n        if (part === '*') {\n          return part; // Don't quote asterisk\n        }\n        return shouldQuoteIdentifier(part) ? `\"${part.replace(/\"/g, '\"\"')}\"` : part;\n      });\n      return quotedParts.join('.');\n    }\n  }\n\n  if (shouldQuoteIdentifier(identifier)) {\n    // Escape double-quotes by doubling them (e.g., \" becomes \"\")\n    const escaped = identifier.replace(/\"/g, '\"\"');\n    return `\"${escaped}\"`;\n  }\n  return identifier; // Return unquoted if no quoting is needed\n}\n\nexport type RenderableQuery =\n  | SelectQuery\n  | InsertQuery\n  | UpdateQuery\n  | DeleteQuery\n  | CreateTableQuery\n  | CreateIndexQuery\n  | CreateViewQuery\n  | AlterTableQuery\n  | DropTableQuery\n  | DropIndexQuery\n  | DropViewQuery;\n\nexport interface QueryRenderer extends SqlTreeNodeVisitor<string> {\n  render(node: RenderableQuery): string;\n}\n\nexport function shouldQuoteIdentifier(identifier: string): boolean {\n  // Check for empty or invalid input\n  if (!identifier || identifier.trim() === '') {\n    return true; // Empty or invalid identifiers should be quoted to avoid errors\n  }\n\n  // Check if the identifier is a reserved keyword (case-insensitive)\n  if (RESERVED_KEYWORDS.has(identifier.toUpperCase())) {\n      return true;\n  }\n\n  // Check if the identifier contains special characters or spaces\n  // Valid unquoted identifiers: letters, digits, underscores; must not start with a digit\n  const validIdentifierPattern = /^[a-zA-Z_][a-zA-Z0-9_]*$/;\n  if (!validIdentifierPattern.test(identifier)) {\n      return true;\n  }\n\n  // Check for case sensitivity (if identifier has uppercase letters)\n  // SQLite is case-insensitive by default, but quoting preserves case\n  const hasUpperCase = /[A-Z]/.test(identifier);\n  if (hasUpperCase) {\n      return true; // Quote if case sensitivity is desired\n  }\n\n  // No quotes needed for simple, lowercase, non-reserved identifiers\n  return false;\n}\n"]}