@prisma-next/adapter-sqlite 0.5.0-dev.9 → 0.6.0-dev.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.
- package/README.md +3 -3
- package/dist/{adapter-BG7_o_3h.d.mts → adapter-DswQk5bT.d.mts} +8 -5
- package/dist/adapter-DswQk5bT.d.mts.map +1 -0
- package/dist/{adapter-CcfiEUus.mjs → adapter-NxKQDxOd.mjs} +60 -64
- package/dist/adapter-NxKQDxOd.mjs.map +1 -0
- package/dist/adapter.d.mts +1 -2
- package/dist/adapter.mjs +2 -4
- package/dist/codec-types.d.mts +2 -42
- package/dist/codec-types.mjs +1 -3
- package/dist/column-types.d.mts +1 -5
- package/dist/column-types.d.mts.map +1 -1
- package/dist/column-types.mjs +3 -8
- package/dist/column-types.mjs.map +1 -1
- package/dist/control.d.mts +41 -3
- package/dist/control.d.mts.map +1 -1
- package/dist/control.mjs +439 -11
- package/dist/control.mjs.map +1 -1
- package/dist/{descriptor-meta-Bg-c1LmL.mjs → descriptor-meta-DA4lgWT_.mjs} +2 -2
- package/dist/{descriptor-meta-Bg-c1LmL.mjs.map → descriptor-meta-DA4lgWT_.mjs.map} +1 -1
- package/dist/runtime.d.mts +2 -3
- package/dist/runtime.d.mts.map +1 -1
- package/dist/runtime.mjs +21 -15
- package/dist/runtime.mjs.map +1 -1
- package/dist/{types-gAqc4ucF.d.mts → types-bTlW__XL.d.mts} +1 -1
- package/dist/types-bTlW__XL.d.mts.map +1 -0
- package/dist/types.d.mts +1 -1
- package/dist/types.mjs +1 -1
- package/package.json +24 -19
- package/src/core/adapter.ts +107 -74
- package/src/core/column-types.ts +1 -7
- package/src/core/control-adapter.ts +330 -15
- package/src/core/control-mutation-defaults.ts +358 -0
- package/src/core/runtime-adapter.ts +19 -12
- package/src/exports/codec-types.ts +2 -6
- package/src/exports/column-types.ts +0 -1
- package/src/exports/control.ts +45 -1
- package/dist/adapter-BG7_o_3h.d.mts.map +0 -1
- package/dist/adapter-CcfiEUus.mjs.map +0 -1
- package/dist/codec-ids-o_Z8i4nt.mjs +0 -15
- package/dist/codec-ids-o_Z8i4nt.mjs.map +0 -1
- package/dist/codec-types.d.mts.map +0 -1
- package/dist/codecs-ANhEQz9X.mjs +0 -102
- package/dist/codecs-ANhEQz9X.mjs.map +0 -1
- package/dist/types-gAqc4ucF.d.mts.map +0 -1
- package/src/core/codec-ids.ts +0 -14
- package/src/core/codecs.ts +0 -129
- package/src/core/sql-utils.ts +0 -35
package/README.md
CHANGED
|
@@ -118,7 +118,7 @@ flowchart TD
|
|
|
118
118
|
- Used in `contract.d.ts` generation
|
|
119
119
|
|
|
120
120
|
**Column Types Export (`column-types.ts`)**
|
|
121
|
-
- Exports column descriptors for built-in types: `textColumn`, `integerColumn`, `realColumn`, `blobColumn`, `
|
|
121
|
+
- Exports column descriptors for built-in types: `textColumn`, `integerColumn`, `realColumn`, `blobColumn`, `datetimeColumn`, `jsonColumn`, `bigintColumn`
|
|
122
122
|
- Uses `as const` to preserve literal `codecId` types through the type system
|
|
123
123
|
|
|
124
124
|
**Types Export (`types.ts`)**
|
|
@@ -187,8 +187,8 @@ DELETE FROM "user" WHERE "user"."id" = ? RETURNING "user"."id", "user"."email"
|
|
|
187
187
|
|
|
188
188
|
## Exports
|
|
189
189
|
|
|
190
|
-
- `./codec-types`: SQLite codec types (`CodecTypes`, `JsonValue
|
|
191
|
-
- `./column-types`: Column type descriptors (`textColumn`, `integerColumn`, `realColumn`, `blobColumn`, `
|
|
190
|
+
- `./codec-types`: SQLite codec types (`CodecTypes`, `JsonValue`)
|
|
191
|
+
- `./column-types`: Column type descriptors (`textColumn`, `integerColumn`, `realColumn`, `blobColumn`, `datetimeColumn`, `jsonColumn`, `bigintColumn`)
|
|
192
192
|
- `./types`: SQLite-specific types
|
|
193
193
|
- `./control`: Control-plane entry point (stubbed for future migration support)
|
|
194
194
|
- `./runtime`: Runtime-plane entry point (runtime adapter descriptor)
|
|
@@ -1,17 +1,20 @@
|
|
|
1
|
-
import { n as SqliteContract, r as SqliteLoweredStatement, t as SqliteAdapterOptions } from "./types-
|
|
2
|
-
import { Adapter, AdapterProfile, AnyQueryAst,
|
|
1
|
+
import { n as SqliteContract, r as SqliteLoweredStatement, t as SqliteAdapterOptions } from "./types-bTlW__XL.mjs";
|
|
2
|
+
import { Adapter, AdapterProfile, AnyQueryAst, LowererContext } from "@prisma-next/sql-relational-core/ast";
|
|
3
3
|
|
|
4
4
|
//#region src/core/adapter.d.ts
|
|
5
5
|
declare class SqliteAdapterImpl implements Adapter<AnyQueryAst, SqliteContract, SqliteLoweredStatement> {
|
|
6
6
|
readonly familyId: "sql";
|
|
7
7
|
readonly targetId: "sqlite";
|
|
8
8
|
readonly profile: AdapterProfile<'sqlite'>;
|
|
9
|
-
private readonly codecRegistry;
|
|
10
9
|
constructor(options?: SqliteAdapterOptions);
|
|
11
|
-
parameterizedCodecs(): ReadonlyArray<CodecParamsDescriptor>;
|
|
12
10
|
lower(ast: AnyQueryAst, context: LowererContext<SqliteContract>): SqliteLoweredStatement;
|
|
13
11
|
}
|
|
12
|
+
/**
|
|
13
|
+
* Lower a SQL query AST into a SQLite-flavored `{ sql, params }` payload.
|
|
14
|
+
*
|
|
15
|
+
* Shared between the runtime adapter (`SqliteAdapterImpl.lower`) and the control adapter (`SqliteControlAdapter.lower`) so both produce byte-identical SQL for the same AST and contract.
|
|
16
|
+
*/
|
|
14
17
|
declare function createSqliteAdapter(options?: SqliteAdapterOptions): Readonly<SqliteAdapterImpl>;
|
|
15
18
|
//#endregion
|
|
16
19
|
export { createSqliteAdapter as t };
|
|
17
|
-
//# sourceMappingURL=adapter-
|
|
20
|
+
//# sourceMappingURL=adapter-DswQk5bT.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"adapter-DswQk5bT.d.mts","names":[],"sources":["../src/core/adapter.ts"],"mappings":";;;;cA6CM,iBAAA,YAA6B,OAAA,CAAQ,WAAA,EAAa,cAAA,EAAgB,sBAAA;EAAA,SAC7D,QAAA;EAAA,SACA,QAAA;EAAA,SAEA,OAAA,EAAS,cAAA;cAEN,OAAA,GAAU,oBAAA;EAStB,KAAA,CAAM,GAAA,EAAK,WAAA,EAAa,OAAA,EAAS,cAAA,CAAe,cAAA,IAAkB,sBAAA;AAAA;;;;;;iBAwepD,mBAAA,CAAoB,OAAA,GAAU,oBAAA,GAAoB,QAAA,CAAA,iBAAA"}
|
|
@@ -1,26 +1,6 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
|
|
4
|
-
//#region src/core/sql-utils.ts
|
|
5
|
-
var SqlEscapeError = class extends Error {
|
|
6
|
-
constructor(message, value, kind) {
|
|
7
|
-
super(message);
|
|
8
|
-
this.value = value;
|
|
9
|
-
this.kind = kind;
|
|
10
|
-
this.name = "SqlEscapeError";
|
|
11
|
-
}
|
|
12
|
-
};
|
|
13
|
-
function quoteIdentifier(identifier) {
|
|
14
|
-
if (identifier.length === 0) throw new SqlEscapeError("Identifier cannot be empty", identifier, "identifier");
|
|
15
|
-
if (identifier.includes("\0")) throw new SqlEscapeError("Identifier cannot contain null bytes", identifier.replace(/\0/g, "\\0"), "identifier");
|
|
16
|
-
return `"${identifier.replace(/"/g, "\"\"")}"`;
|
|
17
|
-
}
|
|
18
|
-
function escapeLiteral(value) {
|
|
19
|
-
if (value.includes("\0")) throw new SqlEscapeError("Literal value cannot contain null bytes", value.replace(/\0/g, "\\0"), "literal");
|
|
20
|
-
return value.replace(/'/g, "''");
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
//#endregion
|
|
1
|
+
import { APP_SPACE_ID } from "@prisma-next/framework-components/control";
|
|
2
|
+
import { parseContractMarkerRow } from "@prisma-next/sql-runtime";
|
|
3
|
+
import { escapeLiteral, quoteIdentifier } from "@prisma-next/target-sqlite/sql-utils";
|
|
24
4
|
//#region src/core/adapter.ts
|
|
25
5
|
const defaultCapabilities = Object.freeze({ sql: {
|
|
26
6
|
orderBy: true,
|
|
@@ -34,53 +14,49 @@ var SqliteAdapterImpl = class {
|
|
|
34
14
|
familyId = "sql";
|
|
35
15
|
targetId = "sqlite";
|
|
36
16
|
profile;
|
|
37
|
-
codecRegistry = (() => {
|
|
38
|
-
const registry = createCodecRegistry();
|
|
39
|
-
for (const definition of Object.values(codecDefinitions)) registry.register(definition.codec);
|
|
40
|
-
return registry;
|
|
41
|
-
})();
|
|
42
17
|
constructor(options) {
|
|
43
18
|
this.profile = Object.freeze({
|
|
44
19
|
id: options?.profileId ?? "sqlite/default@1",
|
|
45
20
|
target: "sqlite",
|
|
46
21
|
capabilities: defaultCapabilities,
|
|
47
|
-
|
|
48
|
-
readMarkerStatement: () => ({
|
|
49
|
-
sql: "select core_hash, profile_hash, contract_json, canonical_version, updated_at, app_tag, meta from prisma_contract_marker where id = ?",
|
|
50
|
-
params: [1]
|
|
51
|
-
})
|
|
22
|
+
readMarker: (queryable) => readSqliteMarker(queryable)
|
|
52
23
|
});
|
|
53
24
|
}
|
|
54
|
-
parameterizedCodecs() {
|
|
55
|
-
return [];
|
|
56
|
-
}
|
|
57
25
|
lower(ast, context) {
|
|
58
|
-
|
|
59
|
-
const params = [];
|
|
60
|
-
for (const ref of collectedParamRefs) params.push(ref.value);
|
|
61
|
-
let sql;
|
|
62
|
-
const node = ast;
|
|
63
|
-
switch (node.kind) {
|
|
64
|
-
case "select":
|
|
65
|
-
sql = renderSelect(node, context.contract);
|
|
66
|
-
break;
|
|
67
|
-
case "insert":
|
|
68
|
-
sql = renderInsert(node);
|
|
69
|
-
break;
|
|
70
|
-
case "update":
|
|
71
|
-
sql = renderUpdate(node, context.contract);
|
|
72
|
-
break;
|
|
73
|
-
case "delete":
|
|
74
|
-
sql = renderDelete(node);
|
|
75
|
-
break;
|
|
76
|
-
default: throw new Error(`Unsupported AST node kind: ${node.kind}`);
|
|
77
|
-
}
|
|
78
|
-
return Object.freeze({
|
|
79
|
-
sql,
|
|
80
|
-
params
|
|
81
|
-
});
|
|
26
|
+
return renderLoweredSql(ast, context.contract);
|
|
82
27
|
}
|
|
83
28
|
};
|
|
29
|
+
/**
|
|
30
|
+
* Lower a SQL query AST into a SQLite-flavored `{ sql, params }` payload.
|
|
31
|
+
*
|
|
32
|
+
* Shared between the runtime adapter (`SqliteAdapterImpl.lower`) and the control adapter (`SqliteControlAdapter.lower`) so both produce byte-identical SQL for the same AST and contract.
|
|
33
|
+
*/
|
|
34
|
+
function renderLoweredSql(ast, contract) {
|
|
35
|
+
const collectedParamRefs = ast.collectParamRefs();
|
|
36
|
+
const params = [];
|
|
37
|
+
for (const ref of collectedParamRefs) params.push(ref.value);
|
|
38
|
+
let sql;
|
|
39
|
+
const node = ast;
|
|
40
|
+
switch (node.kind) {
|
|
41
|
+
case "select":
|
|
42
|
+
sql = renderSelect(node, contract);
|
|
43
|
+
break;
|
|
44
|
+
case "insert":
|
|
45
|
+
sql = renderInsert(node);
|
|
46
|
+
break;
|
|
47
|
+
case "update":
|
|
48
|
+
sql = renderUpdate(node, contract);
|
|
49
|
+
break;
|
|
50
|
+
case "delete":
|
|
51
|
+
sql = renderDelete(node);
|
|
52
|
+
break;
|
|
53
|
+
default: throw new Error(`Unsupported AST node kind: ${node.kind}`);
|
|
54
|
+
}
|
|
55
|
+
return Object.freeze({
|
|
56
|
+
sql,
|
|
57
|
+
params
|
|
58
|
+
});
|
|
59
|
+
}
|
|
84
60
|
function renderSelect(ast, contract) {
|
|
85
61
|
return [
|
|
86
62
|
`SELECT ${ast.distinct ? "DISTINCT " : ""}${renderProjection(ast.projection, contract)}`,
|
|
@@ -321,12 +297,32 @@ function renderDelete(ast) {
|
|
|
321
297
|
}
|
|
322
298
|
function renderReturning(returning) {
|
|
323
299
|
if (!returning?.length) return "";
|
|
324
|
-
return ` RETURNING ${returning.map((
|
|
300
|
+
return ` RETURNING ${returning.map((item) => {
|
|
301
|
+
if (item.expr.kind === "column-ref") {
|
|
302
|
+
const rendered = `${quoteIdentifier(item.expr.table)}.${quoteIdentifier(item.expr.column)}`;
|
|
303
|
+
return item.expr.column === item.alias ? rendered : `${rendered} AS ${quoteIdentifier(item.alias)}`;
|
|
304
|
+
}
|
|
305
|
+
return `${renderExpr(item.expr)} AS ${quoteIdentifier(item.alias)}`;
|
|
306
|
+
}).join(", ")}`;
|
|
307
|
+
}
|
|
308
|
+
async function readSqliteMarker(queryable) {
|
|
309
|
+
if ((await queryable.query("select 1 from sqlite_master where type = 'table' and name = ?", ["_prisma_marker"])).rows.length === 0) return { kind: "no-table" };
|
|
310
|
+
const row = (await queryable.query("select core_hash, profile_hash, contract_json, canonical_version, updated_at, app_tag, meta, invariants from _prisma_marker where space = ?", [APP_SPACE_ID])).rows[0];
|
|
311
|
+
if (!row) return { kind: "absent" };
|
|
312
|
+
const raw = row;
|
|
313
|
+
const invariants = typeof raw["invariants"] === "string" ? JSON.parse(raw["invariants"]) : raw["invariants"];
|
|
314
|
+
return {
|
|
315
|
+
kind: "present",
|
|
316
|
+
record: parseContractMarkerRow({
|
|
317
|
+
...raw,
|
|
318
|
+
invariants
|
|
319
|
+
})
|
|
320
|
+
};
|
|
325
321
|
}
|
|
326
322
|
function createSqliteAdapter(options) {
|
|
327
323
|
return Object.freeze(new SqliteAdapterImpl(options));
|
|
328
324
|
}
|
|
329
|
-
|
|
330
325
|
//#endregion
|
|
331
|
-
export { createSqliteAdapter as t };
|
|
332
|
-
|
|
326
|
+
export { renderLoweredSql as n, createSqliteAdapter as t };
|
|
327
|
+
|
|
328
|
+
//# sourceMappingURL=adapter-NxKQDxOd.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"adapter-NxKQDxOd.mjs","names":[],"sources":["../src/core/adapter.ts"],"sourcesContent":["import { APP_SPACE_ID } from '@prisma-next/framework-components/control';\nimport type {\n Adapter,\n AdapterProfile,\n AggregateExpr,\n AnyExpression,\n AnyFromSource,\n AnyQueryAst,\n BinaryExpr,\n ColumnRef,\n DeleteAst,\n InsertAst,\n InsertValue,\n JoinAst,\n JoinOnExpr,\n JsonArrayAggExpr,\n JsonObjectExpr,\n ListExpression,\n LiteralExpr,\n LowererContext,\n MarkerReadResult,\n NullCheckExpr,\n OperationExpr,\n OrderByItem,\n ProjectionItem,\n SelectAst,\n SqlQueryable,\n SubqueryExpr,\n UpdateAst,\n} from '@prisma-next/sql-relational-core/ast';\nimport { parseContractMarkerRow } from '@prisma-next/sql-runtime';\nimport { escapeLiteral, quoteIdentifier } from '@prisma-next/target-sqlite/sql-utils';\nimport type { SqliteAdapterOptions, SqliteContract, SqliteLoweredStatement } from './types';\n\nconst defaultCapabilities = Object.freeze({\n sql: {\n orderBy: true,\n limit: true,\n lateral: false,\n jsonAgg: true,\n returning: true,\n enums: false,\n },\n});\n\nclass SqliteAdapterImpl implements Adapter<AnyQueryAst, SqliteContract, SqliteLoweredStatement> {\n readonly familyId = 'sql' as const;\n readonly targetId = 'sqlite' as const;\n\n readonly profile: AdapterProfile<'sqlite'>;\n\n constructor(options?: SqliteAdapterOptions) {\n this.profile = Object.freeze({\n id: options?.profileId ?? 'sqlite/default@1',\n target: 'sqlite',\n capabilities: defaultCapabilities,\n readMarker: (queryable: SqlQueryable) => readSqliteMarker(queryable),\n });\n }\n\n lower(ast: AnyQueryAst, context: LowererContext<SqliteContract>): SqliteLoweredStatement {\n return renderLoweredSql(ast, context.contract);\n }\n}\n\n/**\n * Lower a SQL query AST into a SQLite-flavored `{ sql, params }` payload.\n *\n * Shared between the runtime adapter (`SqliteAdapterImpl.lower`) and the control adapter (`SqliteControlAdapter.lower`) so both produce byte-identical SQL for the same AST and contract.\n */\nexport function renderLoweredSql(\n ast: AnyQueryAst,\n contract: SqliteContract,\n): SqliteLoweredStatement {\n const collectedParamRefs = ast.collectParamRefs();\n const params: unknown[] = [];\n for (const ref of collectedParamRefs) {\n params.push(ref.value);\n }\n\n let sql: string;\n\n const node = ast;\n switch (node.kind) {\n case 'select':\n sql = renderSelect(node, contract);\n break;\n case 'insert':\n sql = renderInsert(node);\n break;\n case 'update':\n sql = renderUpdate(node, contract);\n break;\n case 'delete':\n sql = renderDelete(node);\n break;\n default:\n throw new Error(`Unsupported AST node kind: ${(node as { kind: string }).kind}`);\n }\n\n return Object.freeze({ sql, params });\n}\n\nfunction renderSelect(ast: SelectAst, contract?: SqliteContract): string {\n const distinctPrefix = ast.distinct ? 'DISTINCT ' : '';\n const selectClause = `SELECT ${distinctPrefix}${renderProjection(ast.projection, contract)}`;\n const fromClause = `FROM ${renderSource(ast.from, contract)}`;\n\n const joinsClause = ast.joins?.length\n ? ast.joins.map((join) => renderJoin(join, contract)).join(' ')\n : '';\n\n const whereClause = ast.where ? `WHERE ${renderExpr(ast.where, contract)}` : '';\n const groupByClause = ast.groupBy?.length\n ? `GROUP BY ${ast.groupBy.map((expr) => renderExpr(expr, contract)).join(', ')}`\n : '';\n const havingClause = ast.having ? `HAVING ${renderExpr(ast.having, contract)}` : '';\n const orderClause = ast.orderBy?.length\n ? `ORDER BY ${ast.orderBy\n .map((order) => `${renderExpr(order.expr, contract)} ${order.dir.toUpperCase()}`)\n .join(', ')}`\n : '';\n const limitClause = typeof ast.limit === 'number' ? `LIMIT ${ast.limit}` : '';\n const offsetClause = typeof ast.offset === 'number' ? `OFFSET ${ast.offset}` : '';\n\n return [\n selectClause,\n fromClause,\n joinsClause,\n whereClause,\n groupByClause,\n havingClause,\n orderClause,\n limitClause,\n offsetClause,\n ]\n .filter((part) => part.length > 0)\n .join(' ')\n .trim();\n}\n\nfunction renderProjection(\n projection: ReadonlyArray<ProjectionItem>,\n contract?: SqliteContract,\n): string {\n return projection\n .map((item) => {\n const alias = quoteIdentifier(item.alias);\n if (item.expr.kind === 'literal') {\n return `${renderLiteral(item.expr)} AS ${alias}`;\n }\n return `${renderExpr(item.expr, contract)} AS ${alias}`;\n })\n .join(', ');\n}\n\nfunction renderSource(source: AnyFromSource, contract?: SqliteContract): string {\n const node = source;\n switch (node.kind) {\n case 'table-source': {\n const table = quoteIdentifier(node.name);\n if (!node.alias) {\n return table;\n }\n return `${table} AS ${quoteIdentifier(node.alias)}`;\n }\n case 'derived-table-source':\n return `(${renderSelect(node.query, contract)}) AS ${quoteIdentifier(node.alias)}`;\n default:\n throw new Error(`Unsupported source node kind: ${(node as { kind: string }).kind}`);\n }\n}\n\nfunction renderExpr(expr: AnyExpression, contract?: SqliteContract): string {\n const node = expr;\n switch (node.kind) {\n case 'column-ref':\n return renderColumn(node);\n case 'identifier-ref':\n return quoteIdentifier(node.name);\n case 'operation':\n return renderOperation(node, contract);\n case 'subquery':\n return renderSubqueryExpr(node, contract);\n case 'aggregate':\n return renderAggregateExpr(node, contract);\n case 'json-object':\n return renderJsonObjectExpr(node, contract);\n case 'json-array-agg':\n return renderJsonArrayAggExpr(node, contract);\n case 'binary':\n return renderBinary(node, contract);\n case 'and':\n if (node.exprs.length === 0) {\n return 'TRUE';\n }\n return `(${node.exprs.map((part) => renderExpr(part, contract)).join(' AND ')})`;\n case 'or':\n if (node.exprs.length === 0) {\n return 'FALSE';\n }\n return `(${node.exprs.map((part) => renderExpr(part, contract)).join(' OR ')})`;\n case 'exists': {\n const notKeyword = node.notExists ? 'NOT ' : '';\n const subquery = renderSelect(node.subquery, contract);\n return `${notKeyword}EXISTS (${subquery})`;\n }\n case 'null-check':\n return renderNullCheck(node, contract);\n case 'not':\n return `NOT (${renderExpr(node.expr, contract)})`;\n case 'param-ref':\n return '?';\n case 'literal':\n return renderLiteral(node);\n case 'list':\n return renderListLiteral(node);\n default:\n throw new Error(`Unsupported expression node kind: ${(node as { kind: string }).kind}`);\n }\n}\n\n// `excluded` is a pseudo-table in ON CONFLICT DO UPDATE that references the row proposed for insertion. It is not quoted because it's a keyword.\nfunction renderColumn(ref: ColumnRef): string {\n if (ref.table === 'excluded') {\n return `excluded.${quoteIdentifier(ref.column)}`;\n }\n return `${quoteIdentifier(ref.table)}.${quoteIdentifier(ref.column)}`;\n}\n\nfunction renderLiteral(expr: LiteralExpr): string {\n if (typeof expr.value === 'string') {\n return `'${escapeLiteral(expr.value)}'`;\n }\n if (typeof expr.value === 'number' || typeof expr.value === 'boolean') {\n return String(expr.value);\n }\n if (typeof expr.value === 'bigint') {\n return String(expr.value);\n }\n if (expr.value === null || expr.value === undefined) {\n return 'NULL';\n }\n if (expr.value instanceof Date) {\n return `'${escapeLiteral(expr.value.toISOString())}'`;\n }\n const json = JSON.stringify(expr.value);\n if (json === undefined) {\n return 'NULL';\n }\n return `'${escapeLiteral(json)}'`;\n}\n\nfunction renderOperation(expr: OperationExpr, contract?: SqliteContract): string {\n const self = renderExpr(expr.self, contract);\n const args = expr.args.map((arg) => renderExpr(arg, contract));\n\n let result = expr.lowering.template;\n result = result.replace(/\\{\\{self\\}\\}/g, self);\n for (let i = 0; i < args.length; i++) {\n result = result.replace(new RegExp(`\\\\{\\\\{arg${i}\\\\}\\\\}`, 'g'), args[i] ?? '');\n }\n\n return result;\n}\n\nfunction renderSubqueryExpr(expr: SubqueryExpr, contract?: SqliteContract): string {\n if (expr.query.projection.length !== 1) {\n throw new Error('Subquery expressions must project exactly one column');\n }\n return `(${renderSelect(expr.query, contract)})`;\n}\n\nfunction renderNullCheck(expr: NullCheckExpr, contract?: SqliteContract): string {\n const rendered = renderExpr(expr.expr, contract);\n const renderedExpr =\n expr.expr.kind === 'operation' || expr.expr.kind === 'subquery' ? `(${rendered})` : rendered;\n return expr.isNull ? `${renderedExpr} IS NULL` : `${renderedExpr} IS NOT NULL`;\n}\n\nfunction renderBinary(expr: BinaryExpr, contract?: SqliteContract): string {\n if (expr.right.kind === 'list' && expr.right.values.length === 0) {\n if (expr.op === 'in') {\n return 'FALSE';\n }\n if (expr.op === 'notIn') {\n return 'TRUE';\n }\n }\n\n const leftExpr = expr.left;\n const left = renderExpr(leftExpr, contract);\n const leftRendered =\n leftExpr.kind === 'operation' || leftExpr.kind === 'subquery' ? `(${left})` : left;\n\n const rightNode = expr.right;\n let right: string;\n switch (rightNode.kind) {\n case 'list':\n right = renderListLiteral(rightNode);\n break;\n case 'literal':\n right = renderLiteral(rightNode);\n break;\n case 'column-ref':\n right = renderColumn(rightNode);\n break;\n case 'param-ref':\n right = '?';\n break;\n default:\n right = renderExpr(rightNode, contract);\n break;\n }\n\n const operatorMap: Record<BinaryExpr['op'], string> = {\n eq: '=',\n neq: '!=',\n gt: '>',\n lt: '<',\n gte: '>=',\n lte: '<=',\n like: 'LIKE',\n in: 'IN',\n notIn: 'NOT IN',\n };\n\n return `${leftRendered} ${operatorMap[expr.op]} ${right}`;\n}\n\nfunction renderListLiteral(expr: ListExpression): string {\n if (expr.values.length === 0) {\n return '(NULL)';\n }\n const values = expr.values\n .map((v) => {\n if (v.kind === 'param-ref') return '?';\n if (v.kind === 'literal') return renderLiteral(v);\n return renderExpr(v);\n })\n .join(', ');\n return `(${values})`;\n}\n\nfunction renderAggregateExpr(expr: AggregateExpr, contract?: SqliteContract): string {\n const fn = expr.fn.toUpperCase();\n if (!expr.expr) {\n return `${fn}(*)`;\n }\n return `${fn}(${renderExpr(expr.expr, contract)})`;\n}\n\nfunction renderJsonObjectExpr(expr: JsonObjectExpr, contract?: SqliteContract): string {\n const args = expr.entries\n .flatMap((entry): [string, string] => {\n const key = `'${escapeLiteral(entry.key)}'`;\n if (entry.value.kind === 'literal') {\n return [key, renderLiteral(entry.value)];\n }\n return [key, renderExpr(entry.value, contract)];\n })\n .join(', ');\n return `json_object(${args})`;\n}\n\nfunction renderOrderByItems(items: ReadonlyArray<OrderByItem>, contract?: SqliteContract): string {\n return items\n .map((item) => `${renderExpr(item.expr, contract)} ${item.dir.toUpperCase()}`)\n .join(', ');\n}\n\nfunction renderJsonArrayAggExpr(expr: JsonArrayAggExpr, contract?: SqliteContract): string {\n const aggregateOrderBy =\n expr.orderBy && expr.orderBy.length > 0\n ? ` ORDER BY ${renderOrderByItems(expr.orderBy, contract)}`\n : '';\n const aggregated = `json_group_array(${renderExpr(expr.expr, contract)}${aggregateOrderBy})`;\n if (expr.onEmpty === 'emptyArray') {\n return `coalesce(${aggregated}, '[]')`;\n }\n return aggregated;\n}\n\nfunction renderJoin(join: JoinAst, contract?: SqliteContract): string {\n const joinType = join.joinType.toUpperCase();\n const source = renderSource(join.source, contract);\n const onClause = renderJoinOn(join.on, contract);\n return `${joinType} JOIN ${source} ON ${onClause}`;\n}\n\nfunction renderJoinOn(on: JoinOnExpr, contract?: SqliteContract): string {\n if (on.kind === 'eq-col-join-on') {\n return `${renderColumn(on.left)} = ${renderColumn(on.right)}`;\n }\n return renderExpr(on, contract);\n}\n\nfunction renderInsertValue(value: InsertValue): string {\n switch (value.kind) {\n case 'param-ref':\n return '?';\n case 'column-ref':\n return renderColumn(value);\n case 'default-value':\n throw new Error('SQLite does not support DEFAULT as a value in INSERT ... VALUES');\n default:\n throw new Error(`Unsupported value node in INSERT: ${(value as { kind: string }).kind}`);\n }\n}\n\nfunction renderInsert(ast: InsertAst): string {\n const table = quoteIdentifier(ast.table.name);\n const rows = ast.rows;\n if (rows.length === 0) {\n throw new Error('INSERT requires at least one row');\n }\n\n const firstRow = rows[0] as Readonly<Record<string, InsertValue>>;\n const columnOrder = Object.keys(firstRow);\n\n let insertClause: string;\n if (columnOrder.length === 0) {\n insertClause = `INSERT INTO ${table} DEFAULT VALUES`;\n } else {\n const columns = columnOrder.map((column) => quoteIdentifier(column));\n const values = rows\n .map((row) => {\n const renderedRow = columnOrder.map((column) => {\n const value = row[column];\n if (value === undefined) {\n throw new Error(`Missing value for column \"${column}\" in INSERT row`);\n }\n return renderInsertValue(value);\n });\n return `(${renderedRow.join(', ')})`;\n })\n .join(', ');\n insertClause = `INSERT INTO ${table} (${columns.join(', ')}) VALUES ${values}`;\n }\n\n let onConflictClause = '';\n if (ast.onConflict) {\n const conflictColumns = ast.onConflict.columns.map((col) => quoteIdentifier(col.column));\n if (conflictColumns.length === 0) {\n throw new Error('INSERT onConflict requires at least one conflict column');\n }\n\n const action = ast.onConflict.action;\n switch (action.kind) {\n case 'do-nothing':\n onConflictClause = ` ON CONFLICT (${conflictColumns.join(', ')}) DO NOTHING`;\n break;\n case 'do-update-set': {\n const updates = Object.entries(action.set).map(([colName, value]) => {\n const target = quoteIdentifier(colName);\n if (value.kind === 'param-ref') {\n return `${target} = ?`;\n }\n return `${target} = ${renderColumn(value)}`;\n });\n onConflictClause = ` ON CONFLICT (${conflictColumns.join(', ')}) DO UPDATE SET ${updates.join(', ')}`;\n break;\n }\n default:\n throw new Error(`Unsupported onConflict action: ${(action as { kind: string }).kind}`);\n }\n }\n\n const returningClause = renderReturning(ast.returning);\n\n return `${insertClause}${onConflictClause}${returningClause}`;\n}\n\nfunction renderUpdate(ast: UpdateAst, contract: SqliteContract): string {\n const table = quoteIdentifier(ast.table.name);\n const setClauses = Object.entries(ast.set).map(([col, val]) => {\n const column = quoteIdentifier(col);\n let value: string;\n switch (val.kind) {\n case 'param-ref':\n value = '?';\n break;\n case 'column-ref':\n value = renderColumn(val);\n break;\n default:\n throw new Error(`Unsupported value node in UPDATE: ${(val as { kind: string }).kind}`);\n }\n return `${column} = ${value}`;\n });\n\n const whereClause = ast.where ? ` WHERE ${renderExpr(ast.where, contract)}` : '';\n const returningClause = renderReturning(ast.returning);\n\n return `UPDATE ${table} SET ${setClauses.join(', ')}${whereClause}${returningClause}`;\n}\n\nfunction renderDelete(ast: DeleteAst): string {\n const table = quoteIdentifier(ast.table.name);\n const whereClause = ast.where ? ` WHERE ${renderExpr(ast.where)}` : '';\n const returningClause = renderReturning(ast.returning);\n\n return `DELETE FROM ${table}${whereClause}${returningClause}`;\n}\n\nfunction renderReturning(returning: ReadonlyArray<ProjectionItem> | undefined): string {\n if (!returning?.length) {\n return '';\n }\n return ` RETURNING ${returning\n .map((item) => {\n if (item.expr.kind === 'column-ref') {\n const rendered = `${quoteIdentifier(item.expr.table)}.${quoteIdentifier(item.expr.column)}`;\n return item.expr.column === item.alias\n ? rendered\n : `${rendered} AS ${quoteIdentifier(item.alias)}`;\n }\n return `${renderExpr(item.expr)} AS ${quoteIdentifier(item.alias)}`;\n })\n .join(', ')}`;\n}\n\nasync function readSqliteMarker(queryable: SqlQueryable): Promise<MarkerReadResult> {\n const exists = await queryable.query(\n \"select 1 from sqlite_master where type = 'table' and name = ?\",\n ['_prisma_marker'],\n );\n if (exists.rows.length === 0) {\n return { kind: 'no-table' };\n }\n\n const result = await queryable.query(\n 'select core_hash, profile_hash, contract_json, canonical_version, updated_at, app_tag, meta, invariants from _prisma_marker where space = ?',\n [APP_SPACE_ID],\n );\n const row = result.rows[0];\n if (!row) {\n return { kind: 'absent' };\n }\n // SQLite stores arrays as JSON-encoded TEXT (no native array type), so the driver returns `invariants` as a string. Decode before delegating to the shared row schema, which expects `string[]`.\n const raw = row as Record<string, unknown>;\n const invariants =\n typeof raw['invariants'] === 'string'\n ? (JSON.parse(raw['invariants']) as unknown)\n : raw['invariants'];\n return { kind: 'present', record: parseContractMarkerRow({ ...raw, invariants }) };\n}\n\nexport function createSqliteAdapter(options?: SqliteAdapterOptions) {\n return Object.freeze(new SqliteAdapterImpl(options));\n}\n"],"mappings":"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"}
|
package/dist/adapter.d.mts
CHANGED
package/dist/adapter.mjs
CHANGED
package/dist/codec-types.d.mts
CHANGED
|
@@ -1,42 +1,2 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
3
|
-
//#region src/core/codecs.d.ts
|
|
4
|
-
type JsonValue = string | number | boolean | null | {
|
|
5
|
-
readonly [key: string]: JsonValue;
|
|
6
|
-
} | readonly JsonValue[];
|
|
7
|
-
declare const codecs: _prisma_next_sql_relational_core_ast0.CodecDefBuilder<{
|
|
8
|
-
char: _prisma_next_sql_relational_core_ast0.Codec<"sql/char@1", readonly ["equality", "order", "textual"], string, string, Record<string, unknown>, unknown>;
|
|
9
|
-
varchar: _prisma_next_sql_relational_core_ast0.Codec<"sql/varchar@1", readonly ["equality", "order", "textual"], string, string, Record<string, unknown>, unknown>;
|
|
10
|
-
int: _prisma_next_sql_relational_core_ast0.Codec<"sql/int@1", readonly ["equality", "order", "numeric"], number, number, Record<string, unknown>, unknown>;
|
|
11
|
-
float: _prisma_next_sql_relational_core_ast0.Codec<"sql/float@1", readonly ["equality", "order", "numeric"], number, number, Record<string, unknown>, unknown>;
|
|
12
|
-
text: _prisma_next_sql_relational_core_ast0.Codec<"sqlite/text@1", readonly ["equality", "order", "textual"], string, string, Record<string, unknown>, unknown>;
|
|
13
|
-
integer: _prisma_next_sql_relational_core_ast0.Codec<"sqlite/integer@1", readonly ["equality", "order", "numeric"], number, number, Record<string, unknown>, unknown>;
|
|
14
|
-
real: _prisma_next_sql_relational_core_ast0.Codec<"sqlite/real@1", readonly ["equality", "order", "numeric"], number, number, Record<string, unknown>, unknown>;
|
|
15
|
-
blob: _prisma_next_sql_relational_core_ast0.Codec<"sqlite/blob@1", readonly ["equality"], Uint8Array<ArrayBufferLike>, Uint8Array<ArrayBufferLike>, Record<string, unknown>, unknown>;
|
|
16
|
-
boolean: _prisma_next_sql_relational_core_ast0.Codec<"sqlite/boolean@1", readonly ["equality", "boolean"], number, boolean, Record<string, unknown>, unknown>;
|
|
17
|
-
datetime: _prisma_next_sql_relational_core_ast0.Codec<"sqlite/datetime@1", readonly ["equality", "order"], string, Date, Record<string, unknown>, unknown>;
|
|
18
|
-
json: _prisma_next_sql_relational_core_ast0.Codec<"sqlite/json@1", readonly ["equality"], string, string | number | boolean | {
|
|
19
|
-
readonly [key: string]: JsonValue;
|
|
20
|
-
} | readonly JsonValue[] | null, Record<string, unknown>, unknown>;
|
|
21
|
-
} & Record<"bigint", _prisma_next_sql_relational_core_ast0.Codec<"sqlite/bigint@1", readonly ["equality", "order", "numeric"], number | bigint, bigint, Record<string, unknown>, unknown>>>;
|
|
22
|
-
declare const dataTypes: {
|
|
23
|
-
readonly char: "sql/char@1";
|
|
24
|
-
readonly varchar: "sql/varchar@1";
|
|
25
|
-
readonly int: "sql/int@1";
|
|
26
|
-
readonly float: "sql/float@1";
|
|
27
|
-
readonly text: "sqlite/text@1";
|
|
28
|
-
readonly integer: "sqlite/integer@1";
|
|
29
|
-
readonly real: "sqlite/real@1";
|
|
30
|
-
readonly blob: "sqlite/blob@1";
|
|
31
|
-
readonly boolean: "sqlite/boolean@1";
|
|
32
|
-
readonly datetime: "sqlite/datetime@1";
|
|
33
|
-
readonly json: "sqlite/json@1";
|
|
34
|
-
readonly bigint: "sqlite/bigint@1";
|
|
35
|
-
};
|
|
36
|
-
type CodecTypes$1 = typeof codecs.CodecTypes;
|
|
37
|
-
//#endregion
|
|
38
|
-
//#region src/exports/codec-types.d.ts
|
|
39
|
-
type CodecTypes = CodecTypes$1;
|
|
40
|
-
//#endregion
|
|
41
|
-
export { CodecTypes, type JsonValue, dataTypes };
|
|
42
|
-
//# sourceMappingURL=codec-types.d.mts.map
|
|
1
|
+
import { CodecTypes, JsonValue } from "@prisma-next/target-sqlite/codec-types";
|
|
2
|
+
export { type CodecTypes, type JsonValue };
|
package/dist/codec-types.mjs
CHANGED
package/dist/column-types.d.mts
CHANGED
|
@@ -15,10 +15,6 @@ declare const blobColumn: {
|
|
|
15
15
|
readonly codecId: "sqlite/blob@1";
|
|
16
16
|
readonly nativeType: "blob";
|
|
17
17
|
};
|
|
18
|
-
declare const booleanColumn: {
|
|
19
|
-
readonly codecId: "sqlite/boolean@1";
|
|
20
|
-
readonly nativeType: "integer";
|
|
21
|
-
};
|
|
22
18
|
declare const datetimeColumn: {
|
|
23
19
|
readonly codecId: "sqlite/datetime@1";
|
|
24
20
|
readonly nativeType: "text";
|
|
@@ -32,5 +28,5 @@ declare const bigintColumn: {
|
|
|
32
28
|
readonly nativeType: "integer";
|
|
33
29
|
};
|
|
34
30
|
//#endregion
|
|
35
|
-
export { bigintColumn, blobColumn,
|
|
31
|
+
export { bigintColumn, blobColumn, datetimeColumn, integerColumn, jsonColumn, realColumn, textColumn };
|
|
36
32
|
//# sourceMappingURL=column-types.d.mts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"column-types.d.mts","names":[],"sources":["../src/core/column-types.ts"],"
|
|
1
|
+
{"version":3,"file":"column-types.d.mts","names":[],"sources":["../src/core/column-types.ts"],"mappings":";cAUa,UAAA;EAAA,SAGH,OAAA;EAAA,SAAA,UAAA;AAAA;AAAA,cAEG,aAAA;EAAA,SAGH,OAAA;EAAA,SAAA,UAAA;AAAA;AAAA,cAEG,UAAA;EAAA,SAGH,OAAA;EAAA,SAAA,UAAA;AAAA;AAAA,cAEG,UAAA;EAAA,SAGH,OAAA;EAAA,SAAA,UAAA;AAAA;AAAA,cAEG,cAAA;EAAA,SAGH,OAAA;EAAA,SAAA,UAAA;AAAA;AAAA,cAEG,UAAA;EAAA,SAGH,OAAA;EAAA,SAAA,UAAA;AAAA;AAAA,cAEG,YAAA;EAAA,SAGH,OAAA;EAAA,SAAA,UAAA;AAAA"}
|
package/dist/column-types.mjs
CHANGED
|
@@ -1,5 +1,4 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
1
|
+
import { SQLITE_BIGINT_CODEC_ID, SQLITE_BLOB_CODEC_ID, SQLITE_DATETIME_CODEC_ID, SQLITE_INTEGER_CODEC_ID, SQLITE_JSON_CODEC_ID, SQLITE_REAL_CODEC_ID, SQLITE_TEXT_CODEC_ID } from "@prisma-next/target-sqlite/codec-ids";
|
|
3
2
|
//#region src/core/column-types.ts
|
|
4
3
|
const textColumn = {
|
|
5
4
|
codecId: SQLITE_TEXT_CODEC_ID,
|
|
@@ -17,10 +16,6 @@ const blobColumn = {
|
|
|
17
16
|
codecId: SQLITE_BLOB_CODEC_ID,
|
|
18
17
|
nativeType: "blob"
|
|
19
18
|
};
|
|
20
|
-
const booleanColumn = {
|
|
21
|
-
codecId: SQLITE_BOOLEAN_CODEC_ID,
|
|
22
|
-
nativeType: "integer"
|
|
23
|
-
};
|
|
24
19
|
const datetimeColumn = {
|
|
25
20
|
codecId: SQLITE_DATETIME_CODEC_ID,
|
|
26
21
|
nativeType: "text"
|
|
@@ -33,7 +28,7 @@ const bigintColumn = {
|
|
|
33
28
|
codecId: SQLITE_BIGINT_CODEC_ID,
|
|
34
29
|
nativeType: "integer"
|
|
35
30
|
};
|
|
36
|
-
|
|
37
31
|
//#endregion
|
|
38
|
-
export { bigintColumn, blobColumn,
|
|
32
|
+
export { bigintColumn, blobColumn, datetimeColumn, integerColumn, jsonColumn, realColumn, textColumn };
|
|
33
|
+
|
|
39
34
|
//# sourceMappingURL=column-types.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"column-types.mjs","names":[],"sources":["../src/core/column-types.ts"],"sourcesContent":["import {\n SQLITE_BIGINT_CODEC_ID,\n SQLITE_BLOB_CODEC_ID,\n
|
|
1
|
+
{"version":3,"file":"column-types.mjs","names":[],"sources":["../src/core/column-types.ts"],"sourcesContent":["import {\n SQLITE_BIGINT_CODEC_ID,\n SQLITE_BLOB_CODEC_ID,\n SQLITE_DATETIME_CODEC_ID,\n SQLITE_INTEGER_CODEC_ID,\n SQLITE_JSON_CODEC_ID,\n SQLITE_REAL_CODEC_ID,\n SQLITE_TEXT_CODEC_ID,\n} from '@prisma-next/target-sqlite/codec-ids';\n\nexport const textColumn = {\n codecId: SQLITE_TEXT_CODEC_ID,\n nativeType: 'text',\n} as const;\n\nexport const integerColumn = {\n codecId: SQLITE_INTEGER_CODEC_ID,\n nativeType: 'integer',\n} as const;\n\nexport const realColumn = {\n codecId: SQLITE_REAL_CODEC_ID,\n nativeType: 'real',\n} as const;\n\nexport const blobColumn = {\n codecId: SQLITE_BLOB_CODEC_ID,\n nativeType: 'blob',\n} as const;\n\nexport const datetimeColumn = {\n codecId: SQLITE_DATETIME_CODEC_ID,\n nativeType: 'text',\n} as const;\n\nexport const jsonColumn = {\n codecId: SQLITE_JSON_CODEC_ID,\n nativeType: 'text',\n} as const;\n\nexport const bigintColumn = {\n codecId: SQLITE_BIGINT_CODEC_ID,\n nativeType: 'integer',\n} as const;\n"],"mappings":";;AAUA,MAAa,aAAa;CACxB,SAAS;CACT,YAAY;CACb;AAED,MAAa,gBAAgB;CAC3B,SAAS;CACT,YAAY;CACb;AAED,MAAa,aAAa;CACxB,SAAS;CACT,YAAY;CACb;AAED,MAAa,aAAa;CACxB,SAAS;CACT,YAAY;CACb;AAED,MAAa,iBAAiB;CAC5B,SAAS;CACT,YAAY;CACb;AAED,MAAa,aAAa;CACxB,SAAS;CACT,YAAY;CACb;AAED,MAAa,eAAe;CAC1B,SAAS;CACT,YAAY;CACb"}
|
package/dist/control.d.mts
CHANGED
|
@@ -1,7 +1,45 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { ControlDriverInstance } from "@prisma-next/framework-components/control";
|
|
2
|
+
import { SqlEscapeError, escapeLiteral, quoteIdentifier } from "@prisma-next/target-sqlite/sql-utils";
|
|
3
|
+
import { parseSqliteDefault, parseSqliteDefault as parseSqliteDefault$1 } from "@prisma-next/target-sqlite/default-normalizer";
|
|
4
|
+
import { normalizeSqliteNativeType, normalizeSqliteNativeType as normalizeSqliteNativeType$1 } from "@prisma-next/target-sqlite/native-type-normalizer";
|
|
5
|
+
import { SqlControlAdapterDescriptor } from "@prisma-next/family-sql/control";
|
|
6
|
+
import { AnyQueryAst, LoweredStatement, LowererContext } from "@prisma-next/sql-relational-core/ast";
|
|
7
|
+
import { ContractMarkerRecord } from "@prisma-next/contract/types";
|
|
8
|
+
import { SqlControlAdapter } from "@prisma-next/family-sql/control-adapter";
|
|
9
|
+
import { SqlSchemaIR } from "@prisma-next/sql-schema-ir/types";
|
|
2
10
|
|
|
3
11
|
//#region src/core/control-adapter.d.ts
|
|
4
|
-
declare
|
|
12
|
+
declare class SqliteControlAdapter implements SqlControlAdapter<'sqlite'> {
|
|
13
|
+
readonly familyId: "sql";
|
|
14
|
+
readonly targetId: "sqlite";
|
|
15
|
+
readonly normalizeDefault: typeof parseSqliteDefault$1;
|
|
16
|
+
readonly normalizeNativeType: typeof normalizeSqliteNativeType$1;
|
|
17
|
+
/**
|
|
18
|
+
* Lower a SQL query AST into a SQLite-flavored `{ sql, params }` payload.
|
|
19
|
+
*
|
|
20
|
+
* Delegates to the shared `renderLoweredSql` renderer so the control adapter
|
|
21
|
+
* emits byte-identical SQL to `SqliteAdapterImpl.lower()` for the same AST
|
|
22
|
+
* and contract. Used at migration plan/emit time (e.g. by `dataTransform`)
|
|
23
|
+
* without instantiating the runtime adapter.
|
|
24
|
+
*/
|
|
25
|
+
lower(ast: AnyQueryAst, context: LowererContext<unknown>): LoweredStatement;
|
|
26
|
+
/**
|
|
27
|
+
* Reads the contract marker from `_prisma_marker`. Probes `sqlite_master`
|
|
28
|
+
* first so a fresh database (no marker table) returns `null` instead of a
|
|
29
|
+
* "no such table" error.
|
|
30
|
+
*/
|
|
31
|
+
readMarker(driver: ControlDriverInstance<'sql', 'sqlite'>, space: string): Promise<ContractMarkerRecord | null>;
|
|
32
|
+
/**
|
|
33
|
+
* Reads every row from `_prisma_marker` and returns them keyed by
|
|
34
|
+
* `space`. Mirrors the existence probe in {@link readMarker}: a
|
|
35
|
+
* fresh database without the marker table returns an empty map.
|
|
36
|
+
*/
|
|
37
|
+
readAllMarkers(driver: ControlDriverInstance<'sql', 'sqlite'>): Promise<ReadonlyMap<string, ContractMarkerRecord>>;
|
|
38
|
+
introspect(driver: ControlDriverInstance<'sql', 'sqlite'>, _contract?: unknown): Promise<SqlSchemaIR>;
|
|
39
|
+
}
|
|
5
40
|
//#endregion
|
|
6
|
-
|
|
41
|
+
//#region src/exports/control.d.ts
|
|
42
|
+
declare const sqliteAdapterDescriptor: SqlControlAdapterDescriptor<'sqlite'>;
|
|
43
|
+
//#endregion
|
|
44
|
+
export { SqlEscapeError, SqliteControlAdapter, sqliteAdapterDescriptor as default, escapeLiteral, normalizeSqliteNativeType, parseSqliteDefault, quoteIdentifier };
|
|
7
45
|
//# sourceMappingURL=control.d.mts.map
|
package/dist/control.d.mts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"control.d.mts","names":[],"sources":["../src/core/control-adapter.ts"
|
|
1
|
+
{"version":3,"file":"control.d.mts","names":[],"sources":["../src/core/control-adapter.ts","../src/exports/control.ts"],"mappings":";;;;;;;;;;;cAmEa,oBAAA,YAAgC,iBAAA;EAAA,SAClC,QAAA;EAAA,SACA,QAAA;EAAA,SAEA,gBAAA,SAAgB,oBAAA;EAAA,SAChB,mBAAA,SAAmB,2BAAA;EALI;;;;;;;;EAehC,KAAA,CAAM,GAAA,EAAK,WAAA,EAAa,OAAA,EAAS,cAAA,YAA0B,gBAAA;EAYxD;;;;;EAHG,UAAA,CACJ,MAAA,EAAQ,qBAAA,mBACR,KAAA,WACC,OAAA,CAAQ,oBAAA;EAiGA;;;;;EAjDL,cAAA,CACJ,MAAA,EAAQ,qBAAA,oBACP,OAAA,CAAQ,WAAA,SAAoB,oBAAA;EA4CzB,UAAA,CACJ,MAAA,EAAQ,qBAAA,mBACR,SAAA,aACC,OAAA,CAAQ,WAAA;AAAA;;;cCrLP,uBAAA,EAAyB,2BAAA"}
|