@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.
Files changed (150) hide show
  1. package/LICENSE +21 -0
  2. package/dist/change-feed-dispatcher.d.ts +21 -0
  3. package/dist/change-feed-dispatcher.d.ts.map +1 -0
  4. package/dist/change-feed-dispatcher.js +53 -0
  5. package/dist/change-feed-dispatcher.js.map +1 -0
  6. package/dist/collection-change-feed-runtime.d.ts +32 -0
  7. package/dist/collection-change-feed-runtime.d.ts.map +1 -0
  8. package/dist/collection-change-feed-runtime.js +50 -0
  9. package/dist/collection-change-feed-runtime.js.map +1 -0
  10. package/dist/collection-contract.d.ts +525 -0
  11. package/dist/collection-contract.d.ts.map +1 -0
  12. package/dist/collection-contract.js +4 -0
  13. package/dist/collection-contract.js.map +1 -0
  14. package/dist/collection-definition-snapshot.d.ts +64 -0
  15. package/dist/collection-definition-snapshot.d.ts.map +1 -0
  16. package/dist/collection-definition-snapshot.js +122 -0
  17. package/dist/collection-definition-snapshot.js.map +1 -0
  18. package/dist/collection-errors.d.ts +38 -0
  19. package/dist/collection-errors.d.ts.map +1 -0
  20. package/dist/collection-errors.js +17 -0
  21. package/dist/collection-errors.js.map +1 -0
  22. package/dist/collection-ids.d.ts +6 -0
  23. package/dist/collection-ids.d.ts.map +1 -0
  24. package/dist/collection-ids.js +6 -0
  25. package/dist/collection-ids.js.map +1 -0
  26. package/dist/collection-index-materialization.d.ts +29 -0
  27. package/dist/collection-index-materialization.d.ts.map +1 -0
  28. package/dist/collection-index-materialization.js +118 -0
  29. package/dist/collection-index-materialization.js.map +1 -0
  30. package/dist/collection-mutation-queue.d.ts +10 -0
  31. package/dist/collection-mutation-queue.d.ts.map +1 -0
  32. package/dist/collection-mutation-queue.js +46 -0
  33. package/dist/collection-mutation-queue.js.map +1 -0
  34. package/dist/collection-mutation-workflow.d.ts +18 -0
  35. package/dist/collection-mutation-workflow.d.ts.map +1 -0
  36. package/dist/collection-mutation-workflow.js +252 -0
  37. package/dist/collection-mutation-workflow.js.map +1 -0
  38. package/dist/collection-persistence.d.ts +48 -0
  39. package/dist/collection-persistence.d.ts.map +1 -0
  40. package/dist/collection-persistence.js +323 -0
  41. package/dist/collection-persistence.js.map +1 -0
  42. package/dist/collection-policy.d.ts +5 -0
  43. package/dist/collection-policy.d.ts.map +1 -0
  44. package/dist/collection-policy.js +7 -0
  45. package/dist/collection-policy.js.map +1 -0
  46. package/dist/collection-preload.d.ts +21 -0
  47. package/dist/collection-preload.d.ts.map +1 -0
  48. package/dist/collection-preload.js +4 -0
  49. package/dist/collection-preload.js.map +1 -0
  50. package/dist/collection-projection-callback-policy.d.ts +14 -0
  51. package/dist/collection-projection-callback-policy.d.ts.map +1 -0
  52. package/dist/collection-projection-callback-policy.js +25 -0
  53. package/dist/collection-projection-callback-policy.js.map +1 -0
  54. package/dist/collection-reactive-binding.d.ts +72 -0
  55. package/dist/collection-reactive-binding.d.ts.map +1 -0
  56. package/dist/collection-reactive-binding.js +95 -0
  57. package/dist/collection-reactive-binding.js.map +1 -0
  58. package/dist/collection-registry.d.ts +56 -0
  59. package/dist/collection-registry.d.ts.map +1 -0
  60. package/dist/collection-registry.js +123 -0
  61. package/dist/collection-registry.js.map +1 -0
  62. package/dist/collection-row-ingress.d.ts +16 -0
  63. package/dist/collection-row-ingress.d.ts.map +1 -0
  64. package/dist/collection-row-ingress.js +110 -0
  65. package/dist/collection-row-ingress.js.map +1 -0
  66. package/dist/collection-runtime.d.ts +20 -0
  67. package/dist/collection-runtime.d.ts.map +1 -0
  68. package/dist/collection-runtime.js +256 -0
  69. package/dist/collection-runtime.js.map +1 -0
  70. package/dist/collection-snapshot-codec.d.ts +62 -0
  71. package/dist/collection-snapshot-codec.d.ts.map +1 -0
  72. package/dist/collection-snapshot-codec.js +563 -0
  73. package/dist/collection-snapshot-codec.js.map +1 -0
  74. package/dist/collection-state.d.ts +72 -0
  75. package/dist/collection-state.d.ts.map +1 -0
  76. package/dist/collection-state.js +276 -0
  77. package/dist/collection-state.js.map +1 -0
  78. package/dist/collection-sync-load-policy.d.ts +17 -0
  79. package/dist/collection-sync-load-policy.d.ts.map +1 -0
  80. package/dist/collection-sync-load-policy.js +245 -0
  81. package/dist/collection-sync-load-policy.js.map +1 -0
  82. package/dist/collection-value-detachment.d.ts +34 -0
  83. package/dist/collection-value-detachment.d.ts.map +1 -0
  84. package/dist/collection-value-detachment.js +248 -0
  85. package/dist/collection-value-detachment.js.map +1 -0
  86. package/dist/collection-write-commit.d.ts +32 -0
  87. package/dist/collection-write-commit.d.ts.map +1 -0
  88. package/dist/collection-write-commit.js +51 -0
  89. package/dist/collection-write-commit.js.map +1 -0
  90. package/dist/flush-policy.d.ts +130 -0
  91. package/dist/flush-policy.d.ts.map +1 -0
  92. package/dist/flush-policy.js +96 -0
  93. package/dist/flush-policy.js.map +1 -0
  94. package/dist/index.d.ts +481 -0
  95. package/dist/index.d.ts.map +1 -0
  96. package/dist/index.js +251 -0
  97. package/dist/index.js.map +1 -0
  98. package/dist/live-query-collection-materialization.d.ts +47 -0
  99. package/dist/live-query-collection-materialization.d.ts.map +1 -0
  100. package/dist/live-query-collection-materialization.js +231 -0
  101. package/dist/live-query-collection-materialization.js.map +1 -0
  102. package/dist/live-query-collection.d.ts +23 -0
  103. package/dist/live-query-collection.d.ts.map +1 -0
  104. package/dist/live-query-collection.js +94 -0
  105. package/dist/live-query-collection.js.map +1 -0
  106. package/dist/live-query-runtime.d.ts +8 -0
  107. package/dist/live-query-runtime.d.ts.map +1 -0
  108. package/dist/live-query-runtime.js +228 -0
  109. package/dist/live-query-runtime.js.map +1 -0
  110. package/dist/live-query-state.d.ts +11 -0
  111. package/dist/live-query-state.d.ts.map +1 -0
  112. package/dist/live-query-state.js +130 -0
  113. package/dist/live-query-state.js.map +1 -0
  114. package/dist/query-builder.d.ts +294 -0
  115. package/dist/query-builder.d.ts.map +1 -0
  116. package/dist/query-builder.js +373 -0
  117. package/dist/query-builder.js.map +1 -0
  118. package/dist/query-context-identity.d.ts +19 -0
  119. package/dist/query-context-identity.d.ts.map +1 -0
  120. package/dist/query-context-identity.js +41 -0
  121. package/dist/query-context-identity.js.map +1 -0
  122. package/dist/query-execution-plan.d.ts +27 -0
  123. package/dist/query-execution-plan.d.ts.map +1 -0
  124. package/dist/query-execution-plan.js +69 -0
  125. package/dist/query-execution-plan.js.map +1 -0
  126. package/dist/query-plan.d.ts +200 -0
  127. package/dist/query-plan.d.ts.map +1 -0
  128. package/dist/query-plan.js +524 -0
  129. package/dist/query-plan.js.map +1 -0
  130. package/dist/query-source-adapter.d.ts +25 -0
  131. package/dist/query-source-adapter.d.ts.map +1 -0
  132. package/dist/query-source-adapter.js +14 -0
  133. package/dist/query-source-adapter.js.map +1 -0
  134. package/dist/runtime-collection-store.d.ts +38 -0
  135. package/dist/runtime-collection-store.d.ts.map +1 -0
  136. package/dist/runtime-collection-store.js +149 -0
  137. package/dist/runtime-collection-store.js.map +1 -0
  138. package/dist/server-collection.d.ts +84 -0
  139. package/dist/server-collection.d.ts.map +1 -0
  140. package/dist/server-collection.js +84 -0
  141. package/dist/server-collection.js.map +1 -0
  142. package/dist/sqlite-persistence.d.ts +239 -0
  143. package/dist/sqlite-persistence.d.ts.map +1 -0
  144. package/dist/sqlite-persistence.js +345 -0
  145. package/dist/sqlite-persistence.js.map +1 -0
  146. package/dist/sync-adapter.d.ts +233 -0
  147. package/dist/sync-adapter.d.ts.map +1 -0
  148. package/dist/sync-adapter.js +226 -0
  149. package/dist/sync-adapter.js.map +1 -0
  150. 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":"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"}
@@ -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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"}