@xsai/generate-text 0.0.26 → 0.0.27

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
@@ -3,6 +3,8 @@ import { ChatOptions, FinishReason, AssistantMessageResponse } from '@xsai/share
3
3
  interface GenerateTextOptions extends ChatOptions {
4
4
  /** @default 1 */
5
5
  maxSteps?: number;
6
+ /** @internal */
7
+ steps?: StepResult[];
6
8
  /** if you want to enable stream, use `@xsai/stream-{text,object}` */
7
9
  stream?: never;
8
10
  }
@@ -24,16 +26,32 @@ interface GenerateTextResponseUsage {
24
26
  prompt_tokens: number;
25
27
  total_tokens: number;
26
28
  }
29
+ interface ToolCall {
30
+ args: string;
31
+ toolCallId: string;
32
+ toolCallType: 'function';
33
+ toolName: string;
34
+ }
35
+ interface ToolResult {
36
+ args: Record<string, unknown>;
37
+ result: string;
38
+ toolCallId: string;
39
+ toolName: string;
40
+ }
27
41
  interface GenerateTextResult {
28
42
  finishReason: FinishReason;
29
43
  steps: StepResult[];
30
44
  text?: string;
45
+ toolCalls: ToolCall[];
46
+ toolResults: ToolResult[];
31
47
  usage: GenerateTextResponseUsage;
32
48
  }
33
49
  interface StepResult {
34
50
  text?: string;
51
+ toolCalls: ToolCall[];
52
+ toolResults: ToolResult[];
35
53
  usage: GenerateTextResponseUsage;
36
54
  }
37
55
  declare const generateText: (options: GenerateTextOptions) => Promise<GenerateTextResult>;
38
56
 
39
- export { type GenerateTextOptions, type GenerateTextResponse, type GenerateTextResponseUsage, type GenerateTextResult, type StepResult, generateText as default, generateText };
57
+ export { type GenerateTextOptions, type GenerateTextResponse, type GenerateTextResponseUsage, type GenerateTextResult, type StepResult, type ToolCall, type ToolResult, generateText as default, generateText };
package/dist/index.js CHANGED
@@ -1,60 +1,75 @@
1
1
  import { chat } from '@xsai/shared-chat';
2
2
 
3
- const generateText = async (options) => {
4
- let currentStep = 0;
5
- let finishReason = "error";
6
- let text;
7
- let usage = {
8
- completion_tokens: 0,
9
- prompt_tokens: 0,
10
- total_tokens: 0
11
- };
12
- const steps = [];
3
+ const rawGenerateText = async (options) => await chat({
4
+ ...options,
5
+ maxSteps: void 0,
6
+ messages: options.messages,
7
+ steps: void 0,
8
+ stream: false
9
+ }).then((res) => res.json()).then(async ({ choices, usage }) => {
13
10
  const messages = options.messages;
14
- while (currentStep < (options.maxSteps ?? 1)) {
15
- currentStep += 1;
16
- const data = await chat({
17
- ...options,
18
- maxSteps: void 0,
19
- messages,
20
- stream: false
21
- }).then((res) => res.json());
22
- const { finish_reason, message } = data.choices[0];
23
- finishReason = finish_reason;
24
- text = message.content;
25
- usage = data.usage;
26
- steps.push({
11
+ const steps = options.steps ?? [];
12
+ const toolCalls = [];
13
+ const toolResults = [];
14
+ const { finish_reason: finishReason, message } = choices[0];
15
+ if (message.content || !message.tool_calls || steps.length >= (options.maxSteps ?? 1)) {
16
+ const step = {
27
17
  text: message.content,
28
- // type: 'initial',
18
+ toolCalls,
19
+ toolResults,
29
20
  usage
21
+ };
22
+ steps.push(step);
23
+ return {
24
+ finishReason,
25
+ steps,
26
+ ...step
27
+ };
28
+ }
29
+ messages.push({ ...message, content: message.content });
30
+ for (const {
31
+ function: { arguments: toolArgs, name: toolName },
32
+ id: toolCallId,
33
+ type: toolCallType
34
+ } of message.tool_calls) {
35
+ const tool = options.tools.find((tool2) => tool2.function.name === toolName);
36
+ const parsedArgs = JSON.parse(toolArgs);
37
+ const result = await tool.execute(parsedArgs);
38
+ toolCalls.push({
39
+ args: toolArgs,
40
+ toolCallId,
41
+ toolCallType,
42
+ toolName
43
+ });
44
+ toolResults.push({
45
+ args: parsedArgs,
46
+ result,
47
+ toolCallId,
48
+ toolName
49
+ });
50
+ messages.push({
51
+ content: result,
52
+ role: "tool",
53
+ tool_call_id: toolCallId
30
54
  });
31
- messages.push({ ...message, content: message.content });
32
- if (message.tool_calls) {
33
- for (const toolCall of message.tool_calls ?? []) {
34
- const tool = options.tools.find((tool2) => tool2.function.name === toolCall.function.name);
35
- const toolResult = await tool.execute(JSON.parse(toolCall.function.arguments));
36
- const toolMessage = {
37
- content: toolResult,
38
- role: "tool",
39
- tool_call_id: toolCall.id
40
- };
41
- messages.push(toolMessage);
42
- }
43
- } else {
44
- return {
45
- finishReason: finish_reason,
46
- steps,
47
- text: message.content,
48
- usage
49
- };
50
- }
51
55
  }
52
- return {
53
- finishReason,
54
- steps,
55
- text,
56
+ steps.push({
57
+ text: message.content,
58
+ toolCalls,
59
+ toolResults,
56
60
  usage
57
- };
61
+ });
62
+ return async () => await rawGenerateText({
63
+ ...options,
64
+ messages,
65
+ steps
66
+ });
67
+ });
68
+ const generateText = async (options) => {
69
+ let result = await rawGenerateText(options);
70
+ while (result instanceof Function)
71
+ result = await result();
72
+ return result;
58
73
  };
59
74
 
60
75
  export { generateText as default, generateText };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@xsai/generate-text",
3
- "version": "0.0.26",
3
+ "version": "0.0.27",
4
4
  "type": "module",
5
5
  "author": "Moeru AI",
6
6
  "license": "MIT",