@lix-js/sdk 0.6.0-preview.4 → 0.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +76 -4
- package/dist/errors.d.ts +7 -0
- package/dist/errors.js +19 -0
- package/dist/index.d.ts +4 -5
- package/dist/index.js +3 -3
- package/dist/native.d.ts +1 -0
- package/dist/native.js +47 -0
- package/dist/open-lix.d.ts +39 -201
- package/dist/open-lix.js +59 -284
- package/dist/result.d.ts +18 -0
- package/dist/result.js +48 -0
- package/dist/types.d.ts +114 -1
- package/dist/value.d.ts +28 -0
- package/dist/value.js +245 -0
- package/package.json +20 -50
- package/SKILL.md +0 -506
- package/dist/builtin-schemas.d.ts +0 -1
- package/dist/builtin-schemas.js +0 -1
- package/dist/engine-wasm/index.d.ts +0 -87
- package/dist/engine-wasm/index.js +0 -339
- package/dist/engine-wasm/wasm/lix_engine.d.ts +0 -79
- package/dist/engine-wasm/wasm/lix_engine.js +0 -821
- package/dist/engine-wasm/wasm/lix_engine.wasm +0 -0
- package/dist/engine-wasm/wasm/lix_engine.wasm.d.ts +0 -26
- package/dist/generated/builtin-schemas.d.ts +0 -427
- package/dist/generated/builtin-schemas.js +0 -643
- package/dist/sqlite/index.d.ts +0 -12
- package/dist/sqlite/index.js +0 -303
- package/dist-engine-src/README.md +0 -18
- package/dist-engine-src/src/backend/kv.rs +0 -358
- package/dist-engine-src/src/backend/mod.rs +0 -12
- package/dist-engine-src/src/backend/testing.rs +0 -658
- package/dist-engine-src/src/backend/types.rs +0 -96
- package/dist-engine-src/src/binary_cas/chunking.rs +0 -31
- package/dist-engine-src/src/binary_cas/codec.rs +0 -346
- package/dist-engine-src/src/binary_cas/context.rs +0 -139
- package/dist-engine-src/src/binary_cas/kv.rs +0 -1063
- package/dist-engine-src/src/binary_cas/mod.rs +0 -11
- package/dist-engine-src/src/binary_cas/types.rs +0 -121
- package/dist-engine-src/src/catalog/context.rs +0 -412
- package/dist-engine-src/src/catalog/mod.rs +0 -10
- package/dist-engine-src/src/catalog/schema.rs +0 -4
- package/dist-engine-src/src/catalog/snapshot.rs +0 -1114
- package/dist-engine-src/src/cel/context.rs +0 -86
- package/dist-engine-src/src/cel/error.rs +0 -19
- package/dist-engine-src/src/cel/mod.rs +0 -8
- package/dist-engine-src/src/cel/provider.rs +0 -9
- package/dist-engine-src/src/cel/runtime.rs +0 -167
- package/dist-engine-src/src/cel/value.rs +0 -50
- package/dist-engine-src/src/commit_graph/context.rs +0 -901
- package/dist-engine-src/src/commit_graph/mod.rs +0 -11
- package/dist-engine-src/src/commit_graph/types.rs +0 -109
- package/dist-engine-src/src/commit_graph/walker.rs +0 -756
- package/dist-engine-src/src/commit_store/codec.rs +0 -887
- package/dist-engine-src/src/commit_store/context.rs +0 -944
- package/dist-engine-src/src/commit_store/materialization.rs +0 -84
- package/dist-engine-src/src/commit_store/mod.rs +0 -16
- package/dist-engine-src/src/commit_store/storage.rs +0 -600
- package/dist-engine-src/src/commit_store/types.rs +0 -215
- package/dist-engine-src/src/common/error.rs +0 -313
- package/dist-engine-src/src/common/fingerprint.rs +0 -3
- package/dist-engine-src/src/common/fs_path.rs +0 -1336
- package/dist-engine-src/src/common/identity.rs +0 -145
- package/dist-engine-src/src/common/json_pointer.rs +0 -67
- package/dist-engine-src/src/common/metadata.rs +0 -40
- package/dist-engine-src/src/common/mod.rs +0 -23
- package/dist-engine-src/src/common/types.rs +0 -105
- package/dist-engine-src/src/common/wire.rs +0 -222
- package/dist-engine-src/src/domain.rs +0 -324
- package/dist-engine-src/src/engine.rs +0 -225
- package/dist-engine-src/src/entity_identity.rs +0 -405
- package/dist-engine-src/src/functions/context.rs +0 -292
- package/dist-engine-src/src/functions/deterministic.rs +0 -113
- package/dist-engine-src/src/functions/mod.rs +0 -18
- package/dist-engine-src/src/functions/provider.rs +0 -130
- package/dist-engine-src/src/functions/state.rs +0 -336
- package/dist-engine-src/src/functions/types.rs +0 -37
- package/dist-engine-src/src/init.rs +0 -558
- package/dist-engine-src/src/json_store/compression.rs +0 -77
- package/dist-engine-src/src/json_store/context.rs +0 -423
- package/dist-engine-src/src/json_store/encoded.rs +0 -15
- package/dist-engine-src/src/json_store/mod.rs +0 -12
- package/dist-engine-src/src/json_store/store.rs +0 -1109
- package/dist-engine-src/src/json_store/types.rs +0 -217
- package/dist-engine-src/src/lib.rs +0 -62
- package/dist-engine-src/src/live_state/context.rs +0 -2019
- package/dist-engine-src/src/live_state/mod.rs +0 -15
- package/dist-engine-src/src/live_state/overlay.rs +0 -75
- package/dist-engine-src/src/live_state/reader.rs +0 -23
- package/dist-engine-src/src/live_state/types.rs +0 -222
- package/dist-engine-src/src/live_state/visibility.rs +0 -223
- package/dist-engine-src/src/plugin/archive.rs +0 -438
- package/dist-engine-src/src/plugin/component.rs +0 -183
- package/dist-engine-src/src/plugin/install.rs +0 -619
- package/dist-engine-src/src/plugin/manifest.rs +0 -516
- package/dist-engine-src/src/plugin/materializer.rs +0 -477
- package/dist-engine-src/src/plugin/mod.rs +0 -33
- package/dist-engine-src/src/plugin/plugin_manifest.json +0 -118
- package/dist-engine-src/src/plugin/storage.rs +0 -74
- package/dist-engine-src/src/schema/annotations/defaults.rs +0 -275
- package/dist-engine-src/src/schema/annotations/mod.rs +0 -1
- package/dist-engine-src/src/schema/builtin/lix_account.json +0 -21
- package/dist-engine-src/src/schema/builtin/lix_active_account.json +0 -29
- package/dist-engine-src/src/schema/builtin/lix_binary_blob_ref.json +0 -29
- package/dist-engine-src/src/schema/builtin/lix_change.json +0 -63
- package/dist-engine-src/src/schema/builtin/lix_change_author.json +0 -45
- package/dist-engine-src/src/schema/builtin/lix_commit.json +0 -24
- package/dist-engine-src/src/schema/builtin/lix_commit_edge.json +0 -53
- package/dist-engine-src/src/schema/builtin/lix_directory_descriptor.json +0 -52
- package/dist-engine-src/src/schema/builtin/lix_file_descriptor.json +0 -52
- package/dist-engine-src/src/schema/builtin/lix_key_value.json +0 -40
- package/dist-engine-src/src/schema/builtin/lix_label.json +0 -29
- package/dist-engine-src/src/schema/builtin/lix_label_assignment.json +0 -74
- package/dist-engine-src/src/schema/builtin/lix_registered_schema.json +0 -25
- package/dist-engine-src/src/schema/builtin/lix_version_descriptor.json +0 -34
- package/dist-engine-src/src/schema/builtin/lix_version_ref.json +0 -48
- package/dist-engine-src/src/schema/builtin/mod.rs +0 -222
- package/dist-engine-src/src/schema/compatibility.rs +0 -787
- package/dist-engine-src/src/schema/definition.json +0 -187
- package/dist-engine-src/src/schema/definition.rs +0 -742
- package/dist-engine-src/src/schema/key.rs +0 -138
- package/dist-engine-src/src/schema/mod.rs +0 -20
- package/dist-engine-src/src/schema/seed.rs +0 -14
- package/dist-engine-src/src/schema/tests.rs +0 -780
- package/dist-engine-src/src/session/context.rs +0 -404
- package/dist-engine-src/src/session/create_version.rs +0 -88
- package/dist-engine-src/src/session/execute.rs +0 -541
- package/dist-engine-src/src/session/merge/analysis.rs +0 -102
- package/dist-engine-src/src/session/merge/apply.rs +0 -23
- package/dist-engine-src/src/session/merge/conflicts.rs +0 -63
- package/dist-engine-src/src/session/merge/mod.rs +0 -11
- package/dist-engine-src/src/session/merge/stats.rs +0 -65
- package/dist-engine-src/src/session/merge/version.rs +0 -427
- package/dist-engine-src/src/session/mod.rs +0 -27
- package/dist-engine-src/src/session/optimization9_sql2_bench.rs +0 -100
- package/dist-engine-src/src/session/switch_version.rs +0 -110
- package/dist-engine-src/src/session/transaction.rs +0 -76
- package/dist-engine-src/src/sql2/change_provider.rs +0 -331
- package/dist-engine-src/src/sql2/classify.rs +0 -174
- package/dist-engine-src/src/sql2/context.rs +0 -311
- package/dist-engine-src/src/sql2/directory_history_provider.rs +0 -631
- package/dist-engine-src/src/sql2/directory_provider.rs +0 -2453
- package/dist-engine-src/src/sql2/dml.rs +0 -148
- package/dist-engine-src/src/sql2/entity_history_provider.rs +0 -440
- package/dist-engine-src/src/sql2/entity_provider.rs +0 -3211
- package/dist-engine-src/src/sql2/error.rs +0 -215
- package/dist-engine-src/src/sql2/execute.rs +0 -3533
- package/dist-engine-src/src/sql2/file_history_provider.rs +0 -910
- package/dist-engine-src/src/sql2/file_provider.rs +0 -3679
- package/dist-engine-src/src/sql2/filesystem_planner.rs +0 -1490
- package/dist-engine-src/src/sql2/filesystem_predicates.rs +0 -159
- package/dist-engine-src/src/sql2/filesystem_visibility.rs +0 -383
- package/dist-engine-src/src/sql2/history_projection.rs +0 -56
- package/dist-engine-src/src/sql2/history_provider.rs +0 -412
- package/dist-engine-src/src/sql2/history_route.rs +0 -657
- package/dist-engine-src/src/sql2/lix_state_provider.rs +0 -2512
- package/dist-engine-src/src/sql2/mod.rs +0 -47
- package/dist-engine-src/src/sql2/predicate_typecheck.rs +0 -246
- package/dist-engine-src/src/sql2/public_bind/assignment.rs +0 -46
- package/dist-engine-src/src/sql2/public_bind/capability.rs +0 -41
- package/dist-engine-src/src/sql2/public_bind/dml.rs +0 -172
- package/dist-engine-src/src/sql2/public_bind/mod.rs +0 -26
- package/dist-engine-src/src/sql2/public_bind/table.rs +0 -168
- package/dist-engine-src/src/sql2/read_only.rs +0 -63
- package/dist-engine-src/src/sql2/record_batch.rs +0 -17
- package/dist-engine-src/src/sql2/result_metadata.rs +0 -29
- package/dist-engine-src/src/sql2/runtime.rs +0 -60
- package/dist-engine-src/src/sql2/session.rs +0 -132
- package/dist-engine-src/src/sql2/udfs/common.rs +0 -295
- package/dist-engine-src/src/sql2/udfs/lix_active_version_commit_id.rs +0 -53
- package/dist-engine-src/src/sql2/udfs/lix_empty_blob.rs +0 -47
- package/dist-engine-src/src/sql2/udfs/lix_json.rs +0 -100
- package/dist-engine-src/src/sql2/udfs/lix_json_get.rs +0 -99
- package/dist-engine-src/src/sql2/udfs/lix_json_get_text.rs +0 -99
- package/dist-engine-src/src/sql2/udfs/lix_text_decode.rs +0 -82
- package/dist-engine-src/src/sql2/udfs/lix_text_encode.rs +0 -85
- package/dist-engine-src/src/sql2/udfs/lix_timestamp.rs +0 -76
- package/dist-engine-src/src/sql2/udfs/lix_uuid_v7.rs +0 -76
- package/dist-engine-src/src/sql2/udfs/mod.rs +0 -89
- package/dist-engine-src/src/sql2/udfs/public_call.rs +0 -238
- package/dist-engine-src/src/sql2/version_provider.rs +0 -1202
- package/dist-engine-src/src/sql2/version_scope.rs +0 -394
- package/dist-engine-src/src/sql2/write_normalization.rs +0 -345
- package/dist-engine-src/src/storage/context.rs +0 -356
- package/dist-engine-src/src/storage/mod.rs +0 -14
- package/dist-engine-src/src/storage/read_scope.rs +0 -88
- package/dist-engine-src/src/storage/types.rs +0 -501
- package/dist-engine-src/src/storage_bench.rs +0 -4863
- package/dist-engine-src/src/test_support.rs +0 -228
- package/dist-engine-src/src/tracked_state/by_file_index.rs +0 -98
- package/dist-engine-src/src/tracked_state/codec.rs +0 -2085
- package/dist-engine-src/src/tracked_state/context.rs +0 -1867
- package/dist-engine-src/src/tracked_state/diff.rs +0 -686
- package/dist-engine-src/src/tracked_state/materialization.rs +0 -403
- package/dist-engine-src/src/tracked_state/materializer.rs +0 -488
- package/dist-engine-src/src/tracked_state/merge.rs +0 -492
- package/dist-engine-src/src/tracked_state/mod.rs +0 -32
- package/dist-engine-src/src/tracked_state/storage.rs +0 -375
- package/dist-engine-src/src/tracked_state/tree.rs +0 -3187
- package/dist-engine-src/src/tracked_state/types.rs +0 -231
- package/dist-engine-src/src/transaction/commit.rs +0 -1484
- package/dist-engine-src/src/transaction/context.rs +0 -1548
- package/dist-engine-src/src/transaction/live_state_overlay.rs +0 -35
- package/dist-engine-src/src/transaction/mod.rs +0 -13
- package/dist-engine-src/src/transaction/normalization.rs +0 -890
- package/dist-engine-src/src/transaction/prep.rs +0 -37
- package/dist-engine-src/src/transaction/schema_resolver.rs +0 -149
- package/dist-engine-src/src/transaction/staging.rs +0 -1731
- package/dist-engine-src/src/transaction/types.rs +0 -460
- package/dist-engine-src/src/transaction/validation.rs +0 -5830
- package/dist-engine-src/src/untracked_state/codec.rs +0 -307
- package/dist-engine-src/src/untracked_state/context.rs +0 -98
- package/dist-engine-src/src/untracked_state/materialization.rs +0 -63
- package/dist-engine-src/src/untracked_state/mod.rs +0 -15
- package/dist-engine-src/src/untracked_state/storage.rs +0 -396
- package/dist-engine-src/src/untracked_state/types.rs +0 -146
- package/dist-engine-src/src/version/context.rs +0 -40
- package/dist-engine-src/src/version/lifecycle.rs +0 -221
- package/dist-engine-src/src/version/mod.rs +0 -13
- package/dist-engine-src/src/version/refs.rs +0 -330
- package/dist-engine-src/src/version/stage_rows.rs +0 -67
- package/dist-engine-src/src/version/types.rs +0 -21
- package/dist-engine-src/src/wasm/mod.rs +0 -60
|
@@ -1,339 +0,0 @@
|
|
|
1
|
-
export { default } from "./wasm/lix_engine.js";
|
|
2
|
-
export * from "./wasm/lix_engine.js";
|
|
3
|
-
export class Value {
|
|
4
|
-
kind;
|
|
5
|
-
value;
|
|
6
|
-
base64;
|
|
7
|
-
constructor(kind, value, base64) {
|
|
8
|
-
this.kind = kind;
|
|
9
|
-
this.value = value;
|
|
10
|
-
this.base64 = base64;
|
|
11
|
-
}
|
|
12
|
-
static null() {
|
|
13
|
-
return new Value("null", null);
|
|
14
|
-
}
|
|
15
|
-
static integer(value) {
|
|
16
|
-
if (!Number.isFinite(value) || !Number.isInteger(value)) {
|
|
17
|
-
throw new TypeError("Value.integer() requires a finite integer number");
|
|
18
|
-
}
|
|
19
|
-
return new Value("integer", value);
|
|
20
|
-
}
|
|
21
|
-
static boolean(value) {
|
|
22
|
-
return new Value("boolean", value);
|
|
23
|
-
}
|
|
24
|
-
static real(value) {
|
|
25
|
-
if (!Number.isFinite(value)) {
|
|
26
|
-
throw new TypeError("Value.real() requires a finite number");
|
|
27
|
-
}
|
|
28
|
-
return new Value("real", value);
|
|
29
|
-
}
|
|
30
|
-
static text(value) {
|
|
31
|
-
if (!isWellFormedUtf16(value)) {
|
|
32
|
-
throw new TypeError("Value.text() requires a well-formed UTF-16 string");
|
|
33
|
-
}
|
|
34
|
-
return new Value("text", value);
|
|
35
|
-
}
|
|
36
|
-
static json(value) {
|
|
37
|
-
return new Value("json", normalizeJsonValue(value));
|
|
38
|
-
}
|
|
39
|
-
static blob(value) {
|
|
40
|
-
return new Value("blob", undefined, bytesToBase64(value));
|
|
41
|
-
}
|
|
42
|
-
static from(raw) {
|
|
43
|
-
if (raw instanceof Value)
|
|
44
|
-
return raw;
|
|
45
|
-
if (isLixValue(raw)) {
|
|
46
|
-
switch (raw.kind) {
|
|
47
|
-
case "null":
|
|
48
|
-
return Value.null();
|
|
49
|
-
case "boolean":
|
|
50
|
-
return Value.boolean(raw.value);
|
|
51
|
-
case "integer":
|
|
52
|
-
return Value.integer(raw.value);
|
|
53
|
-
case "real":
|
|
54
|
-
return Value.real(raw.value);
|
|
55
|
-
case "text":
|
|
56
|
-
return Value.text(raw.value);
|
|
57
|
-
case "json":
|
|
58
|
-
return Value.json(normalizeJsonValue(raw.value));
|
|
59
|
-
case "blob":
|
|
60
|
-
return new Value("blob", undefined, raw.base64);
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
if (raw === null)
|
|
64
|
-
return Value.null();
|
|
65
|
-
if (raw === undefined) {
|
|
66
|
-
throw new TypeError("undefined is not a valid SQL parameter");
|
|
67
|
-
}
|
|
68
|
-
if (typeof raw === "number") {
|
|
69
|
-
return Number.isInteger(raw) ? Value.integer(raw) : Value.real(raw);
|
|
70
|
-
}
|
|
71
|
-
if (typeof raw === "boolean")
|
|
72
|
-
return Value.boolean(raw);
|
|
73
|
-
if (typeof raw === "string")
|
|
74
|
-
return Value.text(raw);
|
|
75
|
-
if (raw instanceof Uint8Array)
|
|
76
|
-
return Value.blob(raw);
|
|
77
|
-
if (raw instanceof ArrayBuffer)
|
|
78
|
-
return Value.blob(new Uint8Array(raw));
|
|
79
|
-
if (ArrayBuffer.isView(raw)) {
|
|
80
|
-
throw new TypeError("typed array SQL parameters must be Uint8Array; other ArrayBuffer views are ambiguous");
|
|
81
|
-
}
|
|
82
|
-
if (raw instanceof Date) {
|
|
83
|
-
throw new TypeError("Date is not a valid SQL parameter; pass date.toISOString() or date.getTime() explicitly");
|
|
84
|
-
}
|
|
85
|
-
if (raw && typeof raw === "object") {
|
|
86
|
-
return Value.json(normalizeJsonValue(raw));
|
|
87
|
-
}
|
|
88
|
-
throw new TypeError("Value.from() requires a LixValue, JSON value, or binary value");
|
|
89
|
-
}
|
|
90
|
-
asInteger() {
|
|
91
|
-
return this.kind === "integer" ? this.value : undefined;
|
|
92
|
-
}
|
|
93
|
-
asBoolean() {
|
|
94
|
-
return this.kind === "boolean" ? this.value : undefined;
|
|
95
|
-
}
|
|
96
|
-
asReal() {
|
|
97
|
-
return this.kind === "real" ? this.value : undefined;
|
|
98
|
-
}
|
|
99
|
-
asText() {
|
|
100
|
-
return this.kind === "text" ? this.value : undefined;
|
|
101
|
-
}
|
|
102
|
-
asJson() {
|
|
103
|
-
return this.kind === "json" ? normalizeJsonValue(this.value) : undefined;
|
|
104
|
-
}
|
|
105
|
-
asBlob() {
|
|
106
|
-
return this.kind === "blob" && this.base64 !== undefined
|
|
107
|
-
? base64ToBytes(this.base64)
|
|
108
|
-
: undefined;
|
|
109
|
-
}
|
|
110
|
-
toJSON() {
|
|
111
|
-
switch (this.kind) {
|
|
112
|
-
case "null":
|
|
113
|
-
return { kind: "null", value: null };
|
|
114
|
-
case "boolean":
|
|
115
|
-
return { kind: "boolean", value: this.asBoolean() ?? false };
|
|
116
|
-
case "integer":
|
|
117
|
-
return { kind: "integer", value: this.asInteger() ?? 0 };
|
|
118
|
-
case "real":
|
|
119
|
-
return { kind: "real", value: this.asReal() ?? 0 };
|
|
120
|
-
case "text":
|
|
121
|
-
return { kind: "text", value: this.asText() ?? "" };
|
|
122
|
-
case "json":
|
|
123
|
-
return { kind: "json", value: this.asJson() ?? null };
|
|
124
|
-
case "blob":
|
|
125
|
-
return { kind: "blob", base64: this.base64 ?? "" };
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
/**
|
|
130
|
-
* Type guard: returns `true` when `err` is a Lix-produced error carrying a
|
|
131
|
-
* structured `code` field (all engine codes start with `LIX_`).
|
|
132
|
-
*/
|
|
133
|
-
export function isLixError(err) {
|
|
134
|
-
return (err instanceof Error &&
|
|
135
|
-
typeof err.code === "string" &&
|
|
136
|
-
err.code.startsWith("LIX_"));
|
|
137
|
-
}
|
|
138
|
-
function isLixValue(value) {
|
|
139
|
-
if (!value || typeof value !== "object") {
|
|
140
|
-
return false;
|
|
141
|
-
}
|
|
142
|
-
const kind = value.kind;
|
|
143
|
-
if (kind === "null") {
|
|
144
|
-
return value.value === null;
|
|
145
|
-
}
|
|
146
|
-
if (kind === "boolean") {
|
|
147
|
-
return typeof value.value === "boolean";
|
|
148
|
-
}
|
|
149
|
-
if (kind === "integer" || kind === "real") {
|
|
150
|
-
const raw = value.value;
|
|
151
|
-
if (typeof raw !== "number" || !Number.isFinite(raw)) {
|
|
152
|
-
return false;
|
|
153
|
-
}
|
|
154
|
-
if (kind === "integer" && !Number.isInteger(raw)) {
|
|
155
|
-
return false;
|
|
156
|
-
}
|
|
157
|
-
return true;
|
|
158
|
-
}
|
|
159
|
-
if (kind === "text") {
|
|
160
|
-
const raw = value.value;
|
|
161
|
-
return typeof raw === "string" && isWellFormedUtf16(raw);
|
|
162
|
-
}
|
|
163
|
-
if (kind === "json") {
|
|
164
|
-
return isJsonValue(value.value);
|
|
165
|
-
}
|
|
166
|
-
if (kind === "blob") {
|
|
167
|
-
return typeof value.base64 === "string";
|
|
168
|
-
}
|
|
169
|
-
return false;
|
|
170
|
-
}
|
|
171
|
-
function isJsonValue(value) {
|
|
172
|
-
try {
|
|
173
|
-
normalizeJsonValue(value);
|
|
174
|
-
return true;
|
|
175
|
-
}
|
|
176
|
-
catch {
|
|
177
|
-
return false;
|
|
178
|
-
}
|
|
179
|
-
}
|
|
180
|
-
function normalizeJsonValue(value, seen = new WeakSet()) {
|
|
181
|
-
if (value === null ||
|
|
182
|
-
typeof value === "boolean") {
|
|
183
|
-
return value;
|
|
184
|
-
}
|
|
185
|
-
if (typeof value === "string") {
|
|
186
|
-
if (!isWellFormedUtf16(value)) {
|
|
187
|
-
throw new TypeError("JSON strings must be well-formed UTF-16");
|
|
188
|
-
}
|
|
189
|
-
return value;
|
|
190
|
-
}
|
|
191
|
-
if (typeof value === "number") {
|
|
192
|
-
if (!Number.isFinite(value)) {
|
|
193
|
-
throw new TypeError("JSON numbers must be finite");
|
|
194
|
-
}
|
|
195
|
-
return value;
|
|
196
|
-
}
|
|
197
|
-
if (Array.isArray(value)) {
|
|
198
|
-
if (seen.has(value)) {
|
|
199
|
-
throw new TypeError("JSON values must not contain circular references");
|
|
200
|
-
}
|
|
201
|
-
seen.add(value);
|
|
202
|
-
const normalized = value.map((item) => normalizeJsonValue(item, seen));
|
|
203
|
-
seen.delete(value);
|
|
204
|
-
return normalized;
|
|
205
|
-
}
|
|
206
|
-
if (!value || typeof value !== "object") {
|
|
207
|
-
throw new TypeError("expected a JSON-compatible value");
|
|
208
|
-
}
|
|
209
|
-
if (value instanceof Date) {
|
|
210
|
-
throw new TypeError("Date is not a JSON value");
|
|
211
|
-
}
|
|
212
|
-
const prototype = Object.getPrototypeOf(value);
|
|
213
|
-
if (prototype !== Object.prototype && prototype !== null) {
|
|
214
|
-
throw new TypeError("JSON objects must be plain objects");
|
|
215
|
-
}
|
|
216
|
-
if (seen.has(value)) {
|
|
217
|
-
throw new TypeError("JSON values must not contain circular references");
|
|
218
|
-
}
|
|
219
|
-
seen.add(value);
|
|
220
|
-
const normalized = {};
|
|
221
|
-
for (const [key, entry] of Object.entries(value)) {
|
|
222
|
-
if (!isWellFormedUtf16(key)) {
|
|
223
|
-
throw new TypeError("JSON object keys must be well-formed UTF-16");
|
|
224
|
-
}
|
|
225
|
-
normalized[key] = normalizeJsonValue(entry, seen);
|
|
226
|
-
}
|
|
227
|
-
seen.delete(value);
|
|
228
|
-
return normalized;
|
|
229
|
-
}
|
|
230
|
-
function isWellFormedUtf16(value) {
|
|
231
|
-
for (let index = 0; index < value.length; index += 1) {
|
|
232
|
-
const code = value.charCodeAt(index);
|
|
233
|
-
if (code >= 0xd800 && code <= 0xdbff) {
|
|
234
|
-
const next = value.charCodeAt(index + 1);
|
|
235
|
-
if (next < 0xdc00 || next > 0xdfff) {
|
|
236
|
-
return false;
|
|
237
|
-
}
|
|
238
|
-
index += 1;
|
|
239
|
-
continue;
|
|
240
|
-
}
|
|
241
|
-
if (code >= 0xdc00 && code <= 0xdfff) {
|
|
242
|
-
return false;
|
|
243
|
-
}
|
|
244
|
-
}
|
|
245
|
-
return true;
|
|
246
|
-
}
|
|
247
|
-
function bytesToBase64(bytes) {
|
|
248
|
-
const maybeBuffer = globalThis.Buffer;
|
|
249
|
-
if (maybeBuffer) {
|
|
250
|
-
return maybeBuffer.from(bytes).toString("base64");
|
|
251
|
-
}
|
|
252
|
-
let binary = "";
|
|
253
|
-
const chunkSize = 0x8000;
|
|
254
|
-
for (let index = 0; index < bytes.length; index += chunkSize) {
|
|
255
|
-
const chunk = bytes.subarray(index, index + chunkSize);
|
|
256
|
-
binary += String.fromCharCode(...chunk);
|
|
257
|
-
}
|
|
258
|
-
return btoa(binary);
|
|
259
|
-
}
|
|
260
|
-
function base64ToBytes(base64) {
|
|
261
|
-
const maybeBuffer = globalThis.Buffer;
|
|
262
|
-
if (maybeBuffer) {
|
|
263
|
-
return new Uint8Array(maybeBuffer.from(base64, "base64"));
|
|
264
|
-
}
|
|
265
|
-
const binary = atob(base64);
|
|
266
|
-
const bytes = new Uint8Array(binary.length);
|
|
267
|
-
for (let index = 0; index < binary.length; index += 1) {
|
|
268
|
-
bytes[index] = binary.charCodeAt(index);
|
|
269
|
-
}
|
|
270
|
-
return bytes;
|
|
271
|
-
}
|
|
272
|
-
const engineWasmUrl = new URL("./wasm/lix_engine.wasm", import.meta.url);
|
|
273
|
-
function isNodeRuntime() {
|
|
274
|
-
const processLike = globalThis.process;
|
|
275
|
-
return (!!processLike &&
|
|
276
|
-
typeof processLike.versions === "object" &&
|
|
277
|
-
!!processLike.versions?.node);
|
|
278
|
-
}
|
|
279
|
-
async function tryReadNodeFileFromViteHttpUrl(url) {
|
|
280
|
-
if (url.protocol !== "http:" && url.protocol !== "https:") {
|
|
281
|
-
return undefined;
|
|
282
|
-
}
|
|
283
|
-
// Vitest/Vite in Node often rewrites module URLs to http://localhost with /@fs/.
|
|
284
|
-
const decodedPathname = decodeURIComponent(url.pathname);
|
|
285
|
-
let filePath;
|
|
286
|
-
if (decodedPathname.startsWith("/@fs/")) {
|
|
287
|
-
filePath = decodedPathname.slice("/@fs".length);
|
|
288
|
-
}
|
|
289
|
-
else if (url.hostname === "localhost" ||
|
|
290
|
-
url.hostname === "127.0.0.1" ||
|
|
291
|
-
url.hostname === "::1") {
|
|
292
|
-
// Some setups expose absolute filesystem paths directly on localhost.
|
|
293
|
-
filePath = decodedPathname;
|
|
294
|
-
}
|
|
295
|
-
if (!filePath) {
|
|
296
|
-
return undefined;
|
|
297
|
-
}
|
|
298
|
-
const fsModuleName = "node:fs/promises";
|
|
299
|
-
const { readFile } = await import(fsModuleName);
|
|
300
|
-
try {
|
|
301
|
-
return new Uint8Array(await readFile(filePath));
|
|
302
|
-
}
|
|
303
|
-
catch {
|
|
304
|
-
return undefined;
|
|
305
|
-
}
|
|
306
|
-
}
|
|
307
|
-
/**
|
|
308
|
-
* Returns a wasm-bindgen-compatible init input that works in both browser and Node.
|
|
309
|
-
*
|
|
310
|
-
* - Browser: use a URL so the runtime fetches the `.wasm` asset.
|
|
311
|
-
* - Node: read bytes from disk because `fetch(file://...)` is not supported.
|
|
312
|
-
*/
|
|
313
|
-
export async function resolveEngineWasmModuleOrPath() {
|
|
314
|
-
if (!isNodeRuntime()) {
|
|
315
|
-
return engineWasmUrl;
|
|
316
|
-
}
|
|
317
|
-
if (engineWasmUrl.protocol === "file:") {
|
|
318
|
-
const fsModuleName = "node:fs/promises";
|
|
319
|
-
const urlModuleName = "node:url";
|
|
320
|
-
const [{ readFile }, { fileURLToPath }] = await Promise.all([
|
|
321
|
-
import(fsModuleName),
|
|
322
|
-
import(urlModuleName),
|
|
323
|
-
]);
|
|
324
|
-
return readFile(fileURLToPath(engineWasmUrl));
|
|
325
|
-
}
|
|
326
|
-
if (engineWasmUrl.protocol === "http:" ||
|
|
327
|
-
engineWasmUrl.protocol === "https:") {
|
|
328
|
-
const localBytes = await tryReadNodeFileFromViteHttpUrl(engineWasmUrl);
|
|
329
|
-
if (localBytes) {
|
|
330
|
-
return localBytes;
|
|
331
|
-
}
|
|
332
|
-
const response = await fetch(engineWasmUrl);
|
|
333
|
-
if (!response.ok) {
|
|
334
|
-
throw new Error(`failed to fetch wasm module from '${engineWasmUrl.toString()}': ${response.status} ${response.statusText}`);
|
|
335
|
-
}
|
|
336
|
-
return new Uint8Array(await response.arrayBuffer());
|
|
337
|
-
}
|
|
338
|
-
return engineWasmUrl;
|
|
339
|
-
}
|
|
@@ -1,79 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @param {any | null} [args]
|
|
3
|
-
* @returns {Promise<Lix>}
|
|
4
|
-
*/
|
|
5
|
-
export function openLix(args?: any | null): Promise<Lix>;
|
|
6
|
-
export class Lix {
|
|
7
|
-
static __wrap(ptr: any): any;
|
|
8
|
-
__destroy_into_raw(): number | undefined;
|
|
9
|
-
__wbg_ptr: number | undefined;
|
|
10
|
-
free(): void;
|
|
11
|
-
/**
|
|
12
|
-
* @returns {Promise<string>}
|
|
13
|
-
*/
|
|
14
|
-
activeVersionId(): Promise<string>;
|
|
15
|
-
/**
|
|
16
|
-
* @returns {Promise<LixTransaction>}
|
|
17
|
-
*/
|
|
18
|
-
beginTransaction(): Promise<LixTransaction>;
|
|
19
|
-
/**
|
|
20
|
-
* @returns {Promise<void>}
|
|
21
|
-
*/
|
|
22
|
-
close(): Promise<void>;
|
|
23
|
-
/**
|
|
24
|
-
* @param {any} args
|
|
25
|
-
* @returns {Promise<any>}
|
|
26
|
-
*/
|
|
27
|
-
createVersion(args: any): Promise<any>;
|
|
28
|
-
/**
|
|
29
|
-
* Executes one DataFusion SQL statement against this Lix session.
|
|
30
|
-
*
|
|
31
|
-
* The SQL dialect is DataFusion SQL, not SQLite SQL. Positional
|
|
32
|
-
* placeholders use `?` or `$1`, `$2`, and so on. SQLite-specific catalog
|
|
33
|
-
* tables and transaction statements such as `sqlite_master`, `BEGIN`,
|
|
34
|
-
* and `COMMIT` are not part of this contract; use
|
|
35
|
-
* `information_schema` for catalog inspection.
|
|
36
|
-
* @param {any} sql
|
|
37
|
-
* @param {any} params
|
|
38
|
-
* @returns {Promise<any>}
|
|
39
|
-
*/
|
|
40
|
-
execute(sql: any, params: any): Promise<any>;
|
|
41
|
-
/**
|
|
42
|
-
* @param {any} args
|
|
43
|
-
* @returns {Promise<any>}
|
|
44
|
-
*/
|
|
45
|
-
mergeVersion(args: any): Promise<any>;
|
|
46
|
-
/**
|
|
47
|
-
* @param {any} args
|
|
48
|
-
* @returns {Promise<any>}
|
|
49
|
-
*/
|
|
50
|
-
mergeVersionPreview(args: any): Promise<any>;
|
|
51
|
-
/**
|
|
52
|
-
* @param {any} args
|
|
53
|
-
* @returns {Promise<any>}
|
|
54
|
-
*/
|
|
55
|
-
switchVersion(args: any): Promise<any>;
|
|
56
|
-
}
|
|
57
|
-
export class LixTransaction {
|
|
58
|
-
static __wrap(ptr: any): any;
|
|
59
|
-
__destroy_into_raw(): number | undefined;
|
|
60
|
-
__wbg_ptr: number | undefined;
|
|
61
|
-
free(): void;
|
|
62
|
-
/**
|
|
63
|
-
* @returns {Promise<void>}
|
|
64
|
-
*/
|
|
65
|
-
commit(): Promise<void>;
|
|
66
|
-
/**
|
|
67
|
-
* @param {any} sql
|
|
68
|
-
* @param {any} params
|
|
69
|
-
* @returns {Promise<any>}
|
|
70
|
-
*/
|
|
71
|
-
execute(sql: any, params: any): Promise<any>;
|
|
72
|
-
/**
|
|
73
|
-
* @returns {Promise<void>}
|
|
74
|
-
*/
|
|
75
|
-
rollback(): Promise<void>;
|
|
76
|
-
}
|
|
77
|
-
export function initSync(module: any): any;
|
|
78
|
-
declare function __wbg_init(module_or_path: any): Promise<any>;
|
|
79
|
-
export { __wbg_init as default };
|