@winspan/claude-forge 0.6.9 → 0.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/daemon/handlers/orchestration-context.d.ts +2 -0
- package/dist/daemon/handlers/orchestration-context.d.ts.map +1 -1
- package/dist/daemon/handlers/stages/11-intent-analysis.d.ts.map +1 -1
- package/dist/daemon/handlers/stages/11-intent-analysis.js +23 -2
- package/dist/daemon/handlers/stages/11-intent-analysis.js.map +1 -1
- package/dist/daemon/handlers/stages/18-complex-task.d.ts.map +1 -1
- package/dist/daemon/handlers/stages/18-complex-task.js +29 -3
- package/dist/daemon/handlers/stages/18-complex-task.js.map +1 -1
- package/dist/daemon/handlers/user-prompt-handler.d.ts.map +1 -1
- package/dist/daemon/handlers/user-prompt-handler.js +30 -7
- package/dist/daemon/handlers/user-prompt-handler.js.map +1 -1
- package/dist/utils/stage-trace.d.ts +74 -0
- package/dist/utils/stage-trace.d.ts.map +1 -0
- package/dist/utils/stage-trace.js +125 -0
- package/dist/utils/stage-trace.js.map +1 -0
- package/package.json +1 -1
|
@@ -4,6 +4,7 @@ import type { IntentAnalysis } from '../../autopilot/intent-engine.js';
|
|
|
4
4
|
import type { ActivePlanSummary } from '../../utils/plan-reader.js';
|
|
5
5
|
import type { TemplateRegistry } from '../../pipeline/template-registry.js';
|
|
6
6
|
import type { TemplateRouter } from '../../pipeline/template-router.js';
|
|
7
|
+
import type { StageTraceLogger } from '../../utils/stage-trace.js';
|
|
7
8
|
/** session 级注入缓存条目,避免同一 session 内重复注入相同内容 */
|
|
8
9
|
export interface InjectionCache {
|
|
9
10
|
decisionsKey: string;
|
|
@@ -36,5 +37,6 @@ export interface OrchestrationContext {
|
|
|
36
37
|
activePlan?: ActivePlanSummary;
|
|
37
38
|
interventionLevel?: string;
|
|
38
39
|
card?: string;
|
|
40
|
+
stageTracer: StageTraceLogger;
|
|
39
41
|
}
|
|
40
42
|
//# sourceMappingURL=orchestration-context.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"orchestration-context.d.ts","sourceRoot":"","sources":["../../../src/daemon/handlers/orchestration-context.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,kCAAkC,CAAC;AACvE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AACpE,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAC;AAC5E,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;
|
|
1
|
+
{"version":3,"file":"orchestration-context.d.ts","sourceRoot":"","sources":["../../../src/daemon/handlers/orchestration-context.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,kCAAkC,CAAC;AACvE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AACpE,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAC;AAC5E,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AACxE,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAC;AAEnE,6CAA6C;AAC7C,MAAM,WAAW,cAAc;IAC7B,YAAY,EAAE,MAAM,CAAC;IACrB,eAAe,EAAE,MAAM,CAAC;IACxB,gBAAgB,EAAE,MAAM,CAAC;IACzB,eAAe,EAAE,OAAO,CAAC;IACzB,mBAAmB,EAAE,OAAO,CAAC;IAC7B,wBAAwB,EAAE,OAAO,CAAC;CACnC;AAED;;;GAGG;AACH,MAAM,WAAW,oBAAoB;IAEnC,KAAK,EAAE,UAAU,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,cAAc,CAAC;IAG3B,iBAAiB,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACxC,mBAAmB,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACzC,cAAc,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACpC,cAAc,EAAE,GAAG,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC;IAC5C,gBAAgB,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACtC,sBAAsB,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;IACpC,wBAAwB,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC9C,oBAAoB,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;IAClC,cAAc,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACpC,gBAAgB,EAAE,gBAAgB,GAAG,IAAI,CAAC;IAC1C,cAAc,EAAE,cAAc,GAAG,IAAI,CAAC;IAGtC,QAAQ,CAAC,EAAE,cAAc,CAAC;IAC1B,UAAU,CAAC,EAAE,iBAAiB,CAAC;IAC/B,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,IAAI,CAAC,EAAE,MAAM,CAAC;IAGd,WAAW,EAAE,gBAAgB,CAAC;CAC/B"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"11-intent-analysis.d.ts","sourceRoot":"","sources":["../../../../src/daemon/handlers/stages/11-intent-analysis.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAC/D,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAKxE,wEAAwE;AACxE,qBAAa,mBAAoB,YAAW,KAAK;IAC/C,QAAQ,CAAC,IAAI,8BAAU;IACvB,QAAQ,CAAC,QAAQ,QAAQ;IAEnB,OAAO,CAAC,GAAG,EAAE,oBAAoB,GAAG,OAAO,CAAC,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"11-intent-analysis.d.ts","sourceRoot":"","sources":["../../../../src/daemon/handlers/stages/11-intent-analysis.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAC/D,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAKxE,wEAAwE;AACxE,qBAAa,mBAAoB,YAAW,KAAK;IAC/C,QAAQ,CAAC,IAAI,8BAAU;IACvB,QAAQ,CAAC,QAAQ,QAAQ;IAEnB,OAAO,CAAC,GAAG,EAAE,oBAAoB,GAAG,OAAO,CAAC,WAAW,CAAC;IAuE9D,8BAA8B;IACxB,QAAQ,CAAC,GAAG,EAAE,oBAAoB,EAAE,KAAK,EAAE,OAAO,GAAG,OAAO,CAAC,WAAW,CAAC;CA+BhF"}
|
|
@@ -25,9 +25,24 @@ export class IntentAnalysisStage {
|
|
|
25
25
|
engine_name: 'IntentEngine',
|
|
26
26
|
}, () => intentEngine.analyze(ctx.userPrompt, ctx.event.project_path, undefined, history, isForgeManaged(ctx.event.project_path), activePlan, userContext));
|
|
27
27
|
const pipelineStr = analysis.requiresPipeline ? '需要多步骤编排' : '直接执行';
|
|
28
|
-
logger.info(
|
|
28
|
+
logger.info(`[意图分析] 复杂度=${analysis.complexity} | ${pipelineStr} | ` +
|
|
29
29
|
`预估文件=${analysis.estimatedFiles} | 需求="${analysis.requirement}"`);
|
|
30
|
-
logger.info(
|
|
30
|
+
logger.info(`[意图分析] 决策理由:${analysis.reasoning}`);
|
|
31
|
+
if (analysis.searchKeywords?.length) {
|
|
32
|
+
logger.info(`[意图分析] 关键词:${analysis.searchKeywords.join(', ')}`);
|
|
33
|
+
}
|
|
34
|
+
// 记录决策依据到 stageTracer
|
|
35
|
+
ctx.stageTracer.recordDecision(this.name, {
|
|
36
|
+
context: [
|
|
37
|
+
activePlan ? `活跃计划:${activePlan.title ?? '存在'}` : '无活跃计划',
|
|
38
|
+
history && history.length > 0 ? `对话历史:${history.length} 条` : '无历史',
|
|
39
|
+
],
|
|
40
|
+
}, `复杂度=${analysis.complexity},${pipelineStr},理由:${analysis.reasoning}`);
|
|
41
|
+
ctx.stageTracer.recordAction(this.name, `调用 IntentEngine.analyze(),需求="${analysis.requirement}"`);
|
|
42
|
+
ctx.stageTracer.recordResult(this.name, {
|
|
43
|
+
type: 'continue',
|
|
44
|
+
summary: `complexity=${analysis.complexity} requiresPipeline=${analysis.requiresPipeline} estimatedFiles=${analysis.estimatedFiles}`,
|
|
45
|
+
});
|
|
31
46
|
if (analysis.searchKeywords?.length) {
|
|
32
47
|
ctx.handlerCtx.skillRegistry.setIntentKeywords(analysis.searchKeywords);
|
|
33
48
|
}
|
|
@@ -51,6 +66,12 @@ export class IntentAnalysisStage {
|
|
|
51
66
|
clarifyQuestions: [],
|
|
52
67
|
reasoning: '规则降级(AI 分析不可用)',
|
|
53
68
|
};
|
|
69
|
+
ctx.stageTracer.recordDecision(this.name, { rules: ['关键词匹配:重构/架构/迁移 → complex', '关键词匹配:ls/pwd/cat → simple', '默认 → moderate'] }, `AI 不可用,使用规则降级,判定为 ${ctx.analysis.complexity}`);
|
|
70
|
+
ctx.stageTracer.recordAction(this.name, '正则匹配用户提示关键词');
|
|
71
|
+
ctx.stageTracer.recordResult(this.name, {
|
|
72
|
+
type: 'continue',
|
|
73
|
+
summary: `降级分析:complexity=${ctx.analysis.complexity}`,
|
|
74
|
+
});
|
|
54
75
|
return { shouldTerminate: false };
|
|
55
76
|
}
|
|
56
77
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"11-intent-analysis.js","sourceRoot":"","sources":["../../../../src/daemon/handlers/stages/11-intent-analysis.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACvD,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACpD,OAAO,EAAE,MAAM,EAAE,MAAM,0BAA0B,CAAC;AAElD,wEAAwE;AACxE,MAAM,OAAO,mBAAmB;IACrB,IAAI,GAAG,MAAM,CAAC;IACd,QAAQ,GAAG,IAAI,CAAC;IAEzB,KAAK,CAAC,OAAO,CAAC,GAAyB;QACrC,MAAM,EAAE,YAAY,EAAE,aAAa,EAAE,GAAG,GAAG,CAAC,UAAU,CAAC;QACvD,IAAI,CAAC,YAAY;YAAE,OAAO,EAAE,eAAe,EAAE,KAAK,EAAE,CAAC;QAErD,MAAM,OAAO,GAAG,IAAI,cAAc,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QAEnD,+CAA+C;QAC/C,GAAG,CAAC,UAAU,CAAC,iBAAiB,CAAC,oBAAoB,CAAC,GAAG,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;QAC9E,OAAO,CAAC,qBAAqB,CAAC,GAAG,CAAC,KAAK,CAAC,YAAY,EAAE,GAAG,CAAC,cAAc,EAAE,GAAG,CAAC,gBAAgB,CAAC,CAAC;QAChG,OAAO,CAAC,mBAAmB,CAAC,GAAG,CAAC,KAAK,CAAC,YAAY,EAAE,GAAG,CAAC,cAAc,EAAE,GAAG,CAAC,gBAAgB,CAAC,CAAC;QAC9F,OAAO,CAAC,iBAAiB,CAAC,GAAG,CAAC,KAAK,CAAC,YAAY,EAAE,GAAG,CAAC,cAAc,EAAE,GAAG,CAAC,gBAAgB,CAAC,CAAC;QAE5F,MAAM,UAAU,GAAG,OAAO,CAAC,qBAAqB,CAAC,GAAG,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;QACzE,MAAM,WAAW,GAAG,OAAO,CAAC,gBAAgB,CAAC,GAAG,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;QACrE,MAAM,OAAO,GAAG,OAAO,CAAC,wBAAwB,CAAC,GAAG,CAAC,KAAK,CAAC,UAAU,EAAE,GAAG,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;QAE/F,MAAM,QAAQ,GAAG,MAAM,aAAa,CAAC,KAAK,CACxC;YACE,UAAU,EAAE,GAAG,CAAC,KAAK,CAAC,UAAU;YAChC,YAAY,EAAE,GAAG,CAAC,KAAK,CAAC,YAAY;YACpC,UAAU,EAAE,iBAAiB;YAC7B,WAAW,EAAE,cAAc;SAC5B,EACD,GAAG,EAAE,CAAC,YAAY,CAAC,OAAO,CACxB,GAAG,CAAC,UAAU,EACd,GAAG,CAAC,KAAK,CAAC,YAAY,EACtB,SAAS,EACT,OAAO,EACP,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,YAAY,CAAC,EACtC,UAAU,EACV,WAAW,CACZ,CACF,CAAC;QAEF,MAAM,WAAW,GAAG,QAAQ,CAAC,gBAAgB,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC;QACnE,MAAM,CAAC,IAAI,CACT,
|
|
1
|
+
{"version":3,"file":"11-intent-analysis.js","sourceRoot":"","sources":["../../../../src/daemon/handlers/stages/11-intent-analysis.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"18-complex-task.d.ts","sourceRoot":"","sources":["../../../../src/daemon/handlers/stages/18-complex-task.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAC/D,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAOxE,qCAAqC;AACrC,qBAAa,gBAAiB,YAAW,KAAK;IAC5C,QAAQ,CAAC,IAAI,0CAAY;IACzB,QAAQ,CAAC,QAAQ,QAAQ;IAEnB,OAAO,CAAC,GAAG,EAAE,oBAAoB,GAAG,OAAO,CAAC,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"18-complex-task.d.ts","sourceRoot":"","sources":["../../../../src/daemon/handlers/stages/18-complex-task.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAC/D,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAOxE,qCAAqC;AACrC,qBAAa,gBAAiB,YAAW,KAAK;IAC5C,QAAQ,CAAC,IAAI,0CAAY;IACzB,QAAQ,CAAC,QAAQ,QAAQ;IAEnB,OAAO,CAAC,GAAG,EAAE,oBAAoB,GAAG,OAAO,CAAC,WAAW,CAAC;IAsD9D,OAAO,CAAC,SAAS;YAWH,iBAAiB;IA8C/B,OAAO,CAAC,oBAAoB;IAsBtB,QAAQ,CAAC,GAAG,EAAE,oBAAoB,EAAE,KAAK,EAAE,OAAO,GAAG,OAAO,CAAC,WAAW,CAAC;CAgDhF"}
|
|
@@ -14,21 +14,40 @@ export class ComplexTaskStage {
|
|
|
14
14
|
if (!pipelineEngine || !config.autopilot.auto_start_pipeline)
|
|
15
15
|
return { shouldTerminate: false };
|
|
16
16
|
if (pipelineEngine.hasActivePipeline(ctx.event.project_path)) {
|
|
17
|
-
logger.info('已有活跃的编排流程');
|
|
17
|
+
logger.info('[复杂任务] 已有活跃的编排流程');
|
|
18
18
|
return { shouldTerminate: false };
|
|
19
19
|
}
|
|
20
20
|
const card = this.buildCard(analysis);
|
|
21
21
|
ctx.card = card;
|
|
22
22
|
const confirmMode = config.autopilot.pipeline_confirm_mode;
|
|
23
|
+
ctx.stageTracer.recordDecision(this.name, {
|
|
24
|
+
context: [
|
|
25
|
+
`analysis.requiresPipeline=${analysis.requiresPipeline}`,
|
|
26
|
+
`interventionLevel=${interventionLevel ?? 'undefined'}`,
|
|
27
|
+
`confirmMode=${confirmMode}`,
|
|
28
|
+
],
|
|
29
|
+
}, `需要编排流程,确认模式=${confirmMode},干预级别=${interventionLevel ?? 'undefined'}`);
|
|
23
30
|
if (interventionLevel === 'auto' || confirmMode === 'auto') {
|
|
31
|
+
ctx.stageTracer.recordAction(this.name, '自动启动编排流程');
|
|
24
32
|
const response = await this.autoStartPipeline(analysis, card, ctx);
|
|
33
|
+
ctx.stageTracer.recordResult(this.name, {
|
|
34
|
+
type: 'terminate',
|
|
35
|
+
artifact: `pipeline_id=${response?.pipeline_id ?? 'unknown'}`,
|
|
36
|
+
summary: '已启动编排流程',
|
|
37
|
+
});
|
|
25
38
|
return { shouldTerminate: true, response };
|
|
26
39
|
}
|
|
27
40
|
if (confirmMode === 'prompt') {
|
|
41
|
+
ctx.stageTracer.recordAction(this.name, '提示用户选择是否启动编排');
|
|
28
42
|
const response = this.promptPipelineChoice(analysis, card, ctx);
|
|
43
|
+
ctx.stageTracer.recordResult(this.name, {
|
|
44
|
+
type: 'terminate',
|
|
45
|
+
summary: '已提示用户选择',
|
|
46
|
+
});
|
|
29
47
|
return { shouldTerminate: true, response };
|
|
30
48
|
}
|
|
31
|
-
|
|
49
|
+
ctx.stageTracer.recordAction(this.name, '预览模式,不启动编排');
|
|
50
|
+
logger.info('[复杂任务] 预览模式,不启动编排流程');
|
|
32
51
|
return { shouldTerminate: false };
|
|
33
52
|
}
|
|
34
53
|
buildCard(analysis) {
|
|
@@ -87,12 +106,19 @@ export class ComplexTaskStage {
|
|
|
87
106
|
const { analysis } = ctx;
|
|
88
107
|
if (!analysis)
|
|
89
108
|
return { shouldTerminate: false };
|
|
109
|
+
ctx.stageTracer.recordDecision(this.name, { rules: ['Pipeline 不可用时降级为直接执行'] }, `Pipeline 启动失败(${error}),切换为直接执行模式`);
|
|
110
|
+
ctx.stageTracer.recordAction(this.name, '构建降级上下文(directive + decisions)');
|
|
90
111
|
const builder = new ContextBuilder(ctx.handlerCtx);
|
|
91
112
|
const directive = ctx.handlerCtx.intentEngine?.generateDirective(analysis);
|
|
92
113
|
const decisionsContext = await builder.readDecisionsContext(analysis.requirement, ctx.event.project_path, ctx.injectionCache, ctx.injectionCacheAt).catch(() => undefined);
|
|
93
114
|
const fallbackMsg = ForgeFormatter.formatModuleNotification('pipeline', '编排流程暂时不可用,已切换为直接执行模式');
|
|
94
115
|
const context = ContextInjector.build({ content: fallbackMsg, priority: INJECT_PRIORITY.PIPELINE, topic: 'pipeline' }, { content: directive ?? undefined, priority: INJECT_PRIORITY.DIRECTIVE, topic: 'directive' }, { content: decisionsContext, priority: INJECT_PRIORITY.DECISIONS, topic: 'decisions' });
|
|
95
|
-
|
|
116
|
+
ctx.stageTracer.recordResult(this.name, {
|
|
117
|
+
type: 'terminate',
|
|
118
|
+
artifact: 'fallback_context',
|
|
119
|
+
summary: `降级完成:注入 directive + decisions 上下文`,
|
|
120
|
+
});
|
|
121
|
+
logger.info('[复杂任务处理] 降级完成:使用直接执行模式');
|
|
96
122
|
return {
|
|
97
123
|
shouldTerminate: true,
|
|
98
124
|
response: {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"18-complex-task.js","sourceRoot":"","sources":["../../../../src/daemon/handlers/stages/18-complex-task.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACvD,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAC;AAC7D,OAAO,EAAE,eAAe,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAC7E,OAAO,EAAE,MAAM,EAAE,MAAM,0BAA0B,CAAC;AAElD,qCAAqC;AACrC,MAAM,OAAO,gBAAgB;IAClB,IAAI,GAAG,QAAQ,CAAC;IAChB,QAAQ,GAAG,IAAI,CAAC;IAEzB,KAAK,CAAC,OAAO,CAAC,GAAyB;QACrC,MAAM,EAAE,QAAQ,EAAE,iBAAiB,EAAE,GAAG,GAAG,CAAC;QAC5C,IAAI,CAAC,QAAQ,IAAI,CAAC,QAAQ,CAAC,gBAAgB;YAAE,OAAO,EAAE,eAAe,EAAE,KAAK,EAAE,CAAC;QAE/E,MAAM,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,EAAE,GAAG,GAAG,CAAC,UAAU,CAAC;QAC/D,IAAI,CAAC,cAAc,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,mBAAmB;YAAE,OAAO,EAAE,eAAe,EAAE,KAAK,EAAE,CAAC;QAChG,IAAI,cAAc,CAAC,iBAAiB,CAAC,GAAG,CAAC,KAAK,CAAC,YAAY,CAAC,EAAE,CAAC;YAC7D,MAAM,CAAC,IAAI,CAAC,
|
|
1
|
+
{"version":3,"file":"18-complex-task.js","sourceRoot":"","sources":["../../../../src/daemon/handlers/stages/18-complex-task.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"user-prompt-handler.d.ts","sourceRoot":"","sources":["../../../src/daemon/handlers/user-prompt-handler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;
|
|
1
|
+
{"version":3,"file":"user-prompt-handler.d.ts","sourceRoot":"","sources":["../../../src/daemon/handlers/user-prompt-handler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AA2BpD,qBAAa,iBAAkB,SAAQ,eAAe;IACpD,oCAAoC;IACpC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,gBAAgB,CAAkB;IAE1D;;;OAGG;IACH,OAAO,CAAC,iBAAiB,CAA8B;IACvD,OAAO,CAAC,mBAAmB,CAA6B;IACxD;;;OAGG;IACH,OAAO,CAAC,cAAc,CAA6B;IACnD;;;OAGG;IACH,OAAO,CAAC,cAAc,CAAqC;IAC3D,OAAO,CAAC,gBAAgB,CAA6B;IACrD,0DAA0D;IAC1D,OAAO,CAAC,sBAAsB,CAAqB;IACnD,OAAO,CAAC,wBAAwB,CAA6B;IAE7D,8BAA8B;IAC9B,OAAO,CAAC,gBAAgB,CAAiC;IACzD,OAAO,CAAC,cAAc,CAA+B;IAErD,aAAa;IACb,OAAO,CAAC,YAAY,CAAiB;gBAEzB,GAAG,EAAE,cAAc;IAc/B,4DAA4D;IAC5D,OAAO,CAAC,oBAAoB,CAAqB;IACjD,6CAA6C;IAC7C,OAAO,CAAC,cAAc,CAA6B;IAEnD,qBAAqB;IACrB,OAAO,CAAC,iBAAiB;IAqDnB,MAAM,CAAC,KAAK,EAAE,UAAU,GAAG,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC;IAuG7D,OAAO,CAAC,YAAY;CAyBrB"}
|
|
@@ -2,6 +2,7 @@ import { BaseHookHandler } from './base-handler.js';
|
|
|
2
2
|
import { logger, relPath } from '../../utils/logger.js';
|
|
3
3
|
import { TemplateRegistry } from '../../pipeline/template-registry.js';
|
|
4
4
|
import { TemplateRouter } from '../../pipeline/template-router.js';
|
|
5
|
+
import { StageTraceLogger } from '../../utils/stage-trace.js';
|
|
5
6
|
import { FailureSignalStage } from './stages/01-failure-signal.js';
|
|
6
7
|
import { ActiveInterventionStage } from './stages/02-active-intervention.js';
|
|
7
8
|
import { InitPromptStage } from './stages/03-init-prompt.js';
|
|
@@ -116,6 +117,10 @@ export class UserPromptHandler extends BaseHookHandler {
|
|
|
116
117
|
const userPrompt = event.tool_input?.user_prompt || '';
|
|
117
118
|
if (!userPrompt)
|
|
118
119
|
return;
|
|
120
|
+
const proj = relPath(event.project_path);
|
|
121
|
+
const promptPreview = userPrompt.length > 120 ? userPrompt.slice(0, 120) + `…(共${userPrompt.length}字)` : userPrompt;
|
|
122
|
+
logger.info(`[Forge:编排] 开始 | 项目=${proj} | 提示="${promptPreview}"`);
|
|
123
|
+
const stageTracer = new StageTraceLogger();
|
|
119
124
|
const ctx = {
|
|
120
125
|
event,
|
|
121
126
|
userPrompt,
|
|
@@ -131,15 +136,15 @@ export class UserPromptHandler extends BaseHookHandler {
|
|
|
131
136
|
initPromptedAt: this.initPromptedAt,
|
|
132
137
|
templateRegistry: this.templateRegistry,
|
|
133
138
|
templateRouter: this.templateRouter,
|
|
139
|
+
stageTracer,
|
|
134
140
|
};
|
|
135
141
|
const stages = this.createStages();
|
|
136
|
-
const
|
|
137
|
-
const tracer = this.ctx.latencyTracer;
|
|
138
|
-
logger.info(`[Forge:编排] 开始 | 项目=${proj} | prompt="${userPrompt.slice(0, 60)}${userPrompt.length > 60 ? '…' : ''}"`);
|
|
142
|
+
const latencyTracer = this.ctx.latencyTracer;
|
|
139
143
|
let stageIdx = 0;
|
|
140
144
|
for (const stage of stages) {
|
|
141
145
|
stageIdx++;
|
|
142
|
-
|
|
146
|
+
stageTracer.start(stage.name, stageIdx);
|
|
147
|
+
const spanId = latencyTracer.startSpan({
|
|
143
148
|
session_id: event.session_id,
|
|
144
149
|
project_path: event.project_path,
|
|
145
150
|
trace_type: 'stage',
|
|
@@ -147,29 +152,45 @@ export class UserPromptHandler extends BaseHookHandler {
|
|
|
147
152
|
});
|
|
148
153
|
try {
|
|
149
154
|
const result = await stage.execute(ctx);
|
|
150
|
-
|
|
155
|
+
latencyTracer.endSpan(spanId);
|
|
151
156
|
if (result.shouldTerminate) {
|
|
157
|
+
stageTracer.recordResult(stage.name, {
|
|
158
|
+
type: 'terminate',
|
|
159
|
+
summary: result.response ? '返回响应给用户' : '终止流水线(无响应)',
|
|
160
|
+
});
|
|
161
|
+
stageTracer.success(stage.name);
|
|
152
162
|
logger.info(`[Forge:编排] ✓ [${stageIdx}/${stages.length}] ${stage.name} → 终止${result.response ? '(有响应)' : '(无响应)'}`);
|
|
163
|
+
logger.info(`[Forge:编排] 执行摘要:\n${stageTracer.getSummary()}`);
|
|
153
164
|
return result.response ?? undefined;
|
|
154
165
|
}
|
|
155
166
|
if (result.skipRemaining) {
|
|
167
|
+
stageTracer.recordResult(stage.name, { type: 'skip', summary: '跳过剩余 Stage' });
|
|
168
|
+
stageTracer.success(stage.name);
|
|
156
169
|
logger.info(`[Forge:编排] ✓ [${stageIdx}/${stages.length}] ${stage.name} → 跳过剩余`);
|
|
170
|
+
logger.info(`[Forge:编排] 执行摘要:\n${stageTracer.getSummary()}`);
|
|
157
171
|
break;
|
|
158
172
|
}
|
|
173
|
+
stageTracer.recordResult(stage.name, { type: 'continue', summary: '继续' });
|
|
174
|
+
stageTracer.success(stage.name);
|
|
159
175
|
logger.debug(`[Forge:编排] · [${stageIdx}/${stages.length}] ${stage.name} → 继续`);
|
|
160
176
|
}
|
|
161
177
|
catch (err) {
|
|
162
|
-
|
|
163
|
-
|
|
178
|
+
latencyTracer.endSpan(spanId);
|
|
179
|
+
const errMsg = err instanceof Error ? err.message : String(err);
|
|
180
|
+
stageTracer.error(stage.name, errMsg);
|
|
181
|
+
logger.error(`[Forge:编排] ✗ [${stageIdx}/${stages.length}] ${stage.name} 执行失败:${errMsg}`);
|
|
164
182
|
// 尝试降级处理
|
|
165
183
|
if (stage.fallback) {
|
|
166
184
|
try {
|
|
167
185
|
logger.info(`[Forge:编排] ↓ [${stageIdx}/${stages.length}] ${stage.name} 尝试降级处理`);
|
|
168
186
|
const fallbackResult = await stage.fallback(ctx, err);
|
|
169
187
|
if (fallbackResult.shouldTerminate) {
|
|
188
|
+
stageTracer.recordResult(stage.name, { type: 'terminate', summary: '降级后终止' });
|
|
170
189
|
logger.info(`[Forge:编排] ✓ [${stageIdx}/${stages.length}] ${stage.name} 降级成功 → 终止`);
|
|
190
|
+
logger.info(`[Forge:编排] 执行摘要:\n${stageTracer.getSummary()}`);
|
|
171
191
|
return fallbackResult.response ?? undefined;
|
|
172
192
|
}
|
|
193
|
+
stageTracer.recordResult(stage.name, { type: 'continue', summary: '降级后继续' });
|
|
173
194
|
logger.info(`[Forge:编排] ✓ [${stageIdx}/${stages.length}] ${stage.name} 降级成功 → 继续`);
|
|
174
195
|
continue;
|
|
175
196
|
}
|
|
@@ -180,11 +201,13 @@ export class UserPromptHandler extends BaseHookHandler {
|
|
|
180
201
|
// 关键 Stage 失败则终止流水线
|
|
181
202
|
if (stage.critical) {
|
|
182
203
|
logger.warn(`[Forge:编排] 关键 Stage 失败,终止流水线`);
|
|
204
|
+
logger.info(`[Forge:编排] 执行摘要:\n${stageTracer.getSummary()}`);
|
|
183
205
|
break;
|
|
184
206
|
}
|
|
185
207
|
}
|
|
186
208
|
}
|
|
187
209
|
logger.info(`[Forge:编排] 完成 | 项目=${proj} | 所有 Stage 通过,无响应`);
|
|
210
|
+
logger.info(`[Forge:编排] 执行摘要:\n${stageTracer.getSummary()}`);
|
|
188
211
|
}
|
|
189
212
|
createStages() {
|
|
190
213
|
return [
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"user-prompt-handler.js","sourceRoot":"","sources":["../../../src/daemon/handlers/user-prompt-handler.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,uBAAuB,CAAC;AACxD,OAAO,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAC;AACvE,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;
|
|
1
|
+
{"version":3,"file":"user-prompt-handler.js","sourceRoot":"","sources":["../../../src/daemon/handlers/user-prompt-handler.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Stage 执行透明度追踪
|
|
3
|
+
* 记录每个 Stage 的决策依据、执行动作、产出结果
|
|
4
|
+
*/
|
|
5
|
+
export interface StageTrace {
|
|
6
|
+
/** Stage 名称 */
|
|
7
|
+
stage: string;
|
|
8
|
+
/** Stage 索引(1-based) */
|
|
9
|
+
index: number;
|
|
10
|
+
/** 开始时间戳 */
|
|
11
|
+
startTs: number;
|
|
12
|
+
/** 结束时间戳 */
|
|
13
|
+
endTs?: number;
|
|
14
|
+
/** 执行状态 */
|
|
15
|
+
status: 'running' | 'success' | 'fallback' | 'error' | 'skipped';
|
|
16
|
+
/** 决策依据:使用了哪些规范/规则/上下文 */
|
|
17
|
+
decisionBasis?: {
|
|
18
|
+
conventions?: string[];
|
|
19
|
+
rules?: string[];
|
|
20
|
+
context?: string[];
|
|
21
|
+
};
|
|
22
|
+
/** 决策原因:为什么做这个决定 */
|
|
23
|
+
decisionReason?: string;
|
|
24
|
+
/** 执行动作:具体做了什么 */
|
|
25
|
+
executionAction?: string;
|
|
26
|
+
/** 执行结果:产出了什么 */
|
|
27
|
+
executionResult?: {
|
|
28
|
+
type: 'terminate' | 'continue' | 'skip';
|
|
29
|
+
artifact?: string;
|
|
30
|
+
summary?: string;
|
|
31
|
+
};
|
|
32
|
+
/** 错误信息(如果失败) */
|
|
33
|
+
error?: string;
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Stage 追踪日志器
|
|
37
|
+
* 提供结构化的 Stage 执行记录能力
|
|
38
|
+
*/
|
|
39
|
+
export declare class StageTraceLogger {
|
|
40
|
+
private traces;
|
|
41
|
+
/** 开始追踪一个 Stage */
|
|
42
|
+
start(stage: string, index: number): void;
|
|
43
|
+
/** 记录决策依据 */
|
|
44
|
+
recordDecision(stage: string, basis: {
|
|
45
|
+
conventions?: string[];
|
|
46
|
+
rules?: string[];
|
|
47
|
+
context?: string[];
|
|
48
|
+
}, reason: string): void;
|
|
49
|
+
/** 记录执行动作 */
|
|
50
|
+
recordAction(stage: string, action: string): void;
|
|
51
|
+
/** 记录执行结果 */
|
|
52
|
+
recordResult(stage: string, result: {
|
|
53
|
+
type: 'terminate' | 'continue' | 'skip';
|
|
54
|
+
artifact?: string;
|
|
55
|
+
summary?: string;
|
|
56
|
+
}): void;
|
|
57
|
+
/** 标记 Stage 成功完成 */
|
|
58
|
+
success(stage: string): void;
|
|
59
|
+
/** 标记 Stage 降级处理 */
|
|
60
|
+
fallback(stage: string, error: string): void;
|
|
61
|
+
/** 标记 Stage 失败 */
|
|
62
|
+
error(stage: string, error: string): void;
|
|
63
|
+
/** 标记 Stage 跳过 */
|
|
64
|
+
skip(stage: string): void;
|
|
65
|
+
/** 获取所有追踪记录 */
|
|
66
|
+
getTraces(): StageTrace[];
|
|
67
|
+
/** 获取简明摘要(用户友好) */
|
|
68
|
+
getSummary(): string;
|
|
69
|
+
/** 获取完整 JSON(调试用) */
|
|
70
|
+
getJSON(): string;
|
|
71
|
+
private findTrace;
|
|
72
|
+
private getStatusIcon;
|
|
73
|
+
}
|
|
74
|
+
//# sourceMappingURL=stage-trace.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stage-trace.d.ts","sourceRoot":"","sources":["../../src/utils/stage-trace.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,MAAM,WAAW,UAAU;IACzB,eAAe;IACf,KAAK,EAAE,MAAM,CAAC;IACd,wBAAwB;IACxB,KAAK,EAAE,MAAM,CAAC;IACd,YAAY;IACZ,OAAO,EAAE,MAAM,CAAC;IAChB,YAAY;IACZ,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,WAAW;IACX,MAAM,EAAE,SAAS,GAAG,SAAS,GAAG,UAAU,GAAG,OAAO,GAAG,SAAS,CAAC;IACjE,0BAA0B;IAC1B,aAAa,CAAC,EAAE;QACd,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;QACvB,KAAK,CAAC,EAAE,MAAM,EAAE,CAAC;QACjB,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;KACpB,CAAC;IACF,oBAAoB;IACpB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,kBAAkB;IAClB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,iBAAiB;IACjB,eAAe,CAAC,EAAE;QAChB,IAAI,EAAE,WAAW,GAAG,UAAU,GAAG,MAAM,CAAC;QACxC,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,OAAO,CAAC,EAAE,MAAM,CAAC;KAClB,CAAC;IACF,iBAAiB;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED;;;GAGG;AACH,qBAAa,gBAAgB;IAC3B,OAAO,CAAC,MAAM,CAAoB;IAElC,mBAAmB;IACnB,KAAK,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;IASzC,aAAa;IACb,cAAc,CACZ,KAAK,EAAE,MAAM,EACb,KAAK,EAAE;QAAE,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,EAAE,CAAC;QAAC,OAAO,CAAC,EAAE,MAAM,EAAE,CAAA;KAAE,EACvE,MAAM,EAAE,MAAM,GACb,IAAI;IAQP,aAAa;IACb,YAAY,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,IAAI;IAOjD,aAAa;IACb,YAAY,CACV,KAAK,EAAE,MAAM,EACb,MAAM,EAAE;QACN,IAAI,EAAE,WAAW,GAAG,UAAU,GAAG,MAAM,CAAC;QACxC,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,OAAO,CAAC,EAAE,MAAM,CAAC;KAClB,GACA,IAAI;IAOP,oBAAoB;IACpB,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAQ5B,oBAAoB;IACpB,QAAQ,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;IAS5C,kBAAkB;IAClB,KAAK,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;IASzC,kBAAkB;IAClB,IAAI,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAQzB,eAAe;IACf,SAAS,IAAI,UAAU,EAAE;IAIzB,mBAAmB;IACnB,UAAU,IAAI,MAAM;IAwBpB,qBAAqB;IACrB,OAAO,IAAI,MAAM;IAIjB,OAAO,CAAC,SAAS;IAUjB,OAAO,CAAC,aAAa;CAStB"}
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Stage 执行透明度追踪
|
|
3
|
+
* 记录每个 Stage 的决策依据、执行动作、产出结果
|
|
4
|
+
*/
|
|
5
|
+
/**
|
|
6
|
+
* Stage 追踪日志器
|
|
7
|
+
* 提供结构化的 Stage 执行记录能力
|
|
8
|
+
*/
|
|
9
|
+
export class StageTraceLogger {
|
|
10
|
+
traces = [];
|
|
11
|
+
/** 开始追踪一个 Stage */
|
|
12
|
+
start(stage, index) {
|
|
13
|
+
this.traces.push({
|
|
14
|
+
stage,
|
|
15
|
+
index,
|
|
16
|
+
startTs: Date.now(),
|
|
17
|
+
status: 'running',
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
/** 记录决策依据 */
|
|
21
|
+
recordDecision(stage, basis, reason) {
|
|
22
|
+
const trace = this.findTrace(stage);
|
|
23
|
+
if (trace) {
|
|
24
|
+
trace.decisionBasis = basis;
|
|
25
|
+
trace.decisionReason = reason;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
/** 记录执行动作 */
|
|
29
|
+
recordAction(stage, action) {
|
|
30
|
+
const trace = this.findTrace(stage);
|
|
31
|
+
if (trace) {
|
|
32
|
+
trace.executionAction = action;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
/** 记录执行结果 */
|
|
36
|
+
recordResult(stage, result) {
|
|
37
|
+
const trace = this.findTrace(stage);
|
|
38
|
+
if (trace) {
|
|
39
|
+
trace.executionResult = result;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
/** 标记 Stage 成功完成 */
|
|
43
|
+
success(stage) {
|
|
44
|
+
const trace = this.findTrace(stage);
|
|
45
|
+
if (trace) {
|
|
46
|
+
trace.status = 'success';
|
|
47
|
+
trace.endTs = Date.now();
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
/** 标记 Stage 降级处理 */
|
|
51
|
+
fallback(stage, error) {
|
|
52
|
+
const trace = this.findTrace(stage);
|
|
53
|
+
if (trace) {
|
|
54
|
+
trace.status = 'fallback';
|
|
55
|
+
trace.error = error;
|
|
56
|
+
trace.endTs = Date.now();
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
/** 标记 Stage 失败 */
|
|
60
|
+
error(stage, error) {
|
|
61
|
+
const trace = this.findTrace(stage);
|
|
62
|
+
if (trace) {
|
|
63
|
+
trace.status = 'error';
|
|
64
|
+
trace.error = error;
|
|
65
|
+
trace.endTs = Date.now();
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
/** 标记 Stage 跳过 */
|
|
69
|
+
skip(stage) {
|
|
70
|
+
const trace = this.findTrace(stage);
|
|
71
|
+
if (trace) {
|
|
72
|
+
trace.status = 'skipped';
|
|
73
|
+
trace.endTs = Date.now();
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
/** 获取所有追踪记录 */
|
|
77
|
+
getTraces() {
|
|
78
|
+
return this.traces;
|
|
79
|
+
}
|
|
80
|
+
/** 获取简明摘要(用户友好) */
|
|
81
|
+
getSummary() {
|
|
82
|
+
const lines = [];
|
|
83
|
+
for (const trace of this.traces) {
|
|
84
|
+
const duration = trace.endTs ? `${trace.endTs - trace.startTs}ms` : '进行中';
|
|
85
|
+
const statusIcon = this.getStatusIcon(trace.status);
|
|
86
|
+
lines.push(`${statusIcon} [${trace.index}] ${trace.stage} (${duration})`);
|
|
87
|
+
if (trace.decisionReason) {
|
|
88
|
+
lines.push(` 决策:${trace.decisionReason}`);
|
|
89
|
+
}
|
|
90
|
+
if (trace.executionAction) {
|
|
91
|
+
lines.push(` 动作:${trace.executionAction}`);
|
|
92
|
+
}
|
|
93
|
+
if (trace.executionResult?.summary) {
|
|
94
|
+
lines.push(` 结果:${trace.executionResult.summary}`);
|
|
95
|
+
}
|
|
96
|
+
if (trace.error) {
|
|
97
|
+
lines.push(` 错误:${trace.error}`);
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
return lines.join('\n');
|
|
101
|
+
}
|
|
102
|
+
/** 获取完整 JSON(调试用) */
|
|
103
|
+
getJSON() {
|
|
104
|
+
return JSON.stringify(this.traces, null, 2);
|
|
105
|
+
}
|
|
106
|
+
findTrace(stage) {
|
|
107
|
+
// 从后往前找,支持同名 Stage 多次执行
|
|
108
|
+
for (let i = this.traces.length - 1; i >= 0; i--) {
|
|
109
|
+
if (this.traces[i].stage === stage && this.traces[i].status === 'running') {
|
|
110
|
+
return this.traces[i];
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
return undefined;
|
|
114
|
+
}
|
|
115
|
+
getStatusIcon(status) {
|
|
116
|
+
switch (status) {
|
|
117
|
+
case 'success': return '✓';
|
|
118
|
+
case 'fallback': return '⚠';
|
|
119
|
+
case 'error': return '✗';
|
|
120
|
+
case 'skipped': return '○';
|
|
121
|
+
case 'running': return '●';
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
//# sourceMappingURL=stage-trace.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stage-trace.js","sourceRoot":"","sources":["../../src/utils/stage-trace.ts"],"names":[],"mappings":"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"}
|