@bian-womp/spark-graph 0.2.21 → 0.2.23
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/lib/cjs/index.cjs +194 -15
- package/lib/cjs/index.cjs.map +1 -1
- package/lib/cjs/src/core/categories.d.ts +2 -13
- package/lib/cjs/src/core/categories.d.ts.map +1 -1
- package/lib/cjs/src/core/types.d.ts +16 -6
- package/lib/cjs/src/core/types.d.ts.map +1 -1
- package/lib/cjs/src/examples/arrays.d.ts +5 -0
- package/lib/cjs/src/examples/arrays.d.ts.map +1 -0
- package/lib/cjs/src/examples/run.d.ts.map +1 -1
- package/lib/cjs/src/examples/shared.d.ts.map +1 -1
- package/lib/cjs/src/index.d.ts +2 -1
- package/lib/cjs/src/index.d.ts.map +1 -1
- package/lib/cjs/src/plugins/composite.d.ts.map +1 -1
- package/lib/cjs/src/runtime/GraphRuntime.d.ts +6 -1
- package/lib/cjs/src/runtime/GraphRuntime.d.ts.map +1 -1
- package/lib/esm/index.js +194 -16
- package/lib/esm/index.js.map +1 -1
- package/lib/esm/src/core/categories.d.ts +2 -13
- package/lib/esm/src/core/categories.d.ts.map +1 -1
- package/lib/esm/src/core/types.d.ts +16 -6
- package/lib/esm/src/core/types.d.ts.map +1 -1
- package/lib/esm/src/examples/arrays.d.ts +5 -0
- package/lib/esm/src/examples/arrays.d.ts.map +1 -0
- package/lib/esm/src/examples/run.d.ts.map +1 -1
- package/lib/esm/src/examples/shared.d.ts.map +1 -1
- package/lib/esm/src/index.d.ts +2 -1
- package/lib/esm/src/index.d.ts.map +1 -1
- package/lib/esm/src/plugins/composite.d.ts.map +1 -1
- package/lib/esm/src/runtime/GraphRuntime.d.ts +6 -1
- package/lib/esm/src/runtime/GraphRuntime.d.ts.map +1 -1
- package/package.json +2 -2
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import type { NodeCategoryId } from "@bian-womp/spark-protocol";
|
|
2
|
-
import type { ExecutionContext } from "./types";
|
|
2
|
+
import type { ExecutionContext, ExecutionPolicy } from "./types";
|
|
3
3
|
export interface CategoryRuntime<State = unknown> {
|
|
4
4
|
onInputsChanged?: (inputs: Record<string, unknown>, ctx: ExecutionContext<State>) => void | Promise<void>;
|
|
5
5
|
onActivated?: (ctx: ExecutionContext<State>) => void | Promise<void>;
|
|
@@ -17,17 +17,6 @@ export interface NodeCategoryDescriptor<Impl = unknown, State = unknown> {
|
|
|
17
17
|
impl: Impl;
|
|
18
18
|
initialState?: Partial<State>;
|
|
19
19
|
}) => CategoryRuntime<State>;
|
|
20
|
-
policy?:
|
|
21
|
-
mode: "push" | "pull" | "hybrid";
|
|
22
|
-
asyncConcurrency?: "merge" | "switch" | "queue" | "drop";
|
|
23
|
-
timeoutMs?: number;
|
|
24
|
-
maxQueue?: number;
|
|
25
|
-
debounceMs?: number;
|
|
26
|
-
throttleMs?: number;
|
|
27
|
-
retry?: {
|
|
28
|
-
attempts: number;
|
|
29
|
-
backoffMs: (attemptIndex: number) => number;
|
|
30
|
-
};
|
|
31
|
-
};
|
|
20
|
+
policy?: Partial<ExecutionPolicy>;
|
|
32
21
|
}
|
|
33
22
|
//# sourceMappingURL=categories.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"categories.d.ts","sourceRoot":"","sources":["../../../../src/core/categories.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAChE,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"categories.d.ts","sourceRoot":"","sources":["../../../../src/core/categories.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAChE,OAAO,KAAK,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAEjE,MAAM,WAAW,eAAe,CAAC,KAAK,GAAG,OAAO;IAC9C,eAAe,CAAC,EAAE,CAChB,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC/B,GAAG,EAAE,gBAAgB,CAAC,KAAK,CAAC,KACzB,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC1B,WAAW,CAAC,EAAE,CAAC,GAAG,EAAE,gBAAgB,CAAC,KAAK,CAAC,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACrE,aAAa,CAAC,EAAE,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC3C,eAAe,CAAC,EAAE,CAChB,KAAK,EAAE,OAAO,EACd,GAAG,EAAE,gBAAgB,CAAC,KAAK,CAAC,KACzB,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC1B,MAAM,CAAC,EAAE,MAAM,IAAI,CAAC;IACpB,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;CACtB;AAED,MAAM,WAAW,sBAAsB,CAAC,IAAI,GAAG,OAAO,EAAE,KAAK,GAAG,OAAO;IACrE,EAAE,EAAE,cAAc,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,KAAK,IAAI,CAAC;IACpC,aAAa,EAAE,CAAC,OAAO,EAAE;QACvB,MAAM,EAAE,MAAM,CAAC;QACf,IAAI,EAAE,IAAI,CAAC;QACX,YAAY,CAAC,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC;KAC/B,KAAK,eAAe,CAAC,KAAK,CAAC,CAAC;IAC7B,MAAM,CAAC,EAAE,OAAO,CAAC,eAAe,CAAC,CAAC;CACnC"}
|
|
@@ -53,6 +53,17 @@ export declare function getTypedOutputTypeId(v: unknown): DataTypeId | undefined
|
|
|
53
53
|
export declare function getTypedOutputValue(v: unknown): unknown;
|
|
54
54
|
export declare function getInputTypeId(inputs: Record<string, InputHandleDescriptor> | undefined, handle: HandleId): DataTypeId | undefined;
|
|
55
55
|
export declare function isInputPrivate(inputs: Record<string, InputHandleDescriptor> | undefined, handle: HandleId): boolean;
|
|
56
|
+
export interface ExecutionPolicy {
|
|
57
|
+
asyncConcurrency: "merge" | "switch" | "queue" | "drop";
|
|
58
|
+
timeoutMs: number;
|
|
59
|
+
maxQueue: number;
|
|
60
|
+
debounceMs: number;
|
|
61
|
+
throttleMs: number;
|
|
62
|
+
retry: {
|
|
63
|
+
attempts: number;
|
|
64
|
+
backoffMs: (attemptIndex: number) => number;
|
|
65
|
+
};
|
|
66
|
+
}
|
|
56
67
|
export interface NodeTypeDescriptor<I extends Record<string, InputHandleDescriptor> = Record<string, InputHandleDescriptor>, O extends Record<string, DataTypeId | DataTypeId[]> = Record<string, DataTypeId | DataTypeId[]>, State = unknown, Impl = (inputs: Record<string, unknown>, ctx: NodeContext<State>) => void | Record<string, unknown> | Promise<void | Record<string, unknown>>> {
|
|
57
68
|
id: NodeTypeId;
|
|
58
69
|
categoryId: NodeCategoryId;
|
|
@@ -60,15 +71,12 @@ export interface NodeTypeDescriptor<I extends Record<string, InputHandleDescript
|
|
|
60
71
|
inputs: I;
|
|
61
72
|
outputs: O;
|
|
62
73
|
impl: Impl;
|
|
74
|
+
policy?: Partial<ExecutionPolicy>;
|
|
63
75
|
resolveHandles?: (ctx: {
|
|
64
76
|
environment: Record<string, unknown>;
|
|
65
77
|
params?: Record<string, unknown>;
|
|
66
78
|
inputs?: Record<string, unknown>;
|
|
67
|
-
}) =>
|
|
68
|
-
inputs?: Record<string, InputHandleDescriptor>;
|
|
69
|
-
outputs?: Record<string, DataTypeId | DataTypeId[]>;
|
|
70
|
-
inputDefaults?: Record<string, unknown>;
|
|
71
|
-
};
|
|
79
|
+
}) => Partial<ResolvedHandles> | Promise<Partial<ResolvedHandles>>;
|
|
72
80
|
inputDefaults?: Record<string, unknown>;
|
|
73
81
|
lifecycle?: {
|
|
74
82
|
init?: (initial: Record<string, unknown>, ctx: NodeContext<State>) => void | Promise<void>;
|
|
@@ -78,7 +86,9 @@ export interface NodeTypeDescriptor<I extends Record<string, InputHandleDescript
|
|
|
78
86
|
export interface GraphNodeDefinition {
|
|
79
87
|
nodeId: NodeInstanceId;
|
|
80
88
|
typeId: NodeTypeId;
|
|
81
|
-
params?: Record<string, unknown
|
|
89
|
+
params?: Record<string, unknown> & {
|
|
90
|
+
policy?: Partial<ExecutionPolicy>;
|
|
91
|
+
};
|
|
82
92
|
initialInputs?: Record<string, unknown>;
|
|
83
93
|
resolvedHandles?: Partial<ResolvedHandles>;
|
|
84
94
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/core/types.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/core/types.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { GraphDefinition } from "../core/types";
|
|
2
|
+
export declare function createArrayComposeDecomposeDef(): GraphDefinition;
|
|
3
|
+
export declare function createArrayComposeDecomposeRegistry(): import("..").Registry;
|
|
4
|
+
export declare function main(): Promise<void>;
|
|
5
|
+
//# sourceMappingURL=arrays.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"arrays.d.ts","sourceRoot":"","sources":["../../../../src/examples/arrays.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAKhD,wBAAgB,8BAA8B,IAAI,eAAe,CAchE;AAED,wBAAgB,mCAAmC,0BAElD;AAED,wBAAsB,IAAI,kBAsDzB"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"run.d.ts","sourceRoot":"","sources":["../../../../src/examples/run.ts"],"names":[],"mappings":"AAAA,wBAAsB,GAAG,CAAC,OAAO,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"run.d.ts","sourceRoot":"","sources":["../../../../src/examples/run.ts"],"names":[],"mappings":"AAAA,wBAAsB,GAAG,CAAC,OAAO,EAAE,MAAM,iBA0BxC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"shared.d.ts","sourceRoot":"","sources":["../../../../src/examples/shared.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAEhD,wBAAgB,cAAc,CAAC,MAAM,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"shared.d.ts","sourceRoot":"","sources":["../../../../src/examples/shared.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAEhD,wBAAgB,cAAc,CAAC,MAAM,EAAE,MAAM,QAsC5C"}
|
package/lib/cjs/src/index.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export type {
|
|
1
|
+
export type { DataTypeDescriptor, InvalidateReason, NodeContext, ExecutionContext, NodeTypeDescriptor, GraphDefinition, RuntimeNodeStats, RuntimeEdgeStats, TypedOutputValue, } from "./core/types";
|
|
2
2
|
export { typed, isTypedOutput, getTypedOutputTypeId, getTypedOutputValue, getInputTypeId, isInputPrivate, } from "./core/types";
|
|
3
3
|
export type { CategoryRuntime, NodeCategoryDescriptor, } from "./core/categories";
|
|
4
4
|
export { Registry } from "./builder/Registry";
|
|
@@ -20,5 +20,6 @@ export { createSimpleGraphRegistry, createSimpleGraphDef, } from "./examples/sim
|
|
|
20
20
|
export { createAsyncGraphRegistry, createAsyncGraphDef, } from "./examples/async";
|
|
21
21
|
export { createProgressGraphRegistry, createProgressGraphDef, } from "./examples/progress";
|
|
22
22
|
export { createValidationGraphRegistry, createValidationGraphDef, } from "./examples/validation";
|
|
23
|
+
export { installLogging } from "./examples/shared";
|
|
23
24
|
export { registerDelayNode, registerProgressNodes } from "./misc/base";
|
|
24
25
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/index.ts"],"names":[],"mappings":"AAAA,YAAY,EACV,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/index.ts"],"names":[],"mappings":"AAAA,YAAY,EACV,kBAAkB,EAClB,gBAAgB,EAChB,WAAW,EACX,gBAAgB,EAChB,kBAAkB,EAClB,eAAe,EACf,gBAAgB,EAChB,gBAAgB,EAChB,gBAAgB,GACjB,MAAM,cAAc,CAAC;AACtB,OAAO,EACL,KAAK,EACL,aAAa,EACb,oBAAoB,EACpB,mBAAmB,EACnB,cAAc,EACd,cAAc,GACf,MAAM,cAAc,CAAC;AACtB,YAAY,EACV,eAAe,EACf,sBAAsB,GACvB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAC9C,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,YAAY,EAAE,eAAe,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAChF,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,YAAY,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,YAAY,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAChF,YAAY,EACV,MAAM,EACN,mBAAmB,EACnB,cAAc,EACd,eAAe,GAChB,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AACxD,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAExD,OAAO,EACL,yBAAyB,EACzB,oBAAoB,GACrB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EACL,wBAAwB,EACxB,mBAAmB,GACpB,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EACL,2BAA2B,EAC3B,sBAAsB,GACvB,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EACL,6BAA6B,EAC7B,wBAAwB,GACzB,MAAM,uBAAuB,CAAC;AAC/B,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAEnD,OAAO,EAAE,iBAAiB,EAAE,qBAAqB,EAAE,MAAM,aAAa,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"composite.d.ts","sourceRoot":"","sources":["../../../../src/plugins/composite.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,oBAAoB,CAAC;AACjE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AACrD,OAAO,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAEvD,MAAM,WAAW,aAAa;IAC5B,GAAG,EAAE,eAAe,CAAC;IACrB,QAAQ,EAAE;QACR,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE;YAAE,MAAM,EAAE,MAAM,CAAC;YAAC,MAAM,EAAE,MAAM,CAAA;SAAE,CAAC,CAAC;QAC3D,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE;YAAE,MAAM,EAAE,MAAM,CAAC;YAAC,MAAM,EAAE,MAAM,CAAA;SAAE,CAAC,CAAC;KAC7D,CAAC;CACH;AAED,eAAO,MAAM,iBAAiB,GAC5B,UAAU,QAAQ,KACjB,sBAAsB,CACvB,aAAa,EACb;IAAE,KAAK,CAAC,EAAE,YAAY,CAAC;IAAC,KAAK,CAAC,EAAE,MAAM,IAAI,CAAA;CAAE,
|
|
1
|
+
{"version":3,"file":"composite.d.ts","sourceRoot":"","sources":["../../../../src/plugins/composite.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,oBAAoB,CAAC;AACjE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AACrD,OAAO,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAEvD,MAAM,WAAW,aAAa;IAC5B,GAAG,EAAE,eAAe,CAAC;IACrB,QAAQ,EAAE;QACR,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE;YAAE,MAAM,EAAE,MAAM,CAAC;YAAC,MAAM,EAAE,MAAM,CAAA;SAAE,CAAC,CAAC;QAC3D,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE;YAAE,MAAM,EAAE,MAAM,CAAC;YAAC,MAAM,EAAE,MAAM,CAAA;SAAE,CAAC,CAAC;KAC7D,CAAC;CACH;AAED,eAAO,MAAM,iBAAiB,GAC5B,UAAU,QAAQ,KACjB,sBAAsB,CACvB,aAAa,EACb;IAAE,KAAK,CAAC,EAAE,YAAY,CAAC;IAAC,KAAK,CAAC,EAAE,MAAM,IAAI,CAAA;CAAE,CAsD5C,CAAC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import type { RuntimeValue, RuntimeInvalidate, RuntimeError, RuntimeStats, ResolvedHandles } from "@bian-womp/spark-protocol";
|
|
2
|
-
import type { GraphDefinition, RuntimeNodeStats } from "../core/types";
|
|
2
|
+
import type { GraphDefinition, RuntimeNodeStats, ExecutionPolicy } from "../core/types";
|
|
3
3
|
import { Registry } from "../builder/Registry";
|
|
4
4
|
export type RuntimeEventListener<K extends RuntimeEventName> = (e: RuntimeEventMap[K]) => void;
|
|
5
5
|
export type RuntimeEventName = "value" | "invalidate" | "error" | "stats";
|
|
@@ -12,9 +12,11 @@ export interface RuntimeEventMap {
|
|
|
12
12
|
export declare class GraphRuntime {
|
|
13
13
|
private nodes;
|
|
14
14
|
private edges;
|
|
15
|
+
private registry?;
|
|
15
16
|
private resolvedByNode;
|
|
16
17
|
private listeners;
|
|
17
18
|
private environment;
|
|
19
|
+
private recomputeTokenByNode;
|
|
18
20
|
private paused;
|
|
19
21
|
private arrayInputBuckets;
|
|
20
22
|
private valuesEqual;
|
|
@@ -54,6 +56,7 @@ export declare class GraphRuntime {
|
|
|
54
56
|
typeId: string;
|
|
55
57
|
params: {
|
|
56
58
|
[x: string]: unknown;
|
|
59
|
+
policy?: Partial<ExecutionPolicy>;
|
|
57
60
|
} | undefined;
|
|
58
61
|
resolvedHandles: {
|
|
59
62
|
inputs: Record<string, import("@bian-womp/spark-protocol").InputHandleDescriptor>;
|
|
@@ -86,5 +89,7 @@ export declare class GraphRuntime {
|
|
|
86
89
|
reemit?: boolean;
|
|
87
90
|
}): void;
|
|
88
91
|
update(def: GraphDefinition, registry: Registry): void;
|
|
92
|
+
private scheduleRecomputeHandles;
|
|
93
|
+
private recomputeHandlesForNode;
|
|
89
94
|
}
|
|
90
95
|
//# sourceMappingURL=GraphRuntime.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"GraphRuntime.d.ts","sourceRoot":"","sources":["../../../../src/runtime/GraphRuntime.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,YAAY,EACZ,iBAAiB,EACjB,YAAY,EACZ,YAAY,EACZ,eAAe,EAChB,MAAM,2BAA2B,CAAC;AACnC,OAAO,KAAK,EACV,eAAe,EAIf,gBAAgB,
|
|
1
|
+
{"version":3,"file":"GraphRuntime.d.ts","sourceRoot":"","sources":["../../../../src/runtime/GraphRuntime.ts"],"names":[],"mappings":"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"}
|
package/lib/esm/index.js
CHANGED
|
@@ -400,6 +400,13 @@ class Registry {
|
|
|
400
400
|
}
|
|
401
401
|
}
|
|
402
402
|
|
|
403
|
+
// Helper: typed promise detection and unwrapping for T | Promise<T>
|
|
404
|
+
function isPromise(value) {
|
|
405
|
+
return !!value && typeof value.then === "function";
|
|
406
|
+
}
|
|
407
|
+
async function unwrapMaybePromise(value) {
|
|
408
|
+
return isPromise(value) ? await value : value;
|
|
409
|
+
}
|
|
403
410
|
class GraphRuntime {
|
|
404
411
|
constructor() {
|
|
405
412
|
this.nodes = new Map();
|
|
@@ -408,6 +415,8 @@ class GraphRuntime {
|
|
|
408
415
|
this.resolvedByNode = new Map();
|
|
409
416
|
this.listeners = new Map();
|
|
410
417
|
this.environment = {};
|
|
418
|
+
// Token to guard async resolveHandles recomputes per node
|
|
419
|
+
this.recomputeTokenByNode = new Map();
|
|
411
420
|
this.paused = false;
|
|
412
421
|
// For array-typed target inputs, keep per-edge contributions so successive runs
|
|
413
422
|
// from the same source replace their slice instead of accumulating forever.
|
|
@@ -432,9 +441,11 @@ class GraphRuntime {
|
|
|
432
441
|
}
|
|
433
442
|
static create(def, registry, opts) {
|
|
434
443
|
const gr = new GraphRuntime();
|
|
444
|
+
gr.registry = registry;
|
|
435
445
|
gr.environment = opts?.environment ?? {};
|
|
436
446
|
// Precompute per-node resolved handles (use def-provided overrides; do not compute dynamically here)
|
|
437
|
-
|
|
447
|
+
const initial = GraphRuntime.computeResolvedHandleMap(def, registry, gr.environment);
|
|
448
|
+
gr.resolvedByNode = initial.map;
|
|
438
449
|
// Instantiate nodes
|
|
439
450
|
for (const n of def.nodes) {
|
|
440
451
|
const desc = registry.nodes.get(n.typeId);
|
|
@@ -460,8 +471,10 @@ class GraphRuntime {
|
|
|
460
471
|
params: n.params,
|
|
461
472
|
policy: {
|
|
462
473
|
...cat.policy,
|
|
463
|
-
...
|
|
474
|
+
...desc.policy,
|
|
475
|
+
...n.params?.policy,
|
|
464
476
|
},
|
|
477
|
+
runSeq: 0,
|
|
465
478
|
activeControllers: new Set(),
|
|
466
479
|
queue: [],
|
|
467
480
|
stats: {
|
|
@@ -505,6 +518,9 @@ class GraphRuntime {
|
|
|
505
518
|
: JSON.parse(JSON.stringify(value));
|
|
506
519
|
}
|
|
507
520
|
}
|
|
521
|
+
// Schedule async recompute only for nodes that indicated Promise-based resolveHandles
|
|
522
|
+
for (const nodeId of initial.pending)
|
|
523
|
+
gr.scheduleRecomputeHandles(nodeId);
|
|
508
524
|
return gr;
|
|
509
525
|
}
|
|
510
526
|
on(event, handler) {
|
|
@@ -545,6 +561,9 @@ class GraphRuntime {
|
|
|
545
561
|
// Only schedule if all inbound inputs are present (or there are none)
|
|
546
562
|
if (anyChanged && this.allInboundHaveValue(nodeId))
|
|
547
563
|
this.scheduleInputsChanged(nodeId);
|
|
564
|
+
// Recompute dynamic handles for this node when its direct inputs change
|
|
565
|
+
if (anyChanged)
|
|
566
|
+
this.scheduleRecomputeHandles(nodeId);
|
|
548
567
|
}
|
|
549
568
|
}
|
|
550
569
|
getOutput(nodeId, output) {
|
|
@@ -617,12 +636,14 @@ class GraphRuntime {
|
|
|
617
636
|
now - node.lastScheduledAt < policy.debounceMs) {
|
|
618
637
|
// debounce: replace latest queued
|
|
619
638
|
node.queue.splice(0, node.queue.length);
|
|
620
|
-
|
|
639
|
+
node.runSeq += 1;
|
|
640
|
+
const rid = `${nodeId}:${node.runSeq}:${now}`;
|
|
621
641
|
node.queue.push({ runId: rid, inputs: { ...node.inputs } });
|
|
622
642
|
return;
|
|
623
643
|
}
|
|
624
644
|
node.lastScheduledAt = now;
|
|
625
|
-
|
|
645
|
+
node.runSeq += 1;
|
|
646
|
+
const rid = `${nodeId}:${node.runSeq}:${now}`;
|
|
626
647
|
node.latestRunId = rid;
|
|
627
648
|
const startRun = (runId, capturedInputs, onDone) => {
|
|
628
649
|
const controller = new AbortController();
|
|
@@ -845,6 +866,8 @@ class GraphRuntime {
|
|
|
845
866
|
io: "input",
|
|
846
867
|
runtimeTypeId: getTypedOutputTypeId(next),
|
|
847
868
|
});
|
|
869
|
+
// Recompute dynamic handles for the destination node on input change
|
|
870
|
+
this.scheduleRecomputeHandles(e.target.nodeId);
|
|
848
871
|
if (!this.paused && this.allInboundHaveValue(e.target.nodeId))
|
|
849
872
|
this.scheduleInputsChanged(e.target.nodeId);
|
|
850
873
|
}
|
|
@@ -902,8 +925,9 @@ class GraphRuntime {
|
|
|
902
925
|
}
|
|
903
926
|
}
|
|
904
927
|
// Helper: build map of resolved handles per node from def (prefer def.resolvedHandles, otherwise registry statics)
|
|
905
|
-
static computeResolvedHandleMap(def, registry) {
|
|
928
|
+
static computeResolvedHandleMap(def, registry, environment) {
|
|
906
929
|
const out = new Map();
|
|
930
|
+
const pending = new Set();
|
|
907
931
|
for (const n of def.nodes) {
|
|
908
932
|
const desc = registry.nodes.get(n.typeId);
|
|
909
933
|
if (!desc)
|
|
@@ -911,13 +935,47 @@ class GraphRuntime {
|
|
|
911
935
|
const overrideInputs = n.resolvedHandles?.inputs;
|
|
912
936
|
const overrideOutputs = n.resolvedHandles?.outputs;
|
|
913
937
|
const overrideDefaults = n.resolvedHandles?.inputDefaults;
|
|
914
|
-
//
|
|
915
|
-
|
|
916
|
-
|
|
917
|
-
|
|
938
|
+
// Resolve dynamic handles if available (initial pass: inputs may be undefined)
|
|
939
|
+
let dyn = {};
|
|
940
|
+
try {
|
|
941
|
+
if (typeof desc.resolveHandles === "function") {
|
|
942
|
+
const maybe = desc.resolveHandles({
|
|
943
|
+
environment: environment || {},
|
|
944
|
+
params: n.params,
|
|
945
|
+
inputs: undefined,
|
|
946
|
+
});
|
|
947
|
+
// Only use sync results here; async results are applied via recompute later
|
|
948
|
+
if (isPromise(maybe)) {
|
|
949
|
+
// mark node as pending async recompute
|
|
950
|
+
pending.add(n.nodeId);
|
|
951
|
+
}
|
|
952
|
+
else {
|
|
953
|
+
dyn = maybe || {};
|
|
954
|
+
}
|
|
955
|
+
}
|
|
956
|
+
}
|
|
957
|
+
catch {
|
|
958
|
+
// ignore dynamic resolution errors at this stage
|
|
959
|
+
}
|
|
960
|
+
// Merge base with dynamic and overrides (allow partial resolvedHandles)
|
|
961
|
+
const inputs = {
|
|
962
|
+
...desc.inputs,
|
|
963
|
+
...dyn.inputs,
|
|
964
|
+
...overrideInputs,
|
|
965
|
+
};
|
|
966
|
+
const outputs = {
|
|
967
|
+
...desc.outputs,
|
|
968
|
+
...dyn.outputs,
|
|
969
|
+
...overrideOutputs,
|
|
970
|
+
};
|
|
971
|
+
const inputDefaults = {
|
|
972
|
+
...desc.inputDefaults,
|
|
973
|
+
...dyn.inputDefaults,
|
|
974
|
+
...overrideDefaults,
|
|
975
|
+
};
|
|
918
976
|
out.set(n.nodeId, { inputs, outputs, inputDefaults });
|
|
919
977
|
}
|
|
920
|
-
return out;
|
|
978
|
+
return { map: out, pending };
|
|
921
979
|
}
|
|
922
980
|
// Helper: build runtime edges with coercions using resolved handles
|
|
923
981
|
static buildEdges(def, registry, resolvedByNode) {
|
|
@@ -1096,6 +1154,10 @@ class GraphRuntime {
|
|
|
1096
1154
|
}
|
|
1097
1155
|
setEnvironment(env) {
|
|
1098
1156
|
this.environment = { ...env };
|
|
1157
|
+
// Recompute dynamic handles for all nodes when environment changes
|
|
1158
|
+
for (const nodeId of this.nodes.keys()) {
|
|
1159
|
+
this.scheduleRecomputeHandles(nodeId);
|
|
1160
|
+
}
|
|
1099
1161
|
}
|
|
1100
1162
|
// Export a GraphDefinition reflecting the current runtime view
|
|
1101
1163
|
getGraphDef() {
|
|
@@ -1252,8 +1314,10 @@ class GraphRuntime {
|
|
|
1252
1314
|
params: n.params,
|
|
1253
1315
|
policy: {
|
|
1254
1316
|
...cat.policy,
|
|
1255
|
-
...
|
|
1317
|
+
...desc.policy,
|
|
1318
|
+
...n.params?.policy,
|
|
1256
1319
|
},
|
|
1320
|
+
runSeq: 0,
|
|
1257
1321
|
activeControllers: new Set(),
|
|
1258
1322
|
queue: [],
|
|
1259
1323
|
stats: {
|
|
@@ -1312,8 +1376,9 @@ class GraphRuntime {
|
|
|
1312
1376
|
tmap.set(e.source.handle, tset);
|
|
1313
1377
|
prevOutTargets.set(e.source.nodeId, tmap);
|
|
1314
1378
|
}
|
|
1315
|
-
// Precompute per-node resolved handles for updated graph
|
|
1316
|
-
|
|
1379
|
+
// Precompute per-node resolved handles for updated graph (include dynamic)
|
|
1380
|
+
const resolved = GraphRuntime.computeResolvedHandleMap(def, registry, this.environment);
|
|
1381
|
+
this.resolvedByNode = resolved.map;
|
|
1317
1382
|
// Rebuild edges mapping with coercions
|
|
1318
1383
|
this.edges = GraphRuntime.buildEdges(def, registry, this.resolvedByNode);
|
|
1319
1384
|
// Build new inbound map
|
|
@@ -1472,6 +1537,87 @@ class GraphRuntime {
|
|
|
1472
1537
|
if (byHandle.size === 0)
|
|
1473
1538
|
this.arrayInputBuckets.delete(nodeId);
|
|
1474
1539
|
}
|
|
1540
|
+
// Schedule async recompute for nodes that indicated Promise-based resolveHandles in this update
|
|
1541
|
+
for (const nodeId of resolved.pending)
|
|
1542
|
+
this.scheduleRecomputeHandles(nodeId);
|
|
1543
|
+
}
|
|
1544
|
+
// Schedule a recomputation of dynamic handles for a node (async to avoid mutating during propagation)
|
|
1545
|
+
scheduleRecomputeHandles(nodeId) {
|
|
1546
|
+
// If no registry or node not found, skip
|
|
1547
|
+
if (!this.registry)
|
|
1548
|
+
return;
|
|
1549
|
+
const node = this.nodes.get(nodeId);
|
|
1550
|
+
if (!node)
|
|
1551
|
+
return;
|
|
1552
|
+
setTimeout(() => {
|
|
1553
|
+
void this.recomputeHandlesForNode(nodeId);
|
|
1554
|
+
}, 0);
|
|
1555
|
+
}
|
|
1556
|
+
// Recompute dynamic handles for a single node using current inputs/environment
|
|
1557
|
+
async recomputeHandlesForNode(nodeId) {
|
|
1558
|
+
const registry = this.registry;
|
|
1559
|
+
const node = this.nodes.get(nodeId);
|
|
1560
|
+
if (!node)
|
|
1561
|
+
return;
|
|
1562
|
+
const desc = registry.nodes.get(node.typeId);
|
|
1563
|
+
if (!desc)
|
|
1564
|
+
return;
|
|
1565
|
+
const resolveHandles = desc.resolveHandles;
|
|
1566
|
+
if (typeof resolveHandles !== "function")
|
|
1567
|
+
return;
|
|
1568
|
+
const token = (this.recomputeTokenByNode.get(nodeId) ?? 0) + 1;
|
|
1569
|
+
this.recomputeTokenByNode.set(nodeId, token);
|
|
1570
|
+
let r;
|
|
1571
|
+
try {
|
|
1572
|
+
const res = resolveHandles({
|
|
1573
|
+
environment: this.environment || {},
|
|
1574
|
+
params: node.params,
|
|
1575
|
+
inputs: node.inputs || {},
|
|
1576
|
+
});
|
|
1577
|
+
r = await unwrapMaybePromise(res);
|
|
1578
|
+
}
|
|
1579
|
+
catch {
|
|
1580
|
+
return;
|
|
1581
|
+
}
|
|
1582
|
+
// If a newer recompute was scheduled, drop this result
|
|
1583
|
+
if ((this.recomputeTokenByNode.get(nodeId) ?? 0) !== token)
|
|
1584
|
+
return;
|
|
1585
|
+
const inputs = { ...desc.inputs, ...r?.inputs };
|
|
1586
|
+
const outputs = { ...desc.outputs, ...r?.outputs };
|
|
1587
|
+
const inputDefaults = { ...desc.inputDefaults, ...r?.inputDefaults };
|
|
1588
|
+
const next = { inputs, outputs, inputDefaults };
|
|
1589
|
+
const before = this.resolvedByNode.get(nodeId);
|
|
1590
|
+
// Compare shallow-structurally via JSON
|
|
1591
|
+
if (JSON.stringify(before) === JSON.stringify(next))
|
|
1592
|
+
return;
|
|
1593
|
+
this.resolvedByNode.set(nodeId, next);
|
|
1594
|
+
this.updateNodeHandles(nodeId, next, registry);
|
|
1595
|
+
// Seed defaults for newly introduced inputs that are not inbound
|
|
1596
|
+
const inbound = this.edges
|
|
1597
|
+
.filter((e) => e.target.nodeId === nodeId)
|
|
1598
|
+
.map((e) => e.target.handle);
|
|
1599
|
+
for (const [handle, value] of Object.entries(inputDefaults)) {
|
|
1600
|
+
if (value === undefined)
|
|
1601
|
+
continue;
|
|
1602
|
+
if (inbound.includes(handle))
|
|
1603
|
+
continue;
|
|
1604
|
+
if (node.inputs[handle] === undefined) {
|
|
1605
|
+
node.inputs[handle] =
|
|
1606
|
+
typeof structuredClone === "function"
|
|
1607
|
+
? structuredClone(value)
|
|
1608
|
+
: JSON.parse(JSON.stringify(value));
|
|
1609
|
+
// Emit input value event for seeded defaults
|
|
1610
|
+
this.emit("value", {
|
|
1611
|
+
nodeId,
|
|
1612
|
+
handle,
|
|
1613
|
+
value: node.inputs[handle],
|
|
1614
|
+
io: "input",
|
|
1615
|
+
runtimeTypeId: getTypedOutputTypeId(node.inputs[handle]),
|
|
1616
|
+
});
|
|
1617
|
+
}
|
|
1618
|
+
}
|
|
1619
|
+
// Notify graph updated for UI parity
|
|
1620
|
+
this.emit("invalidate", { reason: "graph-updated" });
|
|
1475
1621
|
}
|
|
1476
1622
|
}
|
|
1477
1623
|
|
|
@@ -1948,7 +2094,7 @@ const ComputeCategory = {
|
|
|
1948
2094
|
}
|
|
1949
2095
|
},
|
|
1950
2096
|
}),
|
|
1951
|
-
policy: {
|
|
2097
|
+
policy: { asyncConcurrency: "switch" },
|
|
1952
2098
|
};
|
|
1953
2099
|
|
|
1954
2100
|
const CompositeCategory = (registry) => ({
|
|
@@ -2004,7 +2150,6 @@ const CompositeCategory = (registry) => ({
|
|
|
2004
2150
|
},
|
|
2005
2151
|
};
|
|
2006
2152
|
},
|
|
2007
|
-
policy: { mode: "hybrid" },
|
|
2008
2153
|
});
|
|
2009
2154
|
|
|
2010
2155
|
// Helpers
|
|
@@ -3098,6 +3243,39 @@ function registerProgressNodes(registry) {
|
|
|
3098
3243
|
});
|
|
3099
3244
|
}
|
|
3100
3245
|
|
|
3246
|
+
function installLogging(engine) {
|
|
3247
|
+
engine.on("value", (e) => {
|
|
3248
|
+
const t = e.runtimeTypeId ? ` <${e.runtimeTypeId}>` : "";
|
|
3249
|
+
console.log(`[value:${e.io}]`, `${e.nodeId}.${e.handle}`, e.value, t);
|
|
3250
|
+
});
|
|
3251
|
+
engine.on("stats", (s) => {
|
|
3252
|
+
if (s.kind === "node-progress") {
|
|
3253
|
+
const pct = Math.round((s.progress ?? 0) * 100);
|
|
3254
|
+
console.log(`[progress] ${s.runId || s.nodeId}: ${pct}%`);
|
|
3255
|
+
}
|
|
3256
|
+
else if (s.kind === "node-done") {
|
|
3257
|
+
console.log(`[done] ${s.runId || s.nodeId} in ${s.durationMs ?? 0}ms`);
|
|
3258
|
+
}
|
|
3259
|
+
else if (s.kind === "node-start") {
|
|
3260
|
+
console.log(`[start] ${s.runId || s.nodeId}`);
|
|
3261
|
+
}
|
|
3262
|
+
else if (s.kind === "edge-start") {
|
|
3263
|
+
console.log(`[edge] ${s.source.nodeId}.${s.source.handle} -> ${s.target.nodeId}.${s.target.handle}`);
|
|
3264
|
+
}
|
|
3265
|
+
else if (s.kind === "edge-done") {
|
|
3266
|
+
console.log(`[edge] ${s.source.nodeId}.${s.source.handle} -> ${s.target.nodeId}.${s.target.handle} in ${s.durationMs ?? 0}ms`);
|
|
3267
|
+
}
|
|
3268
|
+
});
|
|
3269
|
+
engine.on("error", (e) => {
|
|
3270
|
+
if (e.kind === "node-run") {
|
|
3271
|
+
console.warn(`[error] ${e.runId || e.nodeId}`, e.err?.message ?? e.err);
|
|
3272
|
+
}
|
|
3273
|
+
else if (e.kind === "edge-convert") {
|
|
3274
|
+
console.warn(`[error] ${e.edgeId} ${e.source.nodeId}.${e.source.handle} -> ${e.target.nodeId}.${e.target.handle}`, e.err?.message ?? e.err);
|
|
3275
|
+
}
|
|
3276
|
+
});
|
|
3277
|
+
}
|
|
3278
|
+
|
|
3101
3279
|
function makeBasicGraphDefinition() {
|
|
3102
3280
|
return {
|
|
3103
3281
|
nodes: [
|
|
@@ -3279,5 +3457,5 @@ function createValidationGraphRegistry() {
|
|
|
3279
3457
|
return registry;
|
|
3280
3458
|
}
|
|
3281
3459
|
|
|
3282
|
-
export { BatchedEngine, CompositeCategory, ComputeCategory, GraphBuilder, GraphRuntime, HybridEngine, LocalRunner, PullEngine, PushEngine, Registry, StepEngine, createAsyncGraphDef, createAsyncGraphRegistry, createProgressGraphDef, createProgressGraphRegistry, createSimpleGraphDef, createSimpleGraphRegistry, createValidationGraphDef, createValidationGraphRegistry, getInputTypeId, getTypedOutputTypeId, getTypedOutputValue, isInputPrivate, isTypedOutput, registerDelayNode, registerProgressNodes, typed };
|
|
3460
|
+
export { BatchedEngine, CompositeCategory, ComputeCategory, GraphBuilder, GraphRuntime, HybridEngine, LocalRunner, PullEngine, PushEngine, Registry, StepEngine, createAsyncGraphDef, createAsyncGraphRegistry, createProgressGraphDef, createProgressGraphRegistry, createSimpleGraphDef, createSimpleGraphRegistry, createValidationGraphDef, createValidationGraphRegistry, getInputTypeId, getTypedOutputTypeId, getTypedOutputValue, installLogging, isInputPrivate, isTypedOutput, registerDelayNode, registerProgressNodes, typed };
|
|
3283
3461
|
//# sourceMappingURL=index.js.map
|