@prisma-next/sql-relational-core 0.3.0-pr.94.2 → 0.3.0-pr.95.2

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 (152) hide show
  1. package/dist/ast/adapter-types.d.ts +28 -0
  2. package/dist/ast/adapter-types.d.ts.map +1 -0
  3. package/dist/ast/codec-types.d.ts +141 -0
  4. package/dist/ast/codec-types.d.ts.map +1 -0
  5. package/dist/ast/common.d.ts +7 -0
  6. package/dist/ast/common.d.ts.map +1 -0
  7. package/dist/ast/delete.d.ts +8 -0
  8. package/dist/ast/delete.d.ts.map +1 -0
  9. package/dist/ast/driver-types.d.ts +20 -0
  10. package/dist/ast/driver-types.d.ts.map +1 -0
  11. package/dist/ast/insert.d.ts +8 -0
  12. package/dist/ast/insert.d.ts.map +1 -0
  13. package/dist/ast/join.d.ts +6 -0
  14. package/dist/ast/join.d.ts.map +1 -0
  15. package/dist/ast/order.d.ts +6 -0
  16. package/dist/ast/order.d.ts.map +1 -0
  17. package/dist/ast/predicate.d.ts +4 -0
  18. package/dist/ast/predicate.d.ts.map +1 -0
  19. package/dist/ast/select.d.ts +18 -0
  20. package/dist/ast/select.d.ts.map +1 -0
  21. package/dist/ast/types.d.ts +130 -0
  22. package/dist/ast/types.d.ts.map +1 -0
  23. package/dist/ast/update.d.ts +9 -0
  24. package/dist/ast/update.d.ts.map +1 -0
  25. package/dist/ast/util.d.ts +2 -0
  26. package/dist/ast/util.d.ts.map +1 -0
  27. package/dist/chunk-2BWK6XEY.js +13 -0
  28. package/dist/chunk-2BWK6XEY.js.map +1 -0
  29. package/dist/chunk-2F7DSEOU.js +8 -0
  30. package/dist/chunk-2F7DSEOU.js.map +1 -0
  31. package/dist/chunk-2MAKNVCP.js +86 -0
  32. package/dist/chunk-2MAKNVCP.js.map +1 -0
  33. package/dist/chunk-36WJWNHT.js +1 -0
  34. package/dist/chunk-36WJWNHT.js.map +1 -0
  35. package/dist/chunk-3F4RFQIB.js +169 -0
  36. package/dist/chunk-3F4RFQIB.js.map +1 -0
  37. package/dist/chunk-7I3EMQID.js +16 -0
  38. package/dist/chunk-7I3EMQID.js.map +1 -0
  39. package/dist/chunk-G52ENULI.js +1 -0
  40. package/dist/chunk-G52ENULI.js.map +1 -0
  41. package/dist/chunk-HV334QHG.js +320 -0
  42. package/dist/chunk-HV334QHG.js.map +1 -0
  43. package/dist/chunk-KYSP7L5C.js +16 -0
  44. package/dist/chunk-KYSP7L5C.js.map +1 -0
  45. package/dist/chunk-L2FZU4IV.js +170 -0
  46. package/dist/chunk-L2FZU4IV.js.map +1 -0
  47. package/dist/chunk-U7AXAUJA.js +1 -0
  48. package/dist/chunk-U7AXAUJA.js.map +1 -0
  49. package/dist/errors.d.ts +2 -0
  50. package/dist/errors.d.ts.map +1 -0
  51. package/dist/exports/ast.d.ts +14 -0
  52. package/dist/exports/ast.d.ts.map +1 -0
  53. package/dist/exports/ast.js +46 -0
  54. package/dist/exports/ast.js.map +1 -0
  55. package/dist/exports/errors.d.ts +2 -0
  56. package/dist/exports/errors.d.ts.map +1 -0
  57. package/dist/exports/errors.js +9 -0
  58. package/dist/exports/errors.js.map +1 -0
  59. package/dist/exports/guards.d.ts +2 -0
  60. package/dist/exports/guards.d.ts.map +1 -0
  61. package/dist/exports/guards.js +31 -0
  62. package/dist/exports/guards.js.map +1 -0
  63. package/dist/exports/operations-registry.d.ts +2 -0
  64. package/dist/exports/operations-registry.d.ts.map +1 -0
  65. package/dist/exports/operations-registry.js +9 -0
  66. package/dist/exports/operations-registry.js.map +1 -0
  67. package/dist/exports/param.d.ts +3 -0
  68. package/dist/exports/param.d.ts.map +1 -0
  69. package/dist/exports/param.js +7 -0
  70. package/dist/exports/param.js.map +1 -0
  71. package/dist/exports/plan.d.ts +2 -0
  72. package/dist/exports/plan.d.ts.map +1 -0
  73. package/dist/exports/plan.js +7 -0
  74. package/dist/exports/plan.js.map +1 -0
  75. package/dist/exports/query-lane-context.d.ts +2 -0
  76. package/dist/exports/query-lane-context.d.ts.map +1 -0
  77. package/dist/exports/query-lane-context.js +2 -0
  78. package/dist/exports/query-lane-context.js.map +1 -0
  79. package/dist/exports/schema.d.ts +3 -0
  80. package/dist/exports/schema.d.ts.map +1 -0
  81. package/dist/exports/schema.js +13 -0
  82. package/dist/exports/schema.js.map +1 -0
  83. package/dist/exports/types.d.ts +2 -0
  84. package/dist/exports/types.d.ts.map +1 -0
  85. package/dist/exports/types.js +10 -0
  86. package/dist/exports/types.js.map +1 -0
  87. package/dist/index.d.ts +9 -0
  88. package/dist/index.d.ts.map +1 -0
  89. package/dist/index.js +81 -0
  90. package/dist/index.js.map +1 -0
  91. package/dist/operations-registry.d.ts +5 -0
  92. package/dist/operations-registry.d.ts.map +1 -0
  93. package/dist/param.d.ts +4 -0
  94. package/dist/param.d.ts.map +1 -0
  95. package/dist/plan.d.ts +23 -0
  96. package/dist/plan.d.ts.map +1 -0
  97. package/dist/query-lane-context.d.ts +16 -0
  98. package/dist/query-lane-context.d.ts.map +1 -0
  99. package/dist/schema.d.ts +68 -0
  100. package/dist/schema.d.ts.map +1 -0
  101. package/dist/types.d.ts +371 -0
  102. package/dist/types.d.ts.map +1 -0
  103. package/dist/{exports/guards.d.mts → utils/guards.d.ts} +19 -25
  104. package/dist/utils/guards.d.ts.map +1 -0
  105. package/package.json +51 -29
  106. package/dist/errors-BwxypN2Q.mjs +0 -3
  107. package/dist/errors-CLx1Ylq0.d.mts +0 -2
  108. package/dist/exports/ast.d.mts +0 -123
  109. package/dist/exports/ast.d.mts.map +0 -1
  110. package/dist/exports/ast.mjs +0 -304
  111. package/dist/exports/ast.mjs.map +0 -1
  112. package/dist/exports/errors.d.mts +0 -2
  113. package/dist/exports/errors.mjs +0 -3
  114. package/dist/exports/guards.d.mts.map +0 -1
  115. package/dist/exports/guards.mjs +0 -3
  116. package/dist/exports/operations-registry.d.mts +0 -5
  117. package/dist/exports/operations-registry.mjs +0 -3
  118. package/dist/exports/param.d.mts +0 -5
  119. package/dist/exports/param.mjs +0 -3
  120. package/dist/exports/plan.d.mts +0 -2
  121. package/dist/exports/plan.mjs +0 -17
  122. package/dist/exports/plan.mjs.map +0 -1
  123. package/dist/exports/query-lane-context.d.mts +0 -2
  124. package/dist/exports/query-lane-context.mjs +0 -1
  125. package/dist/exports/schema.d.mts +0 -5
  126. package/dist/exports/schema.mjs +0 -4
  127. package/dist/exports/types.d.mts +0 -4
  128. package/dist/exports/types.mjs +0 -3
  129. package/dist/guards-4T0IByJo.mjs +0 -132
  130. package/dist/guards-4T0IByJo.mjs.map +0 -1
  131. package/dist/index.d.mts +0 -12
  132. package/dist/index.mjs +0 -12
  133. package/dist/operations-registry-7R5KE2-5.mjs +0 -152
  134. package/dist/operations-registry-7R5KE2-5.mjs.map +0 -1
  135. package/dist/operations-registry-CIcn4f2P.d.mts +0 -9
  136. package/dist/operations-registry-CIcn4f2P.d.mts.map +0 -1
  137. package/dist/param-B4LzVPv2.d.mts +0 -8
  138. package/dist/param-B4LzVPv2.d.mts.map +0 -1
  139. package/dist/param-BFvNAaHR.mjs +0 -14
  140. package/dist/param-BFvNAaHR.mjs.map +0 -1
  141. package/dist/plan-9PvH-Tu3.d.mts +0 -157
  142. package/dist/plan-9PvH-Tu3.d.mts.map +0 -1
  143. package/dist/query-lane-context-wr_XXnB5.d.mts +0 -143
  144. package/dist/query-lane-context-wr_XXnB5.d.mts.map +0 -1
  145. package/dist/schema-BsY2EXAf.mjs +0 -148
  146. package/dist/schema-BsY2EXAf.mjs.map +0 -1
  147. package/dist/schema-Dse48uyP.d.mts +0 -63
  148. package/dist/schema-Dse48uyP.d.mts.map +0 -1
  149. package/dist/types-Bg2kUmUA.d.mts +0 -359
  150. package/dist/types-Bg2kUmUA.d.mts.map +0 -1
  151. package/dist/types-D_FRJvm0.mjs +0 -18
  152. package/dist/types-D_FRJvm0.mjs.map +0 -1
@@ -0,0 +1,170 @@
1
+ import {
2
+ attachOperationsToColumnBuilder
3
+ } from "./chunk-3F4RFQIB.js";
4
+
5
+ // src/schema.ts
6
+ import { planInvalid } from "@prisma-next/plan";
7
+ var ColumnBuilderImpl = class {
8
+ constructor(table, column, storageColumn) {
9
+ this.table = table;
10
+ this.column = column;
11
+ this.storageColumn = storageColumn;
12
+ }
13
+ kind = "column";
14
+ get columnMeta() {
15
+ return this.storageColumn;
16
+ }
17
+ // Type-level helper property (not used at runtime)
18
+ get __jsType() {
19
+ return void 0;
20
+ }
21
+ /**
22
+ * Converts this column builder to a ColumnRef expression.
23
+ * This is the canonical way to get an AST node from a builder.
24
+ */
25
+ toExpr() {
26
+ return Object.freeze({
27
+ kind: "col",
28
+ table: this.table,
29
+ column: this.column
30
+ });
31
+ }
32
+ createBinaryBuilder(op, value) {
33
+ if (value == null) {
34
+ throw planInvalid(
35
+ "Parameter placeholder or expression source required for column comparison"
36
+ );
37
+ }
38
+ if ("toExpr" in value && typeof value.toExpr === "function") {
39
+ return Object.freeze({
40
+ kind: "binary",
41
+ op,
42
+ left: this.toExpr(),
43
+ right: value
44
+ });
45
+ }
46
+ if ("kind" in value && value.kind === "param-placeholder") {
47
+ return Object.freeze({
48
+ kind: "binary",
49
+ op,
50
+ left: this.toExpr(),
51
+ right: value
52
+ });
53
+ }
54
+ throw planInvalid("Parameter placeholder or expression source required for column comparison");
55
+ }
56
+ eq(value) {
57
+ return this.createBinaryBuilder("eq", value);
58
+ }
59
+ neq(value) {
60
+ return this.createBinaryBuilder("neq", value);
61
+ }
62
+ gt(value) {
63
+ return this.createBinaryBuilder("gt", value);
64
+ }
65
+ lt(value) {
66
+ return this.createBinaryBuilder("lt", value);
67
+ }
68
+ gte(value) {
69
+ return this.createBinaryBuilder("gte", value);
70
+ }
71
+ lte(value) {
72
+ return this.createBinaryBuilder("lte", value);
73
+ }
74
+ asc() {
75
+ return Object.freeze({
76
+ kind: "order",
77
+ expr: this.toExpr(),
78
+ dir: "asc"
79
+ });
80
+ }
81
+ desc() {
82
+ return Object.freeze({
83
+ kind: "order",
84
+ expr: this.toExpr(),
85
+ dir: "desc"
86
+ });
87
+ }
88
+ };
89
+ var TableBuilderImpl = class {
90
+ kind = "table";
91
+ columns;
92
+ _name;
93
+ constructor(name, columns) {
94
+ this._name = name;
95
+ this.columns = columns;
96
+ }
97
+ get name() {
98
+ return this._name;
99
+ }
100
+ };
101
+ function buildColumns(tableName, storage, _contract, operationRegistry, contractCapabilities) {
102
+ const table = storage.tables[tableName];
103
+ if (!table) {
104
+ throw planInvalid(`Unknown table ${tableName}`);
105
+ }
106
+ const tableColumns = table.columns;
107
+ const result = {};
108
+ const assignColumn = (columnName, columnDef) => {
109
+ const columnBuilder = new ColumnBuilderImpl(
110
+ tableName,
111
+ columnName,
112
+ columnDef
113
+ );
114
+ const builderWithOps = attachOperationsToColumnBuilder(
115
+ columnBuilder,
116
+ columnDef,
117
+ operationRegistry,
118
+ contractCapabilities
119
+ );
120
+ result[columnName] = builderWithOps;
121
+ };
122
+ for (const columnName of Object.keys(tableColumns)) {
123
+ const columnDef = tableColumns[columnName];
124
+ if (!columnDef) continue;
125
+ assignColumn(columnName, columnDef);
126
+ }
127
+ return result;
128
+ }
129
+ function createTableProxy(table) {
130
+ return new Proxy(table, {
131
+ get(target, prop) {
132
+ if (prop === "name" || prop === "kind" || prop === "columns") {
133
+ return Reflect.get(target, prop);
134
+ }
135
+ if (typeof prop === "string" && prop in target.columns) {
136
+ return target.columns[prop];
137
+ }
138
+ return void 0;
139
+ }
140
+ });
141
+ }
142
+ function schema(context) {
143
+ const contract = context.contract;
144
+ const storage = contract.storage;
145
+ const tables = {};
146
+ const contractCapabilities = contract.capabilities;
147
+ const operationRegistry = context.operations;
148
+ for (const tableName of Object.keys(storage.tables)) {
149
+ const columns = buildColumns(
150
+ tableName,
151
+ storage,
152
+ contract,
153
+ operationRegistry,
154
+ contractCapabilities
155
+ );
156
+ const table = new TableBuilderImpl(tableName, columns);
157
+ const proxiedTable = createTableProxy(table);
158
+ tables[tableName] = Object.freeze(
159
+ proxiedTable
160
+ );
161
+ }
162
+ return Object.freeze({ tables });
163
+ }
164
+
165
+ export {
166
+ ColumnBuilderImpl,
167
+ TableBuilderImpl,
168
+ schema
169
+ };
170
+ //# sourceMappingURL=chunk-L2FZU4IV.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/schema.ts"],"sourcesContent":["import type { OperationRegistry } from '@prisma-next/operations';\nimport { planInvalid } from '@prisma-next/plan';\nimport type {\n ExtractCodecTypes,\n ExtractOperationTypes,\n SqlContract,\n SqlStorage,\n StorageColumn,\n} from '@prisma-next/sql-contract/types';\nimport type { BinaryOp, ColumnRef, ExpressionSource, TableRef } from './ast/types';\nimport { attachOperationsToColumnBuilder } from './operations-registry';\nimport type { QueryLaneContext } from './query-lane-context';\nimport type {\n BinaryBuilder,\n CodecTypes as CodecTypesType,\n ColumnBuilder,\n ComputeColumnJsType,\n OperationTypeSignature,\n OperationTypes,\n OrderBuilder,\n ParamPlaceholder,\n} from './types';\n\ntype TableColumns<Table extends { columns: Record<string, StorageColumn> }> = Table['columns'];\n\ntype ColumnBuilders<\n Contract extends SqlContract<SqlStorage>,\n TableName extends string,\n Columns extends Record<string, StorageColumn>,\n CodecTypes extends CodecTypesType,\n Operations extends OperationTypes,\n> = {\n readonly [K in keyof Columns]: ColumnBuilder<\n K & string,\n Columns[K],\n ComputeColumnJsType<Contract, TableName, K & string, Columns[K], CodecTypes>,\n Operations\n >;\n};\n\nexport class ColumnBuilderImpl<\n ColumnName extends string,\n ColumnMeta extends StorageColumn,\n JsType = unknown,\n> implements ExpressionSource\n{\n readonly kind = 'column' as const;\n\n constructor(\n readonly table: string,\n readonly column: ColumnName,\n private readonly storageColumn: ColumnMeta,\n ) {}\n\n get columnMeta(): ColumnMeta {\n return this.storageColumn;\n }\n\n // Type-level helper property (not used at runtime)\n get __jsType(): JsType {\n return undefined as unknown as JsType;\n }\n\n /**\n * Converts this column builder to a ColumnRef expression.\n * This is the canonical way to get an AST node from a builder.\n */\n toExpr(): ColumnRef {\n return Object.freeze({\n kind: 'col' as const,\n table: this.table,\n column: this.column,\n });\n }\n\n private createBinaryBuilder(\n op: BinaryOp,\n value: ParamPlaceholder | ExpressionSource,\n ): BinaryBuilder<ColumnName, ColumnMeta, JsType> {\n if (value == null) {\n throw planInvalid(\n 'Parameter placeholder or expression source required for column comparison',\n );\n }\n // Check for ExpressionSource first (has toExpr method)\n if ('toExpr' in value && typeof value.toExpr === 'function') {\n return Object.freeze({\n kind: 'binary' as const,\n op,\n left: this.toExpr(),\n right: value,\n }) as BinaryBuilder<ColumnName, ColumnMeta, JsType>;\n }\n // Must be a ParamPlaceholder\n if ('kind' in value && value.kind === 'param-placeholder') {\n return Object.freeze({\n kind: 'binary' as const,\n op,\n left: this.toExpr(),\n right: value,\n }) as BinaryBuilder<ColumnName, ColumnMeta, JsType>;\n }\n throw planInvalid('Parameter placeholder or expression source required for column comparison');\n }\n\n eq(value: ParamPlaceholder | ExpressionSource): BinaryBuilder<ColumnName, ColumnMeta, JsType> {\n return this.createBinaryBuilder('eq', value);\n }\n\n neq(value: ParamPlaceholder | ExpressionSource): BinaryBuilder<ColumnName, ColumnMeta, JsType> {\n return this.createBinaryBuilder('neq', value);\n }\n\n gt(value: ParamPlaceholder | ExpressionSource): BinaryBuilder<ColumnName, ColumnMeta, JsType> {\n return this.createBinaryBuilder('gt', value);\n }\n\n lt(value: ParamPlaceholder | ExpressionSource): BinaryBuilder<ColumnName, ColumnMeta, JsType> {\n return this.createBinaryBuilder('lt', value);\n }\n\n gte(value: ParamPlaceholder | ExpressionSource): BinaryBuilder<ColumnName, ColumnMeta, JsType> {\n return this.createBinaryBuilder('gte', value);\n }\n\n lte(value: ParamPlaceholder | ExpressionSource): BinaryBuilder<ColumnName, ColumnMeta, JsType> {\n return this.createBinaryBuilder('lte', value);\n }\n\n asc(): OrderBuilder<ColumnName, ColumnMeta, JsType> {\n return Object.freeze({\n kind: 'order' as const,\n expr: this.toExpr(),\n dir: 'asc' as const,\n }) as OrderBuilder<ColumnName, ColumnMeta, JsType>;\n }\n\n desc(): OrderBuilder<ColumnName, ColumnMeta, JsType> {\n return Object.freeze({\n kind: 'order' as const,\n expr: this.toExpr(),\n dir: 'desc' as const,\n }) as OrderBuilder<ColumnName, ColumnMeta, JsType>;\n }\n}\n\nexport class TableBuilderImpl<\n Contract extends SqlContract<SqlStorage>,\n TableName extends string,\n Columns extends Record<string, StorageColumn>,\n CodecTypes extends CodecTypesType,\n Operations extends OperationTypes,\n> implements TableRef\n{\n readonly kind = 'table' as const;\n readonly columns: ColumnBuilders<Contract, TableName, Columns, CodecTypes, Operations>;\n private readonly _name: TableName;\n\n constructor(\n name: TableName,\n columns: ColumnBuilders<Contract, TableName, Columns, CodecTypes, Operations>,\n ) {\n this._name = name;\n this.columns = columns;\n }\n\n get name(): string {\n return this._name;\n }\n}\n\nfunction buildColumns<\n Contract extends SqlContract<SqlStorage>,\n TableName extends keyof Contract['storage']['tables'] & string,\n CodecTypes extends CodecTypesType,\n Operations extends OperationTypes,\n>(\n tableName: TableName,\n storage: SqlStorage,\n _contract: Contract,\n operationRegistry?: OperationRegistry,\n contractCapabilities?: Record<string, Record<string, boolean>>,\n): ColumnBuilders<\n Contract,\n TableName,\n Contract['storage']['tables'][TableName]['columns'],\n CodecTypes,\n Operations\n> {\n const table = storage.tables[tableName];\n\n if (!table) {\n throw planInvalid(`Unknown table ${tableName}`);\n }\n\n type Columns = Contract['storage']['tables'][TableName]['columns'];\n const tableColumns = table.columns as Columns;\n\n const result = {} as {\n [K in keyof Columns]: ColumnBuilder<\n K & string,\n Columns[K],\n ComputeColumnJsType<Contract, TableName, K & string, Columns[K], CodecTypes>,\n Operations\n >;\n };\n\n const assignColumn = <ColumnKey extends keyof Columns & string>(\n columnName: ColumnKey,\n columnDef: Columns[ColumnKey],\n ) => {\n type JsType = ComputeColumnJsType<\n Contract,\n TableName,\n ColumnKey,\n Columns[ColumnKey],\n CodecTypes\n >;\n\n const columnBuilder = new ColumnBuilderImpl<ColumnKey, Columns[ColumnKey], JsType>(\n tableName,\n columnName,\n columnDef,\n );\n\n const builderWithOps = attachOperationsToColumnBuilder<\n ColumnKey,\n Columns[ColumnKey],\n JsType,\n Operations\n >(\n columnBuilder as unknown as ColumnBuilder<\n ColumnKey,\n Columns[ColumnKey],\n JsType,\n Record<string, never>\n >,\n columnDef,\n operationRegistry,\n contractCapabilities,\n );\n\n (result as Record<string, unknown>)[columnName] = builderWithOps;\n };\n\n for (const columnName of Object.keys(tableColumns) as Array<keyof Columns & string>) {\n const columnDef = tableColumns[columnName];\n if (!columnDef) continue;\n assignColumn(columnName, columnDef);\n }\n\n return result as ColumnBuilders<Contract, TableName, Columns, CodecTypes, Operations>;\n}\n\n/**\n * Creates a Proxy that enables accessing table columns directly on the table object,\n * in addition to the standard `table.columns.columnName` syntax.\n *\n * This allows both access patterns:\n * - `tables.user.columns.id` (standard access)\n * - `tables.user.id` (convenience access via proxy)\n *\n * The proxy intercepts property access and routes column name lookups to\n * `table.columns[prop]`, while preserving direct access to table properties\n * like `name`, `kind`, and `columns`.\n */\nfunction createTableProxy<\n Contract extends SqlContract<SqlStorage>,\n TableName extends string,\n Columns extends Record<string, StorageColumn>,\n CodecTypes extends CodecTypesType,\n Operations extends OperationTypes,\n>(\n table: TableBuilderImpl<Contract, TableName, Columns, CodecTypes, Operations>,\n): TableBuilderImpl<Contract, TableName, Columns, CodecTypes, Operations> {\n return new Proxy(table, {\n get(target, prop) {\n if (prop === 'name' || prop === 'kind' || prop === 'columns') {\n return Reflect.get(target, prop);\n }\n if (typeof prop === 'string' && prop in target.columns) {\n return target.columns[prop as keyof typeof target.columns];\n }\n return undefined;\n },\n });\n}\n\ntype ExtractSchemaTables<\n Contract extends SqlContract<SqlStorage>,\n CodecTypes extends CodecTypesType,\n Operations extends OperationTypes,\n> = {\n readonly [TableName in keyof Contract['storage']['tables']]: TableBuilderImpl<\n Contract,\n TableName & string,\n TableColumns<Contract['storage']['tables'][TableName]>,\n CodecTypes,\n Operations\n > &\n TableRef;\n};\n\nexport type SchemaHandle<\n Contract extends SqlContract<SqlStorage> = SqlContract<SqlStorage>,\n CodecTypes extends CodecTypesType = CodecTypesType,\n Operations extends OperationTypes = Record<string, never>,\n> = {\n readonly tables: ExtractSchemaTables<Contract, CodecTypes, Operations>;\n};\n\ntype SchemaReturnType<Contract extends SqlContract<SqlStorage>> = SchemaHandle<\n Contract,\n ExtractCodecTypes<Contract>,\n ToOperationTypes<ExtractOperationTypes<Contract>>\n>;\n\ntype NormalizeOperationTypes<T> = {\n [TypeId in keyof T]: {\n [Method in keyof T[TypeId]]: T[TypeId][Method] extends OperationTypeSignature\n ? T[TypeId][Method]\n : OperationTypeSignature;\n };\n};\n\ntype ToOperationTypes<T> = T extends OperationTypes ? T : NormalizeOperationTypes<T>;\n\n/**\n * Creates a schema handle for building SQL queries.\n *\n * @param context - Query lane context containing contract, codec and operation registries\n * @returns A schema handle with typed table builders\n *\n * @example\n * ```typescript\n * const schemaHandle = schema<Contract>(context);\n * const userTable = schemaHandle.tables.user;\n * ```\n */\nexport function schema<Contract extends SqlContract<SqlStorage>>(\n context: QueryLaneContext<Contract>,\n): SchemaReturnType<Contract> {\n const contract = context.contract;\n const storage = contract.storage;\n type CodecTypes = ExtractCodecTypes<Contract>;\n type Operations = ToOperationTypes<ExtractOperationTypes<Contract>>;\n const tables = {} as ExtractSchemaTables<Contract, CodecTypes, Operations>;\n const contractCapabilities = contract.capabilities;\n\n const operationRegistry = context.operations;\n\n for (const tableName of Object.keys(storage.tables) as Array<\n keyof Contract['storage']['tables'] & string\n >) {\n const columns = buildColumns<Contract, typeof tableName, CodecTypes, Operations>(\n tableName,\n storage,\n contract,\n operationRegistry,\n contractCapabilities,\n );\n const table = new TableBuilderImpl<\n Contract,\n typeof tableName & string,\n Contract['storage']['tables'][typeof tableName]['columns'],\n CodecTypes,\n Operations\n >(tableName, columns);\n const proxiedTable = createTableProxy<\n Contract,\n typeof tableName & string,\n Contract['storage']['tables'][typeof tableName]['columns'],\n CodecTypes,\n Operations\n >(table);\n (tables as Record<string, unknown>)[tableName] = Object.freeze(\n proxiedTable,\n ) as ExtractSchemaTables<Contract, CodecTypes, Operations>[typeof tableName];\n }\n\n return Object.freeze({ tables }) as SchemaReturnType<Contract>;\n}\n\nexport type { ColumnBuilderImpl as Column, TableBuilderImpl as Table };\n"],"mappings":"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","names":[]}
@@ -0,0 +1 @@
1
+ //# sourceMappingURL=chunk-U7AXAUJA.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
@@ -0,0 +1,2 @@
1
+ export { planInvalid, planUnsupported } from '@prisma-next/plan';
2
+ //# sourceMappingURL=errors.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../src/errors.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC"}
@@ -0,0 +1,14 @@
1
+ export * from '../ast/adapter-types';
2
+ export * from '../ast/codec-types';
3
+ export * from '../ast/common';
4
+ export * from '../ast/delete';
5
+ export * from '../ast/driver-types';
6
+ export * from '../ast/insert';
7
+ export * from '../ast/join';
8
+ export * from '../ast/order';
9
+ export * from '../ast/predicate';
10
+ export * from '../ast/select';
11
+ export * from '../ast/types';
12
+ export * from '../ast/update';
13
+ export * from '../ast/util';
14
+ //# sourceMappingURL=ast.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ast.d.ts","sourceRoot":"","sources":["../../src/exports/ast.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAC;AACrC,cAAc,oBAAoB,CAAC;AACnC,cAAc,eAAe,CAAC;AAC9B,cAAc,eAAe,CAAC;AAC9B,cAAc,qBAAqB,CAAC;AACpC,cAAc,eAAe,CAAC;AAC9B,cAAc,aAAa,CAAC;AAC5B,cAAc,cAAc,CAAC;AAC7B,cAAc,kBAAkB,CAAC;AACjC,cAAc,eAAe,CAAC;AAC9B,cAAc,cAAc,CAAC;AAC7B,cAAc,eAAe,CAAC;AAC9B,cAAc,aAAa,CAAC"}
@@ -0,0 +1,46 @@
1
+ import {
2
+ codec,
3
+ compact,
4
+ createBinaryExpr,
5
+ createCodecRegistry,
6
+ createColumnRef,
7
+ createDeleteAst,
8
+ createExistsExpr,
9
+ createInsertAst,
10
+ createJoin,
11
+ createJoinOnBuilder,
12
+ createJoinOnExpr,
13
+ createLiteralExpr,
14
+ createOperationExpr,
15
+ createOrderByItem,
16
+ createParamRef,
17
+ createSelectAst,
18
+ createTableRef,
19
+ createUpdateAst,
20
+ defineCodecs,
21
+ isOperationExpr
22
+ } from "../chunk-HV334QHG.js";
23
+ import "../chunk-2BWK6XEY.js";
24
+ export {
25
+ codec,
26
+ compact,
27
+ createBinaryExpr,
28
+ createCodecRegistry,
29
+ createColumnRef,
30
+ createDeleteAst,
31
+ createExistsExpr,
32
+ createInsertAst,
33
+ createJoin,
34
+ createJoinOnBuilder,
35
+ createJoinOnExpr,
36
+ createLiteralExpr,
37
+ createOperationExpr,
38
+ createOrderByItem,
39
+ createParamRef,
40
+ createSelectAst,
41
+ createTableRef,
42
+ createUpdateAst,
43
+ defineCodecs,
44
+ isOperationExpr
45
+ };
46
+ //# sourceMappingURL=ast.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
@@ -0,0 +1,2 @@
1
+ export { planInvalid, planUnsupported } from '../errors';
2
+ //# sourceMappingURL=errors.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../src/exports/errors.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC"}
@@ -0,0 +1,9 @@
1
+ import {
2
+ planInvalid,
3
+ planUnsupported
4
+ } from "../chunk-2F7DSEOU.js";
5
+ export {
6
+ planInvalid,
7
+ planUnsupported
8
+ };
9
+ //# sourceMappingURL=errors.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
@@ -0,0 +1,2 @@
1
+ export { collectColumnRefs, expressionFromSource, extractBaseColumnRef, getColumnInfo, getColumnMeta, getOperationExpr, isColumnBuilder, isExpressionBuilder, isExpressionSource, isOperationExpr, isParamPlaceholder, isValueSource, toExpression, } from '../utils/guards';
2
+ //# sourceMappingURL=guards.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"guards.d.ts","sourceRoot":"","sources":["../../src/exports/guards.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,iBAAiB,EACjB,oBAAoB,EACpB,oBAAoB,EACpB,aAAa,EACb,aAAa,EACb,gBAAgB,EAChB,eAAe,EACf,mBAAmB,EACnB,kBAAkB,EAClB,eAAe,EACf,kBAAkB,EAClB,aAAa,EACb,YAAY,GACb,MAAM,iBAAiB,CAAC"}
@@ -0,0 +1,31 @@
1
+ import {
2
+ collectColumnRefs,
3
+ expressionFromSource,
4
+ extractBaseColumnRef,
5
+ getColumnInfo,
6
+ getColumnMeta,
7
+ getOperationExpr,
8
+ isColumnBuilder,
9
+ isExpressionBuilder,
10
+ isExpressionSource,
11
+ isOperationExpr,
12
+ isParamPlaceholder,
13
+ isValueSource,
14
+ toExpression
15
+ } from "../chunk-2MAKNVCP.js";
16
+ export {
17
+ collectColumnRefs,
18
+ expressionFromSource,
19
+ extractBaseColumnRef,
20
+ getColumnInfo,
21
+ getColumnMeta,
22
+ getOperationExpr,
23
+ isColumnBuilder,
24
+ isExpressionBuilder,
25
+ isExpressionSource,
26
+ isOperationExpr,
27
+ isParamPlaceholder,
28
+ isValueSource,
29
+ toExpression
30
+ };
31
+ //# sourceMappingURL=guards.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
@@ -0,0 +1,2 @@
1
+ export { attachOperationsToColumnBuilder } from '../operations-registry';
2
+ //# sourceMappingURL=operations-registry.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"operations-registry.d.ts","sourceRoot":"","sources":["../../src/exports/operations-registry.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,+BAA+B,EAAE,MAAM,wBAAwB,CAAC"}
@@ -0,0 +1,9 @@
1
+ import "../chunk-G52ENULI.js";
2
+ import {
3
+ attachOperationsToColumnBuilder
4
+ } from "../chunk-3F4RFQIB.js";
5
+ import "../chunk-2MAKNVCP.js";
6
+ export {
7
+ attachOperationsToColumnBuilder
8
+ };
9
+ //# sourceMappingURL=operations-registry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
@@ -0,0 +1,3 @@
1
+ export type { Parameter } from '../param';
2
+ export { param } from '../param';
3
+ //# sourceMappingURL=param.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"param.d.ts","sourceRoot":"","sources":["../../src/exports/param.ts"],"names":[],"mappings":"AAAA,YAAY,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AAC1C,OAAO,EAAE,KAAK,EAAE,MAAM,UAAU,CAAC"}
@@ -0,0 +1,7 @@
1
+ import {
2
+ param
3
+ } from "../chunk-7I3EMQID.js";
4
+ export {
5
+ param
6
+ };
7
+ //# sourceMappingURL=param.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
@@ -0,0 +1,2 @@
1
+ export * from '../plan';
2
+ //# sourceMappingURL=plan.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"plan.d.ts","sourceRoot":"","sources":["../../src/exports/plan.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC"}
@@ -0,0 +1,7 @@
1
+ import {
2
+ augmentDescriptorWithColumnMeta
3
+ } from "../chunk-KYSP7L5C.js";
4
+ export {
5
+ augmentDescriptorWithColumnMeta
6
+ };
7
+ //# sourceMappingURL=plan.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
@@ -0,0 +1,2 @@
1
+ export * from '../query-lane-context';
2
+ //# sourceMappingURL=query-lane-context.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"query-lane-context.d.ts","sourceRoot":"","sources":["../../src/exports/query-lane-context.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAC"}
@@ -0,0 +1,2 @@
1
+ import "../chunk-U7AXAUJA.js";
2
+ //# sourceMappingURL=query-lane-context.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
@@ -0,0 +1,3 @@
1
+ export type { ColumnBuilderImpl as Column, SchemaHandle, TableBuilderImpl as Table, } from '../schema';
2
+ export { ColumnBuilderImpl, schema, TableBuilderImpl } from '../schema';
3
+ //# sourceMappingURL=schema.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"schema.d.ts","sourceRoot":"","sources":["../../src/exports/schema.ts"],"names":[],"mappings":"AAAA,YAAY,EACV,iBAAiB,IAAI,MAAM,EAC3B,YAAY,EACZ,gBAAgB,IAAI,KAAK,GAC1B,MAAM,WAAW,CAAC;AACnB,OAAO,EAAE,iBAAiB,EAAE,MAAM,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAC"}
@@ -0,0 +1,13 @@
1
+ import {
2
+ ColumnBuilderImpl,
3
+ TableBuilderImpl,
4
+ schema
5
+ } from "../chunk-L2FZU4IV.js";
6
+ import "../chunk-3F4RFQIB.js";
7
+ import "../chunk-2MAKNVCP.js";
8
+ export {
9
+ ColumnBuilderImpl,
10
+ TableBuilderImpl,
11
+ schema
12
+ };
13
+ //# sourceMappingURL=schema.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
@@ -0,0 +1,2 @@
1
+ export * from '../types';
2
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/exports/types.ts"],"names":[],"mappings":"AAAA,cAAc,UAAU,CAAC"}
@@ -0,0 +1,10 @@
1
+ import "../chunk-36WJWNHT.js";
2
+ import {
3
+ createOrderBuilder,
4
+ isColumnBuilder
5
+ } from "../chunk-2BWK6XEY.js";
6
+ export {
7
+ createOrderBuilder,
8
+ isColumnBuilder
9
+ };
10
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
@@ -0,0 +1,9 @@
1
+ export * from './exports/ast';
2
+ export * from './exports/errors';
3
+ export * from './exports/operations-registry';
4
+ export * from './exports/param';
5
+ export * from './exports/plan';
6
+ export * from './exports/query-lane-context';
7
+ export * from './exports/schema';
8
+ export * from './exports/types';
9
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,eAAe,CAAC;AAC9B,cAAc,kBAAkB,CAAC;AACjC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,iBAAiB,CAAC;AAChC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,8BAA8B,CAAC;AAC7C,cAAc,kBAAkB,CAAC;AACjC,cAAc,iBAAiB,CAAC"}
package/dist/index.js ADDED
@@ -0,0 +1,81 @@
1
+ import "./chunk-U7AXAUJA.js";
2
+ import {
3
+ ColumnBuilderImpl,
4
+ TableBuilderImpl,
5
+ schema
6
+ } from "./chunk-L2FZU4IV.js";
7
+ import {
8
+ param
9
+ } from "./chunk-7I3EMQID.js";
10
+ import "./chunk-36WJWNHT.js";
11
+ import "./chunk-G52ENULI.js";
12
+ import {
13
+ attachOperationsToColumnBuilder
14
+ } from "./chunk-3F4RFQIB.js";
15
+ import "./chunk-2MAKNVCP.js";
16
+ import {
17
+ planInvalid,
18
+ planUnsupported
19
+ } from "./chunk-2F7DSEOU.js";
20
+ import {
21
+ codec,
22
+ compact,
23
+ createBinaryExpr,
24
+ createCodecRegistry,
25
+ createColumnRef,
26
+ createDeleteAst,
27
+ createExistsExpr,
28
+ createInsertAst,
29
+ createJoin,
30
+ createJoinOnBuilder,
31
+ createJoinOnExpr,
32
+ createLiteralExpr,
33
+ createOperationExpr,
34
+ createOrderByItem,
35
+ createParamRef,
36
+ createSelectAst,
37
+ createTableRef,
38
+ createUpdateAst,
39
+ defineCodecs,
40
+ isOperationExpr
41
+ } from "./chunk-HV334QHG.js";
42
+ import {
43
+ createOrderBuilder,
44
+ isColumnBuilder
45
+ } from "./chunk-2BWK6XEY.js";
46
+ import {
47
+ augmentDescriptorWithColumnMeta
48
+ } from "./chunk-KYSP7L5C.js";
49
+ export {
50
+ ColumnBuilderImpl,
51
+ TableBuilderImpl,
52
+ attachOperationsToColumnBuilder,
53
+ augmentDescriptorWithColumnMeta,
54
+ codec,
55
+ compact,
56
+ createBinaryExpr,
57
+ createCodecRegistry,
58
+ createColumnRef,
59
+ createDeleteAst,
60
+ createExistsExpr,
61
+ createInsertAst,
62
+ createJoin,
63
+ createJoinOnBuilder,
64
+ createJoinOnExpr,
65
+ createLiteralExpr,
66
+ createOperationExpr,
67
+ createOrderBuilder,
68
+ createOrderByItem,
69
+ createParamRef,
70
+ createSelectAst,
71
+ createTableRef,
72
+ createUpdateAst,
73
+ defineCodecs,
74
+ isColumnBuilder,
75
+ isOperationExpr,
76
+ param,
77
+ planInvalid,
78
+ planUnsupported,
79
+ schema
80
+ };
81
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
@@ -0,0 +1,5 @@
1
+ import type { OperationRegistry } from '@prisma-next/operations';
2
+ import type { StorageColumn } from '@prisma-next/sql-contract/types';
3
+ import type { ColumnBuilder, OperationTypes } from './types';
4
+ export declare function attachOperationsToColumnBuilder<ColumnName extends string, ColumnMeta extends StorageColumn, JsType = unknown, Operations extends OperationTypes = Record<string, never>>(columnBuilder: ColumnBuilder<ColumnName, ColumnMeta, JsType, Record<string, never>>, columnMeta: ColumnMeta, registry: OperationRegistry | undefined, contractCapabilities?: Record<string, Record<string, boolean>>): ColumnBuilder<ColumnName, ColumnMeta, JsType, Operations>;
5
+ //# sourceMappingURL=operations-registry.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"operations-registry.d.ts","sourceRoot":"","sources":["../src/operations-registry.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAGjE,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAUrE,OAAO,KAAK,EAGV,aAAa,EAEb,cAAc,EAEf,MAAM,SAAS,CAAC;AAyMjB,wBAAgB,+BAA+B,CAC7C,UAAU,SAAS,MAAM,EACzB,UAAU,SAAS,aAAa,EAChC,MAAM,GAAG,OAAO,EAChB,UAAU,SAAS,cAAc,GAAG,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,EAEzD,aAAa,EAAE,aAAa,CAAC,UAAU,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,EACnF,UAAU,EAAE,UAAU,EACtB,QAAQ,EAAE,iBAAiB,GAAG,SAAS,EACvC,oBAAoB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,GAC7D,aAAa,CAAC,UAAU,EAAE,UAAU,EAAE,MAAM,EAAE,UAAU,CAAC,CA4C3D"}
@@ -0,0 +1,4 @@
1
+ import type { ParamPlaceholder } from './types';
2
+ export type Parameter = ParamPlaceholder;
3
+ export declare function param(name: string): Parameter;
4
+ //# sourceMappingURL=param.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"param.d.ts","sourceRoot":"","sources":["../src/param.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAEhD,MAAM,MAAM,SAAS,GAAG,gBAAgB,CAAC;AAEzC,wBAAgB,KAAK,CAAC,IAAI,EAAE,MAAM,GAAG,SAAS,CAS7C"}
package/dist/plan.d.ts ADDED
@@ -0,0 +1,23 @@
1
+ import type { ExecutionPlan, ParamDescriptor } from '@prisma-next/contract/types';
2
+ import type { StorageColumn } from '@prisma-next/sql-contract/types';
3
+ import type { QueryAst } from './ast/types';
4
+ /**
5
+ * SQL query plan produced by lanes before lowering.
6
+ *
7
+ * Lanes build ASTs and metadata but do not perform SQL lowering.
8
+ * The `sql` field is absent - lowering happens in the runtime executor.
9
+ *
10
+ * Structurally aligns with ExecutionPlan<Row, QueryAst> (without sql field) to maintain
11
+ * compatibility with ExecutionPlan/Plan-based utilities.
12
+ * The generic parameter `_Row` is preserved for type extraction via ResultType.
13
+ */
14
+ export interface SqlQueryPlan<_Row = unknown> extends Pick<ExecutionPlan<_Row, QueryAst>, 'params' | 'meta'> {
15
+ readonly ast: QueryAst;
16
+ readonly _Row?: _Row;
17
+ }
18
+ /**
19
+ * Augments the last ParamDescriptor in the array with codecId and nativeType from columnMeta.
20
+ * This is used when building WHERE expressions to ensure param descriptors have type information.
21
+ */
22
+ export declare function augmentDescriptorWithColumnMeta(descriptors: ParamDescriptor[], columnMeta: StorageColumn | undefined): void;
23
+ //# sourceMappingURL=plan.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"plan.d.ts","sourceRoot":"","sources":["../src/plan.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAClF,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AACrE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAE5C;;;;;;;;;GASG;AACH,MAAM,WAAW,YAAY,CAAC,IAAI,GAAG,OAAO,CAC1C,SAAQ,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,QAAQ,CAAC,EAAE,QAAQ,GAAG,MAAM,CAAC;IAC9D,QAAQ,CAAC,GAAG,EAAE,QAAQ,CAAC;IAGvB,QAAQ,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC;CACtB;AAED;;;GAGG;AACH,wBAAgB,+BAA+B,CAC7C,WAAW,EAAE,eAAe,EAAE,EAC9B,UAAU,EAAE,aAAa,GAAG,SAAS,GACpC,IAAI,CASN"}