liminal 0.5.10 → 0.5.12
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/CHANGELOG.md +17 -0
- package/Context.ts +36 -21
- package/Fiber.ts +56 -52
- package/Handler.ts +2 -2
- package/L/L.ts +4 -3
- package/L/assistant.ts +6 -6
- package/L/catch.ts +10 -2
- package/L/emit.ts +3 -7
- package/L/{_infer.ts → infer.ts} +9 -8
- package/L/{_message.ts → message.ts} +3 -7
- package/L/model.ts +1 -5
- package/L/rune.ts +8 -26
- package/L/strand.ts +75 -0
- package/L/stream.ts +3 -5
- package/L/system.ts +4 -4
- package/L/user.ts +4 -4
- package/MessageRegistry.ts +4 -3
- package/ModelRegistry.ts +13 -8
- package/StrandConfig.ts +12 -0
- package/ToolRegistry.ts +8 -3
- package/dist/Context.d.ts +11 -9
- package/dist/Context.js +30 -17
- package/dist/Context.js.map +1 -1
- package/dist/Fiber.d.ts +18 -15
- package/dist/Fiber.js +32 -30
- package/dist/Fiber.js.map +1 -1
- package/dist/Handler.d.ts +2 -2
- package/dist/Handler.js +2 -2
- package/dist/Handler.js.map +1 -1
- package/dist/L/L.d.ts +4 -3
- package/dist/L/L.js +4 -3
- package/dist/L/L.js.map +1 -1
- package/dist/L/assistant.js +6 -6
- package/dist/L/assistant.js.map +1 -1
- package/dist/L/catch.js +9 -2
- package/dist/L/catch.js.map +1 -1
- package/dist/L/emit.js +3 -7
- package/dist/L/emit.js.map +1 -1
- package/dist/L/infer.d.ts +7 -0
- package/dist/L/{_infer.js → infer.js} +7 -9
- package/dist/L/infer.js.map +1 -0
- package/dist/L/message.d.ts +6 -0
- package/dist/L/message.js +10 -0
- package/dist/L/message.js.map +1 -0
- package/dist/L/model.js +1 -5
- package/dist/L/model.js.map +1 -1
- package/dist/L/rune.d.ts +1 -6
- package/dist/L/rune.js +5 -15
- package/dist/L/rune.js.map +1 -1
- package/dist/L/strand.d.ts +16 -0
- package/dist/L/strand.js +57 -0
- package/dist/L/strand.js.map +1 -0
- package/dist/L/stream.js +3 -5
- package/dist/L/stream.js.map +1 -1
- package/dist/L/system.d.ts +1 -1
- package/dist/L/system.js +2 -2
- package/dist/L/system.js.map +1 -1
- package/dist/L/user.d.ts +1 -1
- package/dist/L/user.js +2 -2
- package/dist/L/user.js.map +1 -1
- package/dist/MessageRegistry.d.ts +2 -2
- package/dist/MessageRegistry.js +2 -2
- package/dist/MessageRegistry.js.map +1 -1
- package/dist/ModelRegistry.d.ts +3 -2
- package/dist/ModelRegistry.js +9 -8
- package/dist/ModelRegistry.js.map +1 -1
- package/dist/StrandConfig.d.ts +11 -0
- package/dist/StrandConfig.js +2 -0
- package/dist/StrandConfig.js.map +1 -0
- package/dist/ToolRegistry.d.ts +3 -2
- package/dist/ToolRegistry.js +5 -2
- package/dist/ToolRegistry.js.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/index.ts +1 -1
- package/package.json +4 -7
- package/Agent.ts +0 -38
- package/L/branch.ts +0 -33
- package/dist/Agent.d.ts +0 -18
- package/dist/Agent.js +0 -20
- package/dist/Agent.js.map +0 -1
- package/dist/L/_infer.d.ts +0 -4
- package/dist/L/_infer.js.map +0 -1
- package/dist/L/_message.d.ts +0 -6
- package/dist/L/_message.js +0 -14
- package/dist/L/_message.js.map +0 -1
- package/dist/L/branch.d.ts +0 -11
- package/dist/L/branch.js +0 -24
- package/dist/L/branch.js.map +0 -1
package/ModelRegistry.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { ContextPart } from "./Context.ts"
|
|
2
2
|
import type { Model } from "./Model.ts"
|
|
3
3
|
|
|
4
4
|
/** An intrusive list for storing `Model`s. */
|
|
@@ -39,6 +39,14 @@ export class ModelRegistry {
|
|
|
39
39
|
}
|
|
40
40
|
node.prev = node.next = undefined
|
|
41
41
|
}
|
|
42
|
+
|
|
43
|
+
clone(): ModelRegistry {
|
|
44
|
+
const instance = new ModelRegistry()
|
|
45
|
+
for (let node = this.head; node; node = node.next) {
|
|
46
|
+
instance.register(node.model)
|
|
47
|
+
}
|
|
48
|
+
return instance
|
|
49
|
+
}
|
|
42
50
|
}
|
|
43
51
|
|
|
44
52
|
export interface ModelRegistryNode {
|
|
@@ -47,10 +55,7 @@ export interface ModelRegistryNode {
|
|
|
47
55
|
next?: ModelRegistryNode | undefined
|
|
48
56
|
}
|
|
49
57
|
|
|
50
|
-
export const ModelRegistryContext:
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
}
|
|
55
|
-
return instance
|
|
56
|
-
})
|
|
58
|
+
export const ModelRegistryContext: ContextPart<ModelRegistry> = ContextPart(
|
|
59
|
+
(parent) => parent?.clone() ?? new ModelRegistry(),
|
|
60
|
+
"model_registry",
|
|
61
|
+
)
|
package/StrandConfig.ts
ADDED
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { Fiber } from "./Fiber.ts"
|
|
2
|
+
import type { MessageRegistry } from "./MessageRegistry.ts"
|
|
3
|
+
import type { ModelRegistry } from "./ModelRegistry.ts"
|
|
4
|
+
import type { ToolRegistry } from "./ToolRegistry.ts"
|
|
5
|
+
|
|
6
|
+
export interface StrandConfig<T = any, E = any> {
|
|
7
|
+
handler?: ((this: Fiber<T>, event: E) => void) | undefined
|
|
8
|
+
models?: ModelRegistry | undefined
|
|
9
|
+
messages?: MessageRegistry | undefined
|
|
10
|
+
tools?: ToolRegistry | undefined
|
|
11
|
+
signal?: AbortSignal | undefined
|
|
12
|
+
}
|
package/ToolRegistry.ts
CHANGED
|
@@ -1,5 +1,10 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { ContextPart } from "liminal"
|
|
2
2
|
import type { Tool } from "./Tool"
|
|
3
3
|
|
|
4
|
-
export class ToolRegistry extends Set<Tool> {
|
|
5
|
-
|
|
4
|
+
export class ToolRegistry extends Set<Tool> {
|
|
5
|
+
clone(): ToolRegistry {
|
|
6
|
+
return new ToolRegistry([...this])
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
export const ToolRegistryContext: ContextPart<ToolRegistry> = ContextPart(() => new ToolRegistry(), "tool_registry")
|
package/dist/Context.d.ts
CHANGED
|
@@ -1,11 +1,13 @@
|
|
|
1
|
-
export declare class Context extends Map<
|
|
1
|
+
export declare class Context extends Map<ContextPart, unknown> {
|
|
2
|
+
static get(): Context | undefined;
|
|
2
3
|
static ensure(): Context;
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
run<R>(callback: () => R): R;
|
|
6
|
-
clone(overrides?: Iterable<[ContextHandle, unknown]>): Context;
|
|
4
|
+
run<R>(f: () => R): R;
|
|
5
|
+
fork(): Context;
|
|
7
6
|
}
|
|
8
|
-
export
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
7
|
+
export interface ContextPart<V = any> {
|
|
8
|
+
fork(parent?: V): V;
|
|
9
|
+
get(): V | undefined;
|
|
10
|
+
getOrInit(): V;
|
|
11
|
+
debug?: string;
|
|
12
|
+
}
|
|
13
|
+
export declare function ContextPart<V>(fork: (parent?: V) => V, debug?: string): ContextPart<V>;
|
package/dist/Context.js
CHANGED
|
@@ -2,32 +2,45 @@ import { assert } from "liminal-util";
|
|
|
2
2
|
import { AsyncLocalStorage } from "node:async_hooks";
|
|
3
3
|
const storage = new AsyncLocalStorage();
|
|
4
4
|
export class Context extends Map {
|
|
5
|
-
static
|
|
6
|
-
|
|
7
|
-
assert(context);
|
|
8
|
-
return context;
|
|
9
|
-
}
|
|
10
|
-
get(context) {
|
|
11
|
-
return super.get(context);
|
|
5
|
+
static get() {
|
|
6
|
+
return storage.getStore();
|
|
12
7
|
}
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
8
|
+
static ensure() {
|
|
9
|
+
const current = Context.get();
|
|
10
|
+
assert(current);
|
|
11
|
+
return current;
|
|
16
12
|
}
|
|
17
|
-
run(
|
|
18
|
-
return storage.run(this,
|
|
13
|
+
run(f) {
|
|
14
|
+
return storage.run(this, f);
|
|
19
15
|
}
|
|
20
|
-
|
|
21
|
-
const context = new Context(
|
|
16
|
+
fork() {
|
|
17
|
+
const context = new Context();
|
|
22
18
|
for (const [handle, value] of this.entries()) {
|
|
23
19
|
if (!context.has(handle)) {
|
|
24
|
-
context.set(handle, handle.
|
|
20
|
+
context.set(handle, handle.fork(value));
|
|
25
21
|
}
|
|
26
22
|
}
|
|
27
23
|
return context;
|
|
28
24
|
}
|
|
29
25
|
}
|
|
30
|
-
export function
|
|
31
|
-
|
|
26
|
+
export function ContextPart(fork, debug) {
|
|
27
|
+
const self = {
|
|
28
|
+
fork,
|
|
29
|
+
get() {
|
|
30
|
+
return Context.get()?.get(self);
|
|
31
|
+
},
|
|
32
|
+
getOrInit() {
|
|
33
|
+
const context = Context.get();
|
|
34
|
+
assert(context);
|
|
35
|
+
let value = context.get(this);
|
|
36
|
+
if (!value) {
|
|
37
|
+
value = this.fork();
|
|
38
|
+
context.set(this, value);
|
|
39
|
+
}
|
|
40
|
+
return value;
|
|
41
|
+
},
|
|
42
|
+
...debug && { debug },
|
|
43
|
+
};
|
|
44
|
+
return self;
|
|
32
45
|
}
|
|
33
46
|
//# sourceMappingURL=Context.js.map
|
package/dist/Context.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Context.js","sourceRoot":"","sources":["../Context.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAA;AACrC,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAA;AAEpD,MAAM,OAAO,GAAG,IAAI,iBAAiB,EAAW,CAAA;AAEhD,MAAM,OAAO,OAAQ,SAAQ,
|
|
1
|
+
{"version":3,"file":"Context.js","sourceRoot":"","sources":["../Context.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAA;AACrC,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAA;AAEpD,MAAM,OAAO,GAAG,IAAI,iBAAiB,EAAW,CAAA;AAEhD,MAAM,OAAO,OAAQ,SAAQ,GAAyB;IACpD,MAAM,CAAC,GAAG;QACR,OAAO,OAAO,CAAC,QAAQ,EAAE,CAAA;IAC3B,CAAC;IAED,MAAM,CAAC,MAAM;QACX,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,EAAE,CAAA;QAC7B,MAAM,CAAC,OAAO,CAAC,CAAA;QACf,OAAO,OAAO,CAAA;IAChB,CAAC;IAED,GAAG,CAAI,CAAU;QACf,OAAO,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC,CAAA;IAC7B,CAAC;IAED,IAAI;QACF,MAAM,OAAO,GAAG,IAAI,OAAO,EAAE,CAAA;QAC7B,KAAK,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC;YAC7C,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC;gBACzB,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAA;YACzC,CAAC;QACH,CAAC;QACD,OAAO,OAAO,CAAA;IAChB,CAAC;CACF;AASD,MAAM,UAAU,WAAW,CAAI,IAAuB,EAAE,KAAc;IACpE,MAAM,IAAI,GAAmB;QAC3B,IAAI;QACJ,GAAG;YACD,OAAO,OAAO,CAAC,GAAG,EAAE,EAAE,GAAG,CAAC,IAAI,CAAU,CAAA;QAC1C,CAAC;QACD,SAAS;YACP,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,EAAE,CAAA;YAC7B,MAAM,CAAC,OAAO,CAAC,CAAA;YACf,IAAI,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;YAC7B,IAAI,CAAC,KAAK,EAAE,CAAC;gBACX,KAAK,GAAG,IAAI,CAAC,IAAI,EAAE,CAAA;gBACnB,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,CAAC,CAAA;YAC1B,CAAC;YACD,OAAO,KAAc,CAAA;QACvB,CAAC;QACD,GAAG,KAAK,IAAI,EAAE,KAAK,EAAE;KACtB,CAAA;IACD,OAAO,IAAI,CAAA;AACb,CAAC"}
|
package/dist/Fiber.d.ts
CHANGED
|
@@ -1,5 +1,22 @@
|
|
|
1
|
-
import type
|
|
1
|
+
import { type Rune } from "./Rune.ts";
|
|
2
2
|
import { Runic } from "./Runic.ts";
|
|
3
|
+
export interface FiberConfig {
|
|
4
|
+
parent?: Fiber;
|
|
5
|
+
signal?: AbortSignal;
|
|
6
|
+
}
|
|
7
|
+
export declare class Fiber<T = any> {
|
|
8
|
+
#private;
|
|
9
|
+
static [Symbol.iterator](): Generator<Rune<never>, Fiber>;
|
|
10
|
+
static nextIndex: number;
|
|
11
|
+
readonly index: number;
|
|
12
|
+
readonly depth: number;
|
|
13
|
+
readonly parent?: Fiber;
|
|
14
|
+
status: FiberStatus<T>;
|
|
15
|
+
controller: AbortController;
|
|
16
|
+
constructor(runic: Runic<Rune, T>, config?: FiberConfig);
|
|
17
|
+
handle(event: any): void;
|
|
18
|
+
resolution(): Promise<T>;
|
|
19
|
+
}
|
|
3
20
|
export type FiberStatus<T> = {
|
|
4
21
|
type: "untouched";
|
|
5
22
|
} | {
|
|
@@ -16,17 +33,3 @@ export type FiberStatus<T> = {
|
|
|
16
33
|
type: "rejected";
|
|
17
34
|
exception: unknown;
|
|
18
35
|
};
|
|
19
|
-
export declare class Fiber<T = any> {
|
|
20
|
-
#private;
|
|
21
|
-
static nextIndex: number;
|
|
22
|
-
T: T;
|
|
23
|
-
readonly index: number;
|
|
24
|
-
readonly parent?: Fiber;
|
|
25
|
-
signal: AbortSignal;
|
|
26
|
-
either: AbortSignal;
|
|
27
|
-
abort: (reason?: any) => void;
|
|
28
|
-
status: FiberStatus<T>;
|
|
29
|
-
constructor(runic: Runic<Rune, T>, parent?: Fiber);
|
|
30
|
-
fork<T>(runic: Runic<Rune, T>): Fiber<T>;
|
|
31
|
-
resolution(this: Fiber<T>): Promise<T>;
|
|
32
|
-
}
|
package/dist/Fiber.js
CHANGED
|
@@ -2,45 +2,47 @@ import { attachCustomInspect } from "liminal-util";
|
|
|
2
2
|
import { Context } from "./Context.js";
|
|
3
3
|
import { HandlerContext } from "./Handler.js";
|
|
4
4
|
import { FiberCreated, FiberRejected, FiberResolved, FiberStarted } from "./LEvent.js";
|
|
5
|
+
import { RuneKey } from "./Rune.js";
|
|
5
6
|
import { Runic } from "./Runic.js";
|
|
6
7
|
export class Fiber {
|
|
8
|
+
static *[Symbol.iterator]() {
|
|
9
|
+
return yield Object.assign((fiber) => fiber, {
|
|
10
|
+
[RuneKey]: true,
|
|
11
|
+
debug: "current_fiber",
|
|
12
|
+
});
|
|
13
|
+
}
|
|
7
14
|
static nextIndex = 0;
|
|
8
15
|
index = Fiber.nextIndex++;
|
|
16
|
+
depth;
|
|
17
|
+
#context = Context.get() ?? new Context();
|
|
9
18
|
#runic;
|
|
10
|
-
#
|
|
11
|
-
#
|
|
12
|
-
signal;
|
|
13
|
-
either;
|
|
14
|
-
abort;
|
|
19
|
+
#handler = HandlerContext.get();
|
|
20
|
+
#configSignal;
|
|
15
21
|
status = { type: "untouched" };
|
|
16
|
-
|
|
22
|
+
controller = new AbortController();
|
|
23
|
+
constructor(runic, config) {
|
|
24
|
+
this.depth = (config?.parent?.depth ?? -2) + 1;
|
|
17
25
|
this.#runic = runic;
|
|
18
|
-
|
|
26
|
+
const { parent, signal } = config ?? {};
|
|
27
|
+
if (parent)
|
|
19
28
|
this.parent = parent;
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
this.
|
|
23
|
-
this.either = AbortSignal.any([
|
|
24
|
-
...this.parent?.signal ? [this.parent.signal] : [],
|
|
25
|
-
this.signal,
|
|
26
|
-
]);
|
|
27
|
-
this.abort = controller.abort.bind(controller);
|
|
28
|
-
this.#handler?.call(this, new FiberCreated());
|
|
29
|
+
if (signal)
|
|
30
|
+
this.#configSignal = signal;
|
|
31
|
+
this.handle(new FiberCreated());
|
|
29
32
|
}
|
|
30
|
-
|
|
31
|
-
|
|
33
|
+
handle(event) {
|
|
34
|
+
this.#handler?.call(this, event);
|
|
32
35
|
}
|
|
33
36
|
resolution() {
|
|
34
|
-
|
|
35
|
-
switch (status.type) {
|
|
37
|
+
switch (this.status.type) {
|
|
36
38
|
case "untouched": {
|
|
37
39
|
const { promise, resolve, reject } = Promise.withResolvers();
|
|
38
40
|
this.status = {
|
|
39
41
|
type: "pending",
|
|
40
|
-
self: this.signal,
|
|
42
|
+
self: this.controller.signal,
|
|
41
43
|
promise,
|
|
42
44
|
};
|
|
43
|
-
this
|
|
45
|
+
this.handle(new FiberStarted());
|
|
44
46
|
const iterator = Runic.unwrap(this.#runic);
|
|
45
47
|
let nextArg;
|
|
46
48
|
this.#context.run(async () => {
|
|
@@ -56,8 +58,8 @@ export class Fiber {
|
|
|
56
58
|
type: "resolved",
|
|
57
59
|
value,
|
|
58
60
|
};
|
|
59
|
-
this
|
|
60
|
-
abort();
|
|
61
|
+
this.handle(new FiberResolved(value));
|
|
62
|
+
this.controller.abort();
|
|
61
63
|
resolve(value);
|
|
62
64
|
}
|
|
63
65
|
catch (exception) {
|
|
@@ -65,24 +67,24 @@ export class Fiber {
|
|
|
65
67
|
type: "rejected",
|
|
66
68
|
exception,
|
|
67
69
|
};
|
|
68
|
-
this
|
|
69
|
-
abort(
|
|
70
|
+
this.handle(new FiberRejected(exception));
|
|
71
|
+
this.controller.abort();
|
|
70
72
|
reject(exception);
|
|
71
73
|
}
|
|
72
74
|
});
|
|
73
75
|
return promise;
|
|
74
76
|
}
|
|
75
77
|
case "pending": {
|
|
76
|
-
return status.promise;
|
|
78
|
+
return this.status.promise;
|
|
77
79
|
}
|
|
78
80
|
case "resolved": {
|
|
79
|
-
return Promise.resolve(status.value);
|
|
81
|
+
return Promise.resolve(this.status.value);
|
|
80
82
|
}
|
|
81
83
|
case "rejected": {
|
|
82
|
-
return Promise.reject(status.exception);
|
|
84
|
+
return Promise.reject(this.status.exception);
|
|
83
85
|
}
|
|
84
86
|
case "aborted": {
|
|
85
|
-
return Promise.reject(status.reason);
|
|
87
|
+
return Promise.reject(this.status.reason);
|
|
86
88
|
}
|
|
87
89
|
}
|
|
88
90
|
}
|
package/dist/Fiber.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Fiber.js","sourceRoot":"","sources":["../Fiber.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAA;AAClD,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAA;AACtC,OAAO,EAAgB,cAAc,EAAE,MAAM,cAAc,CAAA;AAC3D,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,aAAa,CAAA;
|
|
1
|
+
{"version":3,"file":"Fiber.js","sourceRoot":"","sources":["../Fiber.ts"],"names":[],"mappings":"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"}
|
package/dist/Handler.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { ContextPart as ContextPart } from "./Context.ts";
|
|
2
2
|
import type { Fiber } from "./Fiber.ts";
|
|
3
3
|
export type Handler<E = any> = [(this: Fiber, event: E) => void][0];
|
|
4
|
-
export declare const HandlerContext:
|
|
4
|
+
export declare const HandlerContext: ContextPart<Handler | undefined>;
|
package/dist/Handler.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import {
|
|
2
|
-
export const HandlerContext =
|
|
1
|
+
import { ContextPart as ContextPart } from "./Context.js";
|
|
2
|
+
export const HandlerContext = ContextPart((parent) => parent, "handler");
|
|
3
3
|
//# sourceMappingURL=Handler.js.map
|
package/dist/Handler.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Handler.js","sourceRoot":"","sources":["../Handler.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"Handler.js","sourceRoot":"","sources":["../Handler.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,IAAI,WAAW,EAAE,MAAM,cAAc,CAAA;AAKzD,MAAM,CAAC,MAAM,cAAc,GAAqC,WAAW,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,EAAE,SAAS,CAAC,CAAA"}
|
package/dist/L/L.d.ts
CHANGED
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
export * from "liminal-schema/factories";
|
|
2
|
-
export * from "./_infer.ts";
|
|
3
|
-
export * from "./_message.ts";
|
|
4
2
|
export * from "./assistant.ts";
|
|
5
|
-
export * from "./branch.ts";
|
|
6
3
|
export * from "./catch.ts";
|
|
7
4
|
export * from "./emit.ts";
|
|
5
|
+
export * from "./infer.ts";
|
|
6
|
+
export * from "./message.ts";
|
|
8
7
|
export * from "./model.ts";
|
|
8
|
+
export * from "./rune.ts";
|
|
9
|
+
export * from "./strand.ts";
|
|
9
10
|
export * from "./stream.ts";
|
|
10
11
|
export * from "./system.ts";
|
|
11
12
|
export * from "./user.ts";
|
package/dist/L/L.js
CHANGED
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
export * from "liminal-schema/factories";
|
|
2
|
-
export * from "./_infer.js";
|
|
3
|
-
export * from "./_message.js";
|
|
4
2
|
export * from "./assistant.js";
|
|
5
|
-
export * from "./branch.js";
|
|
6
3
|
export * from "./catch.js";
|
|
7
4
|
export * from "./emit.js";
|
|
5
|
+
export * from "./infer.js";
|
|
6
|
+
export * from "./message.js";
|
|
8
7
|
export * from "./model.js";
|
|
8
|
+
export * from "./rune.js";
|
|
9
|
+
export * from "./strand.js";
|
|
9
10
|
export * from "./stream.js";
|
|
10
11
|
export * from "./system.js";
|
|
11
12
|
export * from "./user.js";
|
package/dist/L/L.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"L.js","sourceRoot":"","sources":["../../L/L.ts"],"names":[],"mappings":"AAAA,cAAc,0BAA0B,CAAA;AACxC,cAAc,
|
|
1
|
+
{"version":3,"file":"L.js","sourceRoot":"","sources":["../../L/L.ts"],"names":[],"mappings":"AAAA,cAAc,0BAA0B,CAAA;AACxC,cAAc,gBAAgB,CAAA;AAC9B,cAAc,YAAY,CAAA;AAC1B,cAAc,WAAW,CAAA;AACzB,cAAc,YAAY,CAAA;AAC1B,cAAc,cAAc,CAAA;AAC5B,cAAc,YAAY,CAAA;AAC1B,cAAc,WAAW,CAAA;AACzB,cAAc,aAAa,CAAA;AAC3B,cAAc,aAAa,CAAA;AAC3B,cAAc,aAAa,CAAA;AAC3B,cAAc,WAAW,CAAA"}
|
package/dist/L/assistant.js
CHANGED
|
@@ -1,17 +1,17 @@
|
|
|
1
1
|
import { toJSONSchema, validate } from "liminal-schema";
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
2
|
+
import { infer } from "./infer.js";
|
|
3
|
+
import { message } from "./message.js";
|
|
4
4
|
import { rune } from "./rune.js";
|
|
5
5
|
export const assistant = Object.assign(function* (type) {
|
|
6
6
|
const schema = toJSONSchema(type);
|
|
7
|
-
const inference = yield*
|
|
8
|
-
yield*
|
|
7
|
+
const inference = yield* infer(schema);
|
|
8
|
+
yield* message("assistant", [{ part: inference }]);
|
|
9
9
|
const input = JSON.parse(inference);
|
|
10
10
|
return yield* rune(() => validate(type, input), "validate_assistant_message");
|
|
11
11
|
}, {
|
|
12
12
|
*[Symbol.iterator]() {
|
|
13
|
-
const inference = yield*
|
|
14
|
-
yield*
|
|
13
|
+
const inference = yield* infer();
|
|
14
|
+
yield* message("assistant", [{ part: inference }]);
|
|
15
15
|
return inference;
|
|
16
16
|
},
|
|
17
17
|
});
|
package/dist/L/assistant.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"assistant.js","sourceRoot":"","sources":["../../L/assistant.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,YAAY,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAA;AAGnE,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"assistant.js","sourceRoot":"","sources":["../../L/assistant.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,YAAY,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAA;AAGnE,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAClC,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAA;AACtC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAA;AAMhC,MAAM,CAAC,MAAM,SAAS,GAAc,MAAM,CAAC,MAAM,CAC/C,QAAQ,CAAC,EAAI,IAAc;IACzB,MAAM,MAAM,GAAG,YAAY,CAAC,IAAI,CAAC,CAAA;IACjC,MAAM,SAAS,GAAG,KAAK,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAA;IACtC,KAAK,CAAC,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC,CAAA;IAClD,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAA;IACnC,OAAO,KAAK,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,IAAI,EAAE,KAAK,CAAC,EAAE,4BAA4B,CAAC,CAAA;AAC/E,CAAC,EACD;IACE,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC;QAChB,MAAM,SAAS,GAAG,KAAK,CAAC,CAAC,KAAK,EAAE,CAAA;QAChC,KAAK,CAAC,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC,CAAA;QAClD,OAAO,SAAS,CAAA;IAClB,CAAC;CACF,CACF,CAAA"}
|
package/dist/L/catch.js
CHANGED
|
@@ -1,9 +1,16 @@
|
|
|
1
|
+
import { assert } from "liminal-util";
|
|
2
|
+
import { Context } from "../Context.js";
|
|
3
|
+
import { Fiber } from "../Fiber.js";
|
|
1
4
|
import { rune } from "./rune.js";
|
|
2
5
|
export { catch_ as catch };
|
|
3
6
|
function* catch_(runic) {
|
|
4
|
-
return yield* rune(async (
|
|
7
|
+
return yield* rune(async (parent) => {
|
|
5
8
|
try {
|
|
6
|
-
|
|
9
|
+
const context = Context.get();
|
|
10
|
+
assert(context);
|
|
11
|
+
return {
|
|
12
|
+
resolved: await context.fork().run(() => new Fiber(runic, { parent }).resolution()),
|
|
13
|
+
};
|
|
7
14
|
}
|
|
8
15
|
catch (exception) {
|
|
9
16
|
return { rejected: exception };
|
package/dist/L/catch.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"catch.js","sourceRoot":"","sources":["../../L/catch.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"catch.js","sourceRoot":"","sources":["../../L/catch.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAA;AACrC,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAA;AACvC,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAA;AAGnC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAA;AAEhC,OAAO,EAAE,MAAM,IAAI,KAAK,EAAE,CAAA;AAE1B,QAAQ,CAAC,CAAC,MAAM,CAAoB,KAAkB;IACpD,OAAO,KAAK,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE;QAClC,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,EAAE,CAAA;YAC7B,MAAM,CAAC,OAAO,CAAC,CAAA;YACf,OAAO;gBACL,QAAQ,EAAE,MAAM,OAAO,CAAC,IAAI,EAAE,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,KAAK,CAAC,KAAK,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC,UAAU,EAAE,CAAC;aACpF,CAAA;QACH,CAAC;QAAC,OAAO,SAAkB,EAAE,CAAC;YAC5B,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAA;QAChC,CAAC;IACH,CAAC,EAAE,OAAO,CAAC,CAAA;AACb,CAAC;AACD,MAAM,CAAC,cAAc,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAA"}
|
package/dist/L/emit.js
CHANGED
|
@@ -1,10 +1,6 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { HandlerContext } from "../Handler.js";
|
|
3
|
-
import { rune } from "./rune.js";
|
|
1
|
+
import { Fiber } from "../Fiber.js";
|
|
4
2
|
export function* emit(event) {
|
|
5
|
-
const
|
|
6
|
-
|
|
7
|
-
const fiber = yield* rune;
|
|
8
|
-
handler?.call(fiber, event);
|
|
3
|
+
const self = yield* Fiber;
|
|
4
|
+
self.handle(event);
|
|
9
5
|
}
|
|
10
6
|
//# sourceMappingURL=emit.js.map
|
package/dist/L/emit.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"emit.js","sourceRoot":"","sources":["../../L/emit.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"emit.js","sourceRoot":"","sources":["../../L/emit.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAA;AAKnC,MAAM,SAAS,CAAC,CAAC,IAAI,CAAU,KAAsB;IACnD,MAAM,IAAI,GAAG,KAAK,CAAC,CAAC,KAAK,CAAA;IACzB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;AACpB,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { SchemaObject } from "liminal-schema";
|
|
2
|
+
import { type LEvent } from "../LEvent.ts";
|
|
3
|
+
import type { Rune } from "../Rune.ts";
|
|
4
|
+
export { infer_ as infer };
|
|
5
|
+
interface infer_ extends Generator<Rune<LEvent>, string> {
|
|
6
|
+
}
|
|
7
|
+
declare function infer_(schema?: SchemaObject): infer_;
|
|
@@ -1,29 +1,27 @@
|
|
|
1
1
|
import { assert } from "liminal-util";
|
|
2
|
-
import { Context } from "../Context.js";
|
|
3
2
|
import { InferenceRequested, Inferred } from "../LEvent.js";
|
|
4
3
|
import { MessageRegistryContext } from "../MessageRegistry.js";
|
|
5
4
|
import { ModelRegistryContext } from "../ModelRegistry.js";
|
|
6
5
|
import { RequestCounter } from "./_common.js";
|
|
7
6
|
import { emit } from "./emit.js";
|
|
8
7
|
import { rune } from "./rune.js";
|
|
9
|
-
export
|
|
10
|
-
|
|
11
|
-
const modelRegistry =
|
|
12
|
-
assert(modelRegistry);
|
|
8
|
+
export { infer_ as infer };
|
|
9
|
+
function* infer_(schema) {
|
|
10
|
+
const modelRegistry = ModelRegistryContext.getOrInit();
|
|
13
11
|
const model = modelRegistry.peek();
|
|
14
12
|
assert(model);
|
|
15
13
|
const requestId = RequestCounter.next();
|
|
16
14
|
yield* emit(new InferenceRequested(requestId, schema));
|
|
17
|
-
const messageRegistry =
|
|
18
|
-
assert(messageRegistry);
|
|
15
|
+
const messageRegistry = MessageRegistryContext.getOrInit();
|
|
19
16
|
const inference = yield* rune((fiber) => model
|
|
20
17
|
.seal({
|
|
21
18
|
messages: messageRegistry.messages,
|
|
22
19
|
schema,
|
|
23
|
-
signal: fiber.signal,
|
|
20
|
+
signal: fiber.controller.signal,
|
|
24
21
|
})
|
|
25
22
|
.resolve(), "infer");
|
|
26
23
|
yield* emit(new Inferred(requestId, inference));
|
|
27
24
|
return inference;
|
|
28
25
|
}
|
|
29
|
-
|
|
26
|
+
Object.defineProperty(infer_, "name", { value: "infer" });
|
|
27
|
+
//# sourceMappingURL=infer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"infer.js","sourceRoot":"","sources":["../../L/infer.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAA;AACrC,OAAO,EAAE,kBAAkB,EAAE,QAAQ,EAAe,MAAM,cAAc,CAAA;AACxE,OAAO,EAAE,sBAAsB,EAAE,MAAM,uBAAuB,CAAA;AAC9D,OAAO,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAA;AAE1D,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAA;AAC7C,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAA;AAChC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAA;AAEhC,OAAO,EAAE,MAAM,IAAI,KAAK,EAAE,CAAA;AAI1B,QAAQ,CAAC,CAAC,MAAM,CAAC,MAAqB;IACpC,MAAM,aAAa,GAAG,oBAAoB,CAAC,SAAS,EAAE,CAAA;IACtD,MAAM,KAAK,GAAG,aAAa,CAAC,IAAI,EAAE,CAAA;IAClC,MAAM,CAAC,KAAK,CAAC,CAAA;IACb,MAAM,SAAS,GAAG,cAAc,CAAC,IAAI,EAAE,CAAA;IACvC,KAAK,CAAC,CAAC,IAAI,CAAC,IAAI,kBAAkB,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC,CAAA;IACtD,MAAM,eAAe,GAAG,sBAAsB,CAAC,SAAS,EAAE,CAAA;IAC1D,MAAM,SAAS,GAAG,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CACtC,KAAK;SACF,IAAI,CAAC;QACJ,QAAQ,EAAE,eAAe,CAAC,QAAQ;QAClC,MAAM;QACN,MAAM,EAAE,KAAK,CAAC,UAAU,CAAC,MAAM;KAChC,CAAC;SACD,OAAO,EAAE,EAAE,OAAO,CAAC,CAAA;IACxB,KAAK,CAAC,CAAC,IAAI,CAAC,IAAI,QAAQ,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC,CAAA;IAC/C,OAAO,SAAS,CAAA;AAClB,CAAC;AACD,MAAM,CAAC,cAAc,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAA"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { type LEvent } from "../LEvent.ts";
|
|
2
|
+
import type { ContentPart, MessageRole } from "../Message.ts";
|
|
3
|
+
import type { Rune } from "../Rune.ts";
|
|
4
|
+
export interface message extends Generator<Rune<LEvent>, void> {
|
|
5
|
+
}
|
|
6
|
+
export declare function message(role: MessageRole, content: Array<ContentPart>): message;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { MessageAppended } from "../LEvent.js";
|
|
2
|
+
import { MessageRegistryContext } from "../MessageRegistry.js";
|
|
3
|
+
import { emit } from "./emit.js";
|
|
4
|
+
export function* message(role, content) {
|
|
5
|
+
const messageRegistry = MessageRegistryContext.getOrInit();
|
|
6
|
+
const message = { role, content };
|
|
7
|
+
yield* emit(new MessageAppended(message));
|
|
8
|
+
messageRegistry.append(message);
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=message.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"message.js","sourceRoot":"","sources":["../../L/message.ts"],"names":[],"mappings":"AAAA,OAAO,EAAe,eAAe,EAAE,MAAM,cAAc,CAAA;AAE3D,OAAO,EAAE,sBAAsB,EAAE,MAAM,uBAAuB,CAAA;AAE9D,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAA;AAIhC,MAAM,SAAS,CAAC,CAAC,OAAO,CAAC,IAAiB,EAAE,OAA2B;IACrE,MAAM,eAAe,GAAG,sBAAsB,CAAC,SAAS,EAAE,CAAA;IAC1D,MAAM,OAAO,GAAY,EAAE,IAAI,EAAE,OAAO,EAAE,CAAA;IAC1C,KAAK,CAAC,CAAC,IAAI,CAAC,IAAI,eAAe,CAAC,OAAO,CAAC,CAAC,CAAA;IACzC,eAAe,CAAC,MAAM,CAAC,OAAO,CAAC,CAAA;AACjC,CAAC"}
|
package/dist/L/model.js
CHANGED
|
@@ -1,12 +1,8 @@
|
|
|
1
|
-
import { assert } from "liminal-util";
|
|
2
|
-
import { Context } from "../Context.js";
|
|
3
1
|
import { ModelRegistered } from "../LEvent.js";
|
|
4
2
|
import { ModelRegistryContext } from "../ModelRegistry.js";
|
|
5
3
|
import { emit } from "./emit.js";
|
|
6
4
|
export function* model(model) {
|
|
7
|
-
const
|
|
8
|
-
const registry = context.get(ModelRegistryContext);
|
|
9
|
-
assert(registry);
|
|
5
|
+
const registry = ModelRegistryContext.getOrInit();
|
|
10
6
|
registry.register(model);
|
|
11
7
|
yield* emit(new ModelRegistered(model));
|
|
12
8
|
}
|
package/dist/L/model.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"model.js","sourceRoot":"","sources":["../../L/model.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"model.js","sourceRoot":"","sources":["../../L/model.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAA;AAE9C,OAAO,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAA;AAE1D,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAA;AAIhC,MAAM,SAAS,CAAC,CAAC,KAAK,CAAC,KAAY;IACjC,MAAM,QAAQ,GAAG,oBAAoB,CAAC,SAAS,EAAE,CAAA;IACjD,QAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;IACxB,KAAK,CAAC,CAAC,IAAI,CAAC,IAAI,eAAe,CAAC,KAAK,CAAC,CAAC,CAAA;AACzC,CAAC"}
|
package/dist/L/rune.d.ts
CHANGED
|
@@ -1,8 +1,3 @@
|
|
|
1
1
|
import { Fiber } from "../Fiber.ts";
|
|
2
2
|
import { type Rune } from "../Rune.ts";
|
|
3
|
-
export
|
|
4
|
-
<R>(source: (fiber: Fiber) => R, debug?: string): Iterable<Rune<never>, Awaited<R>> & {
|
|
5
|
-
<E>(): Generator<Rune<E>, Awaited<R>>;
|
|
6
|
-
};
|
|
7
|
-
}
|
|
8
|
-
export declare const rune: rune;
|
|
3
|
+
export declare function rune<R>(source: (fiber: Fiber) => R, debug?: string): Generator<Rune<never>, Awaited<R>>;
|
package/dist/L/rune.js
CHANGED
|
@@ -1,19 +1,9 @@
|
|
|
1
1
|
import { Fiber } from "../Fiber.js";
|
|
2
2
|
import { RuneKey } from "../Rune.js";
|
|
3
|
-
export
|
|
4
|
-
return Object.assign(
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
*[Symbol.iterator]() {
|
|
8
|
-
return yield Object.assign(source, { [RuneKey]: true, debug });
|
|
9
|
-
},
|
|
3
|
+
export function* rune(source, debug) {
|
|
4
|
+
return yield Object.assign(source, {
|
|
5
|
+
[RuneKey]: true,
|
|
6
|
+
debug,
|
|
10
7
|
});
|
|
11
|
-
}
|
|
12
|
-
*[Symbol.iterator]() {
|
|
13
|
-
return yield Object.assign((fiber) => fiber, {
|
|
14
|
-
[RuneKey]: true,
|
|
15
|
-
debug: "get_current_fiber",
|
|
16
|
-
});
|
|
17
|
-
},
|
|
18
|
-
});
|
|
8
|
+
}
|
|
19
9
|
//# sourceMappingURL=rune.js.map
|
package/dist/L/rune.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"rune.js","sourceRoot":"","sources":["../../L/rune.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAA;AACnC,OAAO,EAAa,OAAO,EAAE,MAAM,YAAY,CAAA;
|
|
1
|
+
{"version":3,"file":"rune.js","sourceRoot":"","sources":["../../L/rune.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAA;AACnC,OAAO,EAAa,OAAO,EAAE,MAAM,YAAY,CAAA;AAE/C,MAAM,SAAS,CAAC,CAAC,IAAI,CACnB,MAA2B,EAC3B,KAAc;IAEd,OAAO,MAAM,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE;QACjC,CAAC,OAAO,CAAC,EAAE,IAAI;QACf,KAAK;KACN,CAAU,CAAA;AACb,CAAC"}
|