@sunfall/arc-db 0.1.0-alpha.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/LICENSE +21 -0
- package/dist/change-feed-dispatcher.d.ts +21 -0
- package/dist/change-feed-dispatcher.d.ts.map +1 -0
- package/dist/change-feed-dispatcher.js +53 -0
- package/dist/change-feed-dispatcher.js.map +1 -0
- package/dist/collection-change-feed-runtime.d.ts +32 -0
- package/dist/collection-change-feed-runtime.d.ts.map +1 -0
- package/dist/collection-change-feed-runtime.js +50 -0
- package/dist/collection-change-feed-runtime.js.map +1 -0
- package/dist/collection-contract.d.ts +525 -0
- package/dist/collection-contract.d.ts.map +1 -0
- package/dist/collection-contract.js +4 -0
- package/dist/collection-contract.js.map +1 -0
- package/dist/collection-definition-snapshot.d.ts +64 -0
- package/dist/collection-definition-snapshot.d.ts.map +1 -0
- package/dist/collection-definition-snapshot.js +122 -0
- package/dist/collection-definition-snapshot.js.map +1 -0
- package/dist/collection-errors.d.ts +38 -0
- package/dist/collection-errors.d.ts.map +1 -0
- package/dist/collection-errors.js +17 -0
- package/dist/collection-errors.js.map +1 -0
- package/dist/collection-ids.d.ts +6 -0
- package/dist/collection-ids.d.ts.map +1 -0
- package/dist/collection-ids.js +6 -0
- package/dist/collection-ids.js.map +1 -0
- package/dist/collection-index-materialization.d.ts +29 -0
- package/dist/collection-index-materialization.d.ts.map +1 -0
- package/dist/collection-index-materialization.js +118 -0
- package/dist/collection-index-materialization.js.map +1 -0
- package/dist/collection-mutation-queue.d.ts +10 -0
- package/dist/collection-mutation-queue.d.ts.map +1 -0
- package/dist/collection-mutation-queue.js +46 -0
- package/dist/collection-mutation-queue.js.map +1 -0
- package/dist/collection-mutation-workflow.d.ts +18 -0
- package/dist/collection-mutation-workflow.d.ts.map +1 -0
- package/dist/collection-mutation-workflow.js +252 -0
- package/dist/collection-mutation-workflow.js.map +1 -0
- package/dist/collection-persistence.d.ts +48 -0
- package/dist/collection-persistence.d.ts.map +1 -0
- package/dist/collection-persistence.js +323 -0
- package/dist/collection-persistence.js.map +1 -0
- package/dist/collection-policy.d.ts +5 -0
- package/dist/collection-policy.d.ts.map +1 -0
- package/dist/collection-policy.js +7 -0
- package/dist/collection-policy.js.map +1 -0
- package/dist/collection-preload.d.ts +21 -0
- package/dist/collection-preload.d.ts.map +1 -0
- package/dist/collection-preload.js +4 -0
- package/dist/collection-preload.js.map +1 -0
- package/dist/collection-projection-callback-policy.d.ts +14 -0
- package/dist/collection-projection-callback-policy.d.ts.map +1 -0
- package/dist/collection-projection-callback-policy.js +25 -0
- package/dist/collection-projection-callback-policy.js.map +1 -0
- package/dist/collection-reactive-binding.d.ts +72 -0
- package/dist/collection-reactive-binding.d.ts.map +1 -0
- package/dist/collection-reactive-binding.js +95 -0
- package/dist/collection-reactive-binding.js.map +1 -0
- package/dist/collection-registry.d.ts +56 -0
- package/dist/collection-registry.d.ts.map +1 -0
- package/dist/collection-registry.js +123 -0
- package/dist/collection-registry.js.map +1 -0
- package/dist/collection-row-ingress.d.ts +16 -0
- package/dist/collection-row-ingress.d.ts.map +1 -0
- package/dist/collection-row-ingress.js +110 -0
- package/dist/collection-row-ingress.js.map +1 -0
- package/dist/collection-runtime.d.ts +20 -0
- package/dist/collection-runtime.d.ts.map +1 -0
- package/dist/collection-runtime.js +256 -0
- package/dist/collection-runtime.js.map +1 -0
- package/dist/collection-snapshot-codec.d.ts +62 -0
- package/dist/collection-snapshot-codec.d.ts.map +1 -0
- package/dist/collection-snapshot-codec.js +563 -0
- package/dist/collection-snapshot-codec.js.map +1 -0
- package/dist/collection-state.d.ts +72 -0
- package/dist/collection-state.d.ts.map +1 -0
- package/dist/collection-state.js +276 -0
- package/dist/collection-state.js.map +1 -0
- package/dist/collection-sync-load-policy.d.ts +17 -0
- package/dist/collection-sync-load-policy.d.ts.map +1 -0
- package/dist/collection-sync-load-policy.js +245 -0
- package/dist/collection-sync-load-policy.js.map +1 -0
- package/dist/collection-value-detachment.d.ts +34 -0
- package/dist/collection-value-detachment.d.ts.map +1 -0
- package/dist/collection-value-detachment.js +248 -0
- package/dist/collection-value-detachment.js.map +1 -0
- package/dist/collection-write-commit.d.ts +32 -0
- package/dist/collection-write-commit.d.ts.map +1 -0
- package/dist/collection-write-commit.js +51 -0
- package/dist/collection-write-commit.js.map +1 -0
- package/dist/flush-policy.d.ts +130 -0
- package/dist/flush-policy.d.ts.map +1 -0
- package/dist/flush-policy.js +96 -0
- package/dist/flush-policy.js.map +1 -0
- package/dist/index.d.ts +481 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +251 -0
- package/dist/index.js.map +1 -0
- package/dist/live-query-collection-materialization.d.ts +47 -0
- package/dist/live-query-collection-materialization.d.ts.map +1 -0
- package/dist/live-query-collection-materialization.js +231 -0
- package/dist/live-query-collection-materialization.js.map +1 -0
- package/dist/live-query-collection.d.ts +23 -0
- package/dist/live-query-collection.d.ts.map +1 -0
- package/dist/live-query-collection.js +94 -0
- package/dist/live-query-collection.js.map +1 -0
- package/dist/live-query-runtime.d.ts +8 -0
- package/dist/live-query-runtime.d.ts.map +1 -0
- package/dist/live-query-runtime.js +228 -0
- package/dist/live-query-runtime.js.map +1 -0
- package/dist/live-query-state.d.ts +11 -0
- package/dist/live-query-state.d.ts.map +1 -0
- package/dist/live-query-state.js +130 -0
- package/dist/live-query-state.js.map +1 -0
- package/dist/query-builder.d.ts +294 -0
- package/dist/query-builder.d.ts.map +1 -0
- package/dist/query-builder.js +373 -0
- package/dist/query-builder.js.map +1 -0
- package/dist/query-context-identity.d.ts +19 -0
- package/dist/query-context-identity.d.ts.map +1 -0
- package/dist/query-context-identity.js +41 -0
- package/dist/query-context-identity.js.map +1 -0
- package/dist/query-execution-plan.d.ts +27 -0
- package/dist/query-execution-plan.d.ts.map +1 -0
- package/dist/query-execution-plan.js +69 -0
- package/dist/query-execution-plan.js.map +1 -0
- package/dist/query-plan.d.ts +200 -0
- package/dist/query-plan.d.ts.map +1 -0
- package/dist/query-plan.js +524 -0
- package/dist/query-plan.js.map +1 -0
- package/dist/query-source-adapter.d.ts +25 -0
- package/dist/query-source-adapter.d.ts.map +1 -0
- package/dist/query-source-adapter.js +14 -0
- package/dist/query-source-adapter.js.map +1 -0
- package/dist/runtime-collection-store.d.ts +38 -0
- package/dist/runtime-collection-store.d.ts.map +1 -0
- package/dist/runtime-collection-store.js +149 -0
- package/dist/runtime-collection-store.js.map +1 -0
- package/dist/server-collection.d.ts +84 -0
- package/dist/server-collection.d.ts.map +1 -0
- package/dist/server-collection.js +84 -0
- package/dist/server-collection.js.map +1 -0
- package/dist/sqlite-persistence.d.ts +239 -0
- package/dist/sqlite-persistence.d.ts.map +1 -0
- package/dist/sqlite-persistence.js +345 -0
- package/dist/sqlite-persistence.js.map +1 -0
- package/dist/sync-adapter.d.ts +233 -0
- package/dist/sync-adapter.d.ts.map +1 -0
- package/dist/sync-adapter.js +226 -0
- package/dist/sync-adapter.js.map +1 -0
- package/package.json +48 -0
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { ReadonlyCollectionMutation } from "./collection-errors.js";
|
|
2
|
+
import { type LiveQuery, type QueryFactory } from "./query-builder.js";
|
|
3
|
+
import type { QueryEvaluationError } from "./query-plan.js";
|
|
4
|
+
import type { AnyCollection, CollectionDefinition, CollectionIndexRecord, CollectionKey } from "./collection-contract.js";
|
|
5
|
+
/**
|
|
6
|
+
* Options for a read-only collection backed by a live query.
|
|
7
|
+
*
|
|
8
|
+
* Use when derived query results should be addressable as a collection, such as
|
|
9
|
+
* joining or indexing view rows. Mutation effects fail with
|
|
10
|
+
* `ReadonlyCollectionMutation`.
|
|
11
|
+
*/
|
|
12
|
+
export interface CollectionLiveQueryOptions<A extends object, K extends CollectionKey, E = never, R = never> {
|
|
13
|
+
readonly name: string;
|
|
14
|
+
readonly getKey: (value: A) => K;
|
|
15
|
+
readonly indexes?: CollectionIndexRecord<A>;
|
|
16
|
+
readonly query: LiveQuery<A, E, R> | QueryFactory<A, E, R>;
|
|
17
|
+
}
|
|
18
|
+
export type LiveQueryCollectionRegister = (name: string, definition: AnyCollection) => void;
|
|
19
|
+
/**
|
|
20
|
+
* Adapter from a live query to a read-only collection definition.
|
|
21
|
+
*/
|
|
22
|
+
export declare const makeLiveQueryCollectionDefinition: <A extends object, K extends CollectionKey = string, E = never, R = never>(options: CollectionLiveQueryOptions<A, K, E, R>, register: LiveQueryCollectionRegister) => CollectionDefinition<A, K, E | QueryEvaluationError | ReadonlyCollectionMutation, R>;
|
|
23
|
+
//# sourceMappingURL=live-query-collection.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"live-query-collection.d.ts","sourceRoot":"","sources":["../src/live-query-collection.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,0BAA0B,EAAE,MAAM,wBAAwB,CAAC;AAUpE,OAAO,EAAS,KAAK,SAAS,EAAE,KAAK,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAC9E,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,iBAAiB,CAAC;AAC5D,OAAO,KAAK,EACV,aAAa,EACb,oBAAoB,EACpB,qBAAqB,EACrB,aAAa,EAGd,MAAM,0BAA0B,CAAC;AAElC;;;;;;GAMG;AACH,MAAM,WAAW,0BAA0B,CACzC,CAAC,SAAS,MAAM,EAChB,CAAC,SAAS,aAAa,EACvB,CAAC,GAAG,KAAK,EACT,CAAC,GAAG,KAAK;IAET,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,MAAM,EAAE,CAAC,KAAK,EAAE,CAAC,KAAK,CAAC,CAAC;IACjC,QAAQ,CAAC,OAAO,CAAC,EAAE,qBAAqB,CAAC,CAAC,CAAC,CAAC;IAC5C,QAAQ,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,YAAY,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;CAC5D;AAED,MAAM,MAAM,2BAA2B,GAAG,CAAC,IAAI,EAAE,MAAM,EAAE,UAAU,EAAE,aAAa,KAAK,IAAI,CAAC;AAW5F;;GAEG;AACH,eAAO,MAAM,iCAAiC,GAC5C,CAAC,SAAS,MAAM,EAChB,CAAC,SAAS,aAAa,GAAG,MAAM,EAChC,CAAC,GAAG,KAAK,EACT,CAAC,GAAG,KAAK,WAEA,0BAA0B,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,YACrC,2BAA2B,KACpC,oBAAoB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,oBAAoB,GAAG,0BAA0B,EAAE,CAAC,CAiHrF,CAAC"}
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
import { runFork } from "@sunfall/arc-core";
|
|
2
|
+
import { Clock, Effect } from "effect";
|
|
3
|
+
import { CollectionTypeId } from "./collection-ids.js";
|
|
4
|
+
import { ReadonlyCollectionMutation } from "./collection-errors.js";
|
|
5
|
+
import { CollectionSnapshotCodecError } from "./collection-snapshot-codec.js";
|
|
6
|
+
import { markStoreExplicitCollectionSnapshotDefinition, withCollectionDurableSnapshotPermits, } from "./collection-definition-snapshot.js";
|
|
7
|
+
import { persistCollectionSnapshotEffect } from "./collection-persistence.js";
|
|
8
|
+
import { makeLiveQueryCollectionMaterialization } from "./live-query-collection-materialization.js";
|
|
9
|
+
import { collectionStoreEffect } from "./runtime-collection-store.js";
|
|
10
|
+
import { Query } from "./query-builder.js";
|
|
11
|
+
const readonlyCollectionMutation = (collection, operation) => new ReadonlyCollectionMutation({ collection, operation });
|
|
12
|
+
const liveQueryFromInput = (query) => (typeof query === "function" ? Query.live(query) : query);
|
|
13
|
+
/**
|
|
14
|
+
* Adapter from a live query to a read-only collection definition.
|
|
15
|
+
*/
|
|
16
|
+
export const makeLiveQueryCollectionDefinition = (options, register) => {
|
|
17
|
+
const live = liveQueryFromInput(options.query);
|
|
18
|
+
const readonlyFail = (operation) => Effect.fail(readonlyCollectionMutation(options.name, operation));
|
|
19
|
+
const readonlySnapshotCodecFailure = (operation) => new CollectionSnapshotCodecError({
|
|
20
|
+
operation,
|
|
21
|
+
path: "$",
|
|
22
|
+
reason: `Live query collection "${options.name}" is derived and read-only; ${operation} source collections instead.`,
|
|
23
|
+
});
|
|
24
|
+
let definition;
|
|
25
|
+
const materialization = makeLiveQueryCollectionMaterialization({
|
|
26
|
+
name: options.name,
|
|
27
|
+
live,
|
|
28
|
+
definition: () => definition,
|
|
29
|
+
});
|
|
30
|
+
definition = {
|
|
31
|
+
[CollectionTypeId]: CollectionTypeId,
|
|
32
|
+
options: {
|
|
33
|
+
name: options.name,
|
|
34
|
+
getKey: options.getKey,
|
|
35
|
+
...(options.indexes === undefined ? {} : { indexes: options.indexes }),
|
|
36
|
+
load: () => live.preloadEffect().pipe(Effect.map(() => live.evaluate())),
|
|
37
|
+
},
|
|
38
|
+
name: options.name,
|
|
39
|
+
readOnly: true,
|
|
40
|
+
getKey: options.getKey,
|
|
41
|
+
state: () => materialization.state(),
|
|
42
|
+
version: () => materialization.version(),
|
|
43
|
+
get: (key) => materialization.get(key),
|
|
44
|
+
rows: () => materialization.rows(),
|
|
45
|
+
index: (index, value) => materialization.index(index, value),
|
|
46
|
+
firstByIndex: (index, value) => materialization.firstByIndex(index, value),
|
|
47
|
+
preloadEffect: () => live.preloadEffect(),
|
|
48
|
+
refetchEffect: () => live.refetchEffect(),
|
|
49
|
+
pendingMutationsEffect: () => Effect.succeed([]),
|
|
50
|
+
pendingMutations: () => [],
|
|
51
|
+
flushPendingMutationsEffect: () => Effect.succeed([]),
|
|
52
|
+
snapshotEffect: () => Effect.gen(function* () {
|
|
53
|
+
const store = yield* collectionStoreEffect;
|
|
54
|
+
const updatedAt = yield* Clock.currentTimeMillis;
|
|
55
|
+
return yield* withCollectionDurableSnapshotPermits(store, [definition], materialization.snapshotWithStoreEffect(store, updatedAt));
|
|
56
|
+
}),
|
|
57
|
+
snapshot: () => materialization.snapshot(Date.now()),
|
|
58
|
+
snapshotWithStore: (store, updatedAt) => materialization.snapshotWithStore(store, updatedAt),
|
|
59
|
+
snapshotWithStoreEffect: (store, updatedAt) => materialization.snapshotWithStoreEffect(store, updatedAt),
|
|
60
|
+
durableSnapshotSources: () => live.sources,
|
|
61
|
+
hydratePreflightEffect: () => Effect.fail(readonlySnapshotCodecFailure("hydrate")),
|
|
62
|
+
hydrateWithStoreEffect: () => Effect.fail(readonlySnapshotCodecFailure("hydrate")),
|
|
63
|
+
hydrateEffect: () => Effect.fail(readonlySnapshotCodecFailure("hydrate")),
|
|
64
|
+
hydrate: (snapshot, hydrateOptions) => {
|
|
65
|
+
void runFork(definition.hydrateEffect(snapshot, hydrateOptions));
|
|
66
|
+
},
|
|
67
|
+
persistEffect: (storage, persistOptions) => Effect.gen(function* () {
|
|
68
|
+
const store = yield* collectionStoreEffect;
|
|
69
|
+
const updatedAt = yield* Clock.currentTimeMillis;
|
|
70
|
+
const snapshot = yield* withCollectionDurableSnapshotPermits(store, [definition], materialization.snapshotWithStoreEffect(store, updatedAt));
|
|
71
|
+
yield* persistCollectionSnapshotEffect(definition, Effect.succeed(snapshot), storage, persistOptions, store);
|
|
72
|
+
}),
|
|
73
|
+
restoreEffect: () => Effect.fail(readonlySnapshotCodecFailure("restore")),
|
|
74
|
+
insertEffect: () => readonlyFail("insert"),
|
|
75
|
+
updateEffect: () => readonlyFail("update"),
|
|
76
|
+
deleteEffect: () => readonlyFail("delete"),
|
|
77
|
+
writeInsertEffect: () => readonlyFail("writeInsert"),
|
|
78
|
+
writeInsert: (input, writeOptions) => {
|
|
79
|
+
void runFork(definition.writeInsertEffect(input, writeOptions));
|
|
80
|
+
},
|
|
81
|
+
writeUpdateEffect: () => readonlyFail("writeUpdate"),
|
|
82
|
+
writeUpdate: (key, changes, writeOptions) => {
|
|
83
|
+
void runFork(definition.writeUpdateEffect(key, changes, writeOptions));
|
|
84
|
+
},
|
|
85
|
+
writeDeleteEffect: () => readonlyFail("writeDelete"),
|
|
86
|
+
writeDelete: (key) => {
|
|
87
|
+
void runFork(definition.writeDeleteEffect(key));
|
|
88
|
+
},
|
|
89
|
+
};
|
|
90
|
+
markStoreExplicitCollectionSnapshotDefinition(definition);
|
|
91
|
+
register(options.name, definition);
|
|
92
|
+
return definition;
|
|
93
|
+
};
|
|
94
|
+
//# sourceMappingURL=live-query-collection.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"live-query-collection.js","sourceRoot":"","sources":["../src/live-query-collection.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAC5C,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AACvC,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AACvD,OAAO,EAAE,0BAA0B,EAAE,MAAM,wBAAwB,CAAC;AACpE,OAAO,EAAE,4BAA4B,EAAE,MAAM,gCAAgC,CAAC;AAC9E,OAAO,EACL,6CAA6C,EAC7C,oCAAoC,GAErC,MAAM,qCAAqC,CAAC;AAC7C,OAAO,EAAE,+BAA+B,EAAE,MAAM,6BAA6B,CAAC;AAC9E,OAAO,EAAE,sCAAsC,EAAE,MAAM,4CAA4C,CAAC;AACpG,OAAO,EAAE,qBAAqB,EAA+B,MAAM,+BAA+B,CAAC;AACnG,OAAO,EAAE,KAAK,EAAqC,MAAM,oBAAoB,CAAC;AAgC9E,MAAM,0BAA0B,GAAG,CACjC,UAAkB,EAClB,SAAiB,EACW,EAAE,CAAC,IAAI,0BAA0B,CAAC,EAAE,UAAU,EAAE,SAAS,EAAE,CAAC,CAAC;AAE3F,MAAM,kBAAkB,GAAG,CACzB,KAAiD,EAC7B,EAAE,CAAC,CAAC,OAAO,KAAK,KAAK,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAU,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;AAE5F;;GAEG;AACH,MAAM,CAAC,MAAM,iCAAiC,GAAG,CAM/C,OAA+C,EAC/C,QAAqC,EACiD,EAAE;IACxF,MAAM,IAAI,GAAG,kBAAkB,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;IAC/C,MAAM,YAAY,GAAG,CAAM,SAAiB,EAAkD,EAAE,CAC9F,MAAM,CAAC,IAAI,CAAC,0BAA0B,CAAC,OAAO,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC,CAAC;IACnE,MAAM,4BAA4B,GAAG,CACnC,SAAgC,EACF,EAAE,CAChC,IAAI,4BAA4B,CAAC;QAC/B,SAAS;QACT,IAAI,EAAE,GAAG;QACT,MAAM,EAAE,0BAA0B,OAAO,CAAC,IAAI,+BAA+B,SAAS,8BAA8B;KACrH,CAAC,CAAC;IASL,IAAI,UAAyC,CAAC;IAC9C,MAAM,eAAe,GAAG,sCAAsC,CAAa;QACzE,IAAI,EAAE,OAAO,CAAC,IAAI;QAClB,IAAI;QACJ,UAAU,EAAE,GAAG,EAAE,CAAC,UAAU;KAC7B,CAAC,CAAC;IACH,UAAU,GAAG;QACX,CAAC,gBAAgB,CAAC,EAAE,gBAAgB;QACpC,OAAO,EAAE;YACP,IAAI,EAAE,OAAO,CAAC,IAAI;YAClB,MAAM,EAAE,OAAO,CAAC,MAAM;YACtB,GAAG,CAAC,OAAO,CAAC,OAAO,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,CAAC;YACtE,IAAI,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;SACzE;QACD,IAAI,EAAE,OAAO,CAAC,IAAI;QAClB,QAAQ,EAAE,IAAI;QACd,MAAM,EAAE,OAAO,CAAC,MAAM;QACtB,KAAK,EAAE,GAAG,EAAE,CAAC,eAAe,CAAC,KAAK,EAAE;QACpC,OAAO,EAAE,GAAG,EAAE,CAAC,eAAe,CAAC,OAAO,EAAE;QACxC,GAAG,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,eAAe,CAAC,GAAG,CAAC,GAAG,CAAC;QACtC,IAAI,EAAE,GAAG,EAAE,CAAC,eAAe,CAAC,IAAI,EAAE;QAClC,KAAK,EAAE,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE,CAAC,eAAe,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC;QAC5D,YAAY,EAAE,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE,CAAC,eAAe,CAAC,YAAY,CAAC,KAAK,EAAE,KAAK,CAAC;QAC1E,aAAa,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,aAAa,EAAE;QACzC,aAAa,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,aAAa,EAAE;QACzC,sBAAsB,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC;QAChD,gBAAgB,EAAE,GAAG,EAAE,CAAC,EAAE;QAC1B,2BAA2B,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC;QACrD,cAAc,EAAE,GAAG,EAAE,CACnB,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC;YAClB,MAAM,KAAK,GAAG,KAAK,CAAC,CAAC,qBAAqB,CAAC;YAC3C,MAAM,SAAS,GAAG,KAAK,CAAC,CAAC,KAAK,CAAC,iBAAiB,CAAC;YACjD,OAAO,KAAK,CAAC,CAAC,oCAAoC,CAChD,KAAK,EACL,CAAC,UAAU,CAAC,EACZ,eAAe,CAAC,uBAAuB,CAAC,KAAK,EAAE,SAAS,CAAC,CAC1D,CAAC;QACJ,CAAC,CAAC;QACJ,QAAQ,EAAE,GAAG,EAAE,CAAC,eAAe,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;QACpD,iBAAiB,EAAE,CAAC,KAAK,EAAE,SAAS,EAAE,EAAE,CACtC,eAAe,CAAC,iBAAiB,CAAC,KAA+B,EAAE,SAAS,CAAC;QAC/E,uBAAuB,EAAE,CAAC,KAAK,EAAE,SAAS,EAAE,EAAE,CAC5C,eAAe,CAAC,uBAAuB,CAAC,KAA+B,EAAE,SAAS,CAAC;QACrF,sBAAsB,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO;QAC1C,sBAAsB,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,4BAA4B,CAAC,SAAS,CAAC,CAAC;QAClF,sBAAsB,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,4BAA4B,CAAC,SAAS,CAAC,CAAC;QAClF,aAAa,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,4BAA4B,CAAC,SAAS,CAAC,CAAC;QACzE,OAAO,EAAE,CAAC,QAAQ,EAAE,cAAc,EAAE,EAAE;YACpC,KAAK,OAAO,CAAC,UAAU,CAAC,aAAa,CAAC,QAAQ,EAAE,cAAc,CAAC,CAAC,CAAC;QACnE,CAAC;QACD,aAAa,EAAE,CACb,OAA6C,EAC7C,cAAyC,EACzC,EAAE,CACF,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC;YAClB,MAAM,KAAK,GAAG,KAAK,CAAC,CAAC,qBAAqB,CAAC;YAC3C,MAAM,SAAS,GAAG,KAAK,CAAC,CAAC,KAAK,CAAC,iBAAiB,CAAC;YACjD,MAAM,QAAQ,GAAG,KAAK,CAAC,CAAC,oCAAoC,CAC1D,KAAK,EACL,CAAC,UAAU,CAAC,EACZ,eAAe,CAAC,uBAAuB,CAAC,KAAK,EAAE,SAAS,CAAC,CAC1D,CAAC;YACF,KAAK,CAAC,CAAC,+BAA+B,CACpC,UAAU,EACV,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,EACxB,OAAO,EACP,cAAc,EACd,KAAK,CACN,CAAC;QACJ,CAAC,CAAC;QACJ,aAAa,EAAE,GAA6B,EAAE,CAC5C,MAAM,CAAC,IAAI,CAAC,4BAA4B,CAAC,SAAS,CAAC,CAAC;QACtD,YAAY,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,QAAQ,CAAC;QAC1C,YAAY,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,QAAQ,CAAC;QAC1C,YAAY,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,QAAQ,CAAC;QAC1C,iBAAiB,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,aAAa,CAAC;QACpD,WAAW,EAAE,CAAC,KAAK,EAAE,YAAY,EAAE,EAAE;YACnC,KAAK,OAAO,CAAC,UAAU,CAAC,iBAAiB,CAAC,KAAK,EAAE,YAAY,CAAC,CAAC,CAAC;QAClE,CAAC;QACD,iBAAiB,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,aAAa,CAAC;QACpD,WAAW,EAAE,CAAC,GAAG,EAAE,OAAO,EAAE,YAAY,EAAE,EAAE;YAC1C,KAAK,OAAO,CAAC,UAAU,CAAC,iBAAiB,CAAC,GAAG,EAAE,OAAO,EAAE,YAAY,CAAC,CAAC,CAAC;QACzE,CAAC;QACD,iBAAiB,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,aAAa,CAAC;QACpD,WAAW,EAAE,CAAC,GAAG,EAAE,EAAE;YACnB,KAAK,OAAO,CAAC,UAAU,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC,CAAC;QAClD,CAAC;KACF,CAAC;IACF,6CAA6C,CAAC,UAAU,CAAC,CAAC;IAE1D,QAAQ,CAAC,OAAO,CAAC,IAAI,EAAE,UAA2B,CAAC,CAAC;IAEpD,OAAO,UAAU,CAAC;AACpB,CAAC,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { type AnyQueryContext, type QueryStagePlan } from "./query-plan.js";
|
|
2
|
+
import { type QueryExecutionPlanBuilder } from "./query-execution-plan.js";
|
|
3
|
+
export type LiveQueryRuntimeBuilder<TContext extends AnyQueryContext, TResult> = QueryExecutionPlanBuilder<TContext, TResult>;
|
|
4
|
+
export interface LiveQueryRuntime<TResult> {
|
|
5
|
+
evaluate(): ReadonlyArray<TResult>;
|
|
6
|
+
}
|
|
7
|
+
export declare const makeLiveQueryRuntime: <TContext extends AnyQueryContext, TResult>(builder: LiveQueryRuntimeBuilder<TContext, TResult>, stagePlan?: QueryStagePlan<TContext>) => LiveQueryRuntime<TResult>;
|
|
8
|
+
//# sourceMappingURL=live-query-runtime.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"live-query-runtime.d.ts","sourceRoot":"","sources":["../src/live-query-runtime.ts"],"names":[],"mappings":"AAgBA,OAAO,EAUL,KAAK,eAAe,EAGpB,KAAK,cAAc,EACpB,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAGL,KAAK,yBAAyB,EAC/B,MAAM,2BAA2B,CAAC;AAUnC,MAAM,MAAM,uBAAuB,CACjC,QAAQ,SAAS,eAAe,EAChC,OAAO,IACL,yBAAyB,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;AAEjD,MAAM,WAAW,gBAAgB,CAAC,OAAO;IACvC,QAAQ,IAAI,aAAa,CAAC,OAAO,CAAC,CAAC;CACpC;AAmWD,eAAO,MAAM,oBAAoB,GAAI,QAAQ,SAAS,eAAe,EAAE,OAAO,WACnE,uBAAuB,CAAC,QAAQ,EAAE,OAAO,CAAC,cACvC,cAAc,CAAC,QAAQ,CAAC,KACnC,gBAAgB,CAAC,OAAO,CAE1B,CAAC"}
|
|
@@ -0,0 +1,228 @@
|
|
|
1
|
+
import { stableStringify } from "@sunfall/arc-core";
|
|
2
|
+
import { D2, MultiSet, filter as ivmFilter, groupBy as ivmGroupBy, innerJoin as ivmInnerJoin, map as ivmMap, orderByWithFractionalIndex as ivmOrderByWithFractionalIndex, output as ivmOutput, } from "@tanstack/db-ivm";
|
|
3
|
+
import { UnsupportedLiveQuery, compareValue, compileQueryStagePlan, evaluateQueryGroupKey, evaluateQueryJoinKey, evaluateQueryOperation, evaluateQueryStructuredOperation, } from "./query-plan.js";
|
|
4
|
+
import { compareQueryOrderedContexts, projectQueryContexts, } from "./query-execution-plan.js";
|
|
5
|
+
import { mergeQueryContextRecords, queryCollectionRowIdentity, queryContextIdentityOf, querySourceContext, } from "./query-context-identity.js";
|
|
6
|
+
const compareIvmContexts = (orders) => (left, right) => {
|
|
7
|
+
const leftIdentity = queryContextIdentityOf(left);
|
|
8
|
+
const rightIdentity = queryContextIdentityOf(right);
|
|
9
|
+
return compareQueryOrderedContexts(leftIdentity === undefined
|
|
10
|
+
? { row: left, index: 0 }
|
|
11
|
+
: { row: left, index: 0, identity: leftIdentity }, rightIdentity === undefined
|
|
12
|
+
? { row: right, index: 0 }
|
|
13
|
+
: { row: right, index: 0, identity: rightIdentity }, orders);
|
|
14
|
+
};
|
|
15
|
+
const crossJoinKey = "__sunfall_arc_db_all__";
|
|
16
|
+
const wrapIvmGrouping = (grouping) => ({
|
|
17
|
+
key: (row) => evaluateQueryOperation("aggregate", () => {
|
|
18
|
+
const key = grouping.key(row);
|
|
19
|
+
evaluateQueryGroupKey(key);
|
|
20
|
+
return key;
|
|
21
|
+
}),
|
|
22
|
+
sourceFilters: grouping.sourceFilters.map((filter) => (row) => evaluateQueryOperation("filter", () => filter(row))),
|
|
23
|
+
aggregates: Object.fromEntries(Object.entries(grouping.aggregates).map(([name, aggregate]) => [
|
|
24
|
+
name,
|
|
25
|
+
{
|
|
26
|
+
preMap: (row) => evaluateQueryStructuredOperation("aggregate", () => aggregate.preMap(row)),
|
|
27
|
+
reduce: (values) => evaluateQueryStructuredOperation("aggregate", () => aggregate.reduce(values)),
|
|
28
|
+
...(aggregate.postMap
|
|
29
|
+
? {
|
|
30
|
+
postMap: (value) => evaluateQueryStructuredOperation("aggregate", () => aggregate.postMap(value)),
|
|
31
|
+
}
|
|
32
|
+
: {}),
|
|
33
|
+
},
|
|
34
|
+
])),
|
|
35
|
+
});
|
|
36
|
+
const addIvmRuntimeOperator = (graph, operator) => {
|
|
37
|
+
// @tanstack/db-ivm dispatches through IOperator at runtime, but addOperator is typed to internal classes.
|
|
38
|
+
graph.addOperator(operator);
|
|
39
|
+
};
|
|
40
|
+
const ivmFlatMap = (mapInput) => (stream) => {
|
|
41
|
+
const reader = stream.connectReader();
|
|
42
|
+
const output = stream.graph.newInput();
|
|
43
|
+
addIvmRuntimeOperator(stream.graph, {
|
|
44
|
+
run: () => {
|
|
45
|
+
for (const message of reader.drain()) {
|
|
46
|
+
const mapped = [];
|
|
47
|
+
for (const [input, multiplicity] of message.getInner()) {
|
|
48
|
+
for (const outputValue of mapInput(input)) {
|
|
49
|
+
mapped.push([outputValue, multiplicity]);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
if (mapped.length > 0) {
|
|
53
|
+
output.writer.sendData(new MultiSet(mapped));
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
},
|
|
57
|
+
hasPendingWork: () => !reader.isEmpty(),
|
|
58
|
+
});
|
|
59
|
+
return output;
|
|
60
|
+
};
|
|
61
|
+
class IvmLiveQueryRuntime {
|
|
62
|
+
builder;
|
|
63
|
+
#graph = new D2();
|
|
64
|
+
#stagePlan;
|
|
65
|
+
#sources;
|
|
66
|
+
#rows = new Map();
|
|
67
|
+
constructor(builder, stagePlan) {
|
|
68
|
+
this.builder = builder;
|
|
69
|
+
this.#stagePlan = stagePlan ?? compileQueryStagePlan(builder);
|
|
70
|
+
this.#sources = this.#stagePlan.sources.map((source) => ({
|
|
71
|
+
alias: source.alias,
|
|
72
|
+
source: source.adapter,
|
|
73
|
+
input: this.#graph.newInput(),
|
|
74
|
+
previous: new Map(),
|
|
75
|
+
}));
|
|
76
|
+
if (this.#sources.length > 0) {
|
|
77
|
+
this.#compile();
|
|
78
|
+
}
|
|
79
|
+
this.#graph.finalize();
|
|
80
|
+
}
|
|
81
|
+
evaluate() {
|
|
82
|
+
for (const source of this.#sources) {
|
|
83
|
+
source.source.version().get();
|
|
84
|
+
this.#syncSource(source);
|
|
85
|
+
}
|
|
86
|
+
this.#graph.run();
|
|
87
|
+
const rows = Array.from(this.#rows.values());
|
|
88
|
+
if (this.#stagePlan.orders.length > 0) {
|
|
89
|
+
rows.sort((left, right) => compareValue(left.order, right.order));
|
|
90
|
+
}
|
|
91
|
+
return projectQueryContexts(this.builder, rows.map((row) => row.context), {
|
|
92
|
+
filter: false,
|
|
93
|
+
order: this.#stagePlan.orders.length === 0,
|
|
94
|
+
window: this.#stagePlan.orders.length === 0,
|
|
95
|
+
stagePlan: this.#stagePlan,
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
#compile() {
|
|
99
|
+
const sourceByAlias = new Map(this.#sources.map((source) => [source.alias, source]));
|
|
100
|
+
const baseSources = this.#stagePlan.baseSources.map((source) => sourceByAlias.get(source.alias));
|
|
101
|
+
const first = baseSources[0];
|
|
102
|
+
if (!first) {
|
|
103
|
+
return;
|
|
104
|
+
}
|
|
105
|
+
let stream = first.input;
|
|
106
|
+
for (const source of baseSources.slice(1)) {
|
|
107
|
+
if (!source) {
|
|
108
|
+
continue;
|
|
109
|
+
}
|
|
110
|
+
stream = stream.pipe(ivmInnerJoin(source.input), ivmMap(([_, pair]) => {
|
|
111
|
+
const [left, right] = pair;
|
|
112
|
+
return [crossJoinKey, mergeContexts(left, right)];
|
|
113
|
+
}));
|
|
114
|
+
}
|
|
115
|
+
for (const join of this.#stagePlan.joins) {
|
|
116
|
+
const source = sourceByAlias.get(join.alias);
|
|
117
|
+
if (!source) {
|
|
118
|
+
throw new UnsupportedLiveQuery({
|
|
119
|
+
reason: `Join source "${join.alias}" is not registered.`,
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
const keyedLeft = stream.pipe(ivmMap(([_, context]) => [
|
|
123
|
+
evaluateQueryJoinKey(evaluateQueryOperation("join", () => join.leftKey(context))),
|
|
124
|
+
context,
|
|
125
|
+
]));
|
|
126
|
+
const keyedRight = source.input.pipe(ivmFlatMap(([_, context]) => {
|
|
127
|
+
const row = context[join.alias];
|
|
128
|
+
return evaluateQueryStructuredOperation("join", () => join.rightKeys(row)).map((rightKey) => [evaluateQueryJoinKey(rightKey), context]);
|
|
129
|
+
}));
|
|
130
|
+
stream = keyedLeft.pipe(ivmInnerJoin(keyedRight), ivmMap(([_, pair]) => {
|
|
131
|
+
const [left, right] = pair;
|
|
132
|
+
return [crossJoinKey, mergeContexts(left, right)];
|
|
133
|
+
}));
|
|
134
|
+
}
|
|
135
|
+
let resultStream;
|
|
136
|
+
if (this.#stagePlan.grouping) {
|
|
137
|
+
const grouping = wrapIvmGrouping(this.#stagePlan.grouping);
|
|
138
|
+
resultStream = stream.pipe(ivmFilter(([_, context]) => grouping.sourceFilters.every((filter) => filter(context))), ivmMap(([_, context]) => context), ivmGroupBy(grouping.key, grouping.aggregates), ivmFilter(([_, group]) => this.#stagePlan.filters.every((filter) => evaluateQueryOperation("filter", () => filter(group)))), ivmMap(([key, group]) => [key, group]));
|
|
139
|
+
}
|
|
140
|
+
else {
|
|
141
|
+
resultStream = stream.pipe(ivmFilter(([_, context]) => this.#stagePlan.filters.every((filter) => evaluateQueryOperation("filter", () => filter(context)))), ivmMap(([_, context]) => [
|
|
142
|
+
queryContextIdentityOf(context) ?? crossJoinKey,
|
|
143
|
+
context,
|
|
144
|
+
]));
|
|
145
|
+
}
|
|
146
|
+
let outputStream;
|
|
147
|
+
if (this.#stagePlan.orders.length > 0) {
|
|
148
|
+
const orderOptions = {
|
|
149
|
+
comparator: compareIvmContexts(this.#stagePlan.orders),
|
|
150
|
+
offset: this.#stagePlan.window.offset,
|
|
151
|
+
...(this.#stagePlan.window.limit === undefined
|
|
152
|
+
? {}
|
|
153
|
+
: { limit: this.#stagePlan.window.limit }),
|
|
154
|
+
};
|
|
155
|
+
outputStream = resultStream.pipe(ivmOrderByWithFractionalIndex((context) => context, orderOptions), ivmMap(([key, [context, order]]) => [key, { context, order }]));
|
|
156
|
+
}
|
|
157
|
+
else {
|
|
158
|
+
outputStream = resultStream.pipe(ivmMap(([key, context]) => [key, { context, order: undefined }]));
|
|
159
|
+
}
|
|
160
|
+
outputStream.pipe(ivmOutput((data) => this.#applyOutput(data)));
|
|
161
|
+
}
|
|
162
|
+
#applyOutput(data) {
|
|
163
|
+
const changes = new Map();
|
|
164
|
+
for (const [[key, row], multiplicity] of data.getInner()) {
|
|
165
|
+
const existing = changes.get(key) ?? { count: 0, positive: undefined };
|
|
166
|
+
changes.set(key, {
|
|
167
|
+
count: existing.count + multiplicity,
|
|
168
|
+
positive: multiplicity > 0 ? row : existing.positive,
|
|
169
|
+
});
|
|
170
|
+
}
|
|
171
|
+
for (const [key, change] of changes) {
|
|
172
|
+
const existing = this.#rows.get(key);
|
|
173
|
+
const nextCount = (existing?.count ?? 0) + change.count;
|
|
174
|
+
if (nextCount <= 0) {
|
|
175
|
+
this.#rows.delete(key);
|
|
176
|
+
}
|
|
177
|
+
else {
|
|
178
|
+
const row = change.positive ?? existing;
|
|
179
|
+
if (row) {
|
|
180
|
+
this.#rows.set(key, {
|
|
181
|
+
context: row.context,
|
|
182
|
+
count: nextCount,
|
|
183
|
+
order: row.order,
|
|
184
|
+
});
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
#syncSource(source) {
|
|
190
|
+
const current = new Map();
|
|
191
|
+
const deltas = [];
|
|
192
|
+
for (const row of source.source.rows()) {
|
|
193
|
+
const key = queryCollectionRowIdentity(row.$key);
|
|
194
|
+
const hash = evaluateQueryOperation("source", () => stableStringify(row));
|
|
195
|
+
const previous = source.previous.get(key);
|
|
196
|
+
current.set(key, { row, hash });
|
|
197
|
+
if (!previous) {
|
|
198
|
+
deltas.push([sourceContext(source.alias, row), 1]);
|
|
199
|
+
continue;
|
|
200
|
+
}
|
|
201
|
+
if (previous.hash !== hash) {
|
|
202
|
+
deltas.push([sourceContext(source.alias, previous.row), -1]);
|
|
203
|
+
deltas.push([sourceContext(source.alias, row), 1]);
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
for (const [key, previous] of source.previous) {
|
|
207
|
+
if (!current.has(key)) {
|
|
208
|
+
deltas.push([sourceContext(source.alias, previous.row), -1]);
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
source.previous.clear();
|
|
212
|
+
for (const [key, row] of current) {
|
|
213
|
+
source.previous.set(key, row);
|
|
214
|
+
}
|
|
215
|
+
if (deltas.length > 0) {
|
|
216
|
+
source.input.sendData(new MultiSet(deltas));
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
}
|
|
220
|
+
const sourceContext = (alias, row) => [
|
|
221
|
+
crossJoinKey,
|
|
222
|
+
querySourceContext(alias, row),
|
|
223
|
+
];
|
|
224
|
+
const mergeContexts = (left, right) => mergeQueryContextRecords(left, right);
|
|
225
|
+
export const makeLiveQueryRuntime = (builder, stagePlan) => {
|
|
226
|
+
return new IvmLiveQueryRuntime(builder, stagePlan);
|
|
227
|
+
};
|
|
228
|
+
//# sourceMappingURL=live-query-runtime.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"live-query-runtime.js","sourceRoot":"","sources":["../src/live-query-runtime.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { AnyQueryBuilder, LiveQuery } from "./query-builder.js";
|
|
2
|
+
/**
|
|
3
|
+
* Builds the signal-backed state handle returned by `Query.live(...)`.
|
|
4
|
+
*
|
|
5
|
+
* Query Builder owns immutable query descriptions. This Module owns the
|
|
6
|
+
* reactive state Adapter around a Live Query Runtime: last-good data retention,
|
|
7
|
+
* evaluation failures, source collection load-state folding, and source
|
|
8
|
+
* preload/refetch effects.
|
|
9
|
+
*/
|
|
10
|
+
export declare const makeLiveQueryState: <T, E = never, R = never>(builder: AnyQueryBuilder<T, E, R>) => LiveQuery<T, E, R>;
|
|
11
|
+
//# sourceMappingURL=live-query-state.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"live-query-state.d.ts","sourceRoot":"","sources":["../src/live-query-state.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,eAAe,EAAE,SAAS,EAAkB,MAAM,oBAAoB,CAAC;AASrF;;;;;;;GAOG;AACH,eAAO,MAAM,kBAAkB,GAAI,CAAC,EAAE,CAAC,GAAG,KAAK,EAAE,CAAC,GAAG,KAAK,WAC/C,eAAe,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,KAChC,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAuKnB,CAAC"}
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
import { Signal, SignalTypeId } from "@sunfall/arc-core";
|
|
2
|
+
import { Effect } from "effect";
|
|
3
|
+
import { makeLiveQueryRuntime } from "./live-query-runtime.js";
|
|
4
|
+
import { currentCollectionStore, runWithCollectionStore, } from "./runtime-collection-store.js";
|
|
5
|
+
import { compileQueryStagePlan, toQueryEvaluationError, } from "./query-plan.js";
|
|
6
|
+
import { preloadQueryExecutionPlanEffect } from "./query-execution-plan.js";
|
|
7
|
+
/**
|
|
8
|
+
* Builds the signal-backed state handle returned by `Query.live(...)`.
|
|
9
|
+
*
|
|
10
|
+
* Query Builder owns immutable query descriptions. This Module owns the
|
|
11
|
+
* reactive state Adapter around a Live Query Runtime: last-good data retention,
|
|
12
|
+
* evaluation failures, source collection load-state folding, and source
|
|
13
|
+
* preload/refetch effects.
|
|
14
|
+
*/
|
|
15
|
+
export const makeLiveQueryState = (builder) => {
|
|
16
|
+
const initialStagePlan = (() => {
|
|
17
|
+
try {
|
|
18
|
+
return { stagePlan: compileQueryStagePlan(builder) };
|
|
19
|
+
}
|
|
20
|
+
catch (cause) {
|
|
21
|
+
return { error: toQueryEvaluationError("evaluate", cause) };
|
|
22
|
+
}
|
|
23
|
+
})();
|
|
24
|
+
const stagePlan = initialStagePlan.stagePlan;
|
|
25
|
+
const stagePlanError = initialStagePlan.error;
|
|
26
|
+
const sourceAdapters = stagePlan?.sourceAdapters ?? [];
|
|
27
|
+
const sources = sourceAdapters.map((source) => source.collection);
|
|
28
|
+
const storeStates = new WeakMap();
|
|
29
|
+
const currentRuntimeCollectionStore = () => currentCollectionStore();
|
|
30
|
+
const storeState = (store) => {
|
|
31
|
+
const existing = storeStates.get(store);
|
|
32
|
+
if (existing) {
|
|
33
|
+
return existing;
|
|
34
|
+
}
|
|
35
|
+
const state = {
|
|
36
|
+
engine: undefined,
|
|
37
|
+
latestData: [],
|
|
38
|
+
latestEvaluationVersion: undefined,
|
|
39
|
+
latestEvaluation: undefined,
|
|
40
|
+
signals: undefined,
|
|
41
|
+
};
|
|
42
|
+
storeStates.set(store, state);
|
|
43
|
+
return state;
|
|
44
|
+
};
|
|
45
|
+
const sourceVersions = () => sourceAdapters.map((source) => source.version().get());
|
|
46
|
+
const sameVersions = (left, right) => left.length === right.length &&
|
|
47
|
+
left.every((version, index) => Object.is(version, right[index]));
|
|
48
|
+
const withStore = (store, evaluate) => runWithCollectionStore(store, evaluate);
|
|
49
|
+
const storeSignals = (store) => {
|
|
50
|
+
const storeEvaluation = storeState(store);
|
|
51
|
+
if (storeEvaluation.signals) {
|
|
52
|
+
return storeEvaluation.signals;
|
|
53
|
+
}
|
|
54
|
+
const evaluation = Signal.derive(() => withStore(store, () => {
|
|
55
|
+
const versions = sourceVersions();
|
|
56
|
+
if (storeEvaluation.latestEvaluation !== undefined &&
|
|
57
|
+
storeEvaluation.latestEvaluationVersion !== undefined &&
|
|
58
|
+
sameVersions(storeEvaluation.latestEvaluationVersion, versions)) {
|
|
59
|
+
return storeEvaluation.latestEvaluation;
|
|
60
|
+
}
|
|
61
|
+
try {
|
|
62
|
+
if (stagePlanError !== undefined) {
|
|
63
|
+
throw stagePlanError;
|
|
64
|
+
}
|
|
65
|
+
storeEvaluation.engine ??= makeLiveQueryRuntime(builder, stagePlan);
|
|
66
|
+
storeEvaluation.latestData = storeEvaluation.engine.evaluate();
|
|
67
|
+
storeEvaluation.latestEvaluationVersion = versions;
|
|
68
|
+
storeEvaluation.latestEvaluation = { data: storeEvaluation.latestData, error: undefined };
|
|
69
|
+
return storeEvaluation.latestEvaluation;
|
|
70
|
+
}
|
|
71
|
+
catch (cause) {
|
|
72
|
+
storeEvaluation.latestEvaluationVersion = versions;
|
|
73
|
+
storeEvaluation.latestEvaluation = {
|
|
74
|
+
data: storeEvaluation.latestData,
|
|
75
|
+
error: toQueryEvaluationError("evaluate", cause),
|
|
76
|
+
};
|
|
77
|
+
return storeEvaluation.latestEvaluation;
|
|
78
|
+
}
|
|
79
|
+
}));
|
|
80
|
+
const data = Signal.derive(() => evaluation.get().data);
|
|
81
|
+
const state = Signal.derive(() => withStore(store, () => {
|
|
82
|
+
const current = evaluation.get();
|
|
83
|
+
if (current.error) {
|
|
84
|
+
return {
|
|
85
|
+
_tag: "Failure",
|
|
86
|
+
waiting: false,
|
|
87
|
+
error: current.error,
|
|
88
|
+
data: current.data,
|
|
89
|
+
};
|
|
90
|
+
}
|
|
91
|
+
const currentData = current.data;
|
|
92
|
+
for (const source of sourceAdapters) {
|
|
93
|
+
const sourceState = source.state().get();
|
|
94
|
+
if (sourceState._tag === "Failure") {
|
|
95
|
+
return {
|
|
96
|
+
_tag: "Failure",
|
|
97
|
+
waiting: false,
|
|
98
|
+
error: sourceState.error,
|
|
99
|
+
data: currentData,
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
const waiting = sourceAdapters.some((source) => {
|
|
104
|
+
const sourceState = source.state().get();
|
|
105
|
+
return sourceState._tag === "Initial" || sourceState._tag === "Pending";
|
|
106
|
+
});
|
|
107
|
+
return waiting
|
|
108
|
+
? { _tag: "Pending", waiting: true, data: currentData }
|
|
109
|
+
: { _tag: "Success", waiting: false, data: currentData };
|
|
110
|
+
}));
|
|
111
|
+
storeEvaluation.signals = { evaluation, data, state };
|
|
112
|
+
return storeEvaluation.signals;
|
|
113
|
+
};
|
|
114
|
+
const currentStoreSignal = (select) => ({
|
|
115
|
+
[SignalTypeId]: SignalTypeId,
|
|
116
|
+
get: () => select(storeSignals(currentRuntimeCollectionStore())).get(),
|
|
117
|
+
subscribe: (listener) => select(storeSignals(currentRuntimeCollectionStore())).subscribe(listener),
|
|
118
|
+
});
|
|
119
|
+
const data = currentStoreSignal((signals) => signals.data);
|
|
120
|
+
const state = currentStoreSignal((signals) => signals.state);
|
|
121
|
+
return {
|
|
122
|
+
data,
|
|
123
|
+
state,
|
|
124
|
+
sources,
|
|
125
|
+
evaluate: () => data.get(),
|
|
126
|
+
preloadEffect: () => preloadQueryExecutionPlanEffect(builder, false),
|
|
127
|
+
refetchEffect: () => preloadQueryExecutionPlanEffect(builder, true),
|
|
128
|
+
};
|
|
129
|
+
};
|
|
130
|
+
//# sourceMappingURL=live-query-state.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"live-query-state.js","sourceRoot":"","sources":["../src/live-query-state.ts"],"names":[],"mappings":"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"}
|