assistant-stream 0.1.6 → 0.1.7
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/dist/ai-sdk/index.d.ts +5 -0
- package/dist/ai-sdk/index.d.ts.map +1 -0
- package/dist/ai-sdk/index.js +199 -0
- package/dist/ai-sdk/index.js.map +1 -0
- package/dist/ai-sdk/index.mjs +173 -0
- package/dist/ai-sdk/index.mjs.map +1 -0
- package/dist/ai-sdk/language-model.d.ts +6 -0
- package/dist/ai-sdk/language-model.d.ts.map +1 -0
- package/dist/ai-sdk/language-model.js +131 -0
- package/dist/ai-sdk/language-model.js.map +1 -0
- package/dist/ai-sdk/language-model.mjs +106 -0
- package/dist/ai-sdk/language-model.mjs.map +1 -0
- package/dist/ai-sdk.d.ts +3 -24
- package/dist/ai-sdk.d.ts.map +1 -0
- package/dist/ai-sdk.js +5 -782
- package/dist/ai-sdk.js.map +1 -1
- package/dist/ai-sdk.mjs +4 -276
- package/dist/ai-sdk.mjs.map +1 -1
- package/dist/core/AssistantStream.d.ts +12 -0
- package/dist/core/AssistantStream.d.ts.map +1 -0
- package/dist/core/AssistantStream.js +46 -0
- package/dist/core/AssistantStream.js.map +1 -0
- package/dist/core/AssistantStream.mjs +21 -0
- package/dist/core/AssistantStream.mjs.map +1 -0
- package/dist/core/AssistantStreamChunk.d.ts +64 -0
- package/dist/core/AssistantStreamChunk.d.ts.map +1 -0
- package/dist/core/AssistantStreamChunk.js +19 -0
- package/dist/core/AssistantStreamChunk.js.map +1 -0
- package/dist/core/AssistantStreamChunk.mjs +1 -0
- package/dist/core/AssistantStreamChunk.mjs.map +1 -0
- package/dist/core/accumulators/AssistantMessageStream.d.ts +13 -0
- package/dist/core/accumulators/AssistantMessageStream.d.ts.map +1 -0
- package/dist/core/accumulators/AssistantMessageStream.js +79 -0
- package/dist/core/accumulators/AssistantMessageStream.js.map +1 -0
- package/dist/core/accumulators/AssistantMessageStream.mjs +54 -0
- package/dist/core/accumulators/AssistantMessageStream.mjs.map +1 -0
- package/dist/core/accumulators/assistant-message-accumulator.d.ts +8 -0
- package/dist/core/accumulators/assistant-message-accumulator.d.ts.map +1 -0
- package/dist/core/accumulators/assistant-message-accumulator.js +334 -0
- package/dist/core/accumulators/assistant-message-accumulator.js.map +1 -0
- package/dist/core/accumulators/assistant-message-accumulator.mjs +309 -0
- package/dist/core/accumulators/assistant-message-accumulator.mjs.map +1 -0
- package/dist/core/index.d.ts +11 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +55 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/index.mjs +26 -0
- package/dist/core/index.mjs.map +1 -0
- package/dist/core/modules/assistant-stream.d.ts +31 -0
- package/dist/core/modules/assistant-stream.d.ts.map +1 -0
- package/dist/core/modules/assistant-stream.js +224 -0
- package/dist/core/modules/assistant-stream.js.map +1 -0
- package/dist/core/modules/assistant-stream.mjs +202 -0
- package/dist/core/modules/assistant-stream.mjs.map +1 -0
- package/dist/core/modules/text.d.ts +9 -0
- package/dist/core/modules/text.d.ts.map +1 -0
- package/dist/core/modules/text.js +78 -0
- package/dist/core/modules/text.js.map +1 -0
- package/dist/core/modules/text.mjs +52 -0
- package/dist/core/modules/text.mjs.map +1 -0
- package/dist/core/modules/tool-call.d.ts +13 -0
- package/dist/core/modules/tool-call.d.ts.map +1 -0
- package/dist/core/modules/tool-call.js +110 -0
- package/dist/core/modules/tool-call.js.map +1 -0
- package/dist/core/modules/tool-call.mjs +84 -0
- package/dist/core/modules/tool-call.mjs.map +1 -0
- package/dist/core/serialization/PlainText.d.ts +11 -0
- package/dist/core/serialization/PlainText.d.ts.map +1 -0
- package/dist/core/serialization/PlainText.js +70 -0
- package/dist/core/serialization/PlainText.js.map +1 -0
- package/dist/core/serialization/PlainText.mjs +44 -0
- package/dist/core/serialization/PlainText.mjs.map +1 -0
- package/dist/core/serialization/data-stream/DataStream.d.ts +11 -0
- package/dist/core/serialization/data-stream/DataStream.d.ts.map +1 -0
- package/dist/core/serialization/data-stream/DataStream.js +332 -0
- package/dist/core/serialization/data-stream/DataStream.js.map +1 -0
- package/dist/core/serialization/data-stream/DataStream.mjs +311 -0
- package/dist/core/serialization/data-stream/DataStream.mjs.map +1 -0
- package/dist/core/serialization/data-stream/chunk-types.d.ts +86 -0
- package/dist/core/serialization/data-stream/chunk-types.d.ts.map +1 -0
- package/dist/core/serialization/data-stream/chunk-types.js +49 -0
- package/dist/core/serialization/data-stream/chunk-types.js.map +1 -0
- package/dist/core/serialization/data-stream/chunk-types.mjs +24 -0
- package/dist/core/serialization/data-stream/chunk-types.mjs.map +1 -0
- package/dist/core/serialization/data-stream/serialization.d.ts +8 -0
- package/dist/core/serialization/data-stream/serialization.d.ts.map +1 -0
- package/dist/core/serialization/data-stream/serialization.js +56 -0
- package/dist/core/serialization/data-stream/serialization.js.map +1 -0
- package/dist/core/serialization/data-stream/serialization.mjs +30 -0
- package/dist/core/serialization/data-stream/serialization.mjs.map +1 -0
- package/dist/core/tool/ToolCallReader.d.ts +33 -0
- package/dist/core/tool/ToolCallReader.d.ts.map +1 -0
- package/dist/core/tool/ToolCallReader.js +339 -0
- package/dist/core/tool/ToolCallReader.js.map +1 -0
- package/dist/core/tool/ToolCallReader.mjs +315 -0
- package/dist/core/tool/ToolCallReader.mjs.map +1 -0
- package/dist/core/tool/ToolExecutionStream.d.ts +24 -0
- package/dist/core/tool/ToolExecutionStream.d.ts.map +1 -0
- package/dist/core/tool/ToolExecutionStream.js +165 -0
- package/dist/core/tool/ToolExecutionStream.js.map +1 -0
- package/dist/core/tool/ToolExecutionStream.mjs +132 -0
- package/dist/core/tool/ToolExecutionStream.mjs.map +1 -0
- package/dist/core/tool/ToolResponse.d.ts +17 -0
- package/dist/core/tool/ToolResponse.d.ts.map +1 -0
- package/dist/core/tool/ToolResponse.js +47 -0
- package/dist/core/tool/ToolResponse.js.map +1 -0
- package/dist/core/tool/ToolResponse.mjs +22 -0
- package/dist/core/tool/ToolResponse.mjs.map +1 -0
- package/dist/core/tool/index.d.ts +6 -0
- package/dist/core/tool/index.d.ts.map +1 -0
- package/dist/core/tool/index.js +39 -0
- package/dist/core/tool/index.js.map +1 -0
- package/dist/core/tool/index.mjs +14 -0
- package/dist/core/tool/index.mjs.map +1 -0
- package/dist/core/tool/tool-types.d.ts +76 -0
- package/dist/core/tool/tool-types.d.ts.map +1 -0
- package/dist/core/tool/tool-types.js +19 -0
- package/dist/core/tool/tool-types.js.map +1 -0
- package/dist/core/tool/tool-types.mjs +1 -0
- package/dist/core/tool/tool-types.mjs.map +1 -0
- package/dist/core/tool/toolResultStream.d.ts +6 -0
- package/dist/core/tool/toolResultStream.d.ts.map +1 -0
- package/dist/core/tool/toolResultStream.js +104 -0
- package/dist/core/tool/toolResultStream.js.map +1 -0
- package/dist/core/tool/toolResultStream.mjs +78 -0
- package/dist/core/tool/toolResultStream.mjs.map +1 -0
- package/dist/core/tool/type-path-utils.d.ts +23 -0
- package/dist/core/tool/type-path-utils.d.ts.map +1 -0
- package/dist/core/tool/type-path-utils.js +19 -0
- package/dist/core/tool/type-path-utils.js.map +1 -0
- package/dist/core/tool/type-path-utils.mjs +1 -0
- package/dist/core/tool/type-path-utils.mjs.map +1 -0
- package/dist/core/utils/Counter.d.ts +5 -0
- package/dist/core/utils/Counter.d.ts.map +1 -0
- package/dist/core/utils/Counter.js +36 -0
- package/dist/core/utils/Counter.js.map +1 -0
- package/dist/core/utils/Counter.mjs +11 -0
- package/dist/core/utils/Counter.mjs.map +1 -0
- package/dist/core/utils/generateId.d.ts +2 -0
- package/dist/core/utils/generateId.d.ts.map +1 -0
- package/dist/core/utils/generateId.js +35 -0
- package/dist/core/utils/generateId.js.map +1 -0
- package/dist/core/utils/generateId.mjs +10 -0
- package/dist/core/utils/generateId.mjs.map +1 -0
- package/dist/core/utils/stream/AssistantMetaTransformStream.d.ts +20 -0
- package/dist/core/utils/stream/AssistantMetaTransformStream.d.ts.map +1 -0
- package/dist/core/utils/stream/AssistantMetaTransformStream.js +69 -0
- package/dist/core/utils/stream/AssistantMetaTransformStream.js.map +1 -0
- package/dist/core/utils/stream/AssistantMetaTransformStream.mjs +44 -0
- package/dist/core/utils/stream/AssistantMetaTransformStream.mjs.map +1 -0
- package/dist/core/utils/stream/AssistantTransformStream.d.ts +15 -0
- package/dist/core/utils/stream/AssistantTransformStream.d.ts.map +1 -0
- package/dist/core/utils/stream/AssistantTransformStream.js +69 -0
- package/dist/core/utils/stream/AssistantTransformStream.js.map +1 -0
- package/dist/core/utils/stream/AssistantTransformStream.mjs +46 -0
- package/dist/core/utils/stream/AssistantTransformStream.mjs.map +1 -0
- package/dist/core/utils/stream/LineDecoderStream.d.ts +5 -0
- package/dist/core/utils/stream/LineDecoderStream.d.ts.map +1 -0
- package/dist/core/utils/stream/LineDecoderStream.js +52 -0
- package/dist/core/utils/stream/LineDecoderStream.js.map +1 -0
- package/dist/core/utils/stream/LineDecoderStream.mjs +27 -0
- package/dist/core/utils/stream/LineDecoderStream.mjs.map +1 -0
- package/dist/core/utils/stream/PipeableTransformStream.d.ts +4 -0
- package/dist/core/utils/stream/PipeableTransformStream.d.ts.map +1 -0
- package/dist/core/utils/stream/PipeableTransformStream.js +40 -0
- package/dist/core/utils/stream/PipeableTransformStream.js.map +1 -0
- package/dist/core/utils/stream/PipeableTransformStream.mjs +15 -0
- package/dist/core/utils/stream/PipeableTransformStream.mjs.map +1 -0
- package/dist/core/utils/stream/UnderlyingReadable.d.ts +6 -0
- package/dist/core/utils/stream/UnderlyingReadable.d.ts.map +1 -0
- package/dist/core/utils/stream/UnderlyingReadable.js +19 -0
- package/dist/core/utils/stream/UnderlyingReadable.js.map +1 -0
- package/dist/core/utils/stream/UnderlyingReadable.mjs +1 -0
- package/dist/core/utils/stream/UnderlyingReadable.mjs.map +1 -0
- package/dist/core/utils/stream/merge.d.ts +9 -0
- package/dist/core/utils/stream/merge.d.ts.map +1 -0
- package/dist/core/utils/stream/merge.js +110 -0
- package/dist/core/utils/stream/merge.js.map +1 -0
- package/dist/core/utils/stream/merge.mjs +85 -0
- package/dist/core/utils/stream/merge.mjs.map +1 -0
- package/dist/core/utils/stream/path-utils.d.ts +12 -0
- package/dist/core/utils/stream/path-utils.d.ts.map +1 -0
- package/dist/core/utils/stream/path-utils.js +88 -0
- package/dist/core/utils/stream/path-utils.js.map +1 -0
- package/dist/core/utils/stream/path-utils.mjs +61 -0
- package/dist/core/utils/stream/path-utils.mjs.map +1 -0
- package/dist/core/utils/types.d.ts +102 -0
- package/dist/core/utils/types.d.ts.map +1 -0
- package/dist/core/utils/types.js +19 -0
- package/dist/core/utils/types.js.map +1 -0
- package/dist/core/utils/types.mjs +1 -0
- package/dist/core/utils/types.mjs.map +1 -0
- package/dist/core/utils/withPromiseOrValue.d.ts +2 -0
- package/dist/core/utils/withPromiseOrValue.d.ts.map +1 -0
- package/dist/core/utils/withPromiseOrValue.js +42 -0
- package/dist/core/utils/withPromiseOrValue.js.map +1 -0
- package/dist/core/utils/withPromiseOrValue.mjs +17 -0
- package/dist/core/utils/withPromiseOrValue.mjs.map +1 -0
- package/dist/index.d.ts +2 -153
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +3 -2318
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +2 -957
- package/dist/index.mjs.map +1 -1
- package/dist/utils/AsyncIterableStream.d.ts +3 -0
- package/dist/utils/AsyncIterableStream.d.ts.map +1 -0
- package/dist/utils/AsyncIterableStream.js +46 -0
- package/dist/utils/AsyncIterableStream.js.map +1 -0
- package/dist/utils/AsyncIterableStream.mjs +21 -0
- package/dist/utils/AsyncIterableStream.mjs.map +1 -0
- package/dist/utils/json/fix-json.d.ts +2 -0
- package/dist/utils/json/fix-json.d.ts.map +1 -0
- package/dist/{chunk-PQLDKUPN.mjs → utils/json/fix-json.js} +28 -66
- package/dist/utils/json/fix-json.js.map +1 -0
- package/dist/utils/json/fix-json.mjs +362 -0
- package/dist/utils/json/fix-json.mjs.map +1 -0
- package/dist/utils/json/is-json.d.ts +5 -0
- package/dist/utils/json/is-json.d.ts.map +1 -0
- package/dist/utils/json/is-json.js +56 -0
- package/dist/utils/json/is-json.js.map +1 -0
- package/dist/utils/json/is-json.mjs +29 -0
- package/dist/utils/json/is-json.mjs.map +1 -0
- package/dist/utils/json/json-value.d.ts +6 -0
- package/dist/utils/json/json-value.d.ts.map +1 -0
- package/dist/utils/json/json-value.js +19 -0
- package/dist/utils/json/json-value.js.map +1 -0
- package/dist/utils/json/json-value.mjs +1 -0
- package/dist/utils/json/json-value.mjs.map +1 -0
- package/dist/utils/json/parse-partial-json-object.d.ts +14 -0
- package/dist/utils/json/parse-partial-json-object.d.ts.map +1 -0
- package/dist/utils/json/parse-partial-json-object.js +102 -0
- package/dist/utils/json/parse-partial-json-object.js.map +1 -0
- package/dist/utils/json/parse-partial-json-object.mjs +65 -0
- package/dist/utils/json/parse-partial-json-object.mjs.map +1 -0
- package/dist/utils/json/parse-partial-json-object.test.d.ts +2 -0
- package/dist/utils/json/parse-partial-json-object.test.d.ts.map +1 -0
- package/dist/utils/promiseWithResolvers.d.ts +6 -0
- package/dist/utils/promiseWithResolvers.d.ts.map +1 -0
- package/dist/utils/promiseWithResolvers.js +40 -0
- package/dist/utils/promiseWithResolvers.js.map +1 -0
- package/dist/utils/promiseWithResolvers.mjs +15 -0
- package/dist/utils/promiseWithResolvers.mjs.map +1 -0
- package/dist/utils.d.ts +4 -16
- package/dist/utils.d.ts.map +1 -0
- package/dist/utils.js +5 -451
- package/dist/utils.js.map +1 -1
- package/dist/utils.mjs +7 -21
- package/dist/utils.mjs.map +1 -1
- package/package.json +1 -1
- package/dist/AsyncIterableStream-C3C8ZoXv.d.mts +0 -4
- package/dist/AsyncIterableStream-C3C8ZoXv.d.ts +0 -4
- package/dist/ai-sdk.d.mts +0 -24
- package/dist/assistant-stream-ISFjQ0mQ.d.mts +0 -225
- package/dist/assistant-stream-kAoIMgvk.d.ts +0 -225
- package/dist/chunk-EDE6WQ2R.mjs +0 -943
- package/dist/chunk-EDE6WQ2R.mjs.map +0 -1
- package/dist/chunk-PQLDKUPN.mjs.map +0 -1
- package/dist/index.d.mts +0 -153
- package/dist/json-value-Ch5eKkQ_.d.mts +0 -7
- package/dist/json-value-Ch5eKkQ_.d.ts +0 -7
- package/dist/utils.d.mts +0 -16
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
// src/core/utils/stream/merge.ts
|
|
2
|
+
import { promiseWithResolvers } from "../../../utils/promiseWithResolvers.mjs";
|
|
3
|
+
var createMergeStream = () => {
|
|
4
|
+
const list = [];
|
|
5
|
+
let sealed = false;
|
|
6
|
+
let controller;
|
|
7
|
+
let currentPull;
|
|
8
|
+
const handlePull = (item) => {
|
|
9
|
+
if (!item.promise) {
|
|
10
|
+
item.promise = item.reader.read().then(({ done, value }) => {
|
|
11
|
+
item.promise = void 0;
|
|
12
|
+
if (done) {
|
|
13
|
+
list.splice(list.indexOf(item), 1);
|
|
14
|
+
if (sealed && list.length === 0) {
|
|
15
|
+
controller.close();
|
|
16
|
+
}
|
|
17
|
+
} else {
|
|
18
|
+
controller.enqueue(value);
|
|
19
|
+
}
|
|
20
|
+
currentPull?.resolve();
|
|
21
|
+
currentPull = void 0;
|
|
22
|
+
}).catch((e) => {
|
|
23
|
+
console.error(e);
|
|
24
|
+
list.forEach((item2) => {
|
|
25
|
+
item2.reader.cancel();
|
|
26
|
+
});
|
|
27
|
+
list.length = 0;
|
|
28
|
+
controller.error(e);
|
|
29
|
+
currentPull?.reject(e);
|
|
30
|
+
currentPull = void 0;
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
};
|
|
34
|
+
const readable = new ReadableStream({
|
|
35
|
+
start(c) {
|
|
36
|
+
controller = c;
|
|
37
|
+
},
|
|
38
|
+
pull() {
|
|
39
|
+
currentPull = promiseWithResolvers();
|
|
40
|
+
list.forEach((item) => {
|
|
41
|
+
handlePull(item);
|
|
42
|
+
});
|
|
43
|
+
return currentPull.promise;
|
|
44
|
+
},
|
|
45
|
+
cancel() {
|
|
46
|
+
list.forEach((item) => {
|
|
47
|
+
item.reader.cancel();
|
|
48
|
+
});
|
|
49
|
+
list.length = 0;
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
return {
|
|
53
|
+
readable,
|
|
54
|
+
isSealed() {
|
|
55
|
+
return sealed;
|
|
56
|
+
},
|
|
57
|
+
seal() {
|
|
58
|
+
sealed = true;
|
|
59
|
+
if (list.length === 0) controller.close();
|
|
60
|
+
},
|
|
61
|
+
addStream(stream) {
|
|
62
|
+
if (sealed)
|
|
63
|
+
throw new Error(
|
|
64
|
+
"Cannot add streams after the run callback has settled."
|
|
65
|
+
);
|
|
66
|
+
const item = { reader: stream.getReader() };
|
|
67
|
+
list.push(item);
|
|
68
|
+
handlePull(item);
|
|
69
|
+
},
|
|
70
|
+
enqueue(chunk) {
|
|
71
|
+
this.addStream(
|
|
72
|
+
new ReadableStream({
|
|
73
|
+
start(c) {
|
|
74
|
+
c.enqueue(chunk);
|
|
75
|
+
c.close();
|
|
76
|
+
}
|
|
77
|
+
})
|
|
78
|
+
);
|
|
79
|
+
}
|
|
80
|
+
};
|
|
81
|
+
};
|
|
82
|
+
export {
|
|
83
|
+
createMergeStream
|
|
84
|
+
};
|
|
85
|
+
//# sourceMappingURL=merge.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/core/utils/stream/merge.ts"],"sourcesContent":["import { AssistantStreamChunk } from \"../../AssistantStreamChunk\";\nimport { promiseWithResolvers } from \"../../../utils/promiseWithResolvers\";\n\ntype MergeStreamItem = {\n reader: ReadableStreamDefaultReader<AssistantStreamChunk>;\n promise?: Promise<unknown> | undefined;\n};\n\nexport const createMergeStream = () => {\n const list: MergeStreamItem[] = [];\n let sealed = false;\n let controller: ReadableStreamDefaultController<AssistantStreamChunk>;\n let currentPull: ReturnType<typeof promiseWithResolvers<void>> | undefined;\n\n const handlePull = (item: MergeStreamItem) => {\n if (!item.promise) {\n // TODO for most streams, we can directly pipeTo to avoid the microTask queue\n // add an option to eagerly pipe the stream to the merge stream\n // ideally, using assitant-stream w sync run method + piping to a sync WritableStream runs in the same microtask\n // this is useful because we often use AssistantStreams internally as a serialization utility, e. g. AssistantTransformStream\n // idea: avoid reader.read() by instead using a WritableStream & if (!hasPendingPull) await waitForPull()?\n item.promise = item.reader\n .read()\n .then(({ done, value }) => {\n item.promise = undefined;\n if (done) {\n list.splice(list.indexOf(item), 1);\n if (sealed && list.length === 0) {\n controller.close();\n }\n } else {\n controller.enqueue(value);\n }\n\n currentPull?.resolve();\n currentPull = undefined;\n })\n .catch((e) => {\n console.error(e);\n\n list.forEach((item) => {\n item.reader.cancel();\n });\n list.length = 0;\n\n controller.error(e);\n\n currentPull?.reject(e);\n currentPull = undefined;\n });\n }\n };\n\n const readable = new ReadableStream<AssistantStreamChunk>({\n start(c) {\n controller = c;\n },\n pull() {\n currentPull = promiseWithResolvers();\n list.forEach((item) => {\n handlePull(item);\n });\n\n return currentPull.promise;\n },\n cancel() {\n list.forEach((item) => {\n item.reader.cancel();\n });\n list.length = 0;\n },\n });\n\n return {\n readable,\n isSealed() {\n return sealed;\n },\n seal() {\n sealed = true;\n if (list.length === 0) controller.close();\n },\n addStream(stream: ReadableStream<AssistantStreamChunk>) {\n if (sealed)\n throw new Error(\n \"Cannot add streams after the run callback has settled.\",\n );\n\n const item = { reader: stream.getReader() };\n list.push(item);\n handlePull(item);\n },\n enqueue(chunk: AssistantStreamChunk) {\n this.addStream(\n new ReadableStream({\n start(c) {\n c.enqueue(chunk);\n c.close();\n },\n }),\n );\n },\n };\n};\n\n// TODO\n// export class SpanContainerMerger {\n// public get isSealed() {\n// return this.mergeStream.isSealed();\n// }\n\n// public get readable() {\n// return this.mergeStream.readable;\n// }\n\n// private subAllocator = new Counter();\n// private mergeStream = createMergeStream();\n\n// constructor() {\n// // id 0 is auto allocated\n// this.subAllocator.up();\n// }\n\n// add(stream: ReadableStream<AssistantStreamChunk>) {\n// this.mergeStream.addStream(\n// stream.pipeThrough(new SpanParentEncoder(this.subAllocator)),\n// );\n// }\n\n// enqueue(chunk: AssistantStreamChunk & { parentId: 0 }) {\n// this.mergeStream.addStream(\n// new ReadableStream({\n// start(c) {\n// c.enqueue(chunk);\n// c.close();\n// },\n// }),\n// );\n// }\n\n// seal() {\n// this.mergeStream.seal();\n// }\n// }\n\n// export class SpanContainerSplitter {\n// public writable;\n\n// private isSealed = false;\n// private writers = new Map<\n// number,\n// WritableStreamDefaultWriter<AssistantStreamChunk>\n// >();\n\n// private closeTasks: Promise<void>[] = [];\n\n// private allocator = new Counter();\n// private subAllocator = new Counter();\n\n// constructor() {\n// // id 0 is auto-allocated\n// this.allocator.up();\n\n// this.writable = new WritableStream({\n// write: (chunk) => {\n// const { type, parentId } = chunk;\n\n// const writer = this.writers.get(parentId);\n// if (writer === undefined) throw new Error(\"Parent id not found\");\n\n// writer.write(chunk);\n\n// if (type === \"span\") {\n// // allocate a new span id\n// this.writers.set(this.allocator.up(), writer);\n// }\n// if (type === \"finish\") {\n// this.writers.delete(parentId);\n// writer.close();\n\n// if (this.writers.size === 0) {\n// const closeTask = this.writable.close();\n// this.closeTasks.push(closeTask);\n// closeTask.then(() => {\n// this.closeTasks.splice(this.closeTasks.indexOf(closeTask), 1);\n// });\n// }\n// }\n// },\n// close: async () => {\n// if (this.writers.size > 0) throw new Error(\"Not all writers closed\");\n\n// // await and throw on any errors\n// await Promise.all(this.closeTasks);\n// },\n// });\n// }\n\n// add(stream: WritableStream<AssistantStreamChunk>) {\n// if (this.isSealed) throw new Error(\"Cannot add streams after sealing\");\n\n// const decoder = new SpanParentDecoder(this.subAllocator);\n// decoder.readable.pipeTo(stream);\n\n// this.writers.set(this.allocator.up(), decoder.writable.getWriter());\n// }\n\n// seal() {\n// this.isSealed = true;\n// if (this.writers.size === 0) this.writable.close();\n// }\n// }\n"],"mappings":";AACA,SAAS,4BAA4B;AAO9B,IAAM,oBAAoB,MAAM;AACrC,QAAM,OAA0B,CAAC;AACjC,MAAI,SAAS;AACb,MAAI;AACJ,MAAI;AAEJ,QAAM,aAAa,CAAC,SAA0B;AAC5C,QAAI,CAAC,KAAK,SAAS;AAMjB,WAAK,UAAU,KAAK,OACjB,KAAK,EACL,KAAK,CAAC,EAAE,MAAM,MAAM,MAAM;AACzB,aAAK,UAAU;AACf,YAAI,MAAM;AACR,eAAK,OAAO,KAAK,QAAQ,IAAI,GAAG,CAAC;AACjC,cAAI,UAAU,KAAK,WAAW,GAAG;AAC/B,uBAAW,MAAM;AAAA,UACnB;AAAA,QACF,OAAO;AACL,qBAAW,QAAQ,KAAK;AAAA,QAC1B;AAEA,qBAAa,QAAQ;AACrB,sBAAc;AAAA,MAChB,CAAC,EACA,MAAM,CAAC,MAAM;AACZ,gBAAQ,MAAM,CAAC;AAEf,aAAK,QAAQ,CAACA,UAAS;AACrB,UAAAA,MAAK,OAAO,OAAO;AAAA,QACrB,CAAC;AACD,aAAK,SAAS;AAEd,mBAAW,MAAM,CAAC;AAElB,qBAAa,OAAO,CAAC;AACrB,sBAAc;AAAA,MAChB,CAAC;AAAA,IACL;AAAA,EACF;AAEA,QAAM,WAAW,IAAI,eAAqC;AAAA,IACxD,MAAM,GAAG;AACP,mBAAa;AAAA,IACf;AAAA,IACA,OAAO;AACL,oBAAc,qBAAqB;AACnC,WAAK,QAAQ,CAAC,SAAS;AACrB,mBAAW,IAAI;AAAA,MACjB,CAAC;AAED,aAAO,YAAY;AAAA,IACrB;AAAA,IACA,SAAS;AACP,WAAK,QAAQ,CAAC,SAAS;AACrB,aAAK,OAAO,OAAO;AAAA,MACrB,CAAC;AACD,WAAK,SAAS;AAAA,IAChB;AAAA,EACF,CAAC;AAED,SAAO;AAAA,IACL;AAAA,IACA,WAAW;AACT,aAAO;AAAA,IACT;AAAA,IACA,OAAO;AACL,eAAS;AACT,UAAI,KAAK,WAAW,EAAG,YAAW,MAAM;AAAA,IAC1C;AAAA,IACA,UAAU,QAA8C;AACtD,UAAI;AACF,cAAM,IAAI;AAAA,UACR;AAAA,QACF;AAEF,YAAM,OAAO,EAAE,QAAQ,OAAO,UAAU,EAAE;AAC1C,WAAK,KAAK,IAAI;AACd,iBAAW,IAAI;AAAA,IACjB;AAAA,IACA,QAAQ,OAA6B;AACnC,WAAK;AAAA,QACH,IAAI,eAAe;AAAA,UACjB,MAAM,GAAG;AACP,cAAE,QAAQ,KAAK;AACf,cAAE,MAAM;AAAA,UACV;AAAA,QACF,CAAC;AAAA,MACH;AAAA,IACF;AAAA,EACF;AACF;","names":["item"]}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { AssistantStreamChunk } from "../../AssistantStreamChunk";
|
|
2
|
+
import { Counter } from "../Counter";
|
|
3
|
+
export declare class PathAppendEncoder extends TransformStream<AssistantStreamChunk, AssistantStreamChunk> {
|
|
4
|
+
constructor(idx: number);
|
|
5
|
+
}
|
|
6
|
+
export declare class PathAppendDecoder extends TransformStream<AssistantStreamChunk, AssistantStreamChunk> {
|
|
7
|
+
constructor(idx: number);
|
|
8
|
+
}
|
|
9
|
+
export declare class PathMergeEncoder extends TransformStream<AssistantStreamChunk, AssistantStreamChunk> {
|
|
10
|
+
constructor(counter: Counter);
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=path-utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"path-utils.d.ts","sourceRoot":"","sources":["../../../../src/core/utils/stream/path-utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,4BAA4B,CAAC;AAClE,OAAO,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AAErC,qBAAa,iBAAkB,SAAQ,eAAe,CACpD,oBAAoB,EACpB,oBAAoB,CACrB;gBACa,GAAG,EAAE,MAAM;CAUxB;AAED,qBAAa,iBAAkB,SAAQ,eAAe,CACpD,oBAAoB,EACpB,oBAAoB,CACrB;gBACa,GAAG,EAAE,MAAM;CAiBxB;AAED,qBAAa,gBAAiB,SAAQ,eAAe,CACnD,oBAAoB,EACpB,oBAAoB,CACrB;gBACa,OAAO,EAAE,OAAO;CAwB7B"}
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
|
|
20
|
+
// src/core/utils/stream/path-utils.ts
|
|
21
|
+
var path_utils_exports = {};
|
|
22
|
+
__export(path_utils_exports, {
|
|
23
|
+
PathAppendDecoder: () => PathAppendDecoder,
|
|
24
|
+
PathAppendEncoder: () => PathAppendEncoder,
|
|
25
|
+
PathMergeEncoder: () => PathMergeEncoder
|
|
26
|
+
});
|
|
27
|
+
module.exports = __toCommonJS(path_utils_exports);
|
|
28
|
+
var import_Counter = require("../Counter.js");
|
|
29
|
+
var PathAppendEncoder = class extends TransformStream {
|
|
30
|
+
constructor(idx) {
|
|
31
|
+
super({
|
|
32
|
+
transform(chunk, controller) {
|
|
33
|
+
controller.enqueue({
|
|
34
|
+
...chunk,
|
|
35
|
+
path: [idx, ...chunk.path]
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
};
|
|
41
|
+
var PathAppendDecoder = class extends TransformStream {
|
|
42
|
+
constructor(idx) {
|
|
43
|
+
super({
|
|
44
|
+
transform(chunk, controller) {
|
|
45
|
+
const {
|
|
46
|
+
path: [idx2, ...path]
|
|
47
|
+
} = chunk;
|
|
48
|
+
if (idx !== idx2)
|
|
49
|
+
throw new Error(`Path mismatch: expected ${idx}, got ${idx2}`);
|
|
50
|
+
controller.enqueue({
|
|
51
|
+
...chunk,
|
|
52
|
+
path
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
};
|
|
58
|
+
var PathMergeEncoder = class extends TransformStream {
|
|
59
|
+
constructor(counter) {
|
|
60
|
+
const innerCounter = new import_Counter.Counter();
|
|
61
|
+
const mapping = /* @__PURE__ */ new Map();
|
|
62
|
+
super({
|
|
63
|
+
transform(chunk, controller) {
|
|
64
|
+
if (chunk.type === "part-start" && chunk.path.length === 0) {
|
|
65
|
+
mapping.set(innerCounter.up(), counter.up());
|
|
66
|
+
}
|
|
67
|
+
const [idx, ...path] = chunk.path;
|
|
68
|
+
if (idx === void 0) {
|
|
69
|
+
controller.enqueue(chunk);
|
|
70
|
+
return;
|
|
71
|
+
}
|
|
72
|
+
const mappedIdx = mapping.get(idx);
|
|
73
|
+
if (mappedIdx === void 0) throw new Error("Path not found");
|
|
74
|
+
controller.enqueue({
|
|
75
|
+
...chunk,
|
|
76
|
+
path: [mappedIdx, ...path]
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
};
|
|
82
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
83
|
+
0 && (module.exports = {
|
|
84
|
+
PathAppendDecoder,
|
|
85
|
+
PathAppendEncoder,
|
|
86
|
+
PathMergeEncoder
|
|
87
|
+
});
|
|
88
|
+
//# sourceMappingURL=path-utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/core/utils/stream/path-utils.ts"],"sourcesContent":["import { AssistantStreamChunk } from \"../../AssistantStreamChunk\";\nimport { Counter } from \"../Counter\";\n\nexport class PathAppendEncoder extends TransformStream<\n AssistantStreamChunk,\n AssistantStreamChunk\n> {\n constructor(idx: number) {\n super({\n transform(chunk, controller) {\n controller.enqueue({\n ...chunk,\n path: [idx, ...chunk.path],\n });\n },\n });\n }\n}\n\nexport class PathAppendDecoder extends TransformStream<\n AssistantStreamChunk,\n AssistantStreamChunk\n> {\n constructor(idx: number) {\n super({\n transform(chunk, controller) {\n const {\n path: [idx2, ...path],\n } = chunk;\n\n if (idx !== idx2)\n throw new Error(`Path mismatch: expected ${idx}, got ${idx2}`);\n\n controller.enqueue({\n ...chunk,\n path,\n });\n },\n });\n }\n}\n\nexport class PathMergeEncoder extends TransformStream<\n AssistantStreamChunk,\n AssistantStreamChunk\n> {\n constructor(counter: Counter) {\n const innerCounter = new Counter();\n const mapping = new Map<number, number>();\n super({\n transform(chunk, controller) {\n if (chunk.type === \"part-start\" && chunk.path.length === 0) {\n mapping.set(innerCounter.up(), counter.up());\n }\n\n const [idx, ...path] = chunk.path;\n if (idx === undefined) {\n controller.enqueue(chunk);\n return;\n }\n const mappedIdx = mapping.get(idx);\n if (mappedIdx === undefined) throw new Error(\"Path not found\");\n\n controller.enqueue({\n ...chunk,\n path: [mappedIdx, ...path],\n });\n },\n });\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,qBAAwB;AAEjB,IAAM,oBAAN,cAAgC,gBAGrC;AAAA,EACA,YAAY,KAAa;AACvB,UAAM;AAAA,MACJ,UAAU,OAAO,YAAY;AAC3B,mBAAW,QAAQ;AAAA,UACjB,GAAG;AAAA,UACH,MAAM,CAAC,KAAK,GAAG,MAAM,IAAI;AAAA,QAC3B,CAAC;AAAA,MACH;AAAA,IACF,CAAC;AAAA,EACH;AACF;AAEO,IAAM,oBAAN,cAAgC,gBAGrC;AAAA,EACA,YAAY,KAAa;AACvB,UAAM;AAAA,MACJ,UAAU,OAAO,YAAY;AAC3B,cAAM;AAAA,UACJ,MAAM,CAAC,MAAM,GAAG,IAAI;AAAA,QACtB,IAAI;AAEJ,YAAI,QAAQ;AACV,gBAAM,IAAI,MAAM,2BAA2B,GAAG,SAAS,IAAI,EAAE;AAE/D,mBAAW,QAAQ;AAAA,UACjB,GAAG;AAAA,UACH;AAAA,QACF,CAAC;AAAA,MACH;AAAA,IACF,CAAC;AAAA,EACH;AACF;AAEO,IAAM,mBAAN,cAA+B,gBAGpC;AAAA,EACA,YAAY,SAAkB;AAC5B,UAAM,eAAe,IAAI,uBAAQ;AACjC,UAAM,UAAU,oBAAI,IAAoB;AACxC,UAAM;AAAA,MACJ,UAAU,OAAO,YAAY;AAC3B,YAAI,MAAM,SAAS,gBAAgB,MAAM,KAAK,WAAW,GAAG;AAC1D,kBAAQ,IAAI,aAAa,GAAG,GAAG,QAAQ,GAAG,CAAC;AAAA,QAC7C;AAEA,cAAM,CAAC,KAAK,GAAG,IAAI,IAAI,MAAM;AAC7B,YAAI,QAAQ,QAAW;AACrB,qBAAW,QAAQ,KAAK;AACxB;AAAA,QACF;AACA,cAAM,YAAY,QAAQ,IAAI,GAAG;AACjC,YAAI,cAAc,OAAW,OAAM,IAAI,MAAM,gBAAgB;AAE7D,mBAAW,QAAQ;AAAA,UACjB,GAAG;AAAA,UACH,MAAM,CAAC,WAAW,GAAG,IAAI;AAAA,QAC3B,CAAC;AAAA,MACH;AAAA,IACF,CAAC;AAAA,EACH;AACF;","names":[]}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
// src/core/utils/stream/path-utils.ts
|
|
2
|
+
import { Counter } from "../Counter.mjs";
|
|
3
|
+
var PathAppendEncoder = class extends TransformStream {
|
|
4
|
+
constructor(idx) {
|
|
5
|
+
super({
|
|
6
|
+
transform(chunk, controller) {
|
|
7
|
+
controller.enqueue({
|
|
8
|
+
...chunk,
|
|
9
|
+
path: [idx, ...chunk.path]
|
|
10
|
+
});
|
|
11
|
+
}
|
|
12
|
+
});
|
|
13
|
+
}
|
|
14
|
+
};
|
|
15
|
+
var PathAppendDecoder = class extends TransformStream {
|
|
16
|
+
constructor(idx) {
|
|
17
|
+
super({
|
|
18
|
+
transform(chunk, controller) {
|
|
19
|
+
const {
|
|
20
|
+
path: [idx2, ...path]
|
|
21
|
+
} = chunk;
|
|
22
|
+
if (idx !== idx2)
|
|
23
|
+
throw new Error(`Path mismatch: expected ${idx}, got ${idx2}`);
|
|
24
|
+
controller.enqueue({
|
|
25
|
+
...chunk,
|
|
26
|
+
path
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
var PathMergeEncoder = class extends TransformStream {
|
|
33
|
+
constructor(counter) {
|
|
34
|
+
const innerCounter = new Counter();
|
|
35
|
+
const mapping = /* @__PURE__ */ new Map();
|
|
36
|
+
super({
|
|
37
|
+
transform(chunk, controller) {
|
|
38
|
+
if (chunk.type === "part-start" && chunk.path.length === 0) {
|
|
39
|
+
mapping.set(innerCounter.up(), counter.up());
|
|
40
|
+
}
|
|
41
|
+
const [idx, ...path] = chunk.path;
|
|
42
|
+
if (idx === void 0) {
|
|
43
|
+
controller.enqueue(chunk);
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
const mappedIdx = mapping.get(idx);
|
|
47
|
+
if (mappedIdx === void 0) throw new Error("Path not found");
|
|
48
|
+
controller.enqueue({
|
|
49
|
+
...chunk,
|
|
50
|
+
path: [mappedIdx, ...path]
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
};
|
|
56
|
+
export {
|
|
57
|
+
PathAppendDecoder,
|
|
58
|
+
PathAppendEncoder,
|
|
59
|
+
PathMergeEncoder
|
|
60
|
+
};
|
|
61
|
+
//# sourceMappingURL=path-utils.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/core/utils/stream/path-utils.ts"],"sourcesContent":["import { AssistantStreamChunk } from \"../../AssistantStreamChunk\";\nimport { Counter } from \"../Counter\";\n\nexport class PathAppendEncoder extends TransformStream<\n AssistantStreamChunk,\n AssistantStreamChunk\n> {\n constructor(idx: number) {\n super({\n transform(chunk, controller) {\n controller.enqueue({\n ...chunk,\n path: [idx, ...chunk.path],\n });\n },\n });\n }\n}\n\nexport class PathAppendDecoder extends TransformStream<\n AssistantStreamChunk,\n AssistantStreamChunk\n> {\n constructor(idx: number) {\n super({\n transform(chunk, controller) {\n const {\n path: [idx2, ...path],\n } = chunk;\n\n if (idx !== idx2)\n throw new Error(`Path mismatch: expected ${idx}, got ${idx2}`);\n\n controller.enqueue({\n ...chunk,\n path,\n });\n },\n });\n }\n}\n\nexport class PathMergeEncoder extends TransformStream<\n AssistantStreamChunk,\n AssistantStreamChunk\n> {\n constructor(counter: Counter) {\n const innerCounter = new Counter();\n const mapping = new Map<number, number>();\n super({\n transform(chunk, controller) {\n if (chunk.type === \"part-start\" && chunk.path.length === 0) {\n mapping.set(innerCounter.up(), counter.up());\n }\n\n const [idx, ...path] = chunk.path;\n if (idx === undefined) {\n controller.enqueue(chunk);\n return;\n }\n const mappedIdx = mapping.get(idx);\n if (mappedIdx === undefined) throw new Error(\"Path not found\");\n\n controller.enqueue({\n ...chunk,\n path: [mappedIdx, ...path],\n });\n },\n });\n }\n}\n"],"mappings":";AACA,SAAS,eAAe;AAEjB,IAAM,oBAAN,cAAgC,gBAGrC;AAAA,EACA,YAAY,KAAa;AACvB,UAAM;AAAA,MACJ,UAAU,OAAO,YAAY;AAC3B,mBAAW,QAAQ;AAAA,UACjB,GAAG;AAAA,UACH,MAAM,CAAC,KAAK,GAAG,MAAM,IAAI;AAAA,QAC3B,CAAC;AAAA,MACH;AAAA,IACF,CAAC;AAAA,EACH;AACF;AAEO,IAAM,oBAAN,cAAgC,gBAGrC;AAAA,EACA,YAAY,KAAa;AACvB,UAAM;AAAA,MACJ,UAAU,OAAO,YAAY;AAC3B,cAAM;AAAA,UACJ,MAAM,CAAC,MAAM,GAAG,IAAI;AAAA,QACtB,IAAI;AAEJ,YAAI,QAAQ;AACV,gBAAM,IAAI,MAAM,2BAA2B,GAAG,SAAS,IAAI,EAAE;AAE/D,mBAAW,QAAQ;AAAA,UACjB,GAAG;AAAA,UACH;AAAA,QACF,CAAC;AAAA,MACH;AAAA,IACF,CAAC;AAAA,EACH;AACF;AAEO,IAAM,mBAAN,cAA+B,gBAGpC;AAAA,EACA,YAAY,SAAkB;AAC5B,UAAM,eAAe,IAAI,QAAQ;AACjC,UAAM,UAAU,oBAAI,IAAoB;AACxC,UAAM;AAAA,MACJ,UAAU,OAAO,YAAY;AAC3B,YAAI,MAAM,SAAS,gBAAgB,MAAM,KAAK,WAAW,GAAG;AAC1D,kBAAQ,IAAI,aAAa,GAAG,GAAG,QAAQ,GAAG,CAAC;AAAA,QAC7C;AAEA,cAAM,CAAC,KAAK,GAAG,IAAI,IAAI,MAAM;AAC7B,YAAI,QAAQ,QAAW;AACrB,qBAAW,QAAQ,KAAK;AACxB;AAAA,QACF;AACA,cAAM,YAAY,QAAQ,IAAI,GAAG;AACjC,YAAI,cAAc,OAAW,OAAM,IAAI,MAAM,gBAAgB;AAE7D,mBAAW,QAAQ;AAAA,UACjB,GAAG;AAAA,UACH,MAAM,CAAC,WAAW,GAAG,IAAI;AAAA,QAC3B,CAAC;AAAA,MACH;AAAA,IACF,CAAC;AAAA,EACH;AACF;","names":[]}
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
import { ReadonlyJSONObject, ReadonlyJSONValue } from "../../utils/json/json-value";
|
|
2
|
+
type TextStatus = {
|
|
3
|
+
type: "running";
|
|
4
|
+
} | {
|
|
5
|
+
type: "complete";
|
|
6
|
+
reason: "stop" | "unknown";
|
|
7
|
+
} | {
|
|
8
|
+
type: "incomplete";
|
|
9
|
+
reason: "cancelled" | "length" | "content-filter" | "other";
|
|
10
|
+
};
|
|
11
|
+
export type TextPart = {
|
|
12
|
+
type: "text";
|
|
13
|
+
text: string;
|
|
14
|
+
status: TextStatus;
|
|
15
|
+
};
|
|
16
|
+
export type ReasoningPart = {
|
|
17
|
+
type: "reasoning";
|
|
18
|
+
text: string;
|
|
19
|
+
status: TextStatus;
|
|
20
|
+
};
|
|
21
|
+
type ToolCallStatus = {
|
|
22
|
+
type: "running";
|
|
23
|
+
isArgsComplete: boolean;
|
|
24
|
+
} | {
|
|
25
|
+
type: "requires-action";
|
|
26
|
+
reason: "tool-call-result";
|
|
27
|
+
} | {
|
|
28
|
+
type: "complete";
|
|
29
|
+
reason: "stop" | "unknown";
|
|
30
|
+
} | {
|
|
31
|
+
type: "incomplete";
|
|
32
|
+
reason: "cancelled" | "length" | "content-filter" | "other";
|
|
33
|
+
};
|
|
34
|
+
export type ToolCallPart = {
|
|
35
|
+
type: "tool-call";
|
|
36
|
+
state: "partial-call" | "call" | "result";
|
|
37
|
+
status: ToolCallStatus;
|
|
38
|
+
toolCallId: string;
|
|
39
|
+
toolName: string;
|
|
40
|
+
argsText: string;
|
|
41
|
+
args: ReadonlyJSONObject;
|
|
42
|
+
artifact?: unknown;
|
|
43
|
+
result?: ReadonlyJSONValue;
|
|
44
|
+
isError?: boolean;
|
|
45
|
+
};
|
|
46
|
+
export type SourcePart = {
|
|
47
|
+
type: "source";
|
|
48
|
+
sourceType: "url";
|
|
49
|
+
id: string;
|
|
50
|
+
url: string;
|
|
51
|
+
title?: string;
|
|
52
|
+
};
|
|
53
|
+
export type FilePart = {
|
|
54
|
+
type: "file";
|
|
55
|
+
data: string;
|
|
56
|
+
mimeType: string;
|
|
57
|
+
};
|
|
58
|
+
export type AssistantMessagePart = TextPart | ReasoningPart | ToolCallPart | SourcePart | FilePart;
|
|
59
|
+
type AssistantMessageStepUsage = {
|
|
60
|
+
promptTokens: number;
|
|
61
|
+
completionTokens: number;
|
|
62
|
+
};
|
|
63
|
+
type AssistantMessageStepMetadata = {
|
|
64
|
+
state: "started";
|
|
65
|
+
messageId: string;
|
|
66
|
+
} | {
|
|
67
|
+
state: "finished";
|
|
68
|
+
messageId: string;
|
|
69
|
+
finishReason: "stop" | "length" | "content-filter" | "tool-calls" | "error" | "other" | "unknown";
|
|
70
|
+
usage?: AssistantMessageStepUsage;
|
|
71
|
+
isContinued: boolean;
|
|
72
|
+
};
|
|
73
|
+
export type AssistantMessageStatus = {
|
|
74
|
+
type: "running";
|
|
75
|
+
} | {
|
|
76
|
+
type: "requires-action";
|
|
77
|
+
reason: "tool-calls";
|
|
78
|
+
} | {
|
|
79
|
+
type: "complete";
|
|
80
|
+
reason: "stop" | "unknown";
|
|
81
|
+
} | {
|
|
82
|
+
type: "incomplete";
|
|
83
|
+
reason: "cancelled" | "tool-calls" | "length" | "content-filter" | "other" | "error";
|
|
84
|
+
error?: ReadonlyJSONValue;
|
|
85
|
+
};
|
|
86
|
+
export type AssistantMessage = {
|
|
87
|
+
role: "assistant";
|
|
88
|
+
status: AssistantMessageStatus;
|
|
89
|
+
parts: AssistantMessagePart[];
|
|
90
|
+
/**
|
|
91
|
+
* @deprecated Use `parts` instead.
|
|
92
|
+
*/
|
|
93
|
+
content: AssistantMessagePart[];
|
|
94
|
+
metadata: {
|
|
95
|
+
unstable_data: ReadonlyJSONValue[];
|
|
96
|
+
unstable_annotations: ReadonlyJSONValue[];
|
|
97
|
+
steps: AssistantMessageStepMetadata[];
|
|
98
|
+
custom: Record<string, unknown>;
|
|
99
|
+
};
|
|
100
|
+
};
|
|
101
|
+
export {};
|
|
102
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/core/utils/types.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __copyProps = (to, from, except, desc) => {
|
|
7
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
8
|
+
for (let key of __getOwnPropNames(from))
|
|
9
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
10
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
11
|
+
}
|
|
12
|
+
return to;
|
|
13
|
+
};
|
|
14
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
15
|
+
|
|
16
|
+
// src/core/utils/types.ts
|
|
17
|
+
var types_exports = {};
|
|
18
|
+
module.exports = __toCommonJS(types_exports);
|
|
19
|
+
//# sourceMappingURL=types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/core/utils/types.ts"],"sourcesContent":["import {\n ReadonlyJSONObject,\n ReadonlyJSONValue,\n} from \"../../utils/json/json-value\";\n\ntype TextStatus =\n | {\n type: \"running\";\n }\n | {\n type: \"complete\";\n reason: \"stop\" | \"unknown\";\n }\n | {\n type: \"incomplete\";\n reason: \"cancelled\" | \"length\" | \"content-filter\" | \"other\";\n };\n\n// export type StepStartPart = {\n// type: \"step-start\";\n// };\n\nexport type TextPart = {\n type: \"text\";\n text: string;\n status: TextStatus;\n};\n\nexport type ReasoningPart = {\n type: \"reasoning\";\n text: string;\n status: TextStatus;\n};\n\ntype ToolCallStatus =\n | {\n type: \"running\";\n isArgsComplete: boolean;\n }\n | {\n type: \"requires-action\";\n reason: \"tool-call-result\";\n }\n | {\n type: \"complete\";\n reason: \"stop\" | \"unknown\";\n }\n | {\n type: \"incomplete\";\n reason: \"cancelled\" | \"length\" | \"content-filter\" | \"other\";\n };\n\nexport type ToolCallPart = {\n type: \"tool-call\";\n state: \"partial-call\" | \"call\" | \"result\";\n status: ToolCallStatus;\n toolCallId: string;\n toolName: string;\n argsText: string;\n args: ReadonlyJSONObject;\n artifact?: unknown;\n result?: ReadonlyJSONValue;\n isError?: boolean;\n};\n\nexport type SourcePart = {\n type: \"source\";\n sourceType: \"url\";\n id: string;\n url: string;\n title?: string;\n};\n\nexport type FilePart = {\n type: \"file\";\n data: string;\n mimeType: string;\n};\n\nexport type AssistantMessagePart =\n | TextPart\n | ReasoningPart\n | ToolCallPart\n | SourcePart\n | FilePart;\n\ntype AssistantMessageStepUsage = {\n promptTokens: number;\n completionTokens: number;\n};\n\ntype AssistantMessageStepMetadata =\n | {\n state: \"started\";\n messageId: string;\n }\n | {\n state: \"finished\";\n messageId: string;\n finishReason:\n | \"stop\"\n | \"length\"\n | \"content-filter\"\n | \"tool-calls\"\n | \"error\"\n | \"other\"\n | \"unknown\";\n usage?: AssistantMessageStepUsage;\n isContinued: boolean;\n };\n\nexport type AssistantMessageStatus =\n | {\n type: \"running\";\n }\n | {\n type: \"requires-action\";\n reason: \"tool-calls\";\n }\n | {\n type: \"complete\";\n reason: \"stop\" | \"unknown\";\n }\n | {\n type: \"incomplete\";\n reason:\n | \"cancelled\"\n | \"tool-calls\"\n | \"length\"\n | \"content-filter\"\n | \"other\"\n | \"error\";\n error?: ReadonlyJSONValue;\n };\n\nexport type AssistantMessage = {\n role: \"assistant\";\n status: AssistantMessageStatus;\n parts: AssistantMessagePart[];\n /**\n * @deprecated Use `parts` instead.\n */\n content: AssistantMessagePart[];\n metadata: {\n unstable_data: ReadonlyJSONValue[];\n unstable_annotations: ReadonlyJSONValue[];\n steps: AssistantMessageStepMetadata[];\n custom: Record<string, unknown>;\n };\n};\n"],"mappings":";;;;;;;;;;;;;;;;AAAA;AAAA;","names":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
//# sourceMappingURL=types.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"withPromiseOrValue.d.ts","sourceRoot":"","sources":["../../../src/core/utils/withPromiseOrValue.ts"],"names":[],"mappings":"AAAA,wBAAgB,kBAAkB,CAAC,CAAC,EAClC,QAAQ,EAAE,MAAM,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC,EAClC,WAAW,EAAE,CAAC,KAAK,EAAE,CAAC,KAAK,WAAW,CAAC,IAAI,CAAC,GAAG,IAAI,EACnD,YAAY,EAAE,CAAC,KAAK,EAAE,OAAO,KAAK,WAAW,CAAC,IAAI,CAAC,GAAG,IAAI,GACzD,WAAW,CAAC,IAAI,CAAC,GAAG,IAAI,CAe1B"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
|
|
20
|
+
// src/core/utils/withPromiseOrValue.ts
|
|
21
|
+
var withPromiseOrValue_exports = {};
|
|
22
|
+
__export(withPromiseOrValue_exports, {
|
|
23
|
+
withPromiseOrValue: () => withPromiseOrValue
|
|
24
|
+
});
|
|
25
|
+
module.exports = __toCommonJS(withPromiseOrValue_exports);
|
|
26
|
+
function withPromiseOrValue(callback, thenHandler, catchHandler) {
|
|
27
|
+
try {
|
|
28
|
+
const promiseOrValue = callback();
|
|
29
|
+
if (typeof promiseOrValue === "object" && promiseOrValue !== null && "then" in promiseOrValue) {
|
|
30
|
+
return promiseOrValue.then(thenHandler, catchHandler);
|
|
31
|
+
} else {
|
|
32
|
+
thenHandler(promiseOrValue);
|
|
33
|
+
}
|
|
34
|
+
} catch (e) {
|
|
35
|
+
catchHandler(e);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
39
|
+
0 && (module.exports = {
|
|
40
|
+
withPromiseOrValue
|
|
41
|
+
});
|
|
42
|
+
//# sourceMappingURL=withPromiseOrValue.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/core/utils/withPromiseOrValue.ts"],"sourcesContent":["export function withPromiseOrValue<T>(\n callback: () => T | PromiseLike<T>,\n thenHandler: (value: T) => PromiseLike<void> | void,\n catchHandler: (error: unknown) => PromiseLike<void> | void,\n): PromiseLike<void> | void {\n try {\n const promiseOrValue = callback();\n if (\n typeof promiseOrValue === \"object\" &&\n promiseOrValue !== null &&\n \"then\" in promiseOrValue\n ) {\n return promiseOrValue.then(thenHandler, catchHandler);\n } else {\n thenHandler(promiseOrValue);\n }\n } catch (e) {\n catchHandler(e);\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAAS,mBACd,UACA,aACA,cAC0B;AAC1B,MAAI;AACF,UAAM,iBAAiB,SAAS;AAChC,QACE,OAAO,mBAAmB,YAC1B,mBAAmB,QACnB,UAAU,gBACV;AACA,aAAO,eAAe,KAAK,aAAa,YAAY;AAAA,IACtD,OAAO;AACL,kBAAY,cAAc;AAAA,IAC5B;AAAA,EACF,SAAS,GAAG;AACV,iBAAa,CAAC;AAAA,EAChB;AACF;","names":[]}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
// src/core/utils/withPromiseOrValue.ts
|
|
2
|
+
function withPromiseOrValue(callback, thenHandler, catchHandler) {
|
|
3
|
+
try {
|
|
4
|
+
const promiseOrValue = callback();
|
|
5
|
+
if (typeof promiseOrValue === "object" && promiseOrValue !== null && "then" in promiseOrValue) {
|
|
6
|
+
return promiseOrValue.then(thenHandler, catchHandler);
|
|
7
|
+
} else {
|
|
8
|
+
thenHandler(promiseOrValue);
|
|
9
|
+
}
|
|
10
|
+
} catch (e) {
|
|
11
|
+
catchHandler(e);
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
export {
|
|
15
|
+
withPromiseOrValue
|
|
16
|
+
};
|
|
17
|
+
//# sourceMappingURL=withPromiseOrValue.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/core/utils/withPromiseOrValue.ts"],"sourcesContent":["export function withPromiseOrValue<T>(\n callback: () => T | PromiseLike<T>,\n thenHandler: (value: T) => PromiseLike<void> | void,\n catchHandler: (error: unknown) => PromiseLike<void> | void,\n): PromiseLike<void> | void {\n try {\n const promiseOrValue = callback();\n if (\n typeof promiseOrValue === \"object\" &&\n promiseOrValue !== null &&\n \"then\" in promiseOrValue\n ) {\n return promiseOrValue.then(thenHandler, catchHandler);\n } else {\n thenHandler(promiseOrValue);\n }\n } catch (e) {\n catchHandler(e);\n }\n}\n"],"mappings":";AAAO,SAAS,mBACd,UACA,aACA,cAC0B;AAC1B,MAAI;AACF,UAAM,iBAAiB,SAAS;AAChC,QACE,OAAO,mBAAmB,YAC1B,mBAAmB,QACnB,UAAU,gBACV;AACA,aAAO,eAAe,KAAK,aAAa,YAAY;AAAA,IACtD,OAAO;AACL,kBAAY,cAAc;AAAA,IAC5B;AAAA,EACF,SAAS,GAAG;AACV,iBAAa,CAAC;AAAA,EAChB;AACF;","names":[]}
|