@xsai/generate-text 0.5.0-beta.2 → 0.5.0-beta.4

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/index.d.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  import { WithUnknown } from '@xsai/shared';
2
- import { ChatOptions, CompletionStep, PrepareStep, StopCondition, FinishReason, AssistantMessage, Usage, Message, CompletionToolCall, CompletionToolResult } from '@xsai/shared-chat';
2
+ import { ChatOptions, CompletionStep, PrepareStep, StopCondition, Message, Usage, FinishReason, AssistantMessage, ChatCompletionUsage, CompletionToolCall, CompletionToolResult } from '@xsai/shared-chat';
3
3
 
4
4
  interface GenerateTextOptions extends ChatOptions {
5
5
  onStepFinish?: (step: CompletionStep<true>) => Promise<unknown> | unknown;
@@ -7,9 +7,11 @@ interface GenerateTextOptions extends ChatOptions {
7
7
  /** @internal */
8
8
  steps?: CompletionStep<true>[];
9
9
  /** @default `stepCountAtLeast(1)` */
10
- stopWhen?: StopCondition;
10
+ stopWhen?: StopCondition<Message>;
11
11
  /** if you want to enable stream, use `@xsai/stream-{text,object}` */
12
12
  stream?: never;
13
+ /** @internal */
14
+ totalUsage?: Usage;
13
15
  }
14
16
  interface GenerateTextResponse {
15
17
  choices: {
@@ -23,7 +25,7 @@ interface GenerateTextResponse {
23
25
  model: string;
24
26
  object: 'chat.completion';
25
27
  system_fingerprint: string;
26
- usage: Usage;
28
+ usage: ChatCompletionUsage;
27
29
  }
28
30
  interface GenerateTextResult {
29
31
  finishReason: FinishReason;
@@ -33,6 +35,7 @@ interface GenerateTextResult {
33
35
  text?: string;
34
36
  toolCalls: CompletionToolCall[];
35
37
  toolResults: CompletionToolResult[];
38
+ totalUsage: Usage;
36
39
  usage: Usage;
37
40
  }
38
41
  declare const generateText: (options: WithUnknown<GenerateTextOptions>) => Promise<GenerateTextResult>;
package/dist/index.js CHANGED
@@ -1,11 +1,11 @@
1
1
  import { trampoline, responseJSON, InvalidResponseError } from '@xsai/shared';
2
- import { resolveStepOptions, chat, stepCountAtLeast, executeTool, shouldStop, determineStepType } from '@xsai/shared-chat';
2
+ import { resolvePrepareStep, chat, normalizeChatCompletionUsage, computeTotalUsage, stepCountAtLeast, executeTool, shouldStop } from '@xsai/shared-chat';
3
3
 
4
4
  const rawGenerateText = async (options) => {
5
5
  const messages = options.steps == null ? structuredClone(options.messages) : options.messages;
6
6
  const steps = options.steps ?? [];
7
- const stepOptions = await resolveStepOptions({
8
- messages,
7
+ const stepOptions = await resolvePrepareStep({
8
+ input: messages,
9
9
  model: options.model,
10
10
  prepareStep: options.prepareStep,
11
11
  stepNumber: steps.length,
@@ -14,15 +14,16 @@ const rawGenerateText = async (options) => {
14
14
  });
15
15
  return chat({
16
16
  ...options,
17
- maxSteps: void 0,
18
- messages: stepOptions.messages,
17
+ messages: stepOptions.input,
19
18
  model: stepOptions.model,
20
19
  steps: void 0,
21
- stopWhen: void 0,
22
20
  stream: false,
23
- toolChoice: stepOptions.toolChoice
21
+ toolChoice: stepOptions.toolChoice,
22
+ totalUsage: void 0
24
23
  }).then(responseJSON).then(async (res) => {
25
- const { choices, usage } = res;
24
+ const { choices } = res;
25
+ const usage = normalizeChatCompletionUsage(res.usage);
26
+ const totalUsage = computeTotalUsage(options.totalUsage, usage);
26
27
  if (!choices?.length) {
27
28
  const responseBody = JSON.stringify(res);
28
29
  throw new InvalidResponseError(`No choices returned, response body: ${responseBody}`, {
@@ -45,13 +46,17 @@ const rawGenerateText = async (options) => {
45
46
  tools: options.tools
46
47
  }))
47
48
  );
48
- for (const { completionToolCall, completionToolResult, message: message2 } of results) {
49
+ for (const { completionToolCall, completionToolResult, result } of results) {
49
50
  toolCalls.push(completionToolCall);
50
51
  toolResults.push(completionToolResult);
51
- messages.push(message2);
52
+ messages.push({
53
+ content: result,
54
+ role: "tool",
55
+ tool_call_id: completionToolCall.toolCallId
56
+ });
52
57
  }
53
58
  }
54
- const stopStep = {
59
+ const step = {
55
60
  finishReason,
56
61
  text: Array.isArray(message.content) ? message.content.filter((m) => m.type === "text").map((m) => m.text).join("\n") : message.content,
57
62
  toolCalls,
@@ -59,20 +64,11 @@ const rawGenerateText = async (options) => {
59
64
  usage
60
65
  };
61
66
  const stop = shouldStop(stopWhen, {
62
- messages,
63
- step: stopStep,
64
- steps: [...steps, stopStep]
67
+ input: messages,
68
+ step,
69
+ steps: [...steps, step]
65
70
  });
66
71
  const willContinue = toolCalls.length > 0 && !stop;
67
- const step = {
68
- ...stopStep,
69
- stepType: determineStepType({
70
- finishReason,
71
- stepsLength: steps.length,
72
- toolCallsLength: toolCalls.length,
73
- willContinue
74
- })
75
- };
76
72
  steps.push(step);
77
73
  if (options.onStepFinish)
78
74
  await options.onStepFinish(step);
@@ -85,13 +81,15 @@ const rawGenerateText = async (options) => {
85
81
  text: step.text,
86
82
  toolCalls: step.toolCalls,
87
83
  toolResults: step.toolResults,
84
+ totalUsage,
88
85
  usage: step.usage
89
86
  };
90
87
  } else {
91
88
  return async () => rawGenerateText({
92
89
  ...options,
93
90
  messages,
94
- steps
91
+ steps,
92
+ totalUsage
95
93
  });
96
94
  }
97
95
  });
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@xsai/generate-text",
3
3
  "type": "module",
4
- "version": "0.5.0-beta.2",
4
+ "version": "0.5.0-beta.4",
5
5
  "description": "extra-small AI SDK.",
6
6
  "author": "Moeru AI",
7
7
  "license": "MIT",
@@ -33,12 +33,12 @@
33
33
  "dist"
34
34
  ],
35
35
  "dependencies": {
36
- "@xsai/shared": "~0.5.0-beta.2",
37
- "@xsai/shared-chat": "~0.5.0-beta.2"
36
+ "@xsai/shared": "0.5.0-beta.4",
37
+ "@xsai/shared-chat": "0.5.0-beta.4"
38
38
  },
39
39
  "devDependencies": {
40
40
  "valibot": "^1.0.0",
41
- "@xsai/tool": "~0.5.0-beta.2"
41
+ "@xsai/tool": "0.5.0-beta.4"
42
42
  },
43
43
  "scripts": {
44
44
  "build": "pkgroll",