workerclaw 0.3.7 → 0.4.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 (67) hide show
  1. package/dist/agent/agent-engine.d.ts +32 -2
  2. package/dist/agent/agent-engine.d.ts.map +1 -1
  3. package/dist/agent/agent-engine.js +188 -8
  4. package/dist/agent/agent-engine.js.map +1 -1
  5. package/dist/cli/index.js +24 -1
  6. package/dist/cli/index.js.map +1 -1
  7. package/dist/cli/sections/experience.d.ts +10 -0
  8. package/dist/cli/sections/experience.d.ts.map +1 -0
  9. package/dist/cli/sections/experience.js +148 -0
  10. package/dist/cli/sections/experience.js.map +1 -0
  11. package/dist/core/config.d.ts +2 -0
  12. package/dist/core/config.d.ts.map +1 -1
  13. package/dist/core/config.js.map +1 -1
  14. package/dist/core/events.d.ts +19 -1
  15. package/dist/core/events.d.ts.map +1 -1
  16. package/dist/core/events.js +4 -0
  17. package/dist/core/events.js.map +1 -1
  18. package/dist/core/workerclaw.d.ts +7 -0
  19. package/dist/core/workerclaw.d.ts.map +1 -1
  20. package/dist/core/workerclaw.js +30 -0
  21. package/dist/core/workerclaw.js.map +1 -1
  22. package/dist/experience/encapsulator.d.ts +95 -0
  23. package/dist/experience/encapsulator.d.ts.map +1 -0
  24. package/dist/experience/encapsulator.js +239 -0
  25. package/dist/experience/encapsulator.js.map +1 -0
  26. package/dist/experience/hub-client.d.ts +32 -0
  27. package/dist/experience/hub-client.d.ts.map +1 -0
  28. package/dist/experience/hub-client.js +126 -0
  29. package/dist/experience/hub-client.js.map +1 -0
  30. package/dist/experience/index.d.ts +13 -0
  31. package/dist/experience/index.d.ts.map +1 -0
  32. package/dist/experience/index.js +30 -0
  33. package/dist/experience/index.js.map +1 -0
  34. package/dist/experience/local-store.d.ts +102 -0
  35. package/dist/experience/local-store.d.ts.map +1 -0
  36. package/dist/experience/local-store.js +321 -0
  37. package/dist/experience/local-store.js.map +1 -0
  38. package/dist/experience/manager.d.ts +71 -0
  39. package/dist/experience/manager.d.ts.map +1 -0
  40. package/dist/experience/manager.js +184 -0
  41. package/dist/experience/manager.js.map +1 -0
  42. package/dist/experience/search-engine.d.ts +80 -0
  43. package/dist/experience/search-engine.d.ts.map +1 -0
  44. package/dist/experience/search-engine.js +258 -0
  45. package/dist/experience/search-engine.js.map +1 -0
  46. package/dist/experience/signal-detector.d.ts +33 -0
  47. package/dist/experience/signal-detector.d.ts.map +1 -0
  48. package/dist/experience/signal-detector.js +182 -0
  49. package/dist/experience/signal-detector.js.map +1 -0
  50. package/dist/experience/types.d.ts +189 -0
  51. package/dist/experience/types.d.ts.map +1 -0
  52. package/dist/experience/types.js +7 -0
  53. package/dist/experience/types.js.map +1 -0
  54. package/dist/index.d.ts +3 -1
  55. package/dist/index.d.ts.map +1 -1
  56. package/dist/index.js +3 -1
  57. package/dist/index.js.map +1 -1
  58. package/dist/task/task-evaluator.d.ts.map +1 -1
  59. package/dist/task/task-evaluator.js +4 -1
  60. package/dist/task/task-evaluator.js.map +1 -1
  61. package/dist/task/task-manager.d.ts +14 -0
  62. package/dist/task/task-manager.d.ts.map +1 -1
  63. package/dist/task/task-manager.js +127 -5
  64. package/dist/task/task-manager.js.map +1 -1
  65. package/dist/types/task.d.ts +2 -0
  66. package/dist/types/task.d.ts.map +1 -1
  67. package/package.json +1 -1
@@ -0,0 +1,321 @@
1
+ /**
2
+ * 本地经验池存储
3
+ *
4
+ * 基于 JSON 文件的轻量存储方案
5
+ * 存储 genes + capsules + events + reports
6
+ */
7
+ import { existsSync, mkdirSync, readFileSync, writeFileSync } from 'node:fs';
8
+ import { join } from 'node:path';
9
+ import { createLogger } from '../core/logger.js';
10
+ // ==================== 本地经验池 ====================
11
+ export class LocalExperienceStore {
12
+ logger;
13
+ storePath;
14
+ genes = new Map();
15
+ capsules = new Map();
16
+ events = [];
17
+ reports = [];
18
+ initialized = false;
19
+ constructor(storagePath) {
20
+ this.logger = createLogger('ExperienceStore');
21
+ this.storePath = storagePath;
22
+ }
23
+ // ==================== 初始化 ====================
24
+ /**
25
+ * 初始化存储(加载已有数据)
26
+ */
27
+ async init() {
28
+ if (this.initialized)
29
+ return;
30
+ try {
31
+ // 确保目录存在
32
+ if (!existsSync(this.storePath)) {
33
+ mkdirSync(this.storePath, { recursive: true });
34
+ }
35
+ // 加载数据
36
+ await this.loadGenes();
37
+ await this.loadCapsules();
38
+ await this.loadEvents();
39
+ await this.loadReports();
40
+ this.initialized = true;
41
+ this.logger.info(`本地经验池已加载`, {
42
+ genes: this.genes.size,
43
+ capsules: this.capsules.size,
44
+ events: this.events.length,
45
+ });
46
+ }
47
+ catch (err) {
48
+ this.logger.error('本地经验池初始化失败', { error: err.message });
49
+ // 失败不阻塞启动,使用空经验池
50
+ this.initialized = true;
51
+ }
52
+ }
53
+ // ==================== 基因操作 ====================
54
+ /**
55
+ * 保存基因
56
+ */
57
+ async saveGene(gene) {
58
+ this.genes.set(gene.gene_id, gene);
59
+ await this.persistGenes();
60
+ this.logger.debug(`基因已保存 [${gene.gene_id.slice(0, 12)}...]`, {
61
+ category: gene.category,
62
+ signals: gene.signals.length,
63
+ });
64
+ }
65
+ /**
66
+ * 获取基因
67
+ */
68
+ getGene(geneId) {
69
+ return this.genes.get(geneId);
70
+ }
71
+ /**
72
+ * 获取所有基因
73
+ */
74
+ getAllGenes() {
75
+ return Array.from(this.genes.values());
76
+ }
77
+ /**
78
+ * 按分类获取基因
79
+ */
80
+ getGenesByCategory(category) {
81
+ return Array.from(this.genes.values()).filter(g => g.category === category);
82
+ }
83
+ /**
84
+ * 删除基因(同时删除关联的胶囊)
85
+ */
86
+ async deleteGene(geneId) {
87
+ const gene = this.genes.get(geneId);
88
+ if (!gene)
89
+ return false;
90
+ // 删除关联胶囊
91
+ for (const [capId, cap] of this.capsules) {
92
+ if (cap.gene_id === geneId) {
93
+ this.capsules.delete(capId);
94
+ }
95
+ }
96
+ this.genes.delete(geneId);
97
+ await Promise.all([this.persistGenes(), this.persistCapsules()]);
98
+ return true;
99
+ }
100
+ // ==================== 胶囊操作 ====================
101
+ /**
102
+ * 保存胶囊
103
+ */
104
+ async saveCapsule(capsule) {
105
+ this.capsules.set(capsule.capsule_id, capsule);
106
+ // 同时确保关联的基因存在
107
+ if (!this.genes.has(capsule.gene_id) && capsule.context) {
108
+ // 胶囊可以独立存在(基因可能来自 Hub)
109
+ }
110
+ await this.persistCapsules();
111
+ this.logger.debug(`胶囊已保存 [${capsule.capsule_id.slice(0, 12)}...]`);
112
+ }
113
+ /**
114
+ * 获取胶囊
115
+ */
116
+ getCapsule(capsuleId) {
117
+ return this.capsules.get(capsuleId);
118
+ }
119
+ /**
120
+ * 获取基因关联的胶囊列表
121
+ */
122
+ getCapsulesByGene(geneId) {
123
+ return Array.from(this.capsules.values()).filter(c => c.gene_id === geneId);
124
+ }
125
+ /**
126
+ * 获取最佳胶囊(按置信度排序)
127
+ */
128
+ getBestCapsule(geneId) {
129
+ const capsules = this.getCapsulesByGene(geneId);
130
+ if (capsules.length === 0)
131
+ return undefined;
132
+ return capsules.sort((a, b) => b.confidence - a.confidence)[0];
133
+ }
134
+ // ==================== 事件操作 ====================
135
+ /**
136
+ * 记录进化事件
137
+ */
138
+ async recordEvent(event) {
139
+ this.events.push(event);
140
+ await this.persistEvents();
141
+ this.logger.debug(`进化事件已记录`, {
142
+ intent: event.intent,
143
+ status: event.outcome.status,
144
+ });
145
+ }
146
+ /**
147
+ * 获取最近的进化事件
148
+ */
149
+ getRecentEvents(limit = 20) {
150
+ return this.events.slice(-limit).reverse();
151
+ }
152
+ // ==================== 报告操作 ====================
153
+ /**
154
+ * 记录验证报告(待同步到 Hub)
155
+ */
156
+ async addReport(report) {
157
+ this.reports.push(report);
158
+ await this.persistReports();
159
+ }
160
+ /**
161
+ * 获取待同步的报告
162
+ */
163
+ getPendingReports() {
164
+ return [...this.reports];
165
+ }
166
+ /**
167
+ * 清除已同步的报告
168
+ */
169
+ async clearReports() {
170
+ this.reports = [];
171
+ await this.persistReports();
172
+ }
173
+ // ==================== 搜索 ====================
174
+ /**
175
+ * 按信号搜索(关键词匹配)
176
+ */
177
+ searchBySignals(signals) {
178
+ const results = [];
179
+ const normalizedSignals = signals.map(s => s.toLowerCase());
180
+ for (const gene of this.genes.values()) {
181
+ // 计算匹配度
182
+ const matchScore = this.computeMatchScore(gene, normalizedSignals);
183
+ if (matchScore < 0.2)
184
+ continue; // 最低匹配阈值
185
+ // 获取最佳胶囊
186
+ const capsule = this.getBestCapsule(gene.gene_id);
187
+ if (!capsule)
188
+ continue;
189
+ results.push({
190
+ gene,
191
+ capsule,
192
+ matchScore,
193
+ source: 'local',
194
+ });
195
+ }
196
+ // 按匹配度排序
197
+ return results.sort((a, b) => b.matchScore - a.matchScore);
198
+ }
199
+ /**
200
+ * 计算基因与信号的匹配度
201
+ */
202
+ computeMatchScore(gene, normalizedSignals) {
203
+ let matched = 0;
204
+ let total = gene.signals.length;
205
+ for (const geneSignal of gene.signals) {
206
+ const normalizedGene = geneSignal.toLowerCase();
207
+ for (const querySignal of normalizedSignals) {
208
+ if (normalizedGene.includes(querySignal) || querySignal.includes(normalizedGene)) {
209
+ matched++;
210
+ break;
211
+ }
212
+ }
213
+ }
214
+ if (total === 0)
215
+ return 0;
216
+ return matched / total;
217
+ }
218
+ // ==================== 统计 ====================
219
+ getStats() {
220
+ const categories = {
221
+ task_fix: 0, env_fix: 0, api_compat: 0, performance: 0, security: 0,
222
+ };
223
+ for (const gene of this.genes.values()) {
224
+ categories[gene.category]++;
225
+ }
226
+ return {
227
+ genes: this.genes.size,
228
+ capsules: this.capsules.size,
229
+ events: this.events.length,
230
+ categories,
231
+ };
232
+ }
233
+ // ==================== 持久化 ====================
234
+ get filePaths() {
235
+ return {
236
+ genes: join(this.storePath, 'genes.json'),
237
+ capsules: join(this.storePath, 'capsules.json'),
238
+ events: join(this.storePath, 'events.json'),
239
+ reports: join(this.storePath, 'reports.json'),
240
+ };
241
+ }
242
+ async loadGenes() {
243
+ const { genes: filePath } = this.filePaths;
244
+ if (!existsSync(filePath))
245
+ return;
246
+ try {
247
+ const data = JSON.parse(readFileSync(filePath, 'utf-8'));
248
+ if (Array.isArray(data)) {
249
+ for (const gene of data) {
250
+ this.genes.set(gene.gene_id, gene);
251
+ }
252
+ }
253
+ }
254
+ catch (err) {
255
+ this.logger.warn('基因数据加载失败,将使用空经验池', { error: err.message });
256
+ }
257
+ }
258
+ async loadCapsules() {
259
+ const { capsules: filePath } = this.filePaths;
260
+ if (!existsSync(filePath))
261
+ return;
262
+ try {
263
+ const data = JSON.parse(readFileSync(filePath, 'utf-8'));
264
+ if (Array.isArray(data)) {
265
+ for (const cap of data) {
266
+ this.capsules.set(cap.capsule_id, cap);
267
+ }
268
+ }
269
+ }
270
+ catch (err) {
271
+ this.logger.warn('胶囊数据加载失败', { error: err.message });
272
+ }
273
+ }
274
+ async loadEvents() {
275
+ const { events: filePath } = this.filePaths;
276
+ if (!existsSync(filePath))
277
+ return;
278
+ try {
279
+ const data = JSON.parse(readFileSync(filePath, 'utf-8'));
280
+ if (Array.isArray(data)) {
281
+ this.events = data;
282
+ }
283
+ }
284
+ catch (err) {
285
+ this.logger.warn('进化事件数据加载失败', { error: err.message });
286
+ }
287
+ }
288
+ async loadReports() {
289
+ const { reports: filePath } = this.filePaths;
290
+ if (!existsSync(filePath))
291
+ return;
292
+ try {
293
+ const data = JSON.parse(readFileSync(filePath, 'utf-8'));
294
+ if (Array.isArray(data)) {
295
+ this.reports = data;
296
+ }
297
+ }
298
+ catch (err) {
299
+ this.logger.warn('报告数据加载失败', { error: err.message });
300
+ }
301
+ }
302
+ async persistGenes() {
303
+ const { genes: filePath } = this.filePaths;
304
+ const data = Array.from(this.genes.values());
305
+ writeFileSync(filePath, JSON.stringify(data, null, 2), 'utf-8');
306
+ }
307
+ async persistCapsules() {
308
+ const { capsules: filePath } = this.filePaths;
309
+ const data = Array.from(this.capsules.values());
310
+ writeFileSync(filePath, JSON.stringify(data, null, 2), 'utf-8');
311
+ }
312
+ async persistEvents() {
313
+ const { events: filePath } = this.filePaths;
314
+ writeFileSync(filePath, JSON.stringify(this.events, null, 2), 'utf-8');
315
+ }
316
+ async persistReports() {
317
+ const { reports: filePath } = this.filePaths;
318
+ writeFileSync(filePath, JSON.stringify(this.reports, null, 2), 'utf-8');
319
+ }
320
+ }
321
+ //# sourceMappingURL=local-store.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"local-store.js","sourceRoot":"","sources":["../../src/experience/local-store.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,71 @@
1
+ /**
2
+ * 经验管理器
3
+ *
4
+ * 统一管理经验基因系统的所有模块
5
+ * 对外提供简洁 API,集成到 WorkerClaw 主流程
6
+ */
7
+ import type { ExperienceConfig, ExperienceSearchResult, ShrimpGene, ShrimpCapsule, ShrimpEvolution, StrategyStep } from './types.js';
8
+ export declare class ExperienceManager {
9
+ private logger;
10
+ private config;
11
+ private store;
12
+ private signalDetector;
13
+ private searchEngine;
14
+ private encapsulator;
15
+ private hubClient;
16
+ private initialized;
17
+ private currentEvolution;
18
+ constructor(config: ExperienceConfig, botId: string, token: string);
19
+ /**
20
+ * 初始化经验系统
21
+ */
22
+ init(): Promise<void>;
23
+ /**
24
+ * 错误发生时自动搜索经验
25
+ */
26
+ searchOnError(errorMessage: string): Promise<ExperienceSearchResult | null>;
27
+ /**
28
+ * 手动搜索经验
29
+ */
30
+ search(keywords: string[]): Promise<ExperienceSearchResult[]>;
31
+ /**
32
+ * 从错误消息检测信号
33
+ */
34
+ detectSignals(errorMessage: string): import("./signal-detector.js").DetectedSignal;
35
+ /**
36
+ * 开始追踪任务进化过程
37
+ */
38
+ startEvolution(taskId?: string, taskType?: string): void;
39
+ /**
40
+ * 记录一次尝试(方案 + 结果)
41
+ */
42
+ recordMutation(approach: string, result: 'success' | 'failed', error?: string): void;
43
+ /**
44
+ * 完成进化追踪并封装经验
45
+ */
46
+ completeEvolution(status: 'success' | 'failed', fixSummary: string, fixSteps: StrategyStep[], errorMessage: string, options?: {
47
+ diff?: string;
48
+ filesAffected?: number;
49
+ linesChanged?: number;
50
+ components?: string[];
51
+ }): Promise<{
52
+ gene: ShrimpGene;
53
+ capsule: ShrimpCapsule;
54
+ event: ShrimpEvolution;
55
+ } | null>;
56
+ /**
57
+ * 同步 Hub(发布本地新基因 + 上报验证报告)
58
+ */
59
+ syncHub(): Promise<{
60
+ published: number;
61
+ reported: number;
62
+ }>;
63
+ getStats(): import("./local-store.js").LocalStoreStats;
64
+ getAllGenes(): ShrimpGene[];
65
+ getRecentEvents(limit?: number): ShrimpEvolution[];
66
+ /**
67
+ * 清理资源
68
+ */
69
+ dispose(): void;
70
+ }
71
+ //# sourceMappingURL=manager.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"manager.d.ts","sourceRoot":"","sources":["../../src/experience/manager.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAQH,OAAO,KAAK,EACV,gBAAgB,EAAE,sBAAsB,EACxC,UAAU,EAAE,aAAa,EAAE,eAAe,EAC1C,YAAY,EACb,MAAM,YAAY,CAAC;AAIpB,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,MAAM,CAAmB;IACjC,OAAO,CAAC,KAAK,CAAuB;IACpC,OAAO,CAAC,cAAc,CAAiB;IACvC,OAAO,CAAC,YAAY,CAAyB;IAC7C,OAAO,CAAC,YAAY,CAAyB;IAC7C,OAAO,CAAC,SAAS,CAAgC;IACjD,OAAO,CAAC,WAAW,CAAS;IAG5B,OAAO,CAAC,gBAAgB,CAMR;gBAEJ,MAAM,EAAE,gBAAgB,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM;IAoBlE;;OAEG;IACG,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAiB3B;;OAEG;IACG,aAAa,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,sBAAsB,GAAG,IAAI,CAAC;IAKjF;;OAEG;IACG,MAAM,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,sBAAsB,EAAE,CAAC;IAKnE;;OAEG;IACH,aAAa,CAAC,YAAY,EAAE,MAAM;IAMlC;;OAEG;IACH,cAAc,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,GAAG,IAAI;IASxD;;OAEG;IACH,cAAc,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,SAAS,GAAG,QAAQ,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,IAAI;IAWpF;;OAEG;IACG,iBAAiB,CACrB,MAAM,EAAE,SAAS,GAAG,QAAQ,EAC5B,UAAU,EAAE,MAAM,EAClB,QAAQ,EAAE,YAAY,EAAE,EACxB,YAAY,EAAE,MAAM,EACpB,OAAO,CAAC,EAAE;QACR,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,aAAa,CAAC,EAAE,MAAM,CAAC;QACvB,YAAY,CAAC,EAAE,MAAM,CAAC;QACtB,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;KACvB,GACA,OAAO,CAAC;QACT,IAAI,EAAE,UAAU,CAAC;QACjB,OAAO,EAAE,aAAa,CAAC;QACvB,KAAK,EAAE,eAAe,CAAC;KACxB,GAAG,IAAI,CAAC;IA8CT;;OAEG;IACG,OAAO,IAAI,OAAO,CAAC;QAAE,SAAS,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAA;KAAE,CAAC;IAoBjE,QAAQ;IAIR,WAAW,IAAI,UAAU,EAAE;IAI3B,eAAe,CAAC,KAAK,SAAK,GAAG,eAAe,EAAE;IAI9C;;OAEG;IACH,OAAO,IAAI,IAAI;CAGhB"}
@@ -0,0 +1,184 @@
1
+ /**
2
+ * 经验管理器
3
+ *
4
+ * 统一管理经验基因系统的所有模块
5
+ * 对外提供简洁 API,集成到 WorkerClaw 主流程
6
+ */
7
+ import { createLogger } from '../core/logger.js';
8
+ import { LocalExperienceStore } from './local-store.js';
9
+ import { SignalDetector } from './signal-detector.js';
10
+ import { ExperienceSearchEngine } from './search-engine.js';
11
+ import { ExperienceEncapsulator } from './encapsulator.js';
12
+ import { ShrimpHubClient } from './hub-client.js';
13
+ // ==================== 经验管理器 ====================
14
+ export class ExperienceManager {
15
+ logger;
16
+ config;
17
+ store;
18
+ signalDetector;
19
+ searchEngine;
20
+ encapsulator;
21
+ hubClient = null;
22
+ initialized = false;
23
+ // 进化追踪(当前任务)
24
+ currentEvolution = null;
25
+ constructor(config, botId, token) {
26
+ this.logger = createLogger('Experience');
27
+ this.config = config;
28
+ // 初始化子模块
29
+ this.store = new LocalExperienceStore(config.storagePath);
30
+ this.signalDetector = new SignalDetector();
31
+ this.searchEngine = new ExperienceSearchEngine(this.store, config);
32
+ this.encapsulator = new ExperienceEncapsulator(this.store, botId);
33
+ // Hub 客户端
34
+ if (config.hub.enabled) {
35
+ this.hubClient = new ShrimpHubClient(config.hub.endpoint, botId, token);
36
+ // 将 Hub 客户端传递给搜索引擎
37
+ this.searchEngine.setHubClient(this.hubClient);
38
+ }
39
+ }
40
+ // ==================== 生命周期 ====================
41
+ /**
42
+ * 初始化经验系统
43
+ */
44
+ async init() {
45
+ if (this.initialized)
46
+ return;
47
+ await this.store.init();
48
+ this.initialized = true;
49
+ const stats = this.store.getStats();
50
+ this.logger.info(`🧬 经验系统已初始化`, {
51
+ genes: stats.genes,
52
+ capsules: stats.capsules,
53
+ events: stats.events,
54
+ hubEnabled: this.config.hub.enabled,
55
+ });
56
+ }
57
+ // ==================== 搜索 API ====================
58
+ /**
59
+ * 错误发生时自动搜索经验
60
+ */
61
+ async searchOnError(errorMessage) {
62
+ if (!this.initialized)
63
+ return null;
64
+ return this.searchEngine.searchByError(errorMessage);
65
+ }
66
+ /**
67
+ * 手动搜索经验
68
+ */
69
+ async search(keywords) {
70
+ if (!this.initialized)
71
+ return [];
72
+ return this.searchEngine.searchBySignals(keywords);
73
+ }
74
+ /**
75
+ * 从错误消息检测信号
76
+ */
77
+ detectSignals(errorMessage) {
78
+ return this.signalDetector.detect(errorMessage);
79
+ }
80
+ // ==================== 进化追踪 ====================
81
+ /**
82
+ * 开始追踪任务进化过程
83
+ */
84
+ startEvolution(taskId, taskType) {
85
+ this.currentEvolution = {
86
+ taskId,
87
+ taskType,
88
+ startTime: Date.now(),
89
+ mutations: [],
90
+ };
91
+ }
92
+ /**
93
+ * 记录一次尝试(方案 + 结果)
94
+ */
95
+ recordMutation(approach, result, error) {
96
+ if (!this.currentEvolution)
97
+ return;
98
+ this.currentEvolution.mutations.push({
99
+ approach,
100
+ result,
101
+ error,
102
+ duration_ms: Date.now() - this.currentEvolution.startTime,
103
+ });
104
+ }
105
+ /**
106
+ * 完成进化追踪并封装经验
107
+ */
108
+ async completeEvolution(status, fixSummary, fixSteps, errorMessage, options) {
109
+ if (!this.config.autoEncapsulate.enabled || !this.currentEvolution) {
110
+ this.currentEvolution = null;
111
+ return null;
112
+ }
113
+ // 检测信号
114
+ const detected = this.signalDetector.detect(errorMessage);
115
+ if (!detected.shouldSearch) {
116
+ this.currentEvolution = null;
117
+ return null;
118
+ }
119
+ const process = {
120
+ signalDetected: detected.signals[0] || detected.patternName,
121
+ errorMessage,
122
+ taskId: this.currentEvolution.taskId,
123
+ taskType: this.currentEvolution.taskType,
124
+ initialApproach: this.currentEvolution.initialApproach || fixSummary,
125
+ mutations: this.currentEvolution.mutations,
126
+ finalStatus: status,
127
+ totalDurationMs: Date.now() - this.currentEvolution.startTime,
128
+ fixSummary,
129
+ fixSteps,
130
+ diff: options?.diff,
131
+ filesAffected: options?.filesAffected,
132
+ linesChanged: options?.linesChanged,
133
+ components: options?.components,
134
+ };
135
+ this.currentEvolution = null;
136
+ // 封装并保存
137
+ const result = await this.encapsulator.encapsulate(process);
138
+ if (!result)
139
+ return null;
140
+ // 如果 Hub 启用,自动发布
141
+ if (this.hubClient && this.config.hub.enabled) {
142
+ this.hubClient.publishGene(result.gene, result.capsule).catch(() => { });
143
+ }
144
+ return result;
145
+ }
146
+ // ==================== Hub 操作 ====================
147
+ /**
148
+ * 同步 Hub(发布本地新基因 + 上报验证报告)
149
+ */
150
+ async syncHub() {
151
+ if (!this.hubClient)
152
+ return { published: 0, reported: 0 };
153
+ let published = 0;
154
+ let reported = 0;
155
+ // 上报验证报告
156
+ const pendingReports = this.store.getPendingReports();
157
+ for (const report of pendingReports) {
158
+ const ok = await this.hubClient.submitReport(report);
159
+ if (ok)
160
+ reported++;
161
+ }
162
+ if (reported > 0)
163
+ await this.store.clearReports();
164
+ this.logger.info(`Hub 同步完成`, { published, reported });
165
+ return { published, reported };
166
+ }
167
+ // ==================== 统计 ====================
168
+ getStats() {
169
+ return this.store.getStats();
170
+ }
171
+ getAllGenes() {
172
+ return this.store.getAllGenes();
173
+ }
174
+ getRecentEvents(limit = 10) {
175
+ return this.store.getRecentEvents(limit);
176
+ }
177
+ /**
178
+ * 清理资源
179
+ */
180
+ dispose() {
181
+ // JSON 存储,无需特殊清理
182
+ }
183
+ }
184
+ //# sourceMappingURL=manager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"manager.js","sourceRoot":"","sources":["../../src/experience/manager.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,80 @@
1
+ /**
2
+ * 经验搜索引擎 (v2 - 本地+Hub联合 + TF-IDF语义搜索)
3
+ *
4
+ * 搜索策略:
5
+ * 1. 本地经验池:TF-IDF 关键词匹配
6
+ * 2. Hub 远程:如果有本地结果不足,补充搜索 Hub
7
+ * 3. 结果合并去重,按综合评分排序
8
+ */
9
+ import { LocalExperienceStore } from './local-store.js';
10
+ import { SignalDetector } from './signal-detector.js';
11
+ import { ShrimpHubClient } from './hub-client.js';
12
+ import type { ExperienceSearchResult, ExperienceConfig } from './types.js';
13
+ export declare class ExperienceSearchEngine {
14
+ private logger;
15
+ private store;
16
+ private signalDetector;
17
+ private config;
18
+ private hubClient;
19
+ constructor(store: LocalExperienceStore, config: ExperienceConfig, hubClient?: ShrimpHubClient);
20
+ /**
21
+ * 设置 Hub 客户端
22
+ */
23
+ setHubClient(client: ShrimpHubClient): void;
24
+ /**
25
+ * 错误发生时自动搜索匹配经验
26
+ */
27
+ searchByError(errorMessage: string): Promise<ExperienceSearchResult | null>;
28
+ /**
29
+ * 按信号手动搜索
30
+ */
31
+ searchBySignals(signals: string[]): Promise<ExperienceSearchResult[]>;
32
+ /**
33
+ * 语义搜索:基于 TF-IDF 的问题匹配
34
+ * 输入自然语言问题,提取关键词后搜索
35
+ */
36
+ semanticSearch(query: string, limit?: number): Promise<ExperienceSearchResult[]>;
37
+ /**
38
+ * 联合搜索:本地 + Hub
39
+ */
40
+ private unifiedSearch;
41
+ /**
42
+ * 本地搜索(增强版 TF-IDF 匹配)
43
+ */
44
+ private searchLocal;
45
+ /**
46
+ * 增强 TF-IDF 匹配分数计算
47
+ * 除了信号匹配外,还考虑 summary、description、tags 的关键词密度
48
+ */
49
+ private computeEnhancedScore;
50
+ /**
51
+ * Hub 搜索
52
+ */
53
+ private searchHub;
54
+ /**
55
+ * 将 Hub 返回的 GDI + matchScore 转为统一评分
56
+ */
57
+ private hubMatchToScore;
58
+ /**
59
+ * 合并本地和 Hub 结果(去重,本地优先)
60
+ */
61
+ private mergeResults;
62
+ /**
63
+ * 缓存 Hub 基因到本地(异步,不阻塞)
64
+ */
65
+ private cacheHubGene;
66
+ /**
67
+ * 从自然语言查询中提取关键词
68
+ * 简单实现:分词 + 过滤停用词 + 取长度>=2的词
69
+ */
70
+ private extractKeywords;
71
+ /**
72
+ * 获取信号检测器(供封装器使用)
73
+ */
74
+ getSignalDetector(): SignalDetector;
75
+ /**
76
+ * 获取存储实例
77
+ */
78
+ getStore(): LocalExperienceStore;
79
+ }
80
+ //# sourceMappingURL=search-engine.d.ts.map