@ai-zen/air 0.2.3 → 0.3.1

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 (102) hide show
  1. package/dist/agent-commands/back.d.ts +3 -0
  2. package/dist/agent-commands/back.d.ts.map +1 -0
  3. package/dist/{chat/commands → agent-commands}/back.js +4 -5
  4. package/dist/agent-commands/back.js.map +1 -0
  5. package/dist/agent-commands/editor.d.ts +3 -0
  6. package/dist/agent-commands/editor.d.ts.map +1 -0
  7. package/dist/{chat/commands → agent-commands}/editor.js +2 -3
  8. package/dist/agent-commands/editor.js.map +1 -0
  9. package/dist/agent-commands/exit.d.ts +3 -0
  10. package/dist/agent-commands/exit.d.ts.map +1 -0
  11. package/dist/agent-commands/exit.js.map +1 -0
  12. package/dist/agent-commands/help.d.ts.map +1 -0
  13. package/dist/agent-commands/help.js.map +1 -0
  14. package/dist/agent-commands/index.d.ts +3 -0
  15. package/dist/agent-commands/index.d.ts.map +1 -0
  16. package/dist/agent-commands/index.js.map +1 -0
  17. package/dist/agent-commands/load.d.ts +3 -0
  18. package/dist/agent-commands/load.d.ts.map +1 -0
  19. package/dist/{chat/commands → agent-commands}/load.js +3 -3
  20. package/dist/agent-commands/load.js.map +1 -0
  21. package/dist/agent-commands/new.d.ts +3 -0
  22. package/dist/agent-commands/new.d.ts.map +1 -0
  23. package/dist/{chat/commands → agent-commands}/new.js +3 -3
  24. package/dist/agent-commands/new.js.map +1 -0
  25. package/dist/agent-commands/save.d.ts +3 -0
  26. package/dist/agent-commands/save.d.ts.map +1 -0
  27. package/dist/{chat/commands → agent-commands}/save.js +1 -1
  28. package/dist/agent-commands/save.js.map +1 -0
  29. package/dist/agent-constants.d.ts +2 -0
  30. package/dist/agent-constants.d.ts.map +1 -0
  31. package/dist/agent-constants.js +16 -0
  32. package/dist/agent-constants.js.map +1 -0
  33. package/dist/{chat/runtime.d.ts → agent-runtime.d.ts} +1 -1
  34. package/dist/agent-runtime.d.ts.map +1 -0
  35. package/dist/agent-runtime.js +115 -0
  36. package/dist/agent-runtime.js.map +1 -0
  37. package/dist/{chat/shared.d.ts → agent-types.d.ts} +2 -2
  38. package/dist/agent-types.d.ts.map +1 -0
  39. package/dist/agent-types.js +2 -0
  40. package/dist/agent-types.js.map +1 -0
  41. package/dist/cli.js +1 -1
  42. package/dist/cli.js.map +1 -1
  43. package/package.json +12 -10
  44. package/scripts/check-publish-tool.mjs +27 -0
  45. package/src/__tests__/chat.test.ts +14 -14
  46. package/src/{chat/commands → agent-commands}/back.ts +5 -6
  47. package/src/{chat/commands → agent-commands}/editor.ts +3 -4
  48. package/src/{chat/commands → agent-commands}/exit.ts +1 -1
  49. package/src/{chat/commands → agent-commands}/index.ts +1 -1
  50. package/src/{chat/commands → agent-commands}/load.ts +4 -4
  51. package/src/{chat/commands → agent-commands}/new.ts +4 -4
  52. package/src/{chat/commands → agent-commands}/save.ts +2 -2
  53. package/src/agent-constants.ts +15 -0
  54. package/src/agent-runtime.ts +119 -0
  55. package/src/agent-types.ts +6 -0
  56. package/src/cli.ts +1 -1
  57. package/dist/chat/commands/back.d.ts +0 -3
  58. package/dist/chat/commands/back.d.ts.map +0 -1
  59. package/dist/chat/commands/back.js.map +0 -1
  60. package/dist/chat/commands/editor.d.ts +0 -3
  61. package/dist/chat/commands/editor.d.ts.map +0 -1
  62. package/dist/chat/commands/editor.js.map +0 -1
  63. package/dist/chat/commands/exit.d.ts +0 -3
  64. package/dist/chat/commands/exit.d.ts.map +0 -1
  65. package/dist/chat/commands/exit.js.map +0 -1
  66. package/dist/chat/commands/help.d.ts.map +0 -1
  67. package/dist/chat/commands/help.js.map +0 -1
  68. package/dist/chat/commands/index.d.ts +0 -3
  69. package/dist/chat/commands/index.d.ts.map +0 -1
  70. package/dist/chat/commands/index.js.map +0 -1
  71. package/dist/chat/commands/load.d.ts +0 -3
  72. package/dist/chat/commands/load.d.ts.map +0 -1
  73. package/dist/chat/commands/load.js.map +0 -1
  74. package/dist/chat/commands/new.d.ts +0 -3
  75. package/dist/chat/commands/new.d.ts.map +0 -1
  76. package/dist/chat/commands/new.js.map +0 -1
  77. package/dist/chat/commands/save.d.ts +0 -3
  78. package/dist/chat/commands/save.d.ts.map +0 -1
  79. package/dist/chat/commands/save.js.map +0 -1
  80. package/dist/chat/message.d.ts +0 -3
  81. package/dist/chat/message.d.ts.map +0 -1
  82. package/dist/chat/message.js +0 -31
  83. package/dist/chat/message.js.map +0 -1
  84. package/dist/chat/print.d.ts +0 -3
  85. package/dist/chat/print.d.ts.map +0 -1
  86. package/dist/chat/print.js +0 -24
  87. package/dist/chat/print.js.map +0 -1
  88. package/dist/chat/runtime.d.ts.map +0 -1
  89. package/dist/chat/runtime.js +0 -64
  90. package/dist/chat/runtime.js.map +0 -1
  91. package/dist/chat/shared.d.ts.map +0 -1
  92. package/dist/chat/shared.js +0 -16
  93. package/dist/chat/shared.js.map +0 -1
  94. package/src/chat/message.ts +0 -27
  95. package/src/chat/print.ts +0 -27
  96. package/src/chat/runtime.ts +0 -65
  97. package/src/chat/shared.ts +0 -21
  98. /package/dist/{chat/commands → agent-commands}/exit.js +0 -0
  99. /package/dist/{chat/commands → agent-commands}/help.d.ts +0 -0
  100. /package/dist/{chat/commands → agent-commands}/help.js +0 -0
  101. /package/dist/{chat/commands → agent-commands}/index.js +0 -0
  102. /package/src/{chat/commands → agent-commands}/help.ts +0 -0
@@ -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"}
@@ -1,64 +0,0 @@
1
- import { Message } from "@ai-zen/agents-core";
2
- import inquirer from "inquirer";
3
- import { readConfig, readMessages, saveMessages, saveSnapshot } from "../config.js";
4
- import { buildAgent } from "../agent-factory.js";
5
- import { contextSize } from "../migration.js";
6
- import { SYSTEM_PROMPT } from "./shared.js";
7
- import { dispatchCommand } from "./commands/index.js";
8
- import { handleMessage } from "./message.js";
9
- import { sendAndPrint } from "./print.js";
10
- async function chatLoop(ctx) {
11
- while (true) {
12
- const { input } = await inquirer.prompt([
13
- { type: "input", name: "input", message: "你:" },
14
- ]);
15
- const t = input.trim();
16
- if (!t)
17
- continue;
18
- if (t.startsWith("/")) {
19
- await dispatchCommand(ctx, t.toLowerCase());
20
- continue;
21
- }
22
- await handleMessage(ctx, t);
23
- }
24
- }
25
- export async function runChat(initialMessage) {
26
- const config = readConfig();
27
- if (!config.apiKey) {
28
- console.error("❌ 请先设置 API Key: air key <your-key>");
29
- console.error(" 获取 Key: https://platform.deepseek.com/api_keys");
30
- process.exit(1);
31
- }
32
- let msgs = readMessages();
33
- if (msgs.length === 0) {
34
- msgs = [Message.System(SYSTEM_PROMPT)];
35
- saveMessages(msgs);
36
- }
37
- const agent = await buildAgent(msgs);
38
- const ctx = { agent };
39
- if (initialMessage) {
40
- const hasHistory = ctx.agent.messages.some(m => m.role === "user" || m.role === "assistant");
41
- if (hasHistory) {
42
- const snap = saveSnapshot(ctx.agent.messages);
43
- console.log(`💾 已存档旧对话: ${snap}\n`);
44
- }
45
- await dispatchCommand(ctx, "/new");
46
- console.log(`💬 你: ${initialMessage}`);
47
- try {
48
- await sendAndPrint(ctx.agent, initialMessage);
49
- saveMessages(ctx.agent.messages);
50
- }
51
- catch (err) {
52
- console.error(`\n❌ ${err.message}`);
53
- }
54
- console.log("\n💬 继续对话 (输入 /exit 退出)\n");
55
- await chatLoop(ctx);
56
- return;
57
- }
58
- const msgCount = ctx.agent.messages.filter((m) => m.role !== "system").length;
59
- console.log(msgCount > 0
60
- ? `\n💬 继续上次对话 (${msgCount} 条,/${contextSize(ctx.agent.messages)} 字符,输入 /new 重新开始)\n`
61
- : "\n💬 air — 极简 AI 助手 (输入 /help 查看命令)\n");
62
- await chatLoop(ctx);
63
- }
64
- //# sourceMappingURL=runtime.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"runtime.js","sourceRoot":"","sources":["../../src/chat/runtime.ts"],"names":[],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"shared.d.ts","sourceRoot":"","sources":["../../src/chat/shared.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,qBAAqB,CAAC;AAE5C,MAAM,WAAW,OAAO;IACtB,KAAK,EAAE,KAAK,CAAC;CACd;AAED,eAAO,MAAM,aAAa,QAcd,CAAC"}
@@ -1,16 +0,0 @@
1
- export const SYSTEM_PROMPT = [
2
- "你是一个AI助手,专门帮助用户回答问题和执行任务。请用中文回复。",
3
- "",
4
- "## 行为准则",
5
- "1. 做任何改动之前,必须先跟用户商量,获得明确指示之后再行动。",
6
- "2. 用户没有明确要求产出文件时,不得自行创建任何文件到项目中。讨论就停留在讨论层面。",
7
- "3. 区分危险操作:删除文件、覆盖文件、安装卸载软件、修改系统配置、执行耗时任务等属于危险操作。执行前必须评估影响范围,并向用户说明风险,获得用户明确的书面的确认之后再执行。",
8
- "4. 追责原则:你的每一步操作都应当基于用户的明确指令。如果出了问题,可以从用户说过的话追溯责任——是用户让你做的,用户承担责任。所以你不需要畏手畏脚,只要用户明确说了\u201c做\u201d,你就放心去做。",
9
- "",
10
- "## 记忆",
11
- "你可以使用 shell 工具执行任何命令。如果你有需要长期记住的信息(用户偏好、项目约定、任务进度等),请写入以下位置:",
12
- "- 全局记忆: ~/.ai-zen/air/temp/*.md",
13
- "- 项目记忆: $(cwd)/.ai-zen/air/temp/*.md",
14
- "下次启动时用 shell 读取即可。这是你唯一的记忆方式。",
15
- ].join("\n");
16
- //# sourceMappingURL=shared.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"shared.js","sourceRoot":"","sources":["../../src/chat/shared.ts"],"names":[],"mappings":"AAMA,MAAM,CAAC,MAAM,aAAa,GAAG;IAC3B,kCAAkC;IAClC,EAAE;IACF,SAAS;IACT,kCAAkC;IAClC,6CAA6C;IAC7C,yFAAyF;IACzF,2GAA2G;IAC3G,EAAE;IACF,OAAO;IACP,8DAA8D;IAC9D,iCAAiC;IACjC,sCAAsC;IACtC,+BAA+B;CAChC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC"}
@@ -1,27 +0,0 @@
1
- import { Message } from "@ai-zen/agents-core";
2
- import type { ChatCtx } from "./shared.js";
3
- import { SYSTEM_PROMPT } from "./shared.js";
4
- import { sendAndPrint } from "./print.js";
5
- import { saveMessages, saveSnapshot } from "../config.js";
6
- import { buildAgent } from "../agent-factory.js";
7
- import { contextSize, shouldMigrate, generateMigrationDoc, MAX_CONTEXT_CHARS } from "../migration.js";
8
-
9
- export async function handleMessage(ctx: ChatCtx, text: string): Promise<void> {
10
- try {
11
- await sendAndPrint(ctx.agent, text);
12
- saveMessages(ctx.agent.messages);
13
-
14
- if (shouldMigrate(ctx.agent.messages)) {
15
- console.log(`🔄 上下文 ${contextSize(ctx.agent.messages)}/${MAX_CONTEXT_CHARS},准备迁移...`);
16
- try {
17
- const snap = saveSnapshot(ctx.agent.messages);
18
- console.log(` 💾 快照: ${snap}`);
19
- const summary = await generateMigrationDoc(ctx.agent.messages);
20
- const msgs = [Message.System(SYSTEM_PROMPT), Message.User(summary)];
21
- saveMessages(msgs);
22
- console.log("✅ 迁移完成\n");
23
- ctx.agent = await buildAgent(msgs);
24
- } catch (err: any) { console.error(`❌ 迁移失败: ${err.message}\n`); }
25
- }
26
- } catch (err: any) { console.error(`\n❌ ${err.message}`); }
27
- }
package/src/chat/print.ts DELETED
@@ -1,27 +0,0 @@
1
- import chalk from "chalk";
2
- import { Agent } from "@ai-zen/agents-core";
3
- import { DeltaRenderer } from "../delta-renderer.js";
4
- import type { AgentNS } from "@ai-zen/agents-core";
5
-
6
- export async function sendAndPrint(agent: Agent, text: string): Promise<void> {
7
- console.log(chalk.green.bold("\n🤖 AI:"));
8
- const renderer = new DeltaRenderer({
9
- reasoningHeader: "\n\n💭 思考中...\n",
10
- contentHeader: "\n\n💭 回答中...\n",
11
- });
12
-
13
- function onChunk(chunk: AgentNS.StreamResponseData) {
14
- const delta = chunk?.choices?.[0]?.delta;
15
- const fr = chunk?.choices?.[0]?.finish_reason ?? null;
16
- if (delta) renderer.render(delta, fr);
17
- }
18
-
19
- function onRun() { renderer.reset(); }
20
- agent.events.on("run", onRun);
21
- agent.events.on("chunk", onChunk);
22
- await agent.send(text);
23
- agent.events.off("run", onRun);
24
- agent.events.off("chunk", onChunk);
25
- process.stdout.write("\n\n");
26
- console.log();
27
- }
@@ -1,65 +0,0 @@
1
- import { Agent, Message } from "@ai-zen/agents-core";
2
- import inquirer from "inquirer";
3
- import { readConfig, readMessages, saveMessages, saveSnapshot } from "../config.js";
4
- import { buildAgent } from "../agent-factory.js";
5
- import { contextSize } from "../migration.js";
6
- import { ChatCtx, SYSTEM_PROMPT } from "./shared.js";
7
- import { dispatchCommand } from "./commands/index.js";
8
- import { handleMessage } from "./message.js";
9
- import { sendAndPrint } from "./print.js";
10
-
11
- async function chatLoop(ctx: ChatCtx) {
12
- while (true) {
13
- const { input } = await inquirer.prompt([
14
- { type: "input", name: "input", message: "你:" },
15
- ]);
16
- const t = input.trim();
17
- if (!t) continue;
18
- if (t.startsWith("/")) {
19
- await dispatchCommand(ctx, t.toLowerCase());
20
- continue;
21
- }
22
- await handleMessage(ctx, t);
23
- }
24
- }
25
-
26
- export async function runChat(initialMessage?: string): Promise<void> {
27
- const config = readConfig();
28
- if (!config.apiKey) {
29
- console.error("❌ 请先设置 API Key: air key <your-key>");
30
- console.error(" 获取 Key: https://platform.deepseek.com/api_keys");
31
- process.exit(1);
32
- }
33
-
34
- let msgs = readMessages();
35
- if (msgs.length === 0) {
36
- msgs = [Message.System(SYSTEM_PROMPT)];
37
- saveMessages(msgs);
38
- }
39
- const agent: Agent = await buildAgent(msgs);
40
- const ctx: ChatCtx = { agent };
41
-
42
- if (initialMessage) {
43
- const hasHistory = ctx.agent.messages.some(m => m.role === "user" || m.role === "assistant");
44
- if (hasHistory) {
45
- const snap = saveSnapshot(ctx.agent.messages);
46
- console.log(`💾 已存档旧对话: ${snap}\n`);
47
- }
48
- await dispatchCommand(ctx, "/new");
49
- console.log(`💬 你: ${initialMessage}`);
50
- try {
51
- await sendAndPrint(ctx.agent, initialMessage);
52
- saveMessages(ctx.agent.messages);
53
- } catch (err: any) { console.error(`\n❌ ${err.message}`); }
54
- console.log("\n💬 继续对话 (输入 /exit 退出)\n");
55
- await chatLoop(ctx);
56
- return;
57
- }
58
-
59
- const msgCount = ctx.agent.messages.filter((m) => m.role !== "system").length;
60
- console.log(msgCount > 0
61
- ? `\n💬 继续上次对话 (${msgCount} 条,/${contextSize(ctx.agent.messages)} 字符,输入 /new 重新开始)\n`
62
- : "\n💬 air — 极简 AI 助手 (输入 /help 查看命令)\n");
63
-
64
- await chatLoop(ctx);
65
- }