@marimo-team/frontend 0.14.18-dev29 → 0.14.18-dev30

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 (121) hide show
  1. package/dist/assets/{ConnectedDataExplorerComponent-ByyTMxAe.js → ConnectedDataExplorerComponent-oOiI8-Is.js} +1 -1
  2. package/dist/assets/{ImageComparisonComponent-BEvMtMGK.js → ImageComparisonComponent-CrBtZ5gk.js} +1 -1
  3. package/dist/assets/{VegaLite-B6ZXw089.js → VegaLite-BruLY7Yo.js} +1 -1
  4. package/dist/assets/{_baseEach-BM02cWfw.js → _baseEach-Dtl0u6a9.js} +1 -1
  5. package/dist/assets/_baseMap-BbSMx7sO.js +1 -0
  6. package/dist/assets/{_baseUniq-B3VNhTaG.js → _baseUniq-oH3tH_Lx.js} +1 -1
  7. package/dist/assets/{_createAggregator-CBRdQRkQ.js → _createAggregator-DVbCk7I8.js} +1 -1
  8. package/dist/assets/{any-language-editor-EOMlEVeL.js → any-language-editor-DNTe-hGh.js} +1 -1
  9. package/dist/assets/{architectureDiagram-SUXI7LT5-Bz_etWhT.js → architectureDiagram-SUXI7LT5-BNE5Ocu0.js} +1 -1
  10. package/dist/assets/{blockDiagram-6J76NXCF-C3NjjGV1.js → blockDiagram-6J76NXCF-BkAnLDAP.js} +1 -1
  11. package/dist/assets/{c4Diagram-6F6E4RAY-Cfcu16fD.js → c4Diagram-6F6E4RAY-CMvcINsX.js} +1 -1
  12. package/dist/assets/channel-AZKaNSLi.js +1 -0
  13. package/dist/assets/{chunk-353BL4L5-D_x_But5.js → chunk-353BL4L5-DZ6k9BBV.js} +1 -1
  14. package/dist/assets/{chunk-67H74DCK-B78ctzkW.js → chunk-67H74DCK-Btl2ATCi.js} +1 -1
  15. package/dist/assets/{chunk-AACKK3MU-C_X3yBIA.js → chunk-AACKK3MU-Di82a8tq.js} +1 -1
  16. package/dist/assets/{chunk-BFAMUDN2-CmT_5Wnf.js → chunk-BFAMUDN2-C6ACh81N.js} +1 -1
  17. package/dist/assets/{chunk-E2GYISFI-TLOBmOmy.js → chunk-E2GYISFI-BGhna3Tu.js} +1 -1
  18. package/dist/assets/{chunk-OW32GOEJ-C1x0Lb_3.js → chunk-OW32GOEJ-BvQbpZtP.js} +6 -6
  19. package/dist/assets/{chunk-SKB7J2MH-t9L60ESv.js → chunk-SKB7J2MH-B5xc8b3Z.js} +1 -1
  20. package/dist/assets/{chunk-SZ463SBG-OsFZC8Fm.js → chunk-SZ463SBG-DqkT0n2R.js} +1 -1
  21. package/dist/assets/{circle-play-Coa1pbLo.js → circle-play-DPIHEaaR.js} +1 -1
  22. package/dist/assets/classDiagram-M3E45YP4-B7yw2nKS.js +1 -0
  23. package/dist/assets/classDiagram-v2-YAWTLIQI-B7yw2nKS.js +1 -0
  24. package/dist/assets/clone-4KJc73U3.js +1 -0
  25. package/dist/assets/common-keywords-Dg3Y2cJS.js +1 -0
  26. package/dist/assets/{compile-kBFbLKtC.js → compile-DiFbtiAE.js} +1 -1
  27. package/dist/assets/{dagre-JOIXM2OF-KIVae2Ja.js → dagre-JOIXM2OF-1P_Dgkjl.js} +1 -1
  28. package/dist/assets/{data-grid-overlay-editor-ClaYc6AL.js → data-grid-overlay-editor-Dghfz964.js} +1 -1
  29. package/dist/assets/{diagram-5UYTHUR4-CAegkM8o.js → diagram-5UYTHUR4-56oBr9Mj.js} +1 -1
  30. package/dist/assets/{diagram-VMROVX33-COZimksW.js → diagram-VMROVX33-Bg7PYU8p.js} +1 -1
  31. package/dist/assets/{diagram-ZTM2IBQH-RPzV6IQt.js → diagram-ZTM2IBQH-CPzEgjbH.js} +1 -1
  32. package/dist/assets/duckdb-keywords-CFYiiNsB.js +1 -0
  33. package/dist/assets/{edit-page-Bj7J0vUV.js → edit-page-DCrlym3M.js} +4 -4
  34. package/dist/assets/{erDiagram-3M52JZNH-DyyQZo2F.js → erDiagram-3M52JZNH-T300kYM8.js} +1 -1
  35. package/dist/assets/{flowDiagram-KYDEHFYC-BY45MXHx.js → flowDiagram-KYDEHFYC-BYZfYSI2.js} +1 -1
  36. package/dist/assets/{ganttDiagram-EK5VF46D-D0SJ9Vb8.js → ganttDiagram-EK5VF46D-BEDi_5bs.js} +1 -1
  37. package/dist/assets/{gitGraphDiagram-GW3U2K7C-DQIrG7Ne.js → gitGraphDiagram-GW3U2K7C-Cu1vg-Ae.js} +1 -1
  38. package/dist/assets/{glide-data-editor-CvbrMET8.js → glide-data-editor-lK9K3ps-.js} +4 -4
  39. package/dist/assets/{graph-BvDRm3kJ.js → graph-CDj368Ef.js} +1 -1
  40. package/dist/assets/{home-page-StH-FqwP.js → home-page-Bke3YQtW.js} +2 -2
  41. package/dist/assets/{index-FjwIsM4E.js → index-BIamDpT3.js} +1 -1
  42. package/dist/assets/{index-BxpEkFHY.js → index-BdPIybcd.js} +1 -1
  43. package/dist/assets/{index-BMlE8K6G.js → index-BfMKs8fK.js} +188 -179
  44. package/dist/assets/{index-DeBpKt6z.js → index-BgN5JveD.js} +1 -1
  45. package/dist/assets/{index-D6ttr-M5.js → index-BlIpJJ1s.js} +1 -1
  46. package/dist/assets/{index-B2AnidM8.js → index-C1sif23O.js} +1 -1
  47. package/dist/assets/{index-Dl0aViKc.js → index-C5zHu97c.js} +1 -1
  48. package/dist/assets/{index-C1Ev5kmm.js → index-CHUAhpF9.js} +1 -1
  49. package/dist/assets/{index-nhAJG0Zq.js → index-CHvSTvku.js} +1 -1
  50. package/dist/assets/{index-BklcjKLc.js → index-CV-cT8XZ.js} +1 -1
  51. package/dist/assets/{index-DqW_iv-8.js → index-CVJgiMKT.js} +1 -1
  52. package/dist/assets/index-Cd8lKjXa.js +68 -0
  53. package/dist/assets/{index-DcCjqlwv.js → index-D2wUEqSr.js} +1 -1
  54. package/dist/assets/{index-BSAd1_jA.js → index-DQeLlRNN.js} +1 -1
  55. package/dist/assets/{index-D9fGE-pM.js → index-DdE5sj7B.js} +1 -1
  56. package/dist/assets/{index-DWx68F4W.js → index-DpaljNVK.js} +1 -1
  57. package/dist/assets/{index-BqgXsw2X.js → index-DskNGo48.js} +1 -1
  58. package/dist/assets/{index-v9Rqt1AL.js → index-PXSGnTt_.js} +1 -1
  59. package/dist/assets/{index-QQV-w55W.js → index-UakLQEhR.js} +1 -1
  60. package/dist/assets/{index-DXQK0dbr.js → index-uLE7UQoA.js} +1 -1
  61. package/dist/assets/infoDiagram-LHK5PUON-DvKYogid.js +2 -0
  62. package/dist/assets/{journeyDiagram-EWQZEKCU-Cv34gpl9.js → journeyDiagram-EWQZEKCU-qFhtMoPK.js} +1 -1
  63. package/dist/assets/{kanban-definition-ZSS6B67P-FTq3yb2c.js → kanban-definition-ZSS6B67P-d4c_bpNj.js} +1 -1
  64. package/dist/assets/{layout-DGo16j-R.js → layout-B1YrGZ5o.js} +1 -1
  65. package/dist/assets/{linear-0J3_DIzy.js → linear-Ce9Ln0y7.js} +1 -1
  66. package/dist/assets/{links-h2K0p6lB.js → links--FJRrKkU.js} +12 -12
  67. package/dist/assets/{mermaid-BfTGIKjH.js → mermaid-TIsLiY_c.js} +26 -26
  68. package/dist/assets/min-pEaRzhJa.js +1 -0
  69. package/dist/assets/{mindmap-definition-6CBA2TL7-BFWeE5l4.js → mindmap-definition-6CBA2TL7-NzRV0KhB.js} +1 -1
  70. package/dist/assets/{number-overlay-editor-nJ_uE4OC.js → number-overlay-editor-wIfVoa2g.js} +2 -2
  71. package/dist/assets/{pieDiagram-NIOCPIFQ-CIPNZnyq.js → pieDiagram-NIOCPIFQ-DLjq0P3e.js} +3 -3
  72. package/dist/assets/{quadrantDiagram-2OG54O6I-DFTpGGxg.js → quadrantDiagram-2OG54O6I-9Oz1n3p6.js} +1 -1
  73. package/dist/assets/{react-plotly-BHmRdjjS.js → react-plotly-CpyIgXbT.js} +1 -1
  74. package/dist/assets/{requirementDiagram-QOLK2EJ7-bhqWzDfk.js → requirementDiagram-QOLK2EJ7-efmOhh-Y.js} +1 -1
  75. package/dist/assets/{run-page-C08qMCRH.js → run-page-CigF14nw.js} +1 -1
  76. package/dist/assets/{sankeyDiagram-4UZDY2LN-CaS2yE0B.js → sankeyDiagram-4UZDY2LN-C8d1HP5D.js} +1 -1
  77. package/dist/assets/{sequenceDiagram-SKLFT4DO-B7DEVd4j.js → sequenceDiagram-SKLFT4DO-YYvQS_Ez.js} +1 -1
  78. package/dist/assets/{slides-component-CT3uDvEm.js → slides-component-DaIiszro.js} +1 -1
  79. package/dist/assets/sortBy-DPhCeare.js +1 -0
  80. package/dist/assets/{stateDiagram-MI5ZYTHO-DcIY6HTB.js → stateDiagram-MI5ZYTHO-BUsXwOkv.js} +1 -1
  81. package/dist/assets/stateDiagram-v2-5AN5P6BG-C0_3uVRU.js +1 -0
  82. package/dist/assets/{storage-Ciru-sFj.js → storage-DVfCYCuA.js} +5 -5
  83. package/dist/assets/{terminal-Pn5QVsJZ.js → terminal-WkSrTXmZ.js} +1 -1
  84. package/dist/assets/time-CMDJBHm4.js +1 -0
  85. package/dist/assets/{timeline-definition-MYPXXCX6-Cd626Lgg.js → timeline-definition-MYPXXCX6-D6F16eAY.js} +1 -1
  86. package/dist/assets/{tracing-B1pgg2Ra.js → tracing-Bs9fWQQg.js} +2 -2
  87. package/dist/assets/{trash-CKCjDfOY.js → trash-BotaB4h_.js} +1 -1
  88. package/dist/assets/{treemap-75Q7IDZK-D6IH2czJ.js → treemap-75Q7IDZK-ReN7RgbK.js} +1 -1
  89. package/dist/assets/{vega-component-BbGjjrAW.js → vega-component-LxHHxxVY.js} +1 -1
  90. package/dist/assets/{xychartDiagram-H2YORKM3-Dk39Tmbz.js → xychartDiagram-H2YORKM3-BBA6XWcv.js} +1 -1
  91. package/dist/index.html +1 -1
  92. package/package.json +3 -2
  93. package/src/components/app-config/user-config-form.tsx +25 -0
  94. package/src/components/chat/markdown-renderer.tsx +1 -1
  95. package/src/components/editor/ai/add-cell-with-ai.tsx +1 -1
  96. package/src/components/editor/cell/CreateCellButton.tsx +1 -1
  97. package/src/components/editor/cell/code/language-toggle.tsx +1 -1
  98. package/src/components/editor/renderers/CellArray.tsx +1 -1
  99. package/src/core/codemirror/language/LanguageAdapters.ts +1 -1
  100. package/src/core/codemirror/language/__tests__/sql.test.ts +5 -5
  101. package/src/core/codemirror/language/extension.ts +1 -1
  102. package/src/core/codemirror/language/languages/sql/completion-sources.tsx +99 -0
  103. package/src/core/codemirror/language/languages/sql/completion-store.ts +191 -0
  104. package/src/core/codemirror/language/languages/{sql.ts → sql/sql.ts} +124 -248
  105. package/src/core/codemirror/language/languages/sql/utils.ts +42 -0
  106. package/src/core/codemirror/language/panel/panel.tsx +1 -1
  107. package/src/core/config/feature-flag.tsx +2 -0
  108. package/src/theme/useTheme.ts +1 -1
  109. package/dist/assets/_baseMap-CrbS00BX.js +0 -1
  110. package/dist/assets/channel-U5X5dN6K.js +0 -1
  111. package/dist/assets/classDiagram-M3E45YP4-7u91LcR8.js +0 -1
  112. package/dist/assets/classDiagram-v2-YAWTLIQI-7u91LcR8.js +0 -1
  113. package/dist/assets/clone-DltB19IA.js +0 -1
  114. package/dist/assets/infoDiagram-LHK5PUON-BI8vgvHA.js +0 -2
  115. package/dist/assets/min-BN2Aip45.js +0 -1
  116. package/dist/assets/sortBy-_N03fOwk.js +0 -1
  117. package/dist/assets/stateDiagram-v2-5AN5P6BG-BbbtK1gk.js +0 -1
  118. package/dist/assets/time-CzUrup3A.js +0 -1
  119. package/src/core/codemirror/language/languages/sql-dialects/README.md +0 -5
  120. package/src/core/codemirror/language/languages/sql-dialects/duckdb.ts +0 -22
  121. package/src/core/codemirror/language/languages/sql-dialects/spec_duckdb.py +0 -257
@@ -1,52 +1,45 @@
1
1
  /* Copyright 2024 Marimo. All rights reserved. */
2
2
 
3
- import {
4
- autocompletion,
5
- type CompletionSource,
6
- } from "@codemirror/autocomplete";
7
- import {
8
- Cassandra,
9
- keywordCompletionSource,
10
- MariaSQL,
11
- MSSQL,
12
- MySQL,
13
- PLSQL,
14
- PostgreSQL,
15
- type SQLConfig,
16
- type SQLDialect,
17
- SQLite,
18
- StandardSQL,
19
- schemaCompletionSource,
20
- sql,
21
- } from "@codemirror/lang-sql";
3
+ import { acceptCompletion, autocompletion } from "@codemirror/autocomplete";
4
+ import { insertTab } from "@codemirror/commands";
5
+ import { type SQLDialect, type SQLNamespace, sql } from "@codemirror/lang-sql";
22
6
  import type { EditorState, Extension } from "@codemirror/state";
23
7
  import { Compartment } from "@codemirror/state";
24
- import type { EditorView } from "@codemirror/view";
8
+ import { type EditorView, keymap } from "@codemirror/view";
25
9
  import type { SyntaxNode, TreeCursor } from "@lezer/common";
26
10
  import { parser } from "@lezer/python";
11
+ import {
12
+ defaultSqlHoverTheme,
13
+ NodeSqlParser,
14
+ type SupportedDialects as ParserDialects,
15
+ sqlExtension,
16
+ } from "@marimo-team/codemirror-sql";
17
+ import { DuckDBDialect } from "@marimo-team/codemirror-sql/dialects";
27
18
  import dedent from "string-dedent";
28
- import { isSchemaless } from "@/components/datasources/utils";
19
+ import { getFeatureFlag } from "@/core/config/feature-flag";
29
20
  import {
30
- dataConnectionsMapAtom,
31
21
  dataSourceConnectionsAtom,
32
22
  setLatestEngineSelected,
33
23
  } from "@/core/datasets/data-source-connections";
34
24
  import { type ConnectionName, DUCKDB_ENGINE } from "@/core/datasets/engines";
35
- import { datasetTablesAtom } from "@/core/datasets/state";
36
- import type { DataSourceConnection } from "@/core/kernel/messages";
37
25
  import { store } from "@/core/state/jotai";
26
+ import { resolvedThemeAtom } from "@/theme/useTheme";
38
27
  import { Logger } from "@/utils/Logger";
39
- import { LRUCache } from "@/utils/lru";
40
- import { variableCompletionSource } from "../embedded/embedded-python";
41
- import { languageMetadataField } from "../metadata";
42
- import type { LanguageAdapter } from "../types";
43
- import { parseArgsKwargs } from "../utils/ast";
44
- import { indentOneTab } from "../utils/indentOneTab";
45
- import type { QuotePrefixKind } from "../utils/quotes";
46
- import { MarkdownLanguageAdapter } from "./markdown";
47
- import { DuckDBDialect } from "./sql-dialects/duckdb";
28
+ import { variableCompletionSource } from "../../embedded/embedded-python";
29
+ import { languageMetadataField } from "../../metadata";
30
+ import type { LanguageAdapter } from "../../types";
31
+ import { parseArgsKwargs } from "../../utils/ast";
32
+ import { indentOneTab } from "../../utils/indentOneTab";
33
+ import type { QuotePrefixKind } from "../../utils/quotes";
34
+ import { MarkdownLanguageAdapter } from "../markdown";
35
+ import {
36
+ customKeywordCompletionSource,
37
+ tablesCompletionSource,
38
+ } from "./completion-sources";
39
+ import { SCHEMA_CACHE } from "./completion-store";
48
40
 
49
41
  const DEFAULT_DIALECT = DuckDBDialect;
42
+ const DEFAULT_PARSER_DIALECT = "DuckDB";
50
43
 
51
44
  // A compartment for the SQL config, so we can update the config of codemirror
52
45
  const sqlConfigCompartment = new Compartment();
@@ -70,6 +63,16 @@ export class SQLLanguageAdapter
70
63
  implements LanguageAdapter<SQLLanguageAdapterMetadata>
71
64
  {
72
65
  readonly type = "sql";
66
+ sqlLinterEnabled: boolean;
67
+
68
+ constructor() {
69
+ try {
70
+ this.sqlLinterEnabled = getFeatureFlag("sql_linter");
71
+ } catch {
72
+ this.sqlLinterEnabled = false;
73
+ }
74
+ }
75
+
73
76
  get defaultMetadata(): SQLLanguageAdapterMetadata {
74
77
  return {
75
78
  dataframeName: "_df",
@@ -196,9 +199,19 @@ export class SQLLanguageAdapter
196
199
  }
197
200
 
198
201
  getExtension(): Extension[] {
199
- return [
202
+ const extensions = [
200
203
  // This can be updated with a dispatch effect
201
204
  sqlConfigCompartment.of(sql({ dialect: DEFAULT_DIALECT })),
205
+ keymap.of([
206
+ {
207
+ key: "Tab",
208
+ // When tab is pressed, we want to accept the completion or insert a tab
209
+ run: (cm) => {
210
+ return acceptCompletion(cm) || insertTab(cm);
211
+ },
212
+ preventDefault: true,
213
+ },
214
+ ]),
202
215
  autocompletion({
203
216
  // We remove the default keymap because we use our own which
204
217
  // handles the Escape key correctly in Vim
@@ -214,6 +227,45 @@ export class SQLLanguageAdapter
214
227
  ],
215
228
  }),
216
229
  ];
230
+
231
+ if (this.sqlLinterEnabled) {
232
+ const theme = store.get(resolvedThemeAtom);
233
+ const parser = new NodeSqlParser({
234
+ getParserOptions: (state: EditorState) => {
235
+ return {
236
+ database: guessParserDialect(state) ?? DEFAULT_PARSER_DIALECT,
237
+ };
238
+ },
239
+ });
240
+
241
+ extensions.push(
242
+ sqlExtension({
243
+ enableLinting: true,
244
+ linterConfig: {
245
+ delay: 250, // Delay before running validation
246
+ parser: parser,
247
+ },
248
+ enableGutterMarkers: true,
249
+ gutterConfig: {
250
+ backgroundColor: "#3b82f6", // Blue for current statement
251
+ errorBackgroundColor: "#ef4444", // Red for invalid statements
252
+ hideWhenNotFocused: true, // Hide gutter when editor loses focus
253
+ parser: parser,
254
+ },
255
+ hoverConfig: {
256
+ schema: getSchema, // Use the same schema as autocomplete
257
+ hoverTime: 300, // 300ms hover delay
258
+ enableKeywords: true, // Show keyword information
259
+ enableTables: true, // Show table information
260
+ enableColumns: true, // Show column information
261
+ parser: parser,
262
+ theme: defaultSqlHoverTheme(theme),
263
+ },
264
+ }),
265
+ );
266
+ }
267
+
268
+ return extensions;
217
269
  }
218
270
  }
219
271
 
@@ -245,238 +297,62 @@ export function initializeSQLDialect(view: EditorView) {
245
297
  updateSQLDialect(view, dialect);
246
298
  }
247
299
 
248
- type TableToCols = Record<string, string[]>;
249
- type Schemas = Record<string, TableToCols>;
250
- type CachedSchema = Pick<SQLConfig, "schema" | "defaultSchema"> & {
251
- shouldAddLocalTables: boolean;
252
- };
253
-
254
- export class SQLCompletionStore {
255
- private cache: LRUCache<DataSourceConnection, CachedSchema>;
256
-
257
- constructor() {
258
- this.cache = new LRUCache(10, {
259
- create: (connection) => this.getConnectionSchema(connection),
260
- });
261
- }
262
-
263
- private getConnection(
264
- connectionName: ConnectionName,
265
- ): DataSourceConnection | undefined {
266
- const dataConnectionsMap = store.get(dataConnectionsMapAtom);
267
- return dataConnectionsMap.get(connectionName);
268
- }
269
-
270
- private getConnectionSchema(connection: DataSourceConnection): CachedSchema {
271
- const schemaMap: Record<string, TableToCols> = {};
272
- const databaseMap: Record<string, Schemas> = {};
273
-
274
- // When there is only one database, it is the default
275
- const defaultDb = connection.databases.find(
276
- (db) =>
277
- db.name === connection.default_database ||
278
- connection.databases.length === 1,
279
- );
280
-
281
- const dbToVerify = defaultDb ?? connection.databases[0];
282
- const isSchemalessDb =
283
- dbToVerify?.schemas.some((schema) => isSchemaless(schema.name)) ?? false;
284
-
285
- // For schemaless databases, treat databases as schemas
286
- if (isSchemalessDb) {
287
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
288
- const dbToTablesMap: Record<string, any> = {};
289
-
290
- for (const db of connection.databases) {
291
- const isDefaultDb = db.name === defaultDb?.name;
292
-
293
- for (const schema of db.schemas) {
294
- for (const table of schema.tables) {
295
- const columns = table.columns.map((col) => col.name);
296
-
297
- if (isDefaultDb) {
298
- // For default database, add tables directly to top level
299
- dbToTablesMap[table.name] = columns;
300
- } else {
301
- // Otherwise nest under database name
302
- dbToTablesMap[db.name] = dbToTablesMap[db.name] || {};
303
- dbToTablesMap[db.name][table.name] = columns;
304
- }
305
- }
306
- }
307
- }
308
-
309
- return {
310
- shouldAddLocalTables: false,
311
- schema: dbToTablesMap,
312
- defaultSchema: defaultDb?.name,
313
- };
314
- }
315
-
316
- // For default db, we can use the schema name directly
317
- for (const schema of defaultDb?.schemas ?? []) {
318
- schemaMap[schema.name] = {};
319
- for (const table of schema.tables) {
320
- const columns = table.columns.map((col) => col.name);
321
- schemaMap[schema.name][table.name] = columns;
322
- }
323
- }
324
-
325
- // Otherwise, we need to use the fully qualified name
326
- for (const database of connection.databases) {
327
- if (database.name === defaultDb?.name) {
328
- continue;
329
- }
330
- databaseMap[database.name] = {};
331
-
332
- for (const schema of database.schemas) {
333
- databaseMap[database.name][schema.name] = {};
334
-
335
- for (const table of schema.tables) {
336
- const columns = table.columns.map((col) => col.name);
337
- databaseMap[database.name][schema.name][table.name] = columns;
338
- }
339
- }
340
- }
341
-
342
- return {
343
- shouldAddLocalTables: true,
344
- schema: { ...databaseMap, ...schemaMap },
345
- defaultSchema: connection.default_schema ?? undefined,
346
- };
347
- }
348
-
349
- /**
350
- * Get the dialect for a connection.
351
- * If the connection is not found, return the standard SQL dialect.
352
- */
353
- getDialect(connectionName: ConnectionName): SQLDialect {
354
- const connection = this.getConnection(connectionName);
355
- if (!connection) {
356
- return StandardSQL;
357
- }
358
- return guessDialect(connection) ?? StandardSQL;
359
- }
360
-
361
- getCompletionSource(connectionName: ConnectionName): SQLConfig | null {
362
- const connection = this.getConnection(connectionName);
363
- if (!connection) {
364
- return null;
365
- }
366
-
367
- const getTablesMap = () => {
368
- const localTables = store.get(datasetTablesAtom);
369
- // If there is a conflict with connection tables,
370
- // the engine will prioritize the connection tables without special handling
371
- const tablesMap: TableToCols = {};
372
- for (const table of localTables) {
373
- const tableColumns = table.columns.map((col) => col.name);
374
- tablesMap[table.name] = tableColumns;
375
- }
376
- return tablesMap;
377
- };
378
-
379
- const schema = this.cache.getOrCreate(connection);
380
-
381
- return {
382
- dialect: guessDialect(connection),
383
- schema: schema.shouldAddLocalTables
384
- ? { ...schema.schema, ...getTablesMap() }
385
- : schema.schema,
386
- defaultSchema: schema.defaultSchema,
387
- defaultTable: getSingleTable(connection),
388
- };
389
- }
390
- }
391
-
392
- const SCHEMA_CACHE = new SQLCompletionStore();
393
-
394
300
  function getSQLMetadata(state: EditorState): SQLLanguageAdapterMetadata {
395
301
  return state.field(languageMetadataField) as SQLLanguageAdapterMetadata;
396
302
  }
397
303
 
398
- /**
399
- * Custom keyword completion source that dynamically gets the Dialect.
400
- * This also ignores keyword completions on table columns.
401
- */
402
- function customKeywordCompletionSource(): CompletionSource {
403
- return (ctx) => {
404
- const metadata = getSQLMetadata(ctx.state);
405
- const connectionName = metadata.engine;
406
- const dialect = SCHEMA_CACHE.getDialect(connectionName);
407
-
408
- // We want to ignore keyword completions on something like
409
- // `WHERE my_table.col`
410
- // ^cursor
411
- const textBefore = ctx.matchBefore(/\.\w*/);
412
- if (textBefore) {
413
- // If there is a match, we are typing after a dot,
414
- // so we don't want to trigger SQL keyword completion
415
- return null;
416
- }
417
-
418
- const result = keywordCompletionSource(dialect)(ctx);
419
- return result;
420
- };
421
- }
422
-
423
- /**
424
- * Custom schema completion source that dynamically gets the Dialect and SQL tables.
425
- */
426
- function tablesCompletionSource(): CompletionSource {
427
- return (ctx) => {
428
- const metadata = getSQLMetadata(ctx.state);
429
- const connectionName = metadata.engine;
430
- const config = SCHEMA_CACHE.getCompletionSource(connectionName);
431
-
432
- if (!config) {
433
- return null;
434
- }
304
+ function getSchema(view: EditorView): SQLNamespace {
305
+ const metadata = getSQLMetadata(view.state);
306
+ const connectionName = metadata.engine;
307
+ const config = SCHEMA_CACHE.getCompletionSource(connectionName);
308
+ if (!config?.schema) {
309
+ return {};
310
+ }
435
311
 
436
- return schemaCompletionSource(config)(ctx);
437
- };
312
+ return config.schema;
438
313
  }
439
314
 
440
- function getSingleTable(connection: DataSourceConnection): string | undefined {
441
- if (connection.databases.length !== 1) {
442
- return undefined;
443
- }
444
- const database = connection.databases[0];
445
- if (database.schemas.length !== 1) {
446
- return undefined;
447
- }
448
- const schema = database.schemas[0];
449
- if (schema.tables.length !== 1) {
450
- return undefined;
451
- }
452
- return schema.tables[0].name;
453
- }
315
+ function guessParserDialect(state: EditorState): ParserDialects | null {
316
+ const metadata = getSQLMetadata(state);
317
+ const connectionName = metadata.engine;
318
+ const dialect =
319
+ SCHEMA_CACHE.getInternalDialect(connectionName)?.toLowerCase();
454
320
 
455
- export function guessDialect(
456
- connection: DataSourceConnection,
457
- ): SQLDialect | undefined {
458
- switch (connection.dialect) {
321
+ switch (dialect) {
459
322
  case "postgresql":
460
323
  case "postgres":
461
- return PostgreSQL;
324
+ return "PostgreSQL";
325
+ case "db2":
326
+ return "DB2";
462
327
  case "mysql":
463
- return MySQL;
328
+ return "MySQL";
464
329
  case "sqlite":
465
- return SQLite;
330
+ return "Sqlite";
466
331
  case "mssql":
467
332
  case "sqlserver":
468
- return MSSQL;
333
+ return "TransactSQL";
469
334
  case "duckdb":
470
- return DuckDBDialect;
335
+ return "DuckDB";
471
336
  case "mariadb":
472
- return MariaSQL;
337
+ return "MariaDB";
473
338
  case "cassandra":
474
- return Cassandra;
475
- case "oracledb":
476
- case "oracle":
477
- return PLSQL;
339
+ return "Noql";
340
+ case "athena":
341
+ return "Athena";
342
+ case "bigquery":
343
+ return "BigQuery";
344
+ case "hive":
345
+ return "Hive";
346
+ case "redshift":
347
+ return "Redshift";
348
+ case "snowflake":
349
+ return "Snowflake";
350
+ case "flink":
351
+ return "FlinkSQL";
352
+ case "mongodb":
353
+ return "Noql";
478
354
  default:
479
- return undefined;
355
+ return null;
480
356
  }
481
357
  }
482
358
 
@@ -0,0 +1,42 @@
1
+ /* Copyright 2024 Marimo. All rights reserved. */
2
+
3
+ import type { SQLDialect } from "@codemirror/lang-sql";
4
+ import {
5
+ Cassandra,
6
+ MariaSQL,
7
+ MSSQL,
8
+ MySQL,
9
+ PLSQL,
10
+ PostgreSQL,
11
+ SQLite,
12
+ } from "@codemirror/lang-sql";
13
+ import { DuckDBDialect } from "@marimo-team/codemirror-sql/dialects";
14
+ import type { DataSourceConnection } from "@/core/kernel/messages";
15
+
16
+ export function guessDialect(
17
+ connection: DataSourceConnection,
18
+ ): SQLDialect | undefined {
19
+ switch (connection.dialect) {
20
+ case "postgresql":
21
+ case "postgres":
22
+ return PostgreSQL;
23
+ case "mysql":
24
+ return MySQL;
25
+ case "sqlite":
26
+ return SQLite;
27
+ case "mssql":
28
+ case "sqlserver":
29
+ return MSSQL;
30
+ case "duckdb":
31
+ return DuckDBDialect;
32
+ case "mariadb":
33
+ return MariaSQL;
34
+ case "cassandra":
35
+ return Cassandra;
36
+ case "oracledb":
37
+ case "oracle":
38
+ return PLSQL;
39
+ default:
40
+ return undefined;
41
+ }
42
+ }
@@ -13,7 +13,7 @@ import { MarkdownLanguageAdapter } from "../languages/markdown";
13
13
  import {
14
14
  SQLLanguageAdapter,
15
15
  updateSQLDialectFromConnection,
16
- } from "../languages/sql";
16
+ } from "../languages/sql/sql";
17
17
  import {
18
18
  type LanguageMetadata,
19
19
  languageMetadataField,
@@ -13,6 +13,7 @@ export interface ExperimentalFeatures {
13
13
  rtc_v2: boolean;
14
14
  performant_table_charts: boolean;
15
15
  mcp_docs: boolean;
16
+ sql_linter: boolean;
16
17
  // Add new feature flags here
17
18
  }
18
19
 
@@ -23,6 +24,7 @@ const defaultValues: ExperimentalFeatures = {
23
24
  rtc_v2: false,
24
25
  performant_table_charts: false,
25
26
  mcp_docs: false,
27
+ sql_linter: false,
26
28
  };
27
29
 
28
30
  export function getFeatureFlag<T extends keyof ExperimentalFeatures>(
@@ -73,7 +73,7 @@ function setupThemeListener(): void {
73
73
  }
74
74
  setupThemeListener();
75
75
 
76
- const resolvedThemeAtom = atom((get) => {
76
+ export const resolvedThemeAtom = atom((get) => {
77
77
  const theme = get(themeAtom);
78
78
  const prefersDarkMode = get(prefersDarkModeAtom);
79
79
  return theme === "system" ? (prefersDarkMode ? "dark" : "light") : theme;
@@ -1 +0,0 @@
1
- import{b as m}from"./_baseEach-BM02cWfw.js";import{x as s}from"./index-BMlE8K6G.js";function e(r,o){var a=-1,t=s(r)?Array(r.length):[];return m(r,function(n,f,i){t[++a]=o(n,f,i)}),t}export{e as b};
@@ -1 +0,0 @@
1
- import{U as s,C as o}from"./mermaid-BfTGIKjH.js";const n=(a,r)=>s.lang.round(o.parse(a)[r]);export{n as c};
@@ -1 +0,0 @@
1
- import{s as a,c as s,a as t,C as o}from"./chunk-SZ463SBG-OsFZC8Fm.js";import{_ as e}from"./mermaid-BfTGIKjH.js";import"./transform-B8bpuzxV.js";import"./chunk-E2GYISFI-TLOBmOmy.js";import"./chunk-BFAMUDN2-CmT_5Wnf.js";import"./chunk-SKB7J2MH-t9L60ESv.js";import"./index-BMlE8K6G.js";import"./step-BwsUM5iJ.js";import"./timer-BwIYMJWC.js";var i={parser:t,get db(){return new o},renderer:s,styles:a,init:e(r=>{r.class||(r.class={}),r.class.arrowMarkerAbsolute=r.arrowMarkerAbsolute},"init")};export{i as diagram};
@@ -1 +0,0 @@
1
- import{s as a,c as s,a as t,C as o}from"./chunk-SZ463SBG-OsFZC8Fm.js";import{_ as e}from"./mermaid-BfTGIKjH.js";import"./transform-B8bpuzxV.js";import"./chunk-E2GYISFI-TLOBmOmy.js";import"./chunk-BFAMUDN2-CmT_5Wnf.js";import"./chunk-SKB7J2MH-t9L60ESv.js";import"./index-BMlE8K6G.js";import"./step-BwsUM5iJ.js";import"./timer-BwIYMJWC.js";var i={parser:t,get db(){return new o},renderer:s,styles:a,init:e(r=>{r.class||(r.class={}),r.class.arrowMarkerAbsolute=r.arrowMarkerAbsolute},"init")};export{i as diagram};
@@ -1 +0,0 @@
1
- import{b as n}from"./_baseUniq-B3VNhTaG.js";function o(r){return n(r,4)}export{o as c};
@@ -1,2 +0,0 @@
1
- import{_ as a,l as e,I as s,d as p,K as n}from"./mermaid-BfTGIKjH.js";import{p as m}from"./treemap-75Q7IDZK-D6IH2czJ.js";import"./index-BMlE8K6G.js";import"./transform-B8bpuzxV.js";import"./timer-BwIYMJWC.js";import"./step-BwsUM5iJ.js";import"./_baseEach-BM02cWfw.js";import"./_baseUniq-B3VNhTaG.js";import"./min-BN2Aip45.js";import"./_baseMap-CrbS00BX.js";import"./clone-DltB19IA.js";import"./_createAggregator-CBRdQRkQ.js";var d={parse:a(async r=>{const t=await m("info",r);e.debug(t)},"parse")},g={version:n.version+""},v={parser:d,db:{getVersion:a(()=>g.version,"getVersion")},renderer:{draw:a((r,t,i)=>{e.debug(`rendering info diagram
2
- `+r);const o=s(t);p(o,100,400,!0),o.append("g").append("text").attr("x",100).attr("y",40).attr("class","version").attr("font-size",32).style("text-anchor","middle").text(`v${i}`)},"draw")}};export{v as diagram};
@@ -1 +0,0 @@
1
- import{J as b,aE as d,bR as g,bS as O,x as j,Q as y,bT as x,aA as w,ak as P,bU as E,az as M,aC as U}from"./index-BMlE8K6G.js";import{a as v}from"./_baseEach-BM02cWfw.js";import{d as k}from"./_baseUniq-B3VNhTaG.js";import{b as z}from"./_baseMap-CrbS00BX.js";var c=Object.prototype,A=c.hasOwnProperty,C=b(function(a,n){a=Object(a);var u=-1,t=n.length,r=t>2?n[2]:void 0;for(r&&d(n[0],n[1],r)&&(t=1);++u<t;)for(var s=n[u],o=g(s),i=-1,l=o.length;++i<l;){var e=o[i],f=a[e];(f===void 0||O(f,c[e])&&!A.call(a,e))&&(a[e]=s[e])}return a});function J(a){var n=a==null?0:a.length;return n?a[n-1]:void 0}var Q=Math.max,p,R=(p=function(a,n,u){var t=a==null?0:a.length;if(!t)return-1;var r=u==null?0:x(u);return r<0&&(r=Q(t+r,0)),k(a,v(n),r)},function(a,n,u){var t=Object(a);if(!j(a)){var r=v(n);a=y(a),n=function(o){return r(t[o],o,t)}}var s=p(a,n,u);return s>-1?t[r?a[s]:s]:void 0});function S(a,n){return(P(a)?w:z)(a,v(n))}var T=Object.prototype.hasOwnProperty;function _(a,n){return a!=null&&T.call(a,n)}function q(a,n){return a!=null&&E(a,n,_)}function h(a,n){return a<n}function m(a,n,u){for(var t=-1,r=a.length;++t<r;){var s=a[t],o=n(s);if(o!=null&&(i===void 0?o==o&&!M(o):u(o,i)))var i=o,l=s}return l}function B(a){return a&&a.length?m(a,U,h):void 0}export{h as a,m as b,B as c,C as d,R as f,q as h,J as l,S as m};
@@ -1 +0,0 @@
1
- import{az as d,aA as c,ak as x,aB as b,aC as k,aD as z,J as A,aE as g,K as B}from"./index-BMlE8K6G.js";import{a as C}from"./_baseEach-BM02cWfw.js";import{b as D}from"./_baseMap-CrbS00BX.js";function E(n,r){if(n!==r){var u=n!==void 0,l=n===null,t=n==n,a=d(n),e=r!==void 0,o=r===null,f=r==r,i=d(r);if(!o&&!i&&!a&&n>r||a&&e&&f&&!o&&!i||l&&e&&f||!u&&f||!t)return 1;if(!l&&!a&&!i&&n<r||i&&u&&t&&!l&&!a||o&&u&&t||!e&&t||!f)return-1}return 0}function J(n,r,u){r=r.length?c(r,function(t){return x(t)?function(a){return b(a,t.length===1?t[0]:t)}:t}):[k];var l=-1;return r=c(r,z(C)),function(t,a){var e=t.length;for(t.sort(a);e--;)t[e]=t[e].value;return t}(D(n,function(t,a,e){return{criteria:c(r,function(o){return o(t)}),index:++l,value:t}}),function(t,a){return function(e,o,f){for(var i=-1,v=e.criteria,h=o.criteria,m=v.length,p=f.length;++i<m;){var s=E(v[i],h[i]);if(s)return i>=p?s:s*(f[i]=="desc"?-1:1)}return e.index-o.index}(t,a,u)})}var K=A(function(n,r){if(n==null)return[];var u=r.length;return u>1&&g(n,r[0],r[1])?r=[]:u>2&&g(r[0],r[1],r[2])&&(r=[r[0]]),J(n,B(r),[])});export{K as s};
@@ -1 +0,0 @@
1
- import{s as t,b as a,a as e,S as o}from"./chunk-OW32GOEJ-C1x0Lb_3.js";import{_ as s}from"./mermaid-BfTGIKjH.js";import"./transform-B8bpuzxV.js";import"./chunk-BFAMUDN2-CmT_5Wnf.js";import"./chunk-SKB7J2MH-t9L60ESv.js";import"./index-BMlE8K6G.js";import"./step-BwsUM5iJ.js";import"./timer-BwIYMJWC.js";var i={parser:e,get db(){return new o(2)},renderer:a,styles:t,init:s(r=>{r.state||(r.state={}),r.state.arrowMarkerAbsolute=r.arrowMarkerAbsolute},"init")};export{i as diagram};
@@ -1 +0,0 @@
1
- import{R as q,r as ln,d as z,e as E,C as G,n as d,h as fn}from"./timer-BwIYMJWC.js";import{c as bn,a as pn}from"./linear-0J3_DIzy.js";import{i as yn}from"./init-DLRA0X12.js";import{bt as vn,bu as m,bv as M,bw as N,bx as D,by as H,bz as wn,bA as J,bB as P,bC as K,bD as gn,bE as O,bF as Q,bG as R,bH as S,bI as Y,bJ as j,bK as mn,bL as dn,bM as Mn,bN as Nn,bO as Dn,bP as In,bQ as kn}from"./index-BMlE8K6G.js";function xn(n,r){let i;if(r===void 0)for(const e of n)e!=null&&(i<e||i===void 0&&e>=e)&&(i=e);else{let e=-1;for(let a of n)(a=r(a,++e,n))!=null&&(i<a||i===void 0&&a>=a)&&(i=a)}return i}function Pn(n,r){let i;if(r===void 0)for(const e of n)e!=null&&(i>e||i===void 0&&e>=e)&&(i=e);else{let e=-1;for(let a of n)(a=r(a,++e,n))!=null&&(i>a||i===void 0&&a>=a)&&(i=a)}return i}function T(n,r,i,e,a,s){const o=[[m,1,M],[m,5,5*M],[m,15,15*M],[m,30,30*M],[s,1,N],[s,5,5*N],[s,15,15*N],[s,30,30*N],[a,1,D],[a,3,3*D],[a,6,6*D],[a,12,12*D],[e,1,H],[e,2,2*H],[i,1,wn],[r,1,J],[r,3,3*J],[n,1,P]];function b(l,u,c){const v=Math.abs(u-l)/c,h=vn(([,,x])=>x).right(o,v);if(h===o.length)return n.every(K(l/P,u/P,c));if(h===0)return gn.every(Math.max(K(l,u,c),1));const[w,k]=o[v/o[h-1][2]<o[h][2]/v?h-1:h];return w.every(k)}return[function(l,u,c){const v=u<l;v&&([l,u]=[u,l]);const h=c&&typeof c.range=="function"?c:b(l,u,c),w=h?h.range(l,+u+1):[];return v?w.reverse():w},b]}const[An,Bn]=T(In,Dn,Nn,Mn,dn,mn),[Cn,Fn]=T(j,Y,S,R,Q,O),U=Math.PI/180,V=180/Math.PI,W=.96422,X=.82521,Z=4/29,g=6/29,_=3*g*g,Ln=g*g*g;function $(n){if(n instanceof p)return new p(n.l,n.a,n.b,n.opacity);if(n instanceof y)return an(n);n instanceof q||(n=ln(n));var r,i,e=F(n.r),a=F(n.g),s=F(n.b),o=A((.2225045*e+.7168786*a+.0606169*s)/1);return e===a&&a===s?r=i=o:(r=A((.4360747*e+.3850649*a+.1430804*s)/W),i=A((.0139322*e+.0971045*a+.7141733*s)/X)),new p(116*o-16,500*(r-o),200*(o-i),n.opacity)}function nn(n,r,i,e){return arguments.length===1?$(n):new p(n,r,i,e??1)}function p(n,r,i,e){this.l=+n,this.a=+r,this.b=+i,this.opacity=+e}function A(n){return n>Ln?Math.pow(n,1/3):n/_+Z}function B(n){return n>g?n*n*n:_*(n-Z)}function C(n){return 255*(n<=.0031308?12.92*n:1.055*Math.pow(n,1/2.4)-.055)}function F(n){return(n/=255)<=.04045?n/12.92:Math.pow((n+.055)/1.055,2.4)}function I(n,r,i,e){return arguments.length===1?function(a){if(a instanceof y)return new y(a.h,a.c,a.l,a.opacity);if(a instanceof p||(a=$(a)),a.a===0&&a.b===0)return new y(NaN,0<a.l&&a.l<100?0:NaN,a.l,a.opacity);var s=Math.atan2(a.b,a.a)*V;return new y(s<0?s+360:s,Math.sqrt(a.a*a.a+a.b*a.b),a.l,a.opacity)}(n):new y(n,r,i,e??1)}function y(n,r,i,e){this.h=+n,this.c=+r,this.l=+i,this.opacity=+e}function an(n){if(isNaN(n.h))return new p(n.l,0,0,n.opacity);var r=n.h*U;return new p(n.l,Math.cos(r)*n.c,Math.sin(r)*n.c,n.opacity)}function rn(n){return function(r,i){var e=n((r=I(r)).h,(i=I(i)).h),a=d(r.c,i.c),s=d(r.l,i.l),o=d(r.opacity,i.opacity);return function(b){return r.h=e(b),r.c=a(b),r.l=s(b),r.opacity=o(b),r+""}}}z(p,nn,E(G,{brighter(n){return new p(this.l+18*(n??1),this.a,this.b,this.opacity)},darker(n){return new p(this.l-18*(n??1),this.a,this.b,this.opacity)},rgb(){var n=(this.l+16)/116,r=isNaN(this.a)?n:n+this.a/500,i=isNaN(this.b)?n:n-this.b/200;return r=W*B(r),n=1*B(n),i=X*B(i),new q(C(3.1338561*r-1.6168667*n-.4906146*i),C(-.9787684*r+1.9161415*n+.033454*i),C(.0719453*r-.2289914*n+1.4052427*i),this.opacity)}})),z(y,I,E(G,{brighter(n){return new y(this.h,this.c,this.l+18*(n??1),this.opacity)},darker(n){return new y(this.h,this.c,this.l-18*(n??1),this.opacity)},rgb(){return an(this).rgb()}}));const qn=rn(fn);var zn=rn(d);function en(n,r){var i,e=0,a=(n=n.slice()).length-1,s=n[e],o=n[a];return o<s&&(i=e,e=a,a=i,i=s,s=o,o=i),n[e]=r.floor(s),n[a]=r.ceil(o),n}function En(n){return new Date(n)}function Gn(n){return n instanceof Date?+n:+new Date(+n)}function L(n,r,i,e,a,s,o,b,l,u){var c=bn(),v=c.invert,h=c.domain,w=u(".%L"),k=u(":%S"),x=u("%I:%M"),tn=u("%I %p"),sn=u("%a %d"),on=u("%b %d"),un=u("%B"),cn=u("%Y");function hn(t){return(l(t)<t?w:b(t)<t?k:o(t)<t?x:s(t)<t?tn:e(t)<t?a(t)<t?sn:on:i(t)<t?un:cn)(t)}return c.invert=function(t){return new Date(v(t))},c.domain=function(t){return arguments.length?h(Array.from(t,Gn)):h().map(En)},c.ticks=function(t){var f=h();return n(f[0],f[f.length-1],t??10)},c.tickFormat=function(t,f){return f==null?hn:u(f)},c.nice=function(t){var f=h();return t&&typeof t.range=="function"||(t=r(f[0],f[f.length-1],t??10)),t?h(en(f,t)):c},c.copy=function(){return pn(c,L(n,r,i,e,a,s,o,b,l,u))},c}function Hn(){return yn.apply(L(Cn,Fn,j,Y,S,R,Q,O,m,kn).domain([new Date(2e3,0,1),new Date(2e3,0,2)]),arguments)}export{xn as a,An as b,L as c,V as d,I as e,zn as h,qn as i,nn as l,Pn as m,en as n,U as r,Hn as t,Bn as u};
@@ -1,5 +0,0 @@
1
- # Generating SQL Dialects
2
-
3
- SQL Dialects are used for CodeMirror to support SQL syntax highlighting.
4
-
5
- For DuckDB, you can run the python script `spec_duckdb.py` to generate the terms used for `duckdb.ts` file.
@@ -1,22 +0,0 @@
1
- /* Copyright 2024 Marimo. All rights reserved. */
2
- // Credit to https://github.com/sekuel/codemirror-sql-duckdb/blob/main/DuckDBDialect.js for the dialect spec
3
-
4
- import { SQLDialect, type SQLDialectSpec } from "@codemirror/lang-sql";
5
-
6
- const otherFunctions =
7
- "percentile_cont row_number rank dense_rank rank_dense percent_rank cume_dist ntile lag lead first_value last_value nth_value";
8
-
9
- const DuckDBDialectSpec: SQLDialectSpec = {
10
- charSetCasts: true,
11
- doubleQuotedStrings: false,
12
- unquotedBitLiterals: true,
13
- hashComments: false,
14
- spaceAfterDashes: false,
15
- specialVar: "@?",
16
- identifierQuotes: "`",
17
- keywords: `${otherFunctions} !__postfix !~~ !~~* % & && * ** + - ->> / // <-> << <=> <@ >> @ @> Calendar JSON TimeZone ^ ^@ abort abs absolute access access_mode acos acosh action add add_parquet_key admin after age aggregate alias all all_profiling_output allow_community_extensions allow_extensions_metadata_mismatch allow_persistent_secrets allow_unredacted_secrets allow_unsigned_extensions allowed_directories allowed_paths also alter always analyse analyze and anti any any_value apply approx_count_distinct approx_quantile approx_top_k arbitrary arg_max arg_max_null arg_min arg_min_null argmax argmin array array_agg array_aggr array_aggregate array_append array_apply array_cat array_concat array_contains array_cosine_distance array_cosine_similarity array_cross_product array_distance array_distinct array_dot_product array_extract array_filter array_grade_up array_has array_has_all array_has_any array_indexof array_inner_product array_intersect array_length array_negative_dot_product array_negative_inner_product array_pop_back array_pop_front array_position array_prepend array_push_back array_push_front array_reduce array_resize array_reverse array_reverse_sort array_select array_slice array_sort array_to_json array_to_string array_to_string_comma_default array_transform array_unique array_value array_where array_zip arrow_large_buffer_size arrow_lossless_conversion arrow_output_list_view arrow_output_version arrow_scan arrow_scan_dumb as asc ascii asin asinh asof asof_loop_join_threshold assertion assignment asymmetric at atan atan2 atanh attach attribute authorization autoinstall_extension_repository autoinstall_known_extensions autoload_known_extensions avg backward bar base64 before begin between bigint bin binary binary_as_string bit bit_and bit_count bit_length bit_or bit_position bit_xor bitstring bitstring_agg blob bool bool_and bool_or boolean both bpchar by bytea cache call called can_cast_implicitly cardinality cascade cascaded case cast cast_to_type catalog catalog_error_max_schemas cbrt ceil ceiling centuries century chain char char_length character character_length characteristics check checkpoint checkpoint_threshold chr class close cluster coalesce col_description collate collation collations column columns combine comment comments commit committed compression concat concat_ws concurrently configuration conflict connection constant_or_null constraint constraints contains content continue conversion copy copy_database corr cos cosh cost cot count count_if count_star countif covar_pop covar_samp create create_sort_key cross csv cube current current_catalog current_connection_id current_database current_date current_localtime current_localtimestamp current_query current_query_id current_role current_schema current_schemas current_setting current_transaction_id current_user currval cursor custom_extension_repository custom_profiling_settings custom_user_agent cycle damerau_levenshtein data database database_list database_size date date_add date_diff date_part date_sub date_trunc datediff datepart datesub datetime datetrunc day dayname dayofmonth dayofweek dayofyear days deallocate debug_asof_iejoin debug_checkpoint_abort debug_force_external debug_force_no_cross_product debug_skip_checkpoint_on_commit debug_verify_vector debug_window_mode dec decade decades decimal declare decode default default_block_size default_collation default_null_order default_order default_secret_storage defaults deferrable deferred definer degrees delete delimiter delimiters depends desc describe detach dictionary disable disable_checkpoint_on_shutdown disable_logging disable_object_cache disable_optimizer disable_parquet_prefetching disable_print_progress_bar disable_profile disable_profiling disable_progress_bar disable_timestamptz_casts disable_verification disable_verify_external disable_verify_fetch_row disable_verify_parallelism disable_verify_serializer disabled_compression_methods disabled_filesystems disabled_log_types disabled_optimizers discard distinct divide do document domain double drop duckdb_api duckdb_columns duckdb_constraints duckdb_databases duckdb_dependencies duckdb_extensions duckdb_external_file_cache duckdb_functions duckdb_indexes duckdb_keywords duckdb_log_contexts duckdb_logs duckdb_logs_parsed duckdb_memory duckdb_optimizers duckdb_prepared_statements duckdb_schemas duckdb_secret_types duckdb_secrets duckdb_sequences duckdb_settings duckdb_table_sample duckdb_tables duckdb_temporary_files duckdb_types duckdb_variables duckdb_views dynamic_or_filter_threshold each editdist3 element_at else enable enable_checkpoint_on_shutdown enable_external_access enable_external_file_cache enable_fsst_vectors enable_geoparquet_conversion enable_http_logging enable_http_metadata_cache enable_logging enable_macro_dependencies enable_object_cache enable_optimizer enable_print_progress_bar enable_profile enable_profiling enable_progress_bar enable_progress_bar_print enable_verification enable_view_dependencies enabled_log_types encode encoding encrypted end ends_with entropy enum enum_code enum_first enum_last enum_range enum_range_boundary epoch epoch_ms epoch_ns epoch_us equi_width_bins era error errors_as_json escape even event except exclude excluding exclusive execute exists exp explain explain_output export export_state extension extension_directory extension_versions extensions external external_threads extract factorial false family favg fdiv fetch file_search_path filter finalize first flatten float float4 float8 floor fmod following for force force_bitpacking_mode force_checkpoint force_compression foreign format formatReadableDecimalSize formatReadableSize format_bytes format_pg_type format_type forward freeze from from_base64 from_binary from_hex from_json from_json_strict fsum full function functions gamma gcd gen_random_uuid generate_series generate_subscripts generated geomean geometric_mean get_bit get_block_size get_current_time get_current_timestamp getvariable glob global grade_up grant granted greatest greatest_common_divisor group group_concat grouping grouping_id groups guid hamming handler having header hex histogram histogram_exact histogram_values hold home_directory hour hours http_logging_output http_proxy http_proxy_password http_proxy_username hugeint identity ieee_floating_point_ops if ignore ilike ilike_escape immediate immediate_transaction_mode immutable implicit import import_database in in_search_path include including increment index index_scan_max_count index_scan_percentage indexes inet_client_addr inet_client_port inet_server_addr inet_server_port inherit inherits initially inline inner inout input insensitive insert install instead instr int int1 int128 int16 int2 int32 int4 int64 int8 integer integer_division integral intersect interval into invoker is is_histogram_other_bin isfinite isinf isnan isnull isodow isolation isoyear jaccard jaro_similarity jaro_winkler_similarity join json json_array json_array_length json_contains json_deserialize_sql json_each json_execute_serialized_sql json_exists json_extract json_extract_path json_extract_path_text json_extract_string json_group_array json_group_object json_group_structure json_keys json_merge_patch json_object json_pretty json_quote json_serialize_plan json_serialize_sql json_structure json_transform json_transform_strict json_tree json_type json_valid json_value julian kahan_sum key kurtosis kurtosis_pop label lambda lambda_syntax language large last last_day late_materialization_max_rows lateral lcase lcm leading leakproof least least_common_multiple left left_grapheme len length length_grapheme level levenshtein lgamma like like_escape limit list list_aggr list_aggregate list_any_value list_append list_apply list_approx_count_distinct list_avg list_bit_and list_bit_or list_bit_xor list_bool_and list_bool_or list_cat list_concat list_contains list_cosine_distance list_cosine_similarity list_count list_distance list_distinct list_dot_product list_element list_entropy list_extract list_filter list_first list_grade_up list_has list_has_all list_has_any list_histogram list_indexof list_inner_product list_intersect list_kurtosis list_kurtosis_pop list_last list_mad list_max list_median list_min list_mode list_negative_dot_product list_negative_inner_product list_pack list_position list_prepend list_product list_reduce list_resize list_reverse list_reverse_sort list_select list_sem list_skewness list_slice list_sort list_stddev_pop list_stddev_samp list_string_agg list_sum list_transform list_unique list_value list_var_pop list_var_samp list_where list_zip listagg listen ln load local location lock lock_configuration locked log log10 log2 log_query_path logged logging_level logging_mode logging_storage logical long lower lpad ltrim macro mad make_date make_time make_timestamp make_timestamp_ns make_timestamptz map map_concat map_contains map_contains_entry map_contains_value map_entries map_extract map_extract_value map_from_entries map_keys map_to_pg_oid map_values mapping match materialized max max_by max_expression_depth max_memory max_temp_directory_size max_vacuum_tasks maxvalue md5 md5_number md5_number_lower md5_number_upper mean median memory_limit merge_join_threshold metadata_info method microsecond microseconds millennia millennium millisecond milliseconds min min_by minute minutes minvalue mismatches mod mode month monthname months move multiply name names nanosecond national natural nchar nested_loop_join_threshold new next nextafter nextval nfc_normalize no none normalized_interval not not_ilike_escape not_like_escape nothing notify notnull now nowait null null_order nullif nulls numeric nvarchar obj_description object octet_length of off offset oid oids old old_implicit_casting on only operator option options or ord order order_by_non_integer_literal ordered_aggregate_threshold ordinality others out outer over overlaps overlay overriding owned owner pandas_analyze_sample pandas_scan parallel parquet_bloom_probe parquet_file_metadata parquet_kv_metadata parquet_metadata parquet_metadata_cache parquet_scan parquet_schema parse_dirname parse_dirpath parse_duckdb_log_message parse_filename parse_path parser partial partition partitioned partitioned_write_flush_threshold partitioned_write_max_open_files passing password percent perfect_ht_threshold persistent pi pivot pivot_filter_threshold pivot_limit pivot_longer pivot_wider placing plans platform policy position positional pow power pragma pragma_collations pragma_database_size pragma_metadata_info pragma_platform pragma_show pragma_storage_info pragma_table_info pragma_user_agent pragma_version preceding precision prefer_range_joins prefetch_all_parquet_files prefix prepare prepared preserve preserve_identifier_case preserve_insertion_order primary printf prior privileges procedural procedure produce_arrow_string_view product profile_output profiling_mode profiling_output program progress_bar_time publication python_enable_replacements python_map_function python_scan_all_frames qualify quantile quantile_cont quantile_disc quarter quarters query query_table quote radians random range read read_blob read_csv read_csv_auto read_json read_json_auto read_json_objects read_json_objects_auto read_ndjson read_ndjson_auto read_ndjson_objects read_parquet read_text real reassign recheck recursive reduce ref references referencing refresh regexp_escape regexp_extract regexp_extract_all regexp_full_match regexp_matches regexp_replace regexp_split_to_array regexp_split_to_table regr_avgx regr_avgy regr_count regr_intercept regr_r2 regr_slope regr_sxx regr_sxy regr_syy reindex relative release remap_struct rename repeat repeat_row repeatable replace replica reservoir_quantile reset respect restart restrict returning returns reverse revoke right right_grapheme role rollback rollup round round_even roundbankers row row_to_json rows rpad rtrim rule sample savepoint scalar_subquery_error_on_multiple_rows scheduler_process_partial schema schemas scope scroll search search_path second seconds secret secret_directory security select sem semi seq_scan sequence sequences serializable server session session_user set set_bit setof sets setseed sha1 sha256 share shobj_description short show show_databases show_tables show_tables_expanded sign signbit signed similar simple sin sinh skewness skip smallint snapshot sniff_csv some sorted split split_part sql sqrt stable standalone start starts_with statement statistics stats stddev stddev_pop stddev_samp stdin stdout storage storage_compatibility_version storage_info stored str_split str_split_regex streaming_buffer_size strftime strict string string_agg string_split string_split_regex string_to_array strip strip_accents strlen strpos strptime struct struct_concat struct_extract struct_extract_at struct_insert struct_pack subscription substr substring substring_grapheme subtract suffix sum sum_no_overflow sumkahan summarize summary symmetric sysid system table table_info tables tablesample tablespace tan tanh temp temp_directory template temporary test_all_types test_vector_types text then threads ties time time_bucket timestamp timestamp_ms timestamp_ns timestamp_s timestamp_us timestamptz timetz timetz_byte_comparable timezone timezone_hour timezone_minute tinyint to to_base to_base64 to_binary to_centuries to_days to_decades to_hex to_hours to_json to_microseconds to_millennia to_milliseconds to_minutes to_months to_quarters to_seconds to_timestamp to_weeks to_years today trailing transaction transaction_timestamp transform translate treat trigger trim true trunc truncate truncate_duckdb_logs trusted try_cast try_strptime txid_current type typeof types ubigint ucase uhugeint uint128 uint16 uint32 uint64 uint8 uinteger unbin unbounded uncommitted unencrypted unhex unicode union union_extract union_tag union_value unique unknown unlisten unlogged unnest unpack unpivot unpivot_list until update upper url_decode url_encode use user user_agent username using usmallint utinyint uuid uuid_extract_timestamp uuid_extract_version uuidv4 uuidv7 vacuum valid validate validator value values var_pop var_samp varbinary varchar variable variadic variance varint varying vector_type verbose verify_external verify_fetch_row verify_parallelism verify_serializer version view views virtual volatile wal_autocheckpoint wavg week weekday weekofyear weeks weighted_avg when where which_secret whitespace window with within without work worker_threads wrapper write write_log xml xmlattributes xmlconcat xmlelement xmlexists xmlforest xmlnamespaces xmlparse xmlpi xmlroot xmlserialize xmltable xor year years yearweek yes zone zstd_min_string_length | || ~ ~~ ~~* ~~~`,
18
- types:
19
- "JSON bigint binary bit bitstring blob bool boolean bpchar bytea char date datetime dec decimal double enum float float4 float8 guid hugeint int int1 int128 int16 int2 int32 int4 int64 int8 integer integral interval list logical long map null numeric nvarchar oid real row short signed smallint string struct text time timestamp timestamp_ms timestamp_ns timestamp_s timestamp_us timestamptz timetz tinyint ubigint uhugeint uint128 uint16 uint32 uint64 uint8 uinteger union usmallint utinyint uuid varbinary varchar varint",
20
- };
21
-
22
- export const DuckDBDialect = SQLDialect.define(DuckDBDialectSpec);