@ai-zen/air 0.2.3 → 0.3.2

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.
Files changed (104) hide show
  1. package/README.md +27 -29
  2. package/README.zh.md +27 -29
  3. package/dist/agent-commands/back.d.ts +3 -0
  4. package/dist/agent-commands/back.d.ts.map +1 -0
  5. package/dist/{chat/commands → agent-commands}/back.js +4 -5
  6. package/dist/agent-commands/back.js.map +1 -0
  7. package/dist/agent-commands/editor.d.ts +3 -0
  8. package/dist/agent-commands/editor.d.ts.map +1 -0
  9. package/dist/{chat/commands → agent-commands}/editor.js +2 -3
  10. package/dist/agent-commands/editor.js.map +1 -0
  11. package/dist/agent-commands/exit.d.ts +3 -0
  12. package/dist/agent-commands/exit.d.ts.map +1 -0
  13. package/dist/agent-commands/exit.js.map +1 -0
  14. package/dist/agent-commands/help.d.ts.map +1 -0
  15. package/dist/agent-commands/help.js.map +1 -0
  16. package/dist/agent-commands/index.d.ts +3 -0
  17. package/dist/agent-commands/index.d.ts.map +1 -0
  18. package/dist/agent-commands/index.js.map +1 -0
  19. package/dist/agent-commands/load.d.ts +3 -0
  20. package/dist/agent-commands/load.d.ts.map +1 -0
  21. package/dist/{chat/commands → agent-commands}/load.js +3 -3
  22. package/dist/agent-commands/load.js.map +1 -0
  23. package/dist/agent-commands/new.d.ts +3 -0
  24. package/dist/agent-commands/new.d.ts.map +1 -0
  25. package/dist/{chat/commands → agent-commands}/new.js +3 -3
  26. package/dist/agent-commands/new.js.map +1 -0
  27. package/dist/agent-commands/save.d.ts +3 -0
  28. package/dist/agent-commands/save.d.ts.map +1 -0
  29. package/dist/{chat/commands → agent-commands}/save.js +1 -1
  30. package/dist/agent-commands/save.js.map +1 -0
  31. package/dist/agent-constants.d.ts +2 -0
  32. package/dist/agent-constants.d.ts.map +1 -0
  33. package/dist/agent-constants.js +16 -0
  34. package/dist/agent-constants.js.map +1 -0
  35. package/dist/{chat/runtime.d.ts → agent-runtime.d.ts} +1 -1
  36. package/dist/agent-runtime.d.ts.map +1 -0
  37. package/dist/agent-runtime.js +115 -0
  38. package/dist/agent-runtime.js.map +1 -0
  39. package/dist/{chat/shared.d.ts → agent-types.d.ts} +2 -2
  40. package/dist/agent-types.d.ts.map +1 -0
  41. package/dist/agent-types.js +2 -0
  42. package/dist/agent-types.js.map +1 -0
  43. package/dist/cli.js +1 -1
  44. package/dist/cli.js.map +1 -1
  45. package/package.json +12 -10
  46. package/scripts/check-publish-tool.mjs +27 -0
  47. package/src/__tests__/chat.test.ts +14 -14
  48. package/src/{chat/commands → agent-commands}/back.ts +5 -6
  49. package/src/{chat/commands → agent-commands}/editor.ts +3 -4
  50. package/src/{chat/commands → agent-commands}/exit.ts +1 -1
  51. package/src/{chat/commands → agent-commands}/index.ts +1 -1
  52. package/src/{chat/commands → agent-commands}/load.ts +4 -4
  53. package/src/{chat/commands → agent-commands}/new.ts +4 -4
  54. package/src/{chat/commands → agent-commands}/save.ts +2 -2
  55. package/src/agent-constants.ts +15 -0
  56. package/src/agent-runtime.ts +119 -0
  57. package/src/agent-types.ts +6 -0
  58. package/src/cli.ts +1 -1
  59. package/dist/chat/commands/back.d.ts +0 -3
  60. package/dist/chat/commands/back.d.ts.map +0 -1
  61. package/dist/chat/commands/back.js.map +0 -1
  62. package/dist/chat/commands/editor.d.ts +0 -3
  63. package/dist/chat/commands/editor.d.ts.map +0 -1
  64. package/dist/chat/commands/editor.js.map +0 -1
  65. package/dist/chat/commands/exit.d.ts +0 -3
  66. package/dist/chat/commands/exit.d.ts.map +0 -1
  67. package/dist/chat/commands/exit.js.map +0 -1
  68. package/dist/chat/commands/help.d.ts.map +0 -1
  69. package/dist/chat/commands/help.js.map +0 -1
  70. package/dist/chat/commands/index.d.ts +0 -3
  71. package/dist/chat/commands/index.d.ts.map +0 -1
  72. package/dist/chat/commands/index.js.map +0 -1
  73. package/dist/chat/commands/load.d.ts +0 -3
  74. package/dist/chat/commands/load.d.ts.map +0 -1
  75. package/dist/chat/commands/load.js.map +0 -1
  76. package/dist/chat/commands/new.d.ts +0 -3
  77. package/dist/chat/commands/new.d.ts.map +0 -1
  78. package/dist/chat/commands/new.js.map +0 -1
  79. package/dist/chat/commands/save.d.ts +0 -3
  80. package/dist/chat/commands/save.d.ts.map +0 -1
  81. package/dist/chat/commands/save.js.map +0 -1
  82. package/dist/chat/message.d.ts +0 -3
  83. package/dist/chat/message.d.ts.map +0 -1
  84. package/dist/chat/message.js +0 -31
  85. package/dist/chat/message.js.map +0 -1
  86. package/dist/chat/print.d.ts +0 -3
  87. package/dist/chat/print.d.ts.map +0 -1
  88. package/dist/chat/print.js +0 -24
  89. package/dist/chat/print.js.map +0 -1
  90. package/dist/chat/runtime.d.ts.map +0 -1
  91. package/dist/chat/runtime.js +0 -64
  92. package/dist/chat/runtime.js.map +0 -1
  93. package/dist/chat/shared.d.ts.map +0 -1
  94. package/dist/chat/shared.js +0 -16
  95. package/dist/chat/shared.js.map +0 -1
  96. package/src/chat/message.ts +0 -27
  97. package/src/chat/print.ts +0 -27
  98. package/src/chat/runtime.ts +0 -65
  99. package/src/chat/shared.ts +0 -21
  100. /package/dist/{chat/commands → agent-commands}/exit.js +0 -0
  101. /package/dist/{chat/commands → agent-commands}/help.d.ts +0 -0
  102. /package/dist/{chat/commands → agent-commands}/help.js +0 -0
  103. /package/dist/{chat/commands → agent-commands}/index.js +0 -0
  104. /package/src/{chat/commands → agent-commands}/help.ts +0 -0
@@ -0,0 +1,27 @@
1
+ #!/usr/bin/env node
2
+
3
+ /**
4
+ * 检查发布工具是否为 pnpm
5
+ * 防止误用 npm publish 导致 workspace:* 协议未被替换的问题
6
+ */
7
+
8
+ const execPath = process.env.npm_execpath || '';
9
+ const userAgent = process.env.npm_config_user_agent || '';
10
+
11
+ const isPnpm = execPath.includes('pnpm') || userAgent.includes('pnpm');
12
+
13
+ if (!isPnpm) {
14
+ console.error('');
15
+ console.error(' ❌ 发布失败:检测到使用 npm 发布!');
16
+ console.error('');
17
+ console.error(' 本项目的依赖使用了 pnpm workspace 协议 (workspace:*)');
18
+ console.error(' 使用 npm publish 会导致 workspace:* 无法被正确替换为实际版本号');
19
+ console.error(' 从而导致用户安装时找不到依赖包而失败。');
20
+ console.error('');
21
+ console.error(' ✅ 请使用以下命令发布:');
22
+ console.error(' pnpm publish');
23
+ console.error('');
24
+ process.exit(1);
25
+ }
26
+
27
+ console.log(' ✅ 发布工具检测通过 (pnpm)');
@@ -1,5 +1,5 @@
1
1
  import { describe, it, expect, vi, beforeEach } from "vitest";
2
- import type { ChatCtx } from "../chat/shared.js";
2
+ import type { ChatCtx } from "../agent-types.js";
3
3
 
4
4
  // Mock all external dependencies
5
5
  vi.mock("inquirer", () => ({ default: { prompt: vi.fn() } }));
@@ -16,23 +16,23 @@ vi.mock("../agent-factory.js", () => ({
16
16
  send: vi.fn(),
17
17
  })),
18
18
  }));
19
- vi.mock("../chat/print.js", () => ({
20
- sendAndPrint: vi.fn(),
21
- }));
22
19
 
23
20
  const mockPrompt = vi.mocked((await import("inquirer")).default.prompt);
24
21
  const { saveMessages, saveSnapshot, listSnapshots, loadSnapshot } = await import("../config.js");
25
22
  const { buildAgent } = await import("../agent-factory.js");
26
23
 
27
24
  function makeCtx(msgs: any[] = []): ChatCtx {
28
- return { agent: { messages: msgs, events: { on: vi.fn(), off: vi.fn() }, send: vi.fn() } as any };
25
+ return {
26
+ agent: { messages: msgs, events: { on: vi.fn(), off: vi.fn() }, send: vi.fn() } as any,
27
+ send: vi.fn(),
28
+ };
29
29
  }
30
30
 
31
31
  // ==================== cmdNew ====================
32
32
 
33
33
  describe("cmdNew", () => {
34
34
  it("写入 system prompt 并构建 agent", async () => {
35
- const { cmdNew } = await import("../chat/commands/new.js");
35
+ const { cmdNew } = await import("../agent-commands/new.js");
36
36
  const ctx = makeCtx();
37
37
 
38
38
  await cmdNew(ctx);
@@ -54,19 +54,19 @@ describe("dispatchCommand", () => {
54
54
 
55
55
  it('"/exit" 调用 cmdExit(process.exit)', async () => {
56
56
  // Can't easily test process.exit, just verify it doesn't throw
57
- const { runChat } = await import("../chat/runtime.js");
57
+ const { runChat } = await import("../agent-runtime.js");
58
58
  // dispatchCommand is internal, tested via routing only
59
59
  });
60
60
 
61
61
  it('"/save" 调用 cmdSave', async () => {
62
- const { cmdSave } = await import("../chat/commands/save.js");
62
+ const { cmdSave } = await import("../agent-commands/save.js");
63
63
  const ctx = makeCtx([{ role: "system", content: "sys" }]);
64
64
  await cmdSave(ctx);
65
65
  expect(saveSnapshot).toHaveBeenCalledWith(ctx.agent.messages);
66
66
  });
67
67
 
68
68
  it('"/new" 调用 cmdNew 并打印提示', async () => {
69
- const { cmdNew } = await import("../chat/commands/new.js");
69
+ const { cmdNew } = await import("../agent-commands/new.js");
70
70
  const ctx = makeCtx();
71
71
  const spy = vi.spyOn(console, "log").mockImplementation(() => {});
72
72
  await cmdNew(ctx);
@@ -75,7 +75,7 @@ describe("dispatchCommand", () => {
75
75
  });
76
76
 
77
77
  it('"/help" 打印帮助信息', async () => {
78
- const { cmdHelp } = await import("../chat/commands/help.js");
78
+ const { cmdHelp } = await import("../agent-commands/help.js");
79
79
  const spy = vi.spyOn(console, "log").mockImplementation(() => {});
80
80
  cmdHelp();
81
81
  expect(spy).toHaveBeenCalled();
@@ -91,7 +91,7 @@ describe("cmdBack", () => {
91
91
  });
92
92
 
93
93
  it("没有消息时提示无可撤回", async () => {
94
- const { cmdBack } = await import("../chat/commands/back.js");
94
+ const { cmdBack } = await import("../agent-commands/back.js");
95
95
  const ctx = makeCtx([{ role: "system", content: "sys" }]);
96
96
  const spy = vi.spyOn(console, "log").mockImplementation(() => {});
97
97
  await cmdBack(ctx);
@@ -100,7 +100,7 @@ describe("cmdBack", () => {
100
100
  });
101
101
 
102
102
  it("取消操作时不修改消息", async () => {
103
- const { cmdBack } = await import("../chat/commands/back.js");
103
+ const { cmdBack } = await import("../agent-commands/back.js");
104
104
  const msgs = [
105
105
  { role: "system", content: "sys" },
106
106
  { role: "user", content: "你好" },
@@ -120,7 +120,7 @@ describe("cmdLoad", () => {
120
120
  });
121
121
 
122
122
  it("没有快照时提示", async () => {
123
- const { cmdLoad } = await import("../chat/commands/load.js");
123
+ const { cmdLoad } = await import("../agent-commands/load.js");
124
124
  const ctx = makeCtx();
125
125
  vi.mocked(listSnapshots).mockReturnValueOnce([]);
126
126
  const spy = vi.spyOn(console, "log").mockImplementation(() => {});
@@ -138,7 +138,7 @@ describe("cmdEditor", () => {
138
138
  });
139
139
 
140
140
  it("取消编辑不报错", async () => {
141
- const { cmdEditor } = await import("../chat/commands/editor.js");
141
+ const { cmdEditor } = await import("../agent-commands/editor.js");
142
142
  const ctx = makeCtx();
143
143
  mockPrompt.mockResolvedValueOnce({ content: "" });
144
144
  await cmdEditor(ctx);
@@ -1,8 +1,7 @@
1
1
  import inquirer from "inquirer";
2
- import type { ChatCtx } from "../shared.js";
3
- import { sendAndPrint } from "../print.js";
4
- import { saveMessages } from "../../config.js";
5
- import { buildAgent } from "../../agent-factory.js";
2
+ import type { ChatCtx } from "../agent-types.js";
3
+ import { saveMessages } from "../config.js";
4
+ import { buildAgent } from "../agent-factory.js";
6
5
 
7
6
  export async function cmdBack(ctx: ChatCtx): Promise<void> {
8
7
  const targets: { index: number; role: string; label: string; preview: string }[] = [];
@@ -75,7 +74,7 @@ export async function cmdBack(ctx: ChatCtx): Promise<void> {
75
74
  }
76
75
 
77
76
  ctx.agent = await buildAgent(ctx.agent.messages);
78
- await sendAndPrint(ctx.agent, textToSend);
77
+ await ctx.send(textToSend);
79
78
  saveMessages(ctx.agent.messages);
80
79
  } else {
81
80
  console.log("\n💡 请输入一条新消息继续对话\n");
@@ -84,7 +83,7 @@ export async function cmdBack(ctx: ChatCtx): Promise<void> {
84
83
  ]);
85
84
  if (!newMessage.trim()) { console.log("\n已取消\n"); return; }
86
85
  ctx.agent = await buildAgent(ctx.agent.messages);
87
- await sendAndPrint(ctx.agent, newMessage.trim());
86
+ await ctx.send(newMessage.trim());
88
87
  saveMessages(ctx.agent.messages);
89
88
  }
90
89
  }
@@ -1,7 +1,6 @@
1
1
  import inquirer from "inquirer";
2
- import type { ChatCtx } from "../shared.js";
3
- import { sendAndPrint } from "../print.js";
4
- import { saveMessages } from "../../config.js";
2
+ import type { ChatCtx } from "../agent-types.js";
3
+ import { saveMessages } from "../config.js";
5
4
 
6
5
  export async function cmdEditor(ctx: ChatCtx) {
7
6
  const { content } = await inquirer.prompt([
@@ -12,7 +11,7 @@ export async function cmdEditor(ctx: ChatCtx) {
12
11
  return;
13
12
  }
14
13
  try {
15
- await sendAndPrint(ctx.agent, content.trim());
14
+ await ctx.send(content.trim());
16
15
  saveMessages(ctx.agent.messages);
17
16
  } catch (err: any) { console.error(`\n❌ ${err.message}`); }
18
17
  }
@@ -1,4 +1,4 @@
1
- import type { ChatCtx } from "../shared.js";
1
+ import type { ChatCtx } from "../agent-types.js";
2
2
 
3
3
  export async function cmdExit(ctx: ChatCtx): Promise<void> {
4
4
  console.log("\n👋 再见!");
@@ -1,4 +1,4 @@
1
- import type { ChatCtx } from "../shared.js";
1
+ import type { ChatCtx } from "../agent-types.js";
2
2
  import { cmdExit } from "./exit.js";
3
3
  import { cmdHelp } from "./help.js";
4
4
  import { cmdSave } from "./save.js";
@@ -1,9 +1,9 @@
1
1
  import { Message } from "@ai-zen/agents-core";
2
2
  import inquirer from "inquirer";
3
- import type { ChatCtx } from "../shared.js";
4
- import { SYSTEM_PROMPT } from "../shared.js";
5
- import { listSnapshots, loadSnapshot, saveMessages } from "../../config.js";
6
- import { buildAgent } from "../../agent-factory.js";
3
+ import type { ChatCtx } from "../agent-types.js";
4
+ import { SYSTEM_PROMPT } from "../agent-constants.js";
5
+ import { listSnapshots, loadSnapshot, saveMessages } from "../config.js";
6
+ import { buildAgent } from "../agent-factory.js";
7
7
 
8
8
  export async function cmdLoad(ctx: ChatCtx): Promise<void> {
9
9
  const snapshots = listSnapshots();
@@ -1,8 +1,8 @@
1
- import type { ChatCtx } from "../shared.js";
1
+ import type { ChatCtx } from "../agent-types.js";
2
2
  import { Message } from "@ai-zen/agents-core";
3
- import { saveMessages } from "../../config.js";
4
- import { buildAgent } from "../../agent-factory.js";
5
- import { SYSTEM_PROMPT } from "../shared.js";
3
+ import { saveMessages } from "../config.js";
4
+ import { buildAgent } from "../agent-factory.js";
5
+ import { SYSTEM_PROMPT } from "../agent-constants.js";
6
6
 
7
7
  export async function cmdNew(ctx: ChatCtx): Promise<void> {
8
8
  const msgs = [Message.System(SYSTEM_PROMPT)];
@@ -1,5 +1,5 @@
1
- import type { ChatCtx } from "../shared.js";
2
- import { saveSnapshot } from "../../config.js";
1
+ import type { ChatCtx } from "../agent-types.js";
2
+ import { saveSnapshot } from "../config.js";
3
3
 
4
4
  export async function cmdSave(ctx: ChatCtx) {
5
5
  console.log(`\n✅ 快照: ${saveSnapshot(ctx.agent.messages)}\n`);
@@ -0,0 +1,15 @@
1
+ export const SYSTEM_PROMPT = [
2
+ "你是一个AI助手,专门帮助用户回答问题和执行任务。请用中文回复。",
3
+ "",
4
+ "## 行为准则",
5
+ "1. 做任何改动之前,必须先跟用户商量,获得书面确认之后再行动。",
6
+ "2. 用户没有明确要求产出文件时,不得自行创建任何文件到项目中。讨论就停留在讨论层面。",
7
+ "3. 区分危险操作:删除文件、覆盖文件、安装卸载软件、修改系统配置、执行耗时任务等属于危险操作。执行前必须评估影响范围,并向用户说明风险,获得用户明确的书面确认之后再执行。",
8
+ "4. 追责原则:获得用户书面确认的操作,你即可放心执行。每一步操作及其产生的责任,均以用户的书面确认记录为追溯依据,操作不得超出用户书面确认的边界范围。最终责任由用户承担。没有获得书面确认之前,不得擅自行动。",
9
+ "",
10
+ "## 记忆",
11
+ "如果你有需要长期记住的信息(用户偏好、项目约定、任务进度等),请写入以下位置:",
12
+ "- 全局记忆: ~/.ai-zen/air/memory/*.md",
13
+ "- 项目记忆: $(cwd)/.ai-zen/air/memory/*.md",
14
+ "下次启动时读取即可。这是你唯一的记忆方式。",
15
+ ].join("\n");
@@ -0,0 +1,119 @@
1
+ import { Agent, Message } from "@ai-zen/agents-core";
2
+ import type { AgentNS } from "@ai-zen/agents-core";
3
+ import chalk from "chalk";
4
+ import inquirer from "inquirer";
5
+ import { DeltaRenderer } from "./delta-renderer.js";
6
+ import { readConfig, readMessages, saveMessages, saveSnapshot } from "./config.js";
7
+ import { buildAgent } from "./agent-factory.js";
8
+ import { contextSize, shouldMigrate, generateMigrationDoc, MAX_CONTEXT_CHARS } from "./migration.js";
9
+ import { dispatchCommand } from "./agent-commands/index.js";
10
+ import type { ChatCtx } from "./agent-types.js";
11
+ import { SYSTEM_PROMPT } from "./agent-constants.js";
12
+
13
+ // ==================== print (内部使用) ====================
14
+
15
+ async function send(agent: Agent, text: string): Promise<void> {
16
+ console.log(chalk.green.bold("\n🤖 AI:"));
17
+ const renderer = new DeltaRenderer({
18
+ reasoningHeader: "\n\n💭 思考中...\n",
19
+ contentHeader: "\n\n💭 回答中...\n",
20
+ });
21
+
22
+ function onChunk(chunk: AgentNS.StreamResponseData) {
23
+ const delta = chunk?.choices?.[0]?.delta;
24
+ const fr = chunk?.choices?.[0]?.finish_reason ?? null;
25
+ if (delta) renderer.render(delta, fr);
26
+ }
27
+
28
+ function onRun() { renderer.reset(); }
29
+ agent.events.on("run", onRun);
30
+ agent.events.on("chunk", onChunk);
31
+ await agent.send(text);
32
+ agent.events.off("run", onRun);
33
+ agent.events.off("chunk", onChunk);
34
+ process.stdout.write("\n\n");
35
+ console.log();
36
+ }
37
+
38
+ // ==================== message ====================
39
+
40
+ async function handleMessage(ctx: ChatCtx, text: string): Promise<void> {
41
+ try {
42
+ await ctx.send(text);
43
+ saveMessages(ctx.agent.messages);
44
+
45
+ if (shouldMigrate(ctx.agent.messages)) {
46
+ console.log(`🔄 上下文 ${contextSize(ctx.agent.messages)}/${MAX_CONTEXT_CHARS},准备迁移...`);
47
+ try {
48
+ const snap = saveSnapshot(ctx.agent.messages);
49
+ console.log(` 💾 快照: ${snap}`);
50
+ const summary = await generateMigrationDoc(ctx.agent.messages);
51
+ const msgs = [Message.System(SYSTEM_PROMPT), Message.User(summary)];
52
+ saveMessages(msgs);
53
+ console.log("✅ 迁移完成\n");
54
+ ctx.agent = await buildAgent(msgs);
55
+ } catch (err: any) { console.error(`❌ 迁移失败: ${err.message}\n`); }
56
+ }
57
+ } catch (err: any) { console.error(`\n❌ ${err.message}`); }
58
+ }
59
+
60
+ // ==================== runtime ====================
61
+
62
+ async function chatLoop(ctx: ChatCtx) {
63
+ while (true) {
64
+ const { input } = await inquirer.prompt([
65
+ { type: "input", name: "input", message: "你:" },
66
+ ]);
67
+ const t = input.trim();
68
+ if (!t) continue;
69
+ if (t.startsWith("/")) {
70
+ await dispatchCommand(ctx, t.toLowerCase());
71
+ continue;
72
+ }
73
+ await handleMessage(ctx, t);
74
+ }
75
+ }
76
+
77
+ export async function runChat(initialMessage?: string): Promise<void> {
78
+ const config = readConfig();
79
+ if (!config.apiKey) {
80
+ console.error("❌ 请先设置 API Key: air key <your-key>");
81
+ console.error(" 获取 Key: https://platform.deepseek.com/api_keys");
82
+ process.exit(1);
83
+ }
84
+
85
+ let msgs = readMessages();
86
+ if (msgs.length === 0) {
87
+ msgs = [Message.System(SYSTEM_PROMPT)];
88
+ saveMessages(msgs);
89
+ }
90
+ const agent: Agent = await buildAgent(msgs);
91
+ const ctx: ChatCtx = {
92
+ agent,
93
+ send(text: string) { return send(this.agent, text); },
94
+ };
95
+
96
+ if (initialMessage) {
97
+ const hasHistory = ctx.agent.messages.some(m => m.role === "user" || m.role === "assistant");
98
+ if (hasHistory) {
99
+ const snap = saveSnapshot(ctx.agent.messages);
100
+ console.log(`💾 已存档旧对话: ${snap}\n`);
101
+ }
102
+ await dispatchCommand(ctx, "/new");
103
+ console.log(`💬 你: ${initialMessage}`);
104
+ try {
105
+ await ctx.send(initialMessage);
106
+ saveMessages(ctx.agent.messages);
107
+ } catch (err: any) { console.error(`\n❌ ${err.message}`); }
108
+ console.log("\n💬 继续对话 (输入 /exit 退出)\n");
109
+ await chatLoop(ctx);
110
+ return;
111
+ }
112
+
113
+ const msgCount = ctx.agent.messages.filter((m) => m.role !== "system").length;
114
+ console.log(msgCount > 0
115
+ ? `\n💬 继续上次对话 (${msgCount} 条,/${contextSize(ctx.agent.messages)} 字符,输入 /new 重新开始)\n`
116
+ : "\n💬 air — 极简 AI 助手 (输入 /help 查看命令)\n");
117
+
118
+ await chatLoop(ctx);
119
+ }
@@ -0,0 +1,6 @@
1
+ import { Agent } from "@ai-zen/agents-core";
2
+
3
+ export interface ChatCtx {
4
+ agent: Agent;
5
+ send: (text: string) => Promise<void>;
6
+ }
package/src/cli.ts CHANGED
@@ -1,7 +1,7 @@
1
1
  #!/usr/bin/env node
2
2
  import { readFileSync } from "node:fs";
3
3
  import { Command } from "commander";
4
- import { runChat } from "./chat/runtime.js";
4
+ import { runChat } from "./agent-runtime.js";
5
5
  import { installHook, uninstallHook } from "./hook.js";
6
6
  import { readConfig, saveConfig } from "./config.js";
7
7
 
@@ -1,3 +0,0 @@
1
- import type { ChatCtx } from "../shared.js";
2
- export declare function cmdBack(ctx: ChatCtx): Promise<void>;
3
- //# sourceMappingURL=back.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"back.d.ts","sourceRoot":"","sources":["../../../src/chat/commands/back.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAK5C,wBAAsB,OAAO,CAAC,GAAG,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC,CAmFzD"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"back.js","sourceRoot":"","sources":["../../../src/chat/commands/back.ts"],"names":[],"mappings":"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"}
@@ -1,3 +0,0 @@
1
- import type { ChatCtx } from "../shared.js";
2
- export declare function cmdEditor(ctx: ChatCtx): Promise<void>;
3
- //# sourceMappingURL=editor.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"editor.d.ts","sourceRoot":"","sources":["../../../src/chat/commands/editor.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAI5C,wBAAsB,SAAS,CAAC,GAAG,EAAE,OAAO,iBAY3C"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"editor.js","sourceRoot":"","sources":["../../../src/chat/commands/editor.ts"],"names":[],"mappings":"AAAA,OAAO,QAAQ,MAAM,UAAU,CAAC;AAEhC,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAE/C,MAAM,CAAC,KAAK,UAAU,SAAS,CAAC,GAAY;IAC1C,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,QAAQ,CAAC,MAAM,CAAC;QACxC,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE;KACtD,CAAC,CAAC;IACH,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC;QACpB,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QACvB,OAAO;IACT,CAAC;IACD,IAAI,CAAC;QACH,MAAM,YAAY,CAAC,GAAG,CAAC,KAAK,EAAE,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC;QAC9C,YAAY,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;IACnC,CAAC;IAAC,OAAO,GAAQ,EAAE,CAAC;QAAC,OAAO,CAAC,KAAK,CAAC,OAAO,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC;IAAC,CAAC;AAC7D,CAAC"}
@@ -1,3 +0,0 @@
1
- import type { ChatCtx } from "../shared.js";
2
- export declare function cmdExit(ctx: ChatCtx): Promise<void>;
3
- //# sourceMappingURL=exit.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"exit.d.ts","sourceRoot":"","sources":["../../../src/chat/commands/exit.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAE5C,wBAAsB,OAAO,CAAC,GAAG,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC,CAGzD"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"exit.js","sourceRoot":"","sources":["../../../src/chat/commands/exit.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,KAAK,UAAU,OAAO,CAAC,GAAY;IACxC,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;IACxB,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAClB,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"help.d.ts","sourceRoot":"","sources":["../../../src/chat/commands/help.ts"],"names":[],"mappings":"AAAA,wBAAgB,OAAO,SAEtB"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"help.js","sourceRoot":"","sources":["../../../src/chat/commands/help.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,OAAO;IACrB,OAAO,CAAC,GAAG,CAAC,kHAAkH,CAAC,CAAC;AAClI,CAAC"}
@@ -1,3 +0,0 @@
1
- import type { ChatCtx } from "../shared.js";
2
- export declare function dispatchCommand(ctx: ChatCtx, cmd: string): Promise<void>;
3
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/chat/commands/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAS5C,wBAAsB,eAAe,CAAC,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CA4B9E"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/chat/commands/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,GAAY,EAAE,GAAW;IAC7D,QAAQ,GAAG,EAAE,CAAC;QACZ,KAAK,OAAO,CAAC;QACb,KAAK,OAAO;YACV,OAAO,CAAC,GAAG,CAAC,CAAC;YACb,MAAM;QACR,KAAK,OAAO;YACV,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC;YACnB,MAAM;QACR,KAAK,MAAM;YACT,MAAM,MAAM,CAAC,GAAG,CAAC,CAAC;YAClB,MAAM;QACR,KAAK,OAAO;YACV,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC;YACnB,MAAM;QACR,KAAK,OAAO;YACV,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC;YACnB,MAAM;QACR,KAAK,SAAS;YACZ,MAAM,SAAS,CAAC,GAAG,CAAC,CAAC;YACrB,MAAM;QACR,KAAK,OAAO;YACV,OAAO,EAAE,CAAC;YACV,MAAM;QACR;YACE,OAAO,CAAC,GAAG,CAAC,aAAa,GAAG,IAAI,CAAC,CAAC;YAClC,MAAM;IACV,CAAC;AACH,CAAC"}
@@ -1,3 +0,0 @@
1
- import type { ChatCtx } from "../shared.js";
2
- export declare function cmdLoad(ctx: ChatCtx): Promise<void>;
3
- //# sourceMappingURL=load.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"load.d.ts","sourceRoot":"","sources":["../../../src/chat/commands/load.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAK5C,wBAAsB,OAAO,CAAC,GAAG,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC,CA8BzD"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"load.js","sourceRoot":"","sources":["../../../src/chat/commands/load.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC9C,OAAO,QAAQ,MAAM,UAAU,CAAC;AAEhC,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAC7C,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC5E,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AAEpD,MAAM,CAAC,KAAK,UAAU,OAAO,CAAC,GAAY;IACxC,MAAM,SAAS,GAAG,aAAa,EAAE,CAAC;IAClC,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC3B,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;QAC9B,OAAO;IACT,CAAC;IACD,MAAM,EAAE,YAAY,EAAE,GAAG,MAAM,QAAQ,CAAC,MAAM,CAAC;QAC7C;YACE,IAAI,EAAE,MAAM;YACZ,IAAI,EAAE,cAAc;YACpB,OAAO,EAAE,WAAW;YACpB,QAAQ,EAAE,EAAE;YACZ,OAAO,EAAE;gBACP,EAAE,IAAI,EAAE,oBAAoB,EAAE,KAAK,EAAE,EAAE,EAAE;gBACzC,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;aAC3D;SACF;KACF,CAAC,CAAC;IACH,IAAI,CAAC,YAAY,EAAE,CAAC;QAClB,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QACvB,OAAO;IACT,CAAC;IACD,IAAI,MAAM,GAAG,YAAY,CAAC,YAAY,CAAC,CAAC;IACxC,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACxB,MAAM,GAAG,CAAC,OAAO,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC;IAC3C,CAAC;IACD,YAAY,CAAC,MAAM,CAAC,CAAC;IACrB,MAAM,IAAI,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,YAAY,CAAC,CAAC;IAC5D,OAAO,CAAC,GAAG,CAAC,aAAa,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,CAAC;IACtE,GAAG,CAAC,KAAK,GAAG,MAAM,UAAU,CAAC,MAAM,CAAC,CAAC;AACvC,CAAC"}
@@ -1,3 +0,0 @@
1
- import type { ChatCtx } from "../shared.js";
2
- export declare function cmdNew(ctx: ChatCtx): Promise<void>;
3
- //# sourceMappingURL=new.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"new.d.ts","sourceRoot":"","sources":["../../../src/chat/commands/new.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAM5C,wBAAsB,MAAM,CAAC,GAAG,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC,CAKxD"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"new.js","sourceRoot":"","sources":["../../../src/chat/commands/new.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC9C,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACpD,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAE7C,MAAM,CAAC,KAAK,UAAU,MAAM,CAAC,GAAY;IACvC,MAAM,IAAI,GAAG,CAAC,OAAO,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC;IAC7C,YAAY,CAAC,IAAI,CAAC,CAAC;IACnB,GAAG,CAAC,KAAK,GAAG,MAAM,UAAU,CAAC,IAAI,CAAC,CAAC;IACnC,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;AAC5B,CAAC"}
@@ -1,3 +0,0 @@
1
- import type { ChatCtx } from "../shared.js";
2
- export declare function cmdSave(ctx: ChatCtx): Promise<void>;
3
- //# sourceMappingURL=save.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"save.d.ts","sourceRoot":"","sources":["../../../src/chat/commands/save.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAG5C,wBAAsB,OAAO,CAAC,GAAG,EAAE,OAAO,iBAEzC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"save.js","sourceRoot":"","sources":["../../../src/chat/commands/save.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAE/C,MAAM,CAAC,KAAK,UAAU,OAAO,CAAC,GAAY;IACxC,OAAO,CAAC,GAAG,CAAC,WAAW,YAAY,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;AAC/D,CAAC"}
@@ -1,3 +0,0 @@
1
- import type { ChatCtx } from "./shared.js";
2
- export declare function handleMessage(ctx: ChatCtx, text: string): Promise<void>;
3
- //# sourceMappingURL=message.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"message.d.ts","sourceRoot":"","sources":["../../src/chat/message.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAO3C,wBAAsB,aAAa,CAAC,GAAG,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAkB7E"}
@@ -1,31 +0,0 @@
1
- import { Message } from "@ai-zen/agents-core";
2
- import { SYSTEM_PROMPT } from "./shared.js";
3
- import { sendAndPrint } from "./print.js";
4
- import { saveMessages, saveSnapshot } from "../config.js";
5
- import { buildAgent } from "../agent-factory.js";
6
- import { contextSize, shouldMigrate, generateMigrationDoc, MAX_CONTEXT_CHARS } from "../migration.js";
7
- export async function handleMessage(ctx, text) {
8
- try {
9
- await sendAndPrint(ctx.agent, text);
10
- saveMessages(ctx.agent.messages);
11
- if (shouldMigrate(ctx.agent.messages)) {
12
- console.log(`🔄 上下文 ${contextSize(ctx.agent.messages)}/${MAX_CONTEXT_CHARS},准备迁移...`);
13
- try {
14
- const snap = saveSnapshot(ctx.agent.messages);
15
- console.log(` 💾 快照: ${snap}`);
16
- const summary = await generateMigrationDoc(ctx.agent.messages);
17
- const msgs = [Message.System(SYSTEM_PROMPT), Message.User(summary)];
18
- saveMessages(msgs);
19
- console.log("✅ 迁移完成\n");
20
- ctx.agent = await buildAgent(msgs);
21
- }
22
- catch (err) {
23
- console.error(`❌ 迁移失败: ${err.message}\n`);
24
- }
25
- }
26
- }
27
- catch (err) {
28
- console.error(`\n❌ ${err.message}`);
29
- }
30
- }
31
- //# sourceMappingURL=message.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"message.js","sourceRoot":"","sources":["../../src/chat/message.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAE9C,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAC5C,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAC1C,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAC1D,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACjD,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,oBAAoB,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AAEtG,MAAM,CAAC,KAAK,UAAU,aAAa,CAAC,GAAY,EAAE,IAAY;IAC5D,IAAI,CAAC;QACH,MAAM,YAAY,CAAC,GAAG,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QACpC,YAAY,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;QAEjC,IAAI,aAAa,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC;YACtC,OAAO,CAAC,GAAG,CAAC,UAAU,WAAW,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,iBAAiB,UAAU,CAAC,CAAC;YACtF,IAAI,CAAC;gBACH,MAAM,IAAI,GAAG,YAAY,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;gBAC9C,OAAO,CAAC,GAAG,CAAC,YAAY,IAAI,EAAE,CAAC,CAAC;gBAChC,MAAM,OAAO,GAAG,MAAM,oBAAoB,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;gBAC/D,MAAM,IAAI,GAAG,CAAC,OAAO,CAAC,MAAM,CAAC,aAAa,CAAC,EAAE,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;gBACpE,YAAY,CAAC,IAAI,CAAC,CAAC;gBACnB,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;gBACxB,GAAG,CAAC,KAAK,GAAG,MAAM,UAAU,CAAC,IAAI,CAAC,CAAC;YACrC,CAAC;YAAC,OAAO,GAAQ,EAAE,CAAC;gBAAC,OAAO,CAAC,KAAK,CAAC,WAAW,GAAG,CAAC,OAAO,IAAI,CAAC,CAAC;YAAC,CAAC;QACnE,CAAC;IACH,CAAC;IAAC,OAAO,GAAQ,EAAE,CAAC;QAAC,OAAO,CAAC,KAAK,CAAC,OAAO,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC;IAAC,CAAC;AAC7D,CAAC"}
@@ -1,3 +0,0 @@
1
- import { Agent } from "@ai-zen/agents-core";
2
- export declare function sendAndPrint(agent: Agent, text: string): Promise<void>;
3
- //# sourceMappingURL=print.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"print.d.ts","sourceRoot":"","sources":["../../src/chat/print.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,EAAE,MAAM,qBAAqB,CAAC;AAI5C,wBAAsB,YAAY,CAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAqB5E"}
@@ -1,24 +0,0 @@
1
- import chalk from "chalk";
2
- import { DeltaRenderer } from "../delta-renderer.js";
3
- export async function sendAndPrint(agent, text) {
4
- console.log(chalk.green.bold("\n🤖 AI:"));
5
- const renderer = new DeltaRenderer({
6
- reasoningHeader: "\n\n💭 思考中...\n",
7
- contentHeader: "\n\n💭 回答中...\n",
8
- });
9
- function onChunk(chunk) {
10
- const delta = chunk?.choices?.[0]?.delta;
11
- const fr = chunk?.choices?.[0]?.finish_reason ?? null;
12
- if (delta)
13
- renderer.render(delta, fr);
14
- }
15
- function onRun() { renderer.reset(); }
16
- agent.events.on("run", onRun);
17
- agent.events.on("chunk", onChunk);
18
- await agent.send(text);
19
- agent.events.off("run", onRun);
20
- agent.events.off("chunk", onChunk);
21
- process.stdout.write("\n\n");
22
- console.log();
23
- }
24
- //# sourceMappingURL=print.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"print.js","sourceRoot":"","sources":["../../src/chat/print.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAGrD,MAAM,CAAC,KAAK,UAAU,YAAY,CAAC,KAAY,EAAE,IAAY;IAC3D,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;IAC1C,MAAM,QAAQ,GAAG,IAAI,aAAa,CAAC;QACjC,eAAe,EAAE,iBAAiB;QAClC,aAAa,EAAE,iBAAiB;KACjC,CAAC,CAAC;IAEH,SAAS,OAAO,CAAC,KAAiC;QAChD,MAAM,KAAK,GAAG,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC;QACzC,MAAM,EAAE,GAAG,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,aAAa,IAAI,IAAI,CAAC;QACtD,IAAI,KAAK;YAAE,QAAQ,CAAC,MAAM,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;IACxC,CAAC;IAED,SAAS,KAAK,KAAK,QAAQ,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;IACtC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IAC9B,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;IAClC,MAAM,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACvB,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IAC/B,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;IACnC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IAC7B,OAAO,CAAC,GAAG,EAAE,CAAC;AAChB,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"runtime.d.ts","sourceRoot":"","sources":["../../src/chat/runtime.ts"],"names":[],"mappings":"AAyBA,wBAAsB,OAAO,CAAC,cAAc,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAuCpE"}