@uwdata/mosaic-sql 0.19.0 → 0.20.1

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 (210) hide show
  1. package/dist/src/ast/aggregate.d.ts +0 -4
  2. package/dist/src/ast/aggregate.d.ts.map +1 -1
  3. package/dist/src/ast/aggregate.js +0 -15
  4. package/dist/src/ast/aggregate.js.map +1 -1
  5. package/dist/src/ast/between-op.d.ts +0 -8
  6. package/dist/src/ast/between-op.d.ts.map +1 -1
  7. package/dist/src/ast/between-op.js +0 -12
  8. package/dist/src/ast/between-op.js.map +1 -1
  9. package/dist/src/ast/binary-op.d.ts +0 -4
  10. package/dist/src/ast/binary-op.d.ts.map +1 -1
  11. package/dist/src/ast/binary-op.js +0 -6
  12. package/dist/src/ast/binary-op.js.map +1 -1
  13. package/dist/src/ast/case.d.ts +0 -8
  14. package/dist/src/ast/case.d.ts.map +1 -1
  15. package/dist/src/ast/case.js +0 -16
  16. package/dist/src/ast/case.js.map +1 -1
  17. package/dist/src/ast/cast.d.ts +0 -4
  18. package/dist/src/ast/cast.d.ts.map +1 -1
  19. package/dist/src/ast/cast.js +0 -7
  20. package/dist/src/ast/cast.js.map +1 -1
  21. package/dist/src/ast/collate.d.ts +0 -4
  22. package/dist/src/ast/collate.d.ts.map +1 -1
  23. package/dist/src/ast/collate.js +0 -6
  24. package/dist/src/ast/collate.js.map +1 -1
  25. package/dist/src/ast/column-ref.d.ts +0 -4
  26. package/dist/src/ast/column-ref.d.ts.map +1 -1
  27. package/dist/src/ast/column-ref.js +0 -10
  28. package/dist/src/ast/column-ref.js.map +1 -1
  29. package/dist/src/ast/fragment.d.ts +0 -4
  30. package/dist/src/ast/fragment.d.ts.map +1 -1
  31. package/dist/src/ast/fragment.js +0 -6
  32. package/dist/src/ast/fragment.js.map +1 -1
  33. package/dist/src/ast/from.d.ts +10 -3
  34. package/dist/src/ast/from.d.ts.map +1 -1
  35. package/dist/src/ast/from.js +11 -12
  36. package/dist/src/ast/from.js.map +1 -1
  37. package/dist/src/ast/function.d.ts +0 -4
  38. package/dist/src/ast/function.d.ts.map +1 -1
  39. package/dist/src/ast/function.js +0 -7
  40. package/dist/src/ast/function.js.map +1 -1
  41. package/dist/src/ast/in-op.d.ts +0 -4
  42. package/dist/src/ast/in-op.d.ts.map +1 -1
  43. package/dist/src/ast/in-op.js +0 -6
  44. package/dist/src/ast/in-op.js.map +1 -1
  45. package/dist/src/ast/interval.d.ts +0 -4
  46. package/dist/src/ast/interval.d.ts.map +1 -1
  47. package/dist/src/ast/interval.js +0 -6
  48. package/dist/src/ast/interval.js.map +1 -1
  49. package/dist/src/ast/join.d.ts +45 -0
  50. package/dist/src/ast/join.d.ts.map +1 -0
  51. package/dist/src/ast/join.js +47 -0
  52. package/dist/src/ast/join.js.map +1 -0
  53. package/dist/src/ast/list.d.ts +0 -4
  54. package/dist/src/ast/list.d.ts.map +1 -1
  55. package/dist/src/ast/list.js +0 -6
  56. package/dist/src/ast/list.js.map +1 -1
  57. package/dist/src/ast/literal.d.ts +0 -4
  58. package/dist/src/ast/literal.d.ts.map +1 -1
  59. package/dist/src/ast/literal.js +0 -6
  60. package/dist/src/ast/literal.js.map +1 -1
  61. package/dist/src/ast/logical-op.d.ts +0 -4
  62. package/dist/src/ast/logical-op.d.ts.map +1 -1
  63. package/dist/src/ast/logical-op.js +0 -9
  64. package/dist/src/ast/logical-op.js.map +1 -1
  65. package/dist/src/ast/node.d.ts +13 -0
  66. package/dist/src/ast/node.d.ts.map +1 -1
  67. package/dist/src/ast/node.js +25 -3
  68. package/dist/src/ast/node.js.map +1 -1
  69. package/dist/src/ast/order-by.d.ts +0 -4
  70. package/dist/src/ast/order-by.d.ts.map +1 -1
  71. package/dist/src/ast/order-by.js +0 -13
  72. package/dist/src/ast/order-by.js.map +1 -1
  73. package/dist/src/ast/param.d.ts +0 -4
  74. package/dist/src/ast/param.d.ts.map +1 -1
  75. package/dist/src/ast/param.js +0 -7
  76. package/dist/src/ast/param.js.map +1 -1
  77. package/dist/src/ast/query.d.ts +2 -14
  78. package/dist/src/ast/query.d.ts.map +1 -1
  79. package/dist/src/ast/query.js +14 -91
  80. package/dist/src/ast/query.js.map +1 -1
  81. package/dist/src/ast/sample.d.ts +0 -4
  82. package/dist/src/ast/sample.d.ts.map +1 -1
  83. package/dist/src/ast/sample.js +0 -9
  84. package/dist/src/ast/sample.js.map +1 -1
  85. package/dist/src/ast/select.d.ts +0 -4
  86. package/dist/src/ast/select.d.ts.map +1 -1
  87. package/dist/src/ast/select.js +0 -16
  88. package/dist/src/ast/select.js.map +1 -1
  89. package/dist/src/ast/subquery.d.ts +0 -4
  90. package/dist/src/ast/subquery.d.ts.map +1 -1
  91. package/dist/src/ast/subquery.js +0 -6
  92. package/dist/src/ast/subquery.js.map +1 -1
  93. package/dist/src/ast/table-ref.d.ts +0 -4
  94. package/dist/src/ast/table-ref.d.ts.map +1 -1
  95. package/dist/src/ast/table-ref.js +0 -7
  96. package/dist/src/ast/table-ref.js.map +1 -1
  97. package/dist/src/ast/unary-op.d.ts +0 -8
  98. package/dist/src/ast/unary-op.d.ts.map +1 -1
  99. package/dist/src/ast/unary-op.js +0 -12
  100. package/dist/src/ast/unary-op.js.map +1 -1
  101. package/dist/src/ast/unnest.d.ts +0 -4
  102. package/dist/src/ast/unnest.d.ts.map +1 -1
  103. package/dist/src/ast/unnest.js +0 -8
  104. package/dist/src/ast/unnest.js.map +1 -1
  105. package/dist/src/ast/verbatim.d.ts +0 -4
  106. package/dist/src/ast/verbatim.d.ts.map +1 -1
  107. package/dist/src/ast/verbatim.js +0 -6
  108. package/dist/src/ast/verbatim.js.map +1 -1
  109. package/dist/src/ast/window-frame.d.ts +0 -8
  110. package/dist/src/ast/window-frame.d.ts.map +1 -1
  111. package/dist/src/ast/window-frame.js +1 -29
  112. package/dist/src/ast/window-frame.js.map +1 -1
  113. package/dist/src/ast/window.d.ts +0 -16
  114. package/dist/src/ast/window.d.ts.map +1 -1
  115. package/dist/src/ast/window.js +0 -39
  116. package/dist/src/ast/window.js.map +1 -1
  117. package/dist/src/ast/with.d.ts +0 -4
  118. package/dist/src/ast/with.d.ts.map +1 -1
  119. package/dist/src/ast/with.js +0 -10
  120. package/dist/src/ast/with.js.map +1 -1
  121. package/dist/src/constants.d.ts +2 -0
  122. package/dist/src/constants.d.ts.map +1 -1
  123. package/dist/src/constants.js +2 -0
  124. package/dist/src/constants.js.map +1 -1
  125. package/dist/src/functions/from.d.ts +11 -0
  126. package/dist/src/functions/from.d.ts.map +1 -0
  127. package/dist/src/functions/from.js +12 -0
  128. package/dist/src/functions/from.js.map +1 -0
  129. package/dist/src/functions/join.d.ts +49 -0
  130. package/dist/src/functions/join.d.ts.map +1 -0
  131. package/dist/src/functions/join.js +50 -0
  132. package/dist/src/functions/join.js.map +1 -0
  133. package/dist/src/index.d.ts +7 -1
  134. package/dist/src/index.d.ts.map +1 -1
  135. package/dist/src/index.js +8 -1
  136. package/dist/src/index.js.map +1 -1
  137. package/dist/src/init.d.ts +2 -0
  138. package/dist/src/init.d.ts.map +1 -0
  139. package/dist/src/init.js +5 -0
  140. package/dist/src/init.js.map +1 -0
  141. package/dist/src/transforms/bin-histogram.d.ts.map +1 -1
  142. package/dist/src/transforms/bin-histogram.js +7 -2
  143. package/dist/src/transforms/bin-histogram.js.map +1 -1
  144. package/dist/src/transforms/filter-query.d.ts.map +1 -1
  145. package/dist/src/transforms/filter-query.js +2 -0
  146. package/dist/src/transforms/filter-query.js.map +1 -1
  147. package/dist/src/transforms/util/time-interval.d.ts.map +1 -1
  148. package/dist/src/transforms/util/time-interval.js +3 -0
  149. package/dist/src/transforms/util/time-interval.js.map +1 -1
  150. package/dist/src/visit/codegen/duckdb.d.ts +49 -0
  151. package/dist/src/visit/codegen/duckdb.d.ts.map +1 -0
  152. package/dist/src/visit/codegen/duckdb.js +332 -0
  153. package/dist/src/visit/codegen/duckdb.js.map +1 -0
  154. package/dist/src/visit/codegen/sql.d.ts +60 -0
  155. package/dist/src/visit/codegen/sql.d.ts.map +1 -0
  156. package/dist/src/visit/codegen/sql.js +85 -0
  157. package/dist/src/visit/codegen/sql.js.map +1 -0
  158. package/dist/src/visit/duckdb-visitor.d.ts +50 -0
  159. package/dist/src/visit/duckdb-visitor.d.ts.map +1 -0
  160. package/dist/src/visit/duckdb-visitor.js +350 -0
  161. package/dist/src/visit/duckdb-visitor.js.map +1 -0
  162. package/dist/src/visit/recurse.d.ts.map +1 -1
  163. package/dist/src/visit/recurse.js +2 -1
  164. package/dist/src/visit/recurse.js.map +1 -1
  165. package/dist/src/visit/to-string-visitor.d.ts +60 -0
  166. package/dist/src/visit/to-string-visitor.d.ts.map +1 -0
  167. package/dist/src/visit/to-string-visitor.js +80 -0
  168. package/dist/src/visit/to-string-visitor.js.map +1 -0
  169. package/package.json +2 -2
  170. package/src/ast/aggregate.ts +0 -16
  171. package/src/ast/between-op.ts +0 -14
  172. package/src/ast/binary-op.ts +0 -7
  173. package/src/ast/case.ts +0 -18
  174. package/src/ast/cast.ts +0 -8
  175. package/src/ast/collate.ts +0 -7
  176. package/src/ast/column-ref.ts +0 -11
  177. package/src/ast/fragment.ts +0 -7
  178. package/src/ast/from.ts +12 -12
  179. package/src/ast/function.ts +0 -8
  180. package/src/ast/in-op.ts +0 -7
  181. package/src/ast/interval.ts +0 -7
  182. package/src/ast/join.ts +66 -0
  183. package/src/ast/list.ts +0 -7
  184. package/src/ast/literal.ts +0 -7
  185. package/src/ast/logical-op.ts +0 -10
  186. package/src/ast/node.ts +30 -3
  187. package/src/ast/order-by.ts +0 -14
  188. package/src/ast/param.ts +0 -8
  189. package/src/ast/query.ts +14 -102
  190. package/src/ast/sample.ts +0 -10
  191. package/src/ast/select.ts +0 -18
  192. package/src/ast/subquery.ts +0 -7
  193. package/src/ast/table-ref.ts +0 -8
  194. package/src/ast/unary-op.ts +0 -14
  195. package/src/ast/unnest.ts +0 -9
  196. package/src/ast/verbatim.ts +0 -7
  197. package/src/ast/window-frame.ts +1 -32
  198. package/src/ast/window.ts +0 -43
  199. package/src/ast/with.ts +0 -11
  200. package/src/constants.ts +2 -0
  201. package/src/functions/from.ts +18 -0
  202. package/src/functions/join.ts +101 -0
  203. package/src/index.ts +9 -1
  204. package/src/init.ts +5 -0
  205. package/src/transforms/bin-histogram.ts +8 -2
  206. package/src/transforms/filter-query.ts +2 -0
  207. package/src/transforms/util/time-interval.ts +4 -0
  208. package/src/visit/codegen/duckdb.ts +444 -0
  209. package/src/visit/codegen/sql.ts +213 -0
  210. package/src/visit/recurse.ts +2 -0
@@ -0,0 +1,332 @@
1
+ import { ColumnRefNode, isNode, isQuery, isTableRef } from '../../index.js';
2
+ import { quoteIdentifier } from '../../util/string.js';
3
+ import { literalToSQL } from '../../ast/literal.js';
4
+ import { SQLCodeGenerator } from './sql.js';
5
+ import { CURRENT_ROW, FOLLOWING, PRECEDING, UNBOUNDED } from '../../ast/window-frame.js';
6
+ import { WINDOW_EXTENT_EXPR } from '../../constants.js';
7
+ /**
8
+ * DuckDB SQL dialect visitor for converting AST nodes to DuckDB-compatible SQL.
9
+ */
10
+ export class DuckDBCodeGenerator extends SQLCodeGenerator {
11
+ visitAggregate(node) {
12
+ const { name, args, isDistinct, filter, order } = node;
13
+ const arg = [
14
+ isDistinct ? 'DISTINCT' : '',
15
+ args?.length ? this.mapToString(args).join(', ')
16
+ : name.toLowerCase() === 'count' ? '*'
17
+ : '',
18
+ order.length ? `ORDER BY ${this.mapToString(order).join(', ')}` : ''
19
+ ].filter(x => x).join(' ');
20
+ const filt = filter ? ` FILTER (WHERE ${this.toString(filter)})` : '';
21
+ return `${name}(${arg})${filt}`;
22
+ }
23
+ visitBetween(node) {
24
+ return betweenToString(this, node, 'BETWEEN');
25
+ }
26
+ visitBinary(node) {
27
+ const { left, right, op } = node;
28
+ return `(${this.toString(left)} ${op} ${this.toString(right)})`;
29
+ }
30
+ visitCase(node) {
31
+ const { expr, _when, _else } = node;
32
+ return 'CASE '
33
+ + (expr ? `${this.toString(expr)} ` : '')
34
+ + this.mapToString(_when).join(' ')
35
+ + (_else ? ` ELSE ${this.toString(_else)}` : '')
36
+ + ' END';
37
+ }
38
+ visitCast(node) {
39
+ const { expr, cast } = node;
40
+ return `(${this.toString(expr)})::${cast}`;
41
+ }
42
+ visitCollate(node) {
43
+ const { expr, collation } = node;
44
+ return `${this.toString(expr)} COLLATE ${collation}`;
45
+ }
46
+ visitColumnParam(node) {
47
+ return this.visitColumnRef(node);
48
+ }
49
+ visitColumnRef(node) {
50
+ const { column, table } = node;
51
+ const tref = table ? `${this.toString(table)}.` : '';
52
+ const id = column === '*' ? '*' : quoteIdentifier(column);
53
+ return `${tref}${id}`;
54
+ }
55
+ visitDescribeQuery(node) {
56
+ const { query } = node;
57
+ return `DESC ${this.toString(query)}`;
58
+ }
59
+ visitExpression(node) {
60
+ // This method might not be used in practice, but needs to exist for the interface
61
+ // If we reach here, it might be an error or a generic fallback
62
+ throw new Error(`Unexpected EXPRESSION node type. Node: ${JSON.stringify(node)}`);
63
+ }
64
+ visitFragment(node) {
65
+ const { spans } = node;
66
+ return spans.map((span) => {
67
+ return typeof span === 'string' ? span : this.toString(span);
68
+ }).join('');
69
+ }
70
+ visitFromClause(node) {
71
+ const { expr, alias, sample } = node;
72
+ const ref = isQuery(expr) ? `(${this.toString(expr)})` : `${this.toString(expr)}`;
73
+ const from = alias && !(isTableRef(expr) && expr.table?.join('.') === alias)
74
+ ? `${ref} AS ${quoteIdentifier(alias)}`
75
+ : `${ref}`;
76
+ return `${from}${sample ? ` TABLESAMPLE ${this.toString(sample)}` : ''}`;
77
+ }
78
+ visitFunction(node) {
79
+ const { name, args } = node;
80
+ return `${name}(${this.mapToString(args).join(', ')})`;
81
+ }
82
+ visitIn(node) {
83
+ const { expr, values } = node;
84
+ return `(${this.toString(expr)} IN (${this.mapToString(values).join(', ')}))`;
85
+ }
86
+ visitInterval(node) {
87
+ const { steps, name } = node;
88
+ return `INTERVAL ${steps} ${name}`;
89
+ }
90
+ visitJoinClause(node) {
91
+ const { left, right, joinVariant, joinType, condition, using, sample } = node;
92
+ const variant = joinVariant === 'REGULAR' ? '' : `${joinVariant} `;
93
+ let type = '';
94
+ let cond = '';
95
+ if (joinVariant !== 'CROSS') {
96
+ type = joinType !== 'INNER' ? `${joinType} ` : '';
97
+ cond = condition ? ` ON ${this.toString(condition)}`
98
+ : using ? ` USING (${this.mapToString(using).join(', ')})`
99
+ : '';
100
+ }
101
+ const samp = sample ? ` USING SAMPLE ${this.toString(sample)}` : '';
102
+ return `${this.toString(left)} ${variant}${type}JOIN ${this.toString(right)}${cond}${samp}`;
103
+ }
104
+ visitList(node) {
105
+ const { values } = node;
106
+ return `[${this.mapToString(values).join(', ')}]`;
107
+ }
108
+ visitLiteral(node) {
109
+ const { value } = node;
110
+ return literalToSQL(value);
111
+ }
112
+ visitLogicalOperator(node) {
113
+ const { clauses, op } = node;
114
+ const c = this.mapToString(clauses);
115
+ return c.length === 0 ? ''
116
+ : c.length === 1 ? `${c[0]}`
117
+ : `(${c.join(` ${op} `)})`;
118
+ }
119
+ visitNotBetween(node) {
120
+ return betweenToString(this, node, 'NOT BETWEEN');
121
+ }
122
+ visitOrderBy(node) {
123
+ const { expr, desc, nullsFirst } = node;
124
+ const dir = desc ? ' DESC'
125
+ : desc === false ? ' ASC'
126
+ : '';
127
+ const nf = nullsFirst ? ' NULLS FIRST'
128
+ : nullsFirst === false ? ' NULLS LAST'
129
+ : '';
130
+ return `${this.toString(expr)}${dir}${nf}`;
131
+ }
132
+ visitParam(node) {
133
+ const { param } = node;
134
+ // Get the current value from the parameter and format it as a literal
135
+ return literalToSQL(param.value);
136
+ }
137
+ visitSampleClause(node) {
138
+ const { size, perc, method, seed } = node;
139
+ const m = method ? `${method} ` : '';
140
+ const s = seed != null ? ` REPEATABLE (${seed})` : '';
141
+ return `${m}(${size}${perc ? '%' : ' ROWS'})${s}`;
142
+ }
143
+ visitScalarSubquery(node) {
144
+ return `(${this.toString(node.subquery)})`;
145
+ }
146
+ visitSelectClause(node) {
147
+ const { expr, alias } = node;
148
+ return !alias || isColumnRefFor(expr, alias)
149
+ ? this.toString(expr)
150
+ : `${this.toString(expr)} AS ${quoteIdentifier(alias)}`;
151
+ }
152
+ visitSelectQuery(node) {
153
+ const { _with, _select, _distinct, _from, _sample, _where, _groupby, _having, _window, _qualify, _orderby, _limitPerc, _limit, _offset } = node;
154
+ const sql = [];
155
+ // WITH
156
+ if (_with.length) {
157
+ sql.push(`WITH ${this.mapToString(_with).join(', ')}`);
158
+ }
159
+ // SELECT
160
+ sql.push(`SELECT${_distinct ? ' DISTINCT' : ''} ${this.mapToString(_select).join(', ')}`);
161
+ // FROM
162
+ if (_from.length) {
163
+ sql.push(`FROM ${this.mapToString(_from).join(', ')}`);
164
+ }
165
+ // SAMPLE
166
+ if (_sample) {
167
+ sql.push(`USING SAMPLE ${this.toString(_sample)}`);
168
+ }
169
+ // WHERE
170
+ if (_where.length) {
171
+ const clauses = this.mapToString(_where).filter(x => x).join(' AND ');
172
+ if (clauses)
173
+ sql.push(`WHERE ${clauses}`);
174
+ }
175
+ // GROUP BY
176
+ if (_groupby.length) {
177
+ sql.push(`GROUP BY ${this.mapToString(_groupby).join(', ')}`);
178
+ }
179
+ // HAVING
180
+ if (_having.length) {
181
+ const clauses = this.mapToString(_having).filter(x => x).join(' AND ');
182
+ if (clauses)
183
+ sql.push(`HAVING ${clauses}`);
184
+ }
185
+ // WINDOW
186
+ if (_window.length) {
187
+ sql.push(`WINDOW ${this.mapToString(_window).join(', ')}`);
188
+ }
189
+ // QUALIFY
190
+ if (_qualify.length) {
191
+ const clauses = this.mapToString(_qualify).filter(x => x).join(' AND ');
192
+ if (clauses)
193
+ sql.push(`QUALIFY ${clauses}`);
194
+ }
195
+ // ORDER BY
196
+ if (_orderby.length) {
197
+ sql.push(`ORDER BY ${this.mapToString(_orderby).join(', ')}`);
198
+ }
199
+ // LIMIT
200
+ if (_limit) {
201
+ sql.push(`LIMIT ${this.toString(_limit)}${_limitPerc ? '%' : ''}`);
202
+ }
203
+ // OFFSET
204
+ if (_offset != null) {
205
+ sql.push(`OFFSET ${this.toString(_offset)}`);
206
+ }
207
+ return sql.join(' ');
208
+ }
209
+ visitSetOperation(node) {
210
+ const { op, queries, _with, _orderby, _limitPerc, _limit, _offset } = node;
211
+ const sql = [];
212
+ // WITH
213
+ if (_with.length)
214
+ sql.push(`WITH ${this.mapToString(_with).join(', ')}`);
215
+ // SUBQUERIES
216
+ sql.push(queries.join(` ${op} `));
217
+ // ORDER BY
218
+ if (_orderby.length)
219
+ sql.push(`ORDER BY ${this.mapToString(_orderby).join(', ')}`);
220
+ // LIMIT
221
+ if (_limit)
222
+ sql.push(`LIMIT ${this.toString(_limit)}${_limitPerc ? '%' : ''}`);
223
+ // OFFSET
224
+ if (_offset)
225
+ sql.push(`OFFSET ${this.toString(_offset)}`);
226
+ return sql.join(' ');
227
+ }
228
+ visitTableRef(node) {
229
+ const { table } = node;
230
+ return table.map((t) => quoteIdentifier(t)).join('.');
231
+ }
232
+ visitUnary(node) {
233
+ const { expr, op } = node;
234
+ return `(${op} ${this.toString(expr)})`;
235
+ }
236
+ visitUnaryPostfix(node) {
237
+ const { expr, op } = node;
238
+ return `(${this.toString(expr)} ${op})`;
239
+ }
240
+ visitUnnest(node) {
241
+ const { expr, recursive, maxDepth } = node;
242
+ const args = [this.toString(expr)];
243
+ if (recursive) {
244
+ args.push('recursive := true');
245
+ }
246
+ if (maxDepth != null && maxDepth > 0) {
247
+ args.push(`max_depth := ${maxDepth}`);
248
+ }
249
+ return `UNNEST(${args.join(', ')})`;
250
+ }
251
+ visitVerbatim(node) {
252
+ const { value } = node;
253
+ return value;
254
+ }
255
+ visitWhen(node) {
256
+ const { when, then } = node;
257
+ return `WHEN ${this.toString(when)} THEN ${this.toString(then)}`;
258
+ }
259
+ visitWindow(node) {
260
+ const { func, def } = node;
261
+ return `${this.toString(func)} OVER ${this.toString(def)}`;
262
+ }
263
+ visitWindowClause(node) {
264
+ const { name, def } = node;
265
+ return `${quoteIdentifier(name)} AS ${this.toString(def)}`;
266
+ }
267
+ visitWindowDef(node) {
268
+ const { name, partition, order, framedef } = node;
269
+ const base = name && quoteIdentifier(name);
270
+ const def = [
271
+ base,
272
+ partition?.length && `PARTITION BY ${this.mapToString(partition).join(', ')}`,
273
+ order?.length && `ORDER BY ${this.mapToString(order).join(', ')}`,
274
+ framedef && this.toString(framedef)
275
+ ].filter(x => x);
276
+ return base && def.length < 2 ? base : `(${def.join(' ')})`;
277
+ }
278
+ visitWindowExtentExpr(node) {
279
+ const { scope, expr } = node;
280
+ return scope === CURRENT_ROW
281
+ ? scope
282
+ : `${isNode(expr) ? this.toString(expr) : (expr ?? UNBOUNDED)} ${scope}`;
283
+ }
284
+ visitWindowFrame(node) {
285
+ const { frameType, exclude, extent } = node;
286
+ const [prev, next] = isNode(extent)
287
+ ? extent.value
288
+ : extent;
289
+ const a = formatFrameExpr(this, prev, PRECEDING);
290
+ const b = formatFrameExpr(this, next, FOLLOWING);
291
+ return `${frameType} BETWEEN ${a} AND ${b}${exclude ? ` ${exclude}` : ''}`;
292
+ }
293
+ visitWindowFunction(node) {
294
+ const { name, args, ignoreNulls, order } = node;
295
+ const arg = [
296
+ this.mapToString(args).join(', '),
297
+ order.length ? `ORDER BY ${this.mapToString(order).join(', ')}` : '',
298
+ ignoreNulls ? 'IGNORE NULLS' : ''
299
+ ].filter(x => x).join(' ');
300
+ return `${name}(${arg})`;
301
+ }
302
+ visitWithClause(node) {
303
+ const { name, query, materialized } = node;
304
+ const mat = materialized === true ? 'MATERIALIZED '
305
+ : materialized === false ? 'NOT MATERIALIZED '
306
+ : '';
307
+ return `${quoteIdentifier(name)} AS ${mat}(${this.toString(query)})`;
308
+ }
309
+ }
310
+ function isColumnRefFor(expr, name) {
311
+ return expr instanceof ColumnRefNode
312
+ && expr.table == null
313
+ && expr.column === name;
314
+ }
315
+ function betweenToString(visitor, node, op) {
316
+ const { extent, expr } = node;
317
+ if (!extent)
318
+ return '';
319
+ const [a, b] = visitor.mapToString(extent);
320
+ return `(${visitor.toString(expr)} ${op} ${a} AND ${b})`;
321
+ }
322
+ function formatFrameExpr(visitor, value, scope) {
323
+ const x = isNode(value) ? visitor.toString(value) : value;
324
+ return isNode(value) && value.type === WINDOW_EXTENT_EXPR ? x
325
+ : x != null && typeof x !== 'number' ? `${x} ${scope}`
326
+ : x === 0 ? CURRENT_ROW
327
+ : !(x && Number.isFinite(x)) ? `${UNBOUNDED} ${scope}`
328
+ : `${Math.abs(x)} ${scope}`;
329
+ }
330
+ // Create a default DuckDB visitor instance for convenience
331
+ export const duckDBCodeGenerator = new DuckDBCodeGenerator();
332
+ //# sourceMappingURL=duckdb.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"duckdb.js","sourceRoot":"","sources":["../../../../src/visit/codegen/duckdb.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,60 @@
1
+ import type { SQLNode, ExprNode, AggregateNode, BetweenOpNode, NotBetweenOpNode, BinaryOpNode, CaseNode, WhenNode, CastNode, CollateNode, ColumnParamNode, ColumnRefNode, FragmentNode, FromClauseNode, FunctionNode, InOpNode, IntervalNode, JoinNode, ListNode, LiteralNode, LogicalOpNode, OrderByNode, ParamNode, DescribeQuery, SelectQuery, SetOperation, SampleClauseNode, SelectClauseNode, ScalarSubqueryNode, TableRefNode, UnaryOpNode, UnaryPostfixOpNode, UnnestNode, VerbatimNode, WindowNode, WindowClauseNode, WindowDefNode, WindowFunctionNode, WindowFrameNode, WindowFrameExprNode, WithClauseNode } from '../../index.js';
2
+ /**
3
+ * Abstract base class for SQL code generation visitors.
4
+ */
5
+ export declare abstract class SQLCodeGenerator {
6
+ /**
7
+ * Convert a SQL AST node to a string using this visitor.
8
+ * @param node The SQL AST node to convert.
9
+ * @returns The SQL string representation.
10
+ */
11
+ toString(node: SQLNode): string;
12
+ protected getVisitMethod(nodeType: string): ((node: AggregateNode) => string) | ((node: BetweenOpNode) => string) | ((node: BinaryOpNode) => string) | ((node: CaseNode) => string) | ((node: CastNode) => string) | ((node: CollateNode) => string) | ((node: ColumnParamNode) => string) | ((node: DescribeQuery) => string);
13
+ /**
14
+ * Helper method to convert child nodes to strings.
15
+ * @param nodes Array of child nodes.
16
+ * @returns Array of SQL strings.
17
+ */
18
+ mapToString(nodes: SQLNode[]): string[];
19
+ abstract visitAggregate(node: AggregateNode): string;
20
+ abstract visitBetween(node: BetweenOpNode): string;
21
+ abstract visitBinary(node: BinaryOpNode): string;
22
+ abstract visitCase(node: CaseNode): string;
23
+ abstract visitCast(node: CastNode): string;
24
+ abstract visitCollate(node: CollateNode): string;
25
+ abstract visitColumnParam(node: ColumnParamNode): string;
26
+ abstract visitColumnRef(node: ColumnRefNode): string;
27
+ abstract visitDescribeQuery(node: DescribeQuery): string;
28
+ abstract visitExpression(node: ExprNode): string;
29
+ abstract visitFragment(node: FragmentNode): string;
30
+ abstract visitFromClause(node: FromClauseNode): string;
31
+ abstract visitFunction(node: FunctionNode): string;
32
+ abstract visitIn(node: InOpNode): string;
33
+ abstract visitInterval(node: IntervalNode): string;
34
+ abstract visitJoinClause(node: JoinNode): string;
35
+ abstract visitList(node: ListNode): string;
36
+ abstract visitLiteral(node: LiteralNode): string;
37
+ abstract visitLogicalOperator(node: LogicalOpNode<ExprNode>): string;
38
+ abstract visitNotBetween(node: NotBetweenOpNode): string;
39
+ abstract visitOrderBy(node: OrderByNode): string;
40
+ abstract visitParam(node: ParamNode): string;
41
+ abstract visitSampleClause(node: SampleClauseNode): string;
42
+ abstract visitScalarSubquery(node: ScalarSubqueryNode): string;
43
+ abstract visitSelectClause(node: SelectClauseNode): string;
44
+ abstract visitSelectQuery(node: SelectQuery): string;
45
+ abstract visitSetOperation(node: SetOperation): string;
46
+ abstract visitTableRef(node: TableRefNode): string;
47
+ abstract visitUnary(node: UnaryOpNode): string;
48
+ abstract visitUnaryPostfix(node: UnaryPostfixOpNode): string;
49
+ abstract visitUnnest(node: UnnestNode): string;
50
+ abstract visitVerbatim(node: VerbatimNode): string;
51
+ abstract visitWhen(node: WhenNode): string;
52
+ abstract visitWindow(node: WindowNode): string;
53
+ abstract visitWindowClause(node: WindowClauseNode): string;
54
+ abstract visitWindowDef(node: WindowDefNode): string;
55
+ abstract visitWindowExtentExpr(node: WindowFrameExprNode): string;
56
+ abstract visitWindowFrame(node: WindowFrameNode): string;
57
+ abstract visitWindowFunction(node: WindowFunctionNode): string;
58
+ abstract visitWithClause(node: WithClauseNode): string;
59
+ }
60
+ //# sourceMappingURL=sql.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sql.d.ts","sourceRoot":"","sources":["../../../../src/visit/codegen/sql.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,85 @@
1
+ import { AGGREGATE, BETWEEN_OPERATOR, BINARY_OPERATOR, CASE, CAST, COLLATE, COLUMN_PARAM, COLUMN_REF, DESCRIBE_QUERY, EXPRESSION, FRAGMENT, FROM_CLAUSE, FUNCTION, IN_OPERATOR, INTERVAL, JOIN_CLAUSE, LIST, LITERAL, LOGICAL_OPERATOR, NOT_BETWEEN_OPERATOR, ORDER_BY, PARAM, SAMPLE_CLAUSE, SCALAR_SUBQUERY, SELECT_CLAUSE, SELECT_QUERY, SET_OPERATION, TABLE_REF, UNARY_OPERATOR, UNARY_POSTFIX_OPERATOR, UNNEST, VERBATIM, WHEN, WINDOW, WINDOW_CLAUSE, WINDOW_DEF, WINDOW_EXTENT_EXPR, WINDOW_FRAME, WINDOW_FUNCTION, WITH_CLAUSE } from '../../constants.js';
2
+ /**
3
+ * Abstract base class for SQL code generation visitors.
4
+ */
5
+ export class SQLCodeGenerator {
6
+ /**
7
+ * Convert a SQL AST node to a string using this visitor.
8
+ * @param node The SQL AST node to convert.
9
+ * @returns The SQL string representation.
10
+ */
11
+ toString(node) {
12
+ if (!node) {
13
+ throw new Error('Node is null or undefined');
14
+ }
15
+ if (typeof node.type !== 'string') {
16
+ throw new Error(`Node type is not a string: ${typeof node.type}, value: ${node.type}`);
17
+ }
18
+ if (node.type === 'CUSTOM') {
19
+ // custom node types provide their own handling
20
+ // pass the visitor through to apply to child nodes
21
+ return node.toString(this);
22
+ }
23
+ const method = this.getVisitMethod(node.type);
24
+ if (typeof method === 'function') {
25
+ // @ts-expect-error: dispatch based on node type
26
+ return method.call(this, node);
27
+ }
28
+ throw new Error(`No visitor method for node type: '${node.type}'`);
29
+ }
30
+ getVisitMethod(nodeType) {
31
+ switch (nodeType) {
32
+ case AGGREGATE: return this.visitAggregate;
33
+ case BETWEEN_OPERATOR: return this.visitBetween;
34
+ case BINARY_OPERATOR: return this.visitBinary;
35
+ case CASE: return this.visitCase;
36
+ case CAST: return this.visitCast;
37
+ case COLLATE: return this.visitCollate;
38
+ case COLUMN_PARAM: return this.visitColumnParam;
39
+ case COLUMN_REF: return this.visitColumnRef;
40
+ case DESCRIBE_QUERY: return this.visitDescribeQuery;
41
+ case EXPRESSION: return this.visitExpression;
42
+ case FRAGMENT: return this.visitFragment;
43
+ case FROM_CLAUSE: return this.visitFromClause;
44
+ case FUNCTION: return this.visitFunction;
45
+ case IN_OPERATOR: return this.visitIn;
46
+ case INTERVAL: return this.visitInterval;
47
+ case JOIN_CLAUSE: return this.visitJoinClause;
48
+ case LIST: return this.visitList;
49
+ case LITERAL: return this.visitLiteral;
50
+ case LOGICAL_OPERATOR: return this.visitLogicalOperator;
51
+ case NOT_BETWEEN_OPERATOR: return this.visitNotBetween;
52
+ case ORDER_BY: return this.visitOrderBy;
53
+ case PARAM: return this.visitParam;
54
+ case SAMPLE_CLAUSE: return this.visitSampleClause;
55
+ case SCALAR_SUBQUERY: return this.visitScalarSubquery;
56
+ case SELECT_CLAUSE: return this.visitSelectClause;
57
+ case SELECT_QUERY: return this.visitSelectQuery;
58
+ case SET_OPERATION: return this.visitSetOperation;
59
+ case TABLE_REF: return this.visitTableRef;
60
+ case UNARY_OPERATOR: return this.visitUnary;
61
+ case UNARY_POSTFIX_OPERATOR: return this.visitUnaryPostfix;
62
+ case UNNEST: return this.visitUnnest;
63
+ case VERBATIM: return this.visitVerbatim;
64
+ case WHEN: return this.visitWhen;
65
+ case WINDOW: return this.visitWindow;
66
+ case WINDOW_CLAUSE: return this.visitWindowClause;
67
+ case WINDOW_DEF: return this.visitWindowDef;
68
+ case WINDOW_EXTENT_EXPR: return this.visitWindowExtentExpr;
69
+ case WINDOW_FRAME: return this.visitWindowFrame;
70
+ case WINDOW_FUNCTION: return this.visitWindowFunction;
71
+ case WITH_CLAUSE: return this.visitWithClause;
72
+ default:
73
+ throw new Error(`Unknown node type: '${nodeType}'`);
74
+ }
75
+ }
76
+ /**
77
+ * Helper method to convert child nodes to strings.
78
+ * @param nodes Array of child nodes.
79
+ * @returns Array of SQL strings.
80
+ */
81
+ mapToString(nodes) {
82
+ return nodes.map(node => this.toString(node));
83
+ }
84
+ }
85
+ //# sourceMappingURL=sql.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sql.js","sourceRoot":"","sources":["../../../../src/visit/codegen/sql.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,50 @@
1
+ import { ToStringVisitor } from './to-string-visitor.js';
2
+ import { ExprNode, AggregateNode, BetweenOpNode, NotBetweenOpNode, BinaryOpNode, CaseNode, WhenNode, CastNode, CollateNode, ColumnParamNode, ColumnRefNode, FragmentNode, FromClauseNode, FunctionNode, InOpNode, IntervalNode, JoinNode, ListNode, LiteralNode, LogicalOpNode, OrderByNode, ParamNode, DescribeQuery, SelectQuery, SetOperation, SampleClauseNode, SelectClauseNode, ScalarSubqueryNode, TableRefNode, UnaryOpNode, UnaryPostfixOpNode, UnnestNode, VerbatimNode, WindowNode, WindowClauseNode, WindowDefNode, WindowFunctionNode, WindowFrameNode, WindowFrameExprNode, WithClauseNode } from '../index.js';
3
+ /**
4
+ * DuckDB SQL dialect visitor for converting AST nodes to DuckDB-compatible SQL.
5
+ */
6
+ export declare class DuckDBVisitor extends ToStringVisitor {
7
+ visitAggregate(node: AggregateNode): string;
8
+ visitBetween(node: BetweenOpNode): string;
9
+ visitBinary(node: BinaryOpNode): string;
10
+ visitCase(node: CaseNode): string;
11
+ visitCast(node: CastNode): string;
12
+ visitCollate(node: CollateNode): string;
13
+ visitColumnParam(node: ColumnParamNode): string;
14
+ visitColumnRef(node: ColumnRefNode): string;
15
+ visitDescribeQuery(node: DescribeQuery): string;
16
+ visitExpression(node: ExprNode): string;
17
+ visitFragment(node: FragmentNode): string;
18
+ visitFromClause(node: FromClauseNode): string;
19
+ visitFunction(node: FunctionNode): string;
20
+ visitIn(node: InOpNode): string;
21
+ visitInterval(node: IntervalNode): string;
22
+ visitJoinClause(node: JoinNode): string;
23
+ visitList(node: ListNode): string;
24
+ visitLiteral(node: LiteralNode): string;
25
+ visitLogicalOperator(node: LogicalOpNode<ExprNode>): string;
26
+ visitNotBetween(node: NotBetweenOpNode): string;
27
+ visitOrderBy(node: OrderByNode): string;
28
+ visitParam(node: ParamNode): string;
29
+ visitSampleClause(node: SampleClauseNode): string;
30
+ visitScalarSubquery(node: ScalarSubqueryNode): string;
31
+ visitSelectClause(node: SelectClauseNode): string;
32
+ visitSelectQuery(node: SelectQuery): string;
33
+ visitSetOperation(node: SetOperation): string;
34
+ visitTableRef(node: TableRefNode): string;
35
+ visitUnary(node: UnaryOpNode): string;
36
+ visitUnaryPostfix(node: UnaryPostfixOpNode): string;
37
+ visitUnnest(node: UnnestNode): string;
38
+ visitVerbatim(node: VerbatimNode): string;
39
+ visitWhen(node: WhenNode): string;
40
+ visitWindow(node: WindowNode): string;
41
+ visitWindowClause(node: WindowClauseNode): string;
42
+ visitWindowDef(node: WindowDefNode): string;
43
+ visitWindowExtentExpr(node: WindowFrameExprNode): string;
44
+ visitWindowFrame(node: WindowFrameNode): string;
45
+ private formatFrameValue;
46
+ visitWindowFunction(node: WindowFunctionNode): string;
47
+ visitWithClause(node: WithClauseNode): string;
48
+ }
49
+ export declare const duckdbVisitor: DuckDBVisitor;
50
+ //# sourceMappingURL=duckdb-visitor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"duckdb-visitor.d.ts","sourceRoot":"","sources":["../../../src/visit/duckdb-visitor.ts"],"names":[],"mappings":"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"}