front-cpu 0.1.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.
- package/README.md +475 -0
- package/README.zh-CN.md +474 -0
- package/dist/Pipeline.d.ts +119 -0
- package/dist/Pipeline.d.ts.map +1 -0
- package/dist/Pipeline.js +373 -0
- package/dist/Pipeline.js.map +1 -0
- package/dist/debug.d.ts +3 -0
- package/dist/debug.d.ts.map +1 -0
- package/dist/debug.js +12 -0
- package/dist/debug.js.map +1 -0
- package/dist/index.d.ts +20 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +19 -0
- package/dist/index.js.map +1 -0
- package/dist/interfaces.d.ts +49 -0
- package/dist/interfaces.d.ts.map +1 -0
- package/dist/interfaces.js +8 -0
- package/dist/interfaces.js.map +1 -0
- package/dist/isa/index.d.ts +20 -0
- package/dist/isa/index.d.ts.map +1 -0
- package/dist/isa/index.js +26 -0
- package/dist/isa/index.js.map +1 -0
- package/dist/isa/types.d.ts +144 -0
- package/dist/isa/types.d.ts.map +1 -0
- package/dist/isa/types.js +10 -0
- package/dist/isa/types.js.map +1 -0
- package/dist/logging/CPUConsole.d.ts +105 -0
- package/dist/logging/CPUConsole.d.ts.map +1 -0
- package/dist/logging/CPUConsole.js +471 -0
- package/dist/logging/CPUConsole.js.map +1 -0
- package/dist/logging/CPUDebugger.d.ts +91 -0
- package/dist/logging/CPUDebugger.d.ts.map +1 -0
- package/dist/logging/CPUDebugger.js +166 -0
- package/dist/logging/CPUDebugger.js.map +1 -0
- package/dist/logging/CPUEventCollector.d.ts +90 -0
- package/dist/logging/CPUEventCollector.d.ts.map +1 -0
- package/dist/logging/CPUEventCollector.js +353 -0
- package/dist/logging/CPUEventCollector.js.map +1 -0
- package/dist/logging/CPULogger.d.ts +150 -0
- package/dist/logging/CPULogger.d.ts.map +1 -0
- package/dist/logging/CPULogger.js +336 -0
- package/dist/logging/CPULogger.js.map +1 -0
- package/dist/logging/index.d.ts +10 -0
- package/dist/logging/index.d.ts.map +1 -0
- package/dist/logging/index.js +16 -0
- package/dist/logging/index.js.map +1 -0
- package/dist/logging/runtime.d.ts +37 -0
- package/dist/logging/runtime.d.ts.map +1 -0
- package/dist/logging/runtime.js +42 -0
- package/dist/logging/runtime.js.map +1 -0
- package/dist/logging/stack-parser.d.ts +22 -0
- package/dist/logging/stack-parser.d.ts.map +1 -0
- package/dist/logging/stack-parser.js +144 -0
- package/dist/logging/stack-parser.js.map +1 -0
- package/dist/logging/types.d.ts +73 -0
- package/dist/logging/types.d.ts.map +1 -0
- package/dist/logging/types.js +47 -0
- package/dist/logging/types.js.map +1 -0
- package/dist/scheduling/ResourceStrategyRegistry.d.ts +61 -0
- package/dist/scheduling/ResourceStrategyRegistry.d.ts.map +1 -0
- package/dist/scheduling/ResourceStrategyRegistry.js +109 -0
- package/dist/scheduling/ResourceStrategyRegistry.js.map +1 -0
- package/dist/scheduling/index.d.ts +6 -0
- package/dist/scheduling/index.d.ts.map +1 -0
- package/dist/scheduling/index.js +5 -0
- package/dist/scheduling/index.js.map +1 -0
- package/dist/scheduling/types.d.ts +44 -0
- package/dist/scheduling/types.d.ts.map +1 -0
- package/dist/scheduling/types.js +5 -0
- package/dist/scheduling/types.js.map +1 -0
- package/dist/stages/EX.d.ts +17 -0
- package/dist/stages/EX.d.ts.map +1 -0
- package/dist/stages/EX.js +95 -0
- package/dist/stages/EX.js.map +1 -0
- package/dist/stages/IF.d.ts +41 -0
- package/dist/stages/IF.d.ts.map +1 -0
- package/dist/stages/IF.js +83 -0
- package/dist/stages/IF.js.map +1 -0
- package/dist/stages/RES.d.ts +17 -0
- package/dist/stages/RES.d.ts.map +1 -0
- package/dist/stages/RES.js +37 -0
- package/dist/stages/RES.js.map +1 -0
- package/dist/stages/SCH.d.ts +77 -0
- package/dist/stages/SCH.d.ts.map +1 -0
- package/dist/stages/SCH.js +270 -0
- package/dist/stages/SCH.js.map +1 -0
- package/dist/stages/WB.d.ts +19 -0
- package/dist/stages/WB.d.ts.map +1 -0
- package/dist/stages/WB.js +102 -0
- package/dist/stages/WB.js.map +1 -0
- package/dist/types.d.ts +111 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +26 -0
- package/dist/types.js.map +1 -0
- package/dist/utils/InstructionCancellation.d.ts +31 -0
- package/dist/utils/InstructionCancellation.d.ts.map +1 -0
- package/dist/utils/InstructionCancellation.js +53 -0
- package/dist/utils/InstructionCancellation.js.map +1 -0
- package/dist/utils/abortable.d.ts +30 -0
- package/dist/utils/abortable.d.ts.map +1 -0
- package/dist/utils/abortable.js +76 -0
- package/dist/utils/abortable.js.map +1 -0
- package/dist/utils/request.d.ts +27 -0
- package/dist/utils/request.d.ts.map +1 -0
- package/dist/utils/request.js +96 -0
- package/dist/utils/request.js.map +1 -0
- package/package.json +74 -0
- package/src/Pipeline.ts +475 -0
- package/src/debug.ts +15 -0
- package/src/index.ts +67 -0
- package/src/interfaces.ts +53 -0
- package/src/isa/index.ts +34 -0
- package/src/isa/types.ts +178 -0
- package/src/logging/CPUConsole.md +843 -0
- package/src/logging/CPUConsole.ts +631 -0
- package/src/logging/CPUDebugger.ts +235 -0
- package/src/logging/CPUEventCollector.ts +418 -0
- package/src/logging/CPULogger.ts +435 -0
- package/src/logging/CPU_LOGGING_DESIGN.md +1319 -0
- package/src/logging/USAGE_GUIDE.md +505 -0
- package/src/logging/index.ts +21 -0
- package/src/logging/runtime.ts +96 -0
- package/src/logging/stack-parser.ts +168 -0
- package/src/logging/types.ts +101 -0
- package/src/scheduling/ResourceStrategyRegistry.ts +124 -0
- package/src/scheduling/index.ts +13 -0
- package/src/scheduling/types.ts +47 -0
- package/src/stages/EX.ts +121 -0
- package/src/stages/IF.ts +103 -0
- package/src/stages/RES.ts +46 -0
- package/src/stages/SCH.ts +331 -0
- package/src/stages/WB.ts +127 -0
- package/src/types.ts +118 -0
- package/src/utils/InstructionCancellation.ts +73 -0
- package/src/utils/abortable.ts +89 -0
- package/src/utils/request.ts +125 -0
|
@@ -0,0 +1,471 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* CPU 控制台打印系统
|
|
3
|
+
*
|
|
4
|
+
* 职责:
|
|
5
|
+
* 1. 实时打印指令执行过程
|
|
6
|
+
* 2. 美观的彩色输出
|
|
7
|
+
* 3. 分级别控制详细程度
|
|
8
|
+
* 4. 可折叠的详细信息
|
|
9
|
+
*/
|
|
10
|
+
import { ConsoleLevel } from './types';
|
|
11
|
+
import { formatCallSourceShort } from './stack-parser';
|
|
12
|
+
export class CPUConsole {
|
|
13
|
+
constructor() {
|
|
14
|
+
this.enabled = true;
|
|
15
|
+
this.level = ConsoleLevel.NORMAL;
|
|
16
|
+
this.filter = new Set(); // 指令类型过滤
|
|
17
|
+
this.loadSettings();
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* 加载设置
|
|
21
|
+
*/
|
|
22
|
+
loadSettings() {
|
|
23
|
+
const savedLevel = localStorage.getItem('cpu-console-level');
|
|
24
|
+
if (savedLevel) {
|
|
25
|
+
this.level = parseInt(savedLevel);
|
|
26
|
+
}
|
|
27
|
+
const savedFilter = localStorage.getItem('cpu-console-filter');
|
|
28
|
+
if (savedFilter) {
|
|
29
|
+
try {
|
|
30
|
+
const types = JSON.parse(savedFilter);
|
|
31
|
+
this.filter = new Set(types);
|
|
32
|
+
}
|
|
33
|
+
catch (e) {
|
|
34
|
+
// 忽略解析错误
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* 配置方法
|
|
40
|
+
*/
|
|
41
|
+
setLevel(level) {
|
|
42
|
+
this.level = level;
|
|
43
|
+
localStorage.setItem('cpu-console-level', level.toString());
|
|
44
|
+
}
|
|
45
|
+
setFilter(types) {
|
|
46
|
+
this.filter = new Set(types);
|
|
47
|
+
localStorage.setItem('cpu-console-filter', JSON.stringify(types));
|
|
48
|
+
}
|
|
49
|
+
enable() {
|
|
50
|
+
this.enabled = true;
|
|
51
|
+
}
|
|
52
|
+
disable() {
|
|
53
|
+
this.enabled = false;
|
|
54
|
+
}
|
|
55
|
+
getLevel() {
|
|
56
|
+
return this.level;
|
|
57
|
+
}
|
|
58
|
+
// ==================== 打印方法 ====================
|
|
59
|
+
/**
|
|
60
|
+
* 指令创建
|
|
61
|
+
*/
|
|
62
|
+
onInstructionCreated(instruction) {
|
|
63
|
+
if (!this.shouldPrint(instruction.type))
|
|
64
|
+
return;
|
|
65
|
+
if (this.level >= ConsoleLevel.NORMAL) {
|
|
66
|
+
// 🔍 格式化调用源信息
|
|
67
|
+
const callSourceInfo = instruction.context.callSource
|
|
68
|
+
? ` %c📍 ${formatCallSourceShort(instruction.context.callSource)}`
|
|
69
|
+
: '';
|
|
70
|
+
// 🎯 使用与指令成功一致的分组格式
|
|
71
|
+
console.groupCollapsed(`%c[指令创建] %c${this.formatTime()} %c${instruction.type}%c${callSourceInfo}`, 'color: #3b82f6; font-weight: bold', 'color: #666; font-size: 11px', 'color: #3b82f6; font-weight: bold; background: #3b82f615; padding: 2px 6px; border-radius: 3px', 'color: #3b82f6', ...(callSourceInfo ? ['color: #8b5cf6; font-weight: bold'] : []));
|
|
72
|
+
// 🔥 显示指令基本信息
|
|
73
|
+
console.log('%c📋 指令信息:', 'color: #3b82f6; font-weight: bold');
|
|
74
|
+
console.table({
|
|
75
|
+
'Instruction ID': instruction.id,
|
|
76
|
+
'Correlation ID': instruction.context.correlationId,
|
|
77
|
+
'Type': instruction.type,
|
|
78
|
+
'Status': instruction.status,
|
|
79
|
+
'Source': instruction.context.source,
|
|
80
|
+
'Retry Count': instruction.context.retryCount,
|
|
81
|
+
});
|
|
82
|
+
// 🔥 显示指令参数
|
|
83
|
+
if (this.level >= ConsoleLevel.DEBUG) {
|
|
84
|
+
console.log('%c📝 指令参数 (Payload):', 'color: #3b82f6; font-weight: bold');
|
|
85
|
+
console.log(instruction.payload);
|
|
86
|
+
}
|
|
87
|
+
else {
|
|
88
|
+
console.log('%c📝 指令参数: (use level=DEBUG to see payload)', 'color: #666; font-style: italic');
|
|
89
|
+
}
|
|
90
|
+
// 🔥 显示调用源详情
|
|
91
|
+
if (instruction.context.callSource && this.level >= ConsoleLevel.VERBOSE) {
|
|
92
|
+
console.log('%c📍 调用源详情:', 'color: #8b5cf6; font-weight: bold');
|
|
93
|
+
console.table({
|
|
94
|
+
'File': instruction.context.callSource.file,
|
|
95
|
+
'Line': instruction.context.callSource.line,
|
|
96
|
+
'Column': instruction.context.callSource.column,
|
|
97
|
+
'Function': instruction.context.callSource.function || 'N/A',
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
console.groupEnd();
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
/**
|
|
104
|
+
* 指令成功
|
|
105
|
+
*/
|
|
106
|
+
onInstructionSuccess(instruction, duration) {
|
|
107
|
+
if (!this.shouldPrint(instruction.type))
|
|
108
|
+
return;
|
|
109
|
+
// 🔍 格式化调用源信息
|
|
110
|
+
const callSourceInfo = instruction.context.callSource
|
|
111
|
+
? ` %c📍 ${formatCallSourceShort(instruction.context.callSource)}`
|
|
112
|
+
: '';
|
|
113
|
+
// 🎯 核心:折叠分组,方便查看
|
|
114
|
+
console.groupCollapsed(`%c[指令成功] %c${this.formatTime()} %c${instruction.type}%c %c${duration}ms${callSourceInfo}`, 'color: #10b981; font-weight: bold', 'color: #666; font-size: 11px', 'color: #10b981; font-weight: bold; background: #10b98115; padding: 2px 6px; border-radius: 3px', 'color: #10b981', 'color: #10b981; font-weight: bold', ...(callSourceInfo ? ['color: #8b5cf6; font-weight: bold'] : []));
|
|
115
|
+
// 🔥 显示指令输入参数
|
|
116
|
+
if (this.level >= ConsoleLevel.NORMAL) {
|
|
117
|
+
console.log('%c📝 指令参数 (Payload):', 'color: #3b82f6; font-weight: bold');
|
|
118
|
+
console.log(instruction.payload);
|
|
119
|
+
}
|
|
120
|
+
// 🔥 显示后端返回结果
|
|
121
|
+
if (instruction.result && this.level >= ConsoleLevel.NORMAL) {
|
|
122
|
+
console.log('%c📥 后端返回 (Result):', 'color: #10b981; font-weight: bold');
|
|
123
|
+
console.log(instruction.result);
|
|
124
|
+
}
|
|
125
|
+
// 🔥 显示WB阶段真实执行内容
|
|
126
|
+
if (this.level >= ConsoleLevel.VERBOSE && instruction.writeBackExecution) {
|
|
127
|
+
const wbExec = instruction.writeBackExecution;
|
|
128
|
+
console.log('%c💾 WB阶段执行记录:', 'color: #8b5cf6; font-weight: bold');
|
|
129
|
+
if (wbExec.hasCommit) {
|
|
130
|
+
if (wbExec.commitSuccess === true) {
|
|
131
|
+
console.log(' ✅ commit() 函数执行成功');
|
|
132
|
+
console.log(' 📝 commit 调用参数:', wbExec.commitArgs);
|
|
133
|
+
}
|
|
134
|
+
else if (wbExec.commitSuccess === false) {
|
|
135
|
+
console.log(' ❌ commit() 函数执行失败');
|
|
136
|
+
console.log(' 📝 commit 调用参数:', wbExec.commitArgs);
|
|
137
|
+
console.log(' 🚨 commit 错误:', wbExec.commitError);
|
|
138
|
+
}
|
|
139
|
+
else {
|
|
140
|
+
console.log(' ⚠️ commit() 状态未知');
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
else {
|
|
144
|
+
console.log(' ⏭️ 无 commit() 函数');
|
|
145
|
+
}
|
|
146
|
+
if (wbExec.rollbackExecuted) {
|
|
147
|
+
console.log(' 🔄 执行了乐观更新回滚');
|
|
148
|
+
console.log(' 📋 回滚快照:', wbExec.rollbackSnapshot);
|
|
149
|
+
if (wbExec.rollbackError) {
|
|
150
|
+
console.log(' 🚨 回滚错误:', wbExec.rollbackError);
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
// 显示中断处理器注册(成功时)
|
|
154
|
+
if (instruction.status === 'committed') {
|
|
155
|
+
console.log(' 🎯 已注册到中断处理器 (SSE去重)');
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
// 显示流水线阶段
|
|
159
|
+
if (this.level >= ConsoleLevel.VERBOSE) {
|
|
160
|
+
this.printPipelineStages(instruction);
|
|
161
|
+
}
|
|
162
|
+
// 显示详细信息
|
|
163
|
+
if (this.level >= ConsoleLevel.DEBUG) {
|
|
164
|
+
this.printInstructionDetails(instruction);
|
|
165
|
+
}
|
|
166
|
+
console.groupEnd();
|
|
167
|
+
}
|
|
168
|
+
/**
|
|
169
|
+
* 指令被取消
|
|
170
|
+
*/
|
|
171
|
+
onInstructionCancelled(instruction, duration) {
|
|
172
|
+
if (!this.shouldPrint(instruction.type))
|
|
173
|
+
return;
|
|
174
|
+
// 🔍 格式化调用源信息
|
|
175
|
+
const callSourceInfo = instruction.context.callSource
|
|
176
|
+
? ` %c📍 ${formatCallSourceShort(instruction.context.callSource)}`
|
|
177
|
+
: '';
|
|
178
|
+
// 使用橙色表示取消(不同于红色的失败)
|
|
179
|
+
console.groupCollapsed(`%c[指令取消] %c${this.formatTime()} %c${instruction.type}%c %c${duration}ms${callSourceInfo}`, 'color: #f59e0b; font-weight: bold', 'color: #666; font-size: 11px', 'color: #f59e0b; font-weight: bold; background: #f59e0b15; padding: 2px 6px; border-radius: 3px', 'color: #f59e0b', 'color: #f59e0b; font-weight: bold', ...(callSourceInfo ? ['color: #8b5cf6; font-weight: bold'] : []));
|
|
180
|
+
// 显示取消原因
|
|
181
|
+
console.warn(`%c原因: ${instruction.cancelReason || '未知原因'}`, 'color: #f59e0b; font-weight: bold');
|
|
182
|
+
// 显示取消阶段
|
|
183
|
+
if (instruction.cancelledAt) {
|
|
184
|
+
console.log(`%c🔸 取消阶段: ${instruction.cancelledAt}`, 'color: #f59e0b');
|
|
185
|
+
}
|
|
186
|
+
// 🔥 显示指令输入参数
|
|
187
|
+
if (this.level >= ConsoleLevel.NORMAL) {
|
|
188
|
+
console.log('%c📝 指令参数 (Payload):', 'color: #3b82f6; font-weight: bold');
|
|
189
|
+
console.log(instruction.payload);
|
|
190
|
+
}
|
|
191
|
+
// 显示流水线阶段
|
|
192
|
+
if (this.level >= ConsoleLevel.VERBOSE) {
|
|
193
|
+
this.printPipelineStages(instruction);
|
|
194
|
+
}
|
|
195
|
+
console.groupEnd();
|
|
196
|
+
}
|
|
197
|
+
/**
|
|
198
|
+
* 指令失败
|
|
199
|
+
*/
|
|
200
|
+
onInstructionFailure(instruction, error, duration) {
|
|
201
|
+
if (!this.shouldPrint(instruction.type))
|
|
202
|
+
return;
|
|
203
|
+
// 🔍 格式化调用源信息
|
|
204
|
+
const callSourceInfo = instruction.context.callSource
|
|
205
|
+
? ` %c📍 ${formatCallSourceShort(instruction.context.callSource)}`
|
|
206
|
+
: '';
|
|
207
|
+
// 🔥 失败时自动展开,方便排查
|
|
208
|
+
console.group(`%c[指令失败] %c${this.formatTime()} %c${instruction.type}%c %c${duration}ms${callSourceInfo}`, 'color: #ef4444; font-weight: bold', 'color: #666; font-size: 11px', 'color: #ef4444; font-weight: bold; background: #ef444415; padding: 2px 6px; border-radius: 3px', 'color: #ef4444', 'color: #ef4444; font-weight: bold', ...(callSourceInfo ? ['color: #8b5cf6; font-weight: bold'] : []));
|
|
209
|
+
// 显示错误信息
|
|
210
|
+
console.error(`%c原因: ${error.message}`, 'color: #ef4444; font-weight: bold');
|
|
211
|
+
// 🔥 显示指令输入参数
|
|
212
|
+
if (this.level >= ConsoleLevel.NORMAL) {
|
|
213
|
+
console.log('%c📝 指令参数 (Payload):', 'color: #3b82f6; font-weight: bold');
|
|
214
|
+
console.log(instruction.payload);
|
|
215
|
+
}
|
|
216
|
+
// 显示是否回滚
|
|
217
|
+
if (instruction.optimisticSnapshot) {
|
|
218
|
+
console.log('%c🔄 已回滚乐观更新', 'color: #f59e0b; font-weight: bold');
|
|
219
|
+
}
|
|
220
|
+
// 显示流水线阶段
|
|
221
|
+
if (this.level >= ConsoleLevel.VERBOSE) {
|
|
222
|
+
this.printPipelineStages(instruction);
|
|
223
|
+
}
|
|
224
|
+
// 显示详细信息
|
|
225
|
+
if (this.level >= ConsoleLevel.VERBOSE) {
|
|
226
|
+
this.printInstructionDetails(instruction);
|
|
227
|
+
console.error('Error Stack:', error.stack);
|
|
228
|
+
}
|
|
229
|
+
// 🔥 智能建议
|
|
230
|
+
this.printSuggestions(instruction, error);
|
|
231
|
+
console.groupEnd();
|
|
232
|
+
}
|
|
233
|
+
/**
|
|
234
|
+
* 乐观更新应用
|
|
235
|
+
*/
|
|
236
|
+
onOptimisticApplied(instruction) {
|
|
237
|
+
if (!this.shouldPrint(instruction.type))
|
|
238
|
+
return;
|
|
239
|
+
if (this.level >= ConsoleLevel.VERBOSE) {
|
|
240
|
+
// 🔍 格式化调用源信息
|
|
241
|
+
const callSourceInfo = instruction.context.callSource
|
|
242
|
+
? ` %c📍 ${formatCallSourceShort(instruction.context.callSource)}`
|
|
243
|
+
: '';
|
|
244
|
+
console.groupCollapsed(`%c[乐观更新] %c${this.formatTime()} %c${instruction.type}%c${callSourceInfo}`, 'color: #8b5cf6; font-weight: bold', 'color: #666; font-size: 11px', 'color: #8b5cf6; font-weight: bold; background: #8b5cf615; padding: 2px 6px; border-radius: 3px', 'color: #8b5cf6', ...(callSourceInfo ? ['color: #8b5cf6; font-weight: bold'] : []));
|
|
245
|
+
// 显示乐观更新的 payload
|
|
246
|
+
if (this.level >= ConsoleLevel.DEBUG) {
|
|
247
|
+
console.log('%c📝 更新内容:', 'color: #8b5cf6; font-weight: bold');
|
|
248
|
+
console.log(instruction.payload);
|
|
249
|
+
}
|
|
250
|
+
// 显示快照信息
|
|
251
|
+
if (instruction.optimisticSnapshot) {
|
|
252
|
+
console.log('%c💾 已保存快照(用于回滚)', 'color: #10b981; font-size: 11px');
|
|
253
|
+
}
|
|
254
|
+
console.groupEnd();
|
|
255
|
+
}
|
|
256
|
+
}
|
|
257
|
+
/**
|
|
258
|
+
* 乐观更新回滚
|
|
259
|
+
*/
|
|
260
|
+
onOptimisticRolledBack(instruction, reason) {
|
|
261
|
+
if (!this.shouldPrint(instruction.type))
|
|
262
|
+
return;
|
|
263
|
+
// 回滚是重要事件,总是显示
|
|
264
|
+
if (this.level >= ConsoleLevel.MINIMAL) {
|
|
265
|
+
// 🔍 格式化调用源信息
|
|
266
|
+
const callSourceInfo = instruction.context.callSource
|
|
267
|
+
? ` %c📍 ${formatCallSourceShort(instruction.context.callSource)}`
|
|
268
|
+
: '';
|
|
269
|
+
// 🔥 回滚重要,使用展开分组便于立即查看
|
|
270
|
+
console.group(`%c[乐观回滚] %c${this.formatTime()} %c${instruction.type}%c${callSourceInfo}`, 'color: #f59e0b; font-weight: bold', 'color: #666; font-size: 11px', 'color: #f59e0b; font-weight: bold; background: #f59e0b15; padding: 2px 6px; border-radius: 3px', 'color: #f59e0b', ...(callSourceInfo ? ['color: #8b5cf6; font-weight: bold'] : []));
|
|
271
|
+
// 显示回滚原因
|
|
272
|
+
console.log('%c⚠️ 回滚原因:', 'color: #f59e0b; font-weight: bold');
|
|
273
|
+
console.log(reason);
|
|
274
|
+
// 显示指令信息
|
|
275
|
+
console.log('%c📋 指令信息:', 'color: #f59e0b; font-weight: bold');
|
|
276
|
+
console.table({
|
|
277
|
+
'Instruction ID': instruction.id,
|
|
278
|
+
'Correlation ID': instruction.context.correlationId,
|
|
279
|
+
'Type': instruction.type,
|
|
280
|
+
});
|
|
281
|
+
console.groupEnd();
|
|
282
|
+
}
|
|
283
|
+
}
|
|
284
|
+
/**
|
|
285
|
+
* 资源冲突
|
|
286
|
+
*/
|
|
287
|
+
onSchedulerConflict(instruction, conflictingWith, waitTime) {
|
|
288
|
+
if (!this.shouldPrint(instruction.type))
|
|
289
|
+
return;
|
|
290
|
+
if (this.level >= ConsoleLevel.VERBOSE) {
|
|
291
|
+
console.log(`%c ⏳ ${this.formatTime()} 资源冲突,等待 ${waitTime}ms`, 'color: #f59e0b', {
|
|
292
|
+
instructionId: instruction.id,
|
|
293
|
+
conflictingWith,
|
|
294
|
+
});
|
|
295
|
+
}
|
|
296
|
+
}
|
|
297
|
+
/**
|
|
298
|
+
* 网络请求
|
|
299
|
+
*/
|
|
300
|
+
onNetworkRequest(instruction, method, url) {
|
|
301
|
+
if (!this.shouldPrint(instruction.type))
|
|
302
|
+
return;
|
|
303
|
+
if (this.level >= ConsoleLevel.DEBUG) {
|
|
304
|
+
console.log(`%c 🌐 ${this.formatTime()} ${method} ${url}`, 'color: #06b6d4', {
|
|
305
|
+
instructionId: instruction.id,
|
|
306
|
+
correlationId: instruction.context.correlationId,
|
|
307
|
+
});
|
|
308
|
+
}
|
|
309
|
+
}
|
|
310
|
+
/**
|
|
311
|
+
* 网络响应
|
|
312
|
+
*/
|
|
313
|
+
onNetworkResponse(instruction, status, latency) {
|
|
314
|
+
if (!this.shouldPrint(instruction.type))
|
|
315
|
+
return;
|
|
316
|
+
if (this.level >= ConsoleLevel.DEBUG) {
|
|
317
|
+
const statusColor = status >= 200 && status < 300 ? '#10b981' : '#ef4444';
|
|
318
|
+
console.log(`%c ← ${this.formatTime()} HTTP ${status} (${latency}ms)`, `color: ${statusColor}`, {
|
|
319
|
+
instructionId: instruction.id,
|
|
320
|
+
});
|
|
321
|
+
}
|
|
322
|
+
}
|
|
323
|
+
// ==================== 辅助方法 ====================
|
|
324
|
+
/**
|
|
325
|
+
* 打印流水线阶段
|
|
326
|
+
*/
|
|
327
|
+
printPipelineStages(instruction) {
|
|
328
|
+
const timestamps = instruction.timestamps;
|
|
329
|
+
console.log('%c流水线阶段:', 'color: #666; font-weight: bold');
|
|
330
|
+
// 打印各阶段之间的耗时
|
|
331
|
+
const transitions = [];
|
|
332
|
+
if (timestamps.IF && timestamps.SCH) {
|
|
333
|
+
transitions.push({ label: 'IF→SCH', duration: timestamps.SCH - timestamps.IF });
|
|
334
|
+
}
|
|
335
|
+
if (timestamps.SCH && timestamps.EX) {
|
|
336
|
+
transitions.push({ label: 'SCH→EX', duration: timestamps.EX - timestamps.SCH });
|
|
337
|
+
}
|
|
338
|
+
if (timestamps.EX && timestamps.WB) {
|
|
339
|
+
transitions.push({ label: 'EX→WB', duration: timestamps.WB - timestamps.EX });
|
|
340
|
+
}
|
|
341
|
+
for (const transition of transitions) {
|
|
342
|
+
const bar = this.createDurationBar(transition.duration);
|
|
343
|
+
console.log(` %c${transition.label}%c ${bar} %c${transition.duration}ms`, 'color: #3b82f6; font-weight: bold', 'color: #666', 'color: #666; font-weight: bold');
|
|
344
|
+
}
|
|
345
|
+
// 打印总耗时
|
|
346
|
+
if (timestamps.IF && timestamps.WB) {
|
|
347
|
+
const total = timestamps.WB - timestamps.IF;
|
|
348
|
+
console.log(` %c总耗时: %c${total}ms`, 'color: #666; font-weight: bold', 'color: #10b981; font-weight: bold; font-size: 14px');
|
|
349
|
+
}
|
|
350
|
+
// 特殊标记
|
|
351
|
+
if (instruction.optimisticSnapshot) {
|
|
352
|
+
console.log(' %c✓ 乐观更新', 'color: #8b5cf6');
|
|
353
|
+
}
|
|
354
|
+
}
|
|
355
|
+
/**
|
|
356
|
+
* 打印指令详情
|
|
357
|
+
*/
|
|
358
|
+
printInstructionDetails(instruction) {
|
|
359
|
+
console.log('%c详细信息:', 'color: #666; font-weight: bold');
|
|
360
|
+
console.table({
|
|
361
|
+
'Instruction ID': instruction.id,
|
|
362
|
+
'Correlation ID': instruction.context.correlationId,
|
|
363
|
+
Type: instruction.type,
|
|
364
|
+
Status: instruction.status,
|
|
365
|
+
'Created At': instruction.timestamps.IF
|
|
366
|
+
? new Date(instruction.timestamps.IF).toISOString()
|
|
367
|
+
: 'N/A',
|
|
368
|
+
});
|
|
369
|
+
if (this.level >= ConsoleLevel.DEBUG) {
|
|
370
|
+
console.log('%cPayload:', 'color: #666; font-weight: bold', instruction.payload);
|
|
371
|
+
if (instruction.result) {
|
|
372
|
+
console.log('%cResult:', 'color: #666; font-weight: bold', instruction.result);
|
|
373
|
+
}
|
|
374
|
+
}
|
|
375
|
+
}
|
|
376
|
+
/**
|
|
377
|
+
* 打印智能建议
|
|
378
|
+
*/
|
|
379
|
+
printSuggestions(instruction, error) {
|
|
380
|
+
const suggestions = [];
|
|
381
|
+
// 根据错误类型给出建议
|
|
382
|
+
if (error.message.includes('database is locked')) {
|
|
383
|
+
suggestions.push('后端数据库锁定,检查写入许可是否正确获取');
|
|
384
|
+
}
|
|
385
|
+
if (error.message.includes('Network')) {
|
|
386
|
+
suggestions.push('网络错误,检查后端服务是否运行');
|
|
387
|
+
}
|
|
388
|
+
if (error.message.includes('timeout')) {
|
|
389
|
+
suggestions.push('请求超时,考虑增加超时时间或优化后端性能');
|
|
390
|
+
}
|
|
391
|
+
// 根据指令类型给出建议
|
|
392
|
+
const duration = instruction.timestamps.WB && instruction.timestamps.IF
|
|
393
|
+
? instruction.timestamps.WB - instruction.timestamps.IF
|
|
394
|
+
: 0;
|
|
395
|
+
if (duration > 1000) {
|
|
396
|
+
suggestions.push(`执行耗时 ${duration}ms,超过 1 秒,检查是否存在性能问题`);
|
|
397
|
+
}
|
|
398
|
+
if (suggestions.length > 0) {
|
|
399
|
+
console.log('%c💡 建议:', 'color: #f59e0b; font-weight: bold');
|
|
400
|
+
suggestions.forEach((s) => {
|
|
401
|
+
console.log(` • ${s}`);
|
|
402
|
+
});
|
|
403
|
+
}
|
|
404
|
+
}
|
|
405
|
+
/**
|
|
406
|
+
* 创建耗时条形图
|
|
407
|
+
*/
|
|
408
|
+
createDurationBar(duration) {
|
|
409
|
+
const maxWidth = 20;
|
|
410
|
+
const width = Math.min(Math.round(duration / 50), maxWidth);
|
|
411
|
+
const bar = '█'.repeat(width);
|
|
412
|
+
return bar;
|
|
413
|
+
}
|
|
414
|
+
/**
|
|
415
|
+
* 格式化时间
|
|
416
|
+
*/
|
|
417
|
+
formatTime() {
|
|
418
|
+
const now = new Date();
|
|
419
|
+
return now.toLocaleTimeString('zh-CN', {
|
|
420
|
+
hour12: false,
|
|
421
|
+
hour: '2-digit',
|
|
422
|
+
minute: '2-digit',
|
|
423
|
+
second: '2-digit',
|
|
424
|
+
fractionalSecondDigits: 3,
|
|
425
|
+
});
|
|
426
|
+
}
|
|
427
|
+
/**
|
|
428
|
+
* 判断是否应该打印
|
|
429
|
+
*/
|
|
430
|
+
shouldPrint(instructionType) {
|
|
431
|
+
if (!this.enabled)
|
|
432
|
+
return false;
|
|
433
|
+
if (this.level === ConsoleLevel.SILENT)
|
|
434
|
+
return false;
|
|
435
|
+
if (this.filter.size > 0 && !this.filter.has(instructionType))
|
|
436
|
+
return false;
|
|
437
|
+
return true;
|
|
438
|
+
}
|
|
439
|
+
// ==================== 便捷方法 ====================
|
|
440
|
+
/**
|
|
441
|
+
* 打印分隔线
|
|
442
|
+
*/
|
|
443
|
+
printSeparator(title) {
|
|
444
|
+
if (!this.enabled)
|
|
445
|
+
return;
|
|
446
|
+
if (title) {
|
|
447
|
+
console.log(`%c━━━━━━━━━━━━━━━━━━━━━━━━━━ ${title} ━━━━━━━━━━━━━━━━━━━━━━━━━━`, 'color: #666; font-weight: bold');
|
|
448
|
+
}
|
|
449
|
+
else {
|
|
450
|
+
console.log('%c━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━', 'color: #666');
|
|
451
|
+
}
|
|
452
|
+
}
|
|
453
|
+
/**
|
|
454
|
+
* 打印统计信息
|
|
455
|
+
*/
|
|
456
|
+
printStats(stats) {
|
|
457
|
+
if (!this.enabled)
|
|
458
|
+
return;
|
|
459
|
+
console.group('%c📊 流水线统计', 'color: #3b82f6; font-weight: bold; font-size: 14px');
|
|
460
|
+
console.log(` 总指令数: %c${stats.total}`, 'color: #3b82f6; font-weight: bold');
|
|
461
|
+
console.log(` 成功: %c${stats.success} %c(${((stats.success / stats.total) * 100).toFixed(1)}%)`, 'color: #10b981; font-weight: bold', 'color: #666');
|
|
462
|
+
console.log(` 失败: %c${stats.failed} %c(${((stats.failed / stats.total) * 100).toFixed(1)}%)`, 'color: #ef4444; font-weight: bold', 'color: #666');
|
|
463
|
+
console.log(` 平均延迟: %c${stats.avgLatency.toFixed(0)}ms`, 'color: #666; font-weight: bold');
|
|
464
|
+
console.groupEnd();
|
|
465
|
+
}
|
|
466
|
+
}
|
|
467
|
+
// 导出全局单例
|
|
468
|
+
export const cpuConsole = new CPUConsole();
|
|
469
|
+
// 导出枚举
|
|
470
|
+
export { ConsoleLevel };
|
|
471
|
+
//# sourceMappingURL=CPUConsole.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CPUConsole.js","sourceRoot":"","sources":["../../src/logging/CPUConsole.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAGH,OAAO,EAAE,YAAY,EAAE,MAAM,SAAS,CAAA;AACtC,OAAO,EAAE,qBAAqB,EAAE,MAAM,gBAAgB,CAAA;AAEtD,MAAM,OAAO,UAAU;IAKrB;QAJQ,YAAO,GAAY,IAAI,CAAA;QACvB,UAAK,GAAiB,YAAY,CAAC,MAAM,CAAA;QACzC,WAAM,GAAgB,IAAI,GAAG,EAAE,CAAA,CAAC,SAAS;QAG/C,IAAI,CAAC,YAAY,EAAE,CAAA;IACrB,CAAC;IAED;;OAEG;IACK,YAAY;QAClB,MAAM,UAAU,GAAG,YAAY,CAAC,OAAO,CAAC,mBAAmB,CAAC,CAAA;QAC5D,IAAI,UAAU,EAAE,CAAC;YACf,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAC,UAAU,CAAiB,CAAA;QACnD,CAAC;QAED,MAAM,WAAW,GAAG,YAAY,CAAC,OAAO,CAAC,oBAAoB,CAAC,CAAA;QAC9D,IAAI,WAAW,EAAE,CAAC;YAChB,IAAI,CAAC;gBACH,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAA;gBACrC,IAAI,CAAC,MAAM,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,CAAA;YAC9B,CAAC;YAAC,OAAO,CAAC,EAAE,CAAC;gBACX,SAAS;YACX,CAAC;QACH,CAAC;IACH,CAAC;IAED;;OAEG;IACH,QAAQ,CAAC,KAAmB;QAC1B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAA;QAClB,YAAY,CAAC,OAAO,CAAC,mBAAmB,EAAE,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAA;IAC7D,CAAC;IAED,SAAS,CAAC,KAAe;QACvB,IAAI,CAAC,MAAM,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,CAAA;QAC5B,YAAY,CAAC,OAAO,CAAC,oBAAoB,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAA;IACnE,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,OAAO,GAAG,IAAI,CAAA;IACrB,CAAC;IAED,OAAO;QACL,IAAI,CAAC,OAAO,GAAG,KAAK,CAAA;IACtB,CAAC;IAED,QAAQ;QACN,OAAO,IAAI,CAAC,KAAK,CAAA;IACnB,CAAC;IAED,iDAAiD;IAEjD;;OAEG;IACH,oBAAoB,CAAC,WAA8B;QACjD,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,IAAI,CAAC;YAAE,OAAM;QAE/C,IAAI,IAAI,CAAC,KAAK,IAAI,YAAY,CAAC,MAAM,EAAE,CAAC;YACtC,cAAc;YACd,MAAM,cAAc,GAAG,WAAW,CAAC,OAAO,CAAC,UAAU;gBACnD,CAAC,CAAC,SAAS,qBAAqB,CAAC,WAAW,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE;gBAClE,CAAC,CAAC,EAAE,CAAA;YAEN,oBAAoB;YACpB,OAAO,CAAC,cAAc,CACpB,cAAc,IAAI,CAAC,UAAU,EAAE,MAAM,WAAW,CAAC,IAAI,KAAK,cAAc,EAAE,EAC1E,mCAAmC,EACnC,8BAA8B,EAC9B,gGAAgG,EAChG,gBAAgB,EAChB,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,mCAAmC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CACjE,CAAA;YAED,cAAc;YACd,OAAO,CAAC,GAAG,CAAC,YAAY,EAAE,mCAAmC,CAAC,CAAA;YAC9D,OAAO,CAAC,KAAK,CAAC;gBACZ,gBAAgB,EAAE,WAAW,CAAC,EAAE;gBAChC,gBAAgB,EAAE,WAAW,CAAC,OAAO,CAAC,aAAa;gBACnD,MAAM,EAAE,WAAW,CAAC,IAAI;gBACxB,QAAQ,EAAE,WAAW,CAAC,MAAM;gBAC5B,QAAQ,EAAE,WAAW,CAAC,OAAO,CAAC,MAAM;gBACpC,aAAa,EAAE,WAAW,CAAC,OAAO,CAAC,UAAU;aAC9C,CAAC,CAAA;YAEF,YAAY;YACZ,IAAI,IAAI,CAAC,KAAK,IAAI,YAAY,CAAC,KAAK,EAAE,CAAC;gBACrC,OAAO,CAAC,GAAG,CAAC,sBAAsB,EAAE,mCAAmC,CAAC,CAAA;gBACxE,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,OAAO,CAAC,CAAA;YAClC,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,GAAG,CAAC,6CAA6C,EAAE,iCAAiC,CAAC,CAAA;YAC/F,CAAC;YAED,aAAa;YACb,IAAI,WAAW,CAAC,OAAO,CAAC,UAAU,IAAI,IAAI,CAAC,KAAK,IAAI,YAAY,CAAC,OAAO,EAAE,CAAC;gBACzE,OAAO,CAAC,GAAG,CAAC,aAAa,EAAE,mCAAmC,CAAC,CAAA;gBAC/D,OAAO,CAAC,KAAK,CAAC;oBACZ,MAAM,EAAE,WAAW,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI;oBAC3C,MAAM,EAAE,WAAW,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI;oBAC3C,QAAQ,EAAE,WAAW,CAAC,OAAO,CAAC,UAAU,CAAC,MAAM;oBAC/C,UAAU,EAAE,WAAW,CAAC,OAAO,CAAC,UAAU,CAAC,QAAQ,IAAI,KAAK;iBAC7D,CAAC,CAAA;YACJ,CAAC;YAED,OAAO,CAAC,QAAQ,EAAE,CAAA;QACpB,CAAC;IACH,CAAC;IAED;;OAEG;IACH,oBAAoB,CAAC,WAA8B,EAAE,QAAgB;QACnE,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,IAAI,CAAC;YAAE,OAAM;QAE/C,cAAc;QACd,MAAM,cAAc,GAAG,WAAW,CAAC,OAAO,CAAC,UAAU;YACnD,CAAC,CAAC,SAAS,qBAAqB,CAAC,WAAW,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE;YAClE,CAAC,CAAC,EAAE,CAAA;QAEN,kBAAkB;QAClB,OAAO,CAAC,cAAc,CACpB,cAAc,IAAI,CAAC,UAAU,EAAE,MAAM,WAAW,CAAC,IAAI,QAAQ,QAAQ,KAAK,cAAc,EAAE,EAC1F,mCAAmC,EACnC,8BAA8B,EAC9B,gGAAgG,EAChG,gBAAgB,EAChB,mCAAmC,EACnC,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,mCAAmC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CACjE,CAAA;QAED,cAAc;QACd,IAAI,IAAI,CAAC,KAAK,IAAI,YAAY,CAAC,MAAM,EAAE,CAAC;YACtC,OAAO,CAAC,GAAG,CAAC,sBAAsB,EAAE,mCAAmC,CAAC,CAAA;YACxE,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,OAAO,CAAC,CAAA;QAClC,CAAC;QAED,cAAc;QACd,IAAI,WAAW,CAAC,MAAM,IAAI,IAAI,CAAC,KAAK,IAAI,YAAY,CAAC,MAAM,EAAE,CAAC;YAC5D,OAAO,CAAC,GAAG,CAAC,qBAAqB,EAAE,mCAAmC,CAAC,CAAA;YACvE,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,MAAM,CAAC,CAAA;QACjC,CAAC;QAED,kBAAkB;QAClB,IAAI,IAAI,CAAC,KAAK,IAAI,YAAY,CAAC,OAAO,IAAI,WAAW,CAAC,kBAAkB,EAAE,CAAC;YACzE,MAAM,MAAM,GAAG,WAAW,CAAC,kBAAkB,CAAA;YAC7C,OAAO,CAAC,GAAG,CAAC,gBAAgB,EAAE,mCAAmC,CAAC,CAAA;YAElE,IAAI,MAAM,CAAC,SAAS,EAAE,CAAC;gBACrB,IAAI,MAAM,CAAC,aAAa,KAAK,IAAI,EAAE,CAAC;oBAClC,OAAO,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAA;oBAClC,OAAO,CAAC,GAAG,CAAC,mBAAmB,EAAE,MAAM,CAAC,UAAU,CAAC,CAAA;gBACrD,CAAC;qBAAM,IAAI,MAAM,CAAC,aAAa,KAAK,KAAK,EAAE,CAAC;oBAC1C,OAAO,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAA;oBAClC,OAAO,CAAC,GAAG,CAAC,mBAAmB,EAAE,MAAM,CAAC,UAAU,CAAC,CAAA;oBACnD,OAAO,CAAC,GAAG,CAAC,iBAAiB,EAAE,MAAM,CAAC,WAAW,CAAC,CAAA;gBACpD,CAAC;qBAAM,CAAC;oBACN,OAAO,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAA;gBACpC,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAA;YACpC,CAAC;YAED,IAAI,MAAM,CAAC,gBAAgB,EAAE,CAAC;gBAC5B,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAA;gBAC7B,OAAO,CAAC,GAAG,CAAC,YAAY,EAAE,MAAM,CAAC,gBAAgB,CAAC,CAAA;gBAClD,IAAI,MAAM,CAAC,aAAa,EAAE,CAAC;oBACzB,OAAO,CAAC,GAAG,CAAC,YAAY,EAAE,MAAM,CAAC,aAAa,CAAC,CAAA;gBACjD,CAAC;YACH,CAAC;YAED,iBAAiB;YACjB,IAAI,WAAW,CAAC,MAAM,KAAK,WAAW,EAAE,CAAC;gBACvC,OAAO,CAAC,GAAG,CAAC,wBAAwB,CAAC,CAAA;YACvC,CAAC;QACH,CAAC;QAED,UAAU;QACV,IAAI,IAAI,CAAC,KAAK,IAAI,YAAY,CAAC,OAAO,EAAE,CAAC;YACvC,IAAI,CAAC,mBAAmB,CAAC,WAAW,CAAC,CAAA;QACvC,CAAC;QAED,SAAS;QACT,IAAI,IAAI,CAAC,KAAK,IAAI,YAAY,CAAC,KAAK,EAAE,CAAC;YACrC,IAAI,CAAC,uBAAuB,CAAC,WAAW,CAAC,CAAA;QAC3C,CAAC;QAED,OAAO,CAAC,QAAQ,EAAE,CAAA;IACpB,CAAC;IAED;;OAEG;IACH,sBAAsB,CAAC,WAA8B,EAAE,QAAgB;QACrE,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,IAAI,CAAC;YAAE,OAAM;QAE/C,cAAc;QACd,MAAM,cAAc,GAAG,WAAW,CAAC,OAAO,CAAC,UAAU;YACnD,CAAC,CAAC,SAAS,qBAAqB,CAAC,WAAW,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE;YAClE,CAAC,CAAC,EAAE,CAAA;QAEN,qBAAqB;QACrB,OAAO,CAAC,cAAc,CACpB,cAAc,IAAI,CAAC,UAAU,EAAE,MAAM,WAAW,CAAC,IAAI,QAAQ,QAAQ,KAAK,cAAc,EAAE,EAC1F,mCAAmC,EACnC,8BAA8B,EAC9B,gGAAgG,EAChG,gBAAgB,EAChB,mCAAmC,EACnC,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,mCAAmC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CACjE,CAAA;QAED,SAAS;QACT,OAAO,CAAC,IAAI,CACV,SAAS,WAAW,CAAC,YAAY,IAAI,MAAM,EAAE,EAC7C,mCAAmC,CACpC,CAAA;QAED,SAAS;QACT,IAAI,WAAW,CAAC,WAAW,EAAE,CAAC;YAC5B,OAAO,CAAC,GAAG,CACT,cAAc,WAAW,CAAC,WAAW,EAAE,EACvC,gBAAgB,CACjB,CAAA;QACH,CAAC;QAED,cAAc;QACd,IAAI,IAAI,CAAC,KAAK,IAAI,YAAY,CAAC,MAAM,EAAE,CAAC;YACtC,OAAO,CAAC,GAAG,CAAC,sBAAsB,EAAE,mCAAmC,CAAC,CAAA;YACxE,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,OAAO,CAAC,CAAA;QAClC,CAAC;QAED,UAAU;QACV,IAAI,IAAI,CAAC,KAAK,IAAI,YAAY,CAAC,OAAO,EAAE,CAAC;YACvC,IAAI,CAAC,mBAAmB,CAAC,WAAW,CAAC,CAAA;QACvC,CAAC;QAED,OAAO,CAAC,QAAQ,EAAE,CAAA;IACpB,CAAC;IAED;;OAEG;IACH,oBAAoB,CAAC,WAA8B,EAAE,KAAY,EAAE,QAAgB;QACjF,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,IAAI,CAAC;YAAE,OAAM;QAE/C,cAAc;QACd,MAAM,cAAc,GAAG,WAAW,CAAC,OAAO,CAAC,UAAU;YACnD,CAAC,CAAC,SAAS,qBAAqB,CAAC,WAAW,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE;YAClE,CAAC,CAAC,EAAE,CAAA;QAEN,kBAAkB;QAClB,OAAO,CAAC,KAAK,CACX,cAAc,IAAI,CAAC,UAAU,EAAE,MAAM,WAAW,CAAC,IAAI,QAAQ,QAAQ,KAAK,cAAc,EAAE,EAC1F,mCAAmC,EACnC,8BAA8B,EAC9B,gGAAgG,EAChG,gBAAgB,EAChB,mCAAmC,EACnC,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,mCAAmC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CACjE,CAAA;QAED,SAAS;QACT,OAAO,CAAC,KAAK,CAAC,SAAS,KAAK,CAAC,OAAO,EAAE,EAAE,mCAAmC,CAAC,CAAA;QAE5E,cAAc;QACd,IAAI,IAAI,CAAC,KAAK,IAAI,YAAY,CAAC,MAAM,EAAE,CAAC;YACtC,OAAO,CAAC,GAAG,CAAC,sBAAsB,EAAE,mCAAmC,CAAC,CAAA;YACxE,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,OAAO,CAAC,CAAA;QAClC,CAAC;QAED,SAAS;QACT,IAAI,WAAW,CAAC,kBAAkB,EAAE,CAAC;YACnC,OAAO,CAAC,GAAG,CAAC,cAAc,EAAE,mCAAmC,CAAC,CAAA;QAClE,CAAC;QAED,UAAU;QACV,IAAI,IAAI,CAAC,KAAK,IAAI,YAAY,CAAC,OAAO,EAAE,CAAC;YACvC,IAAI,CAAC,mBAAmB,CAAC,WAAW,CAAC,CAAA;QACvC,CAAC;QAED,SAAS;QACT,IAAI,IAAI,CAAC,KAAK,IAAI,YAAY,CAAC,OAAO,EAAE,CAAC;YACvC,IAAI,CAAC,uBAAuB,CAAC,WAAW,CAAC,CAAA;YACzC,OAAO,CAAC,KAAK,CAAC,cAAc,EAAE,KAAK,CAAC,KAAK,CAAC,CAAA;QAC5C,CAAC;QAED,UAAU;QACV,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,KAAK,CAAC,CAAA;QAEzC,OAAO,CAAC,QAAQ,EAAE,CAAA;IACpB,CAAC;IAED;;OAEG;IACH,mBAAmB,CAAC,WAA8B;QAChD,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,IAAI,CAAC;YAAE,OAAM;QAE/C,IAAI,IAAI,CAAC,KAAK,IAAI,YAAY,CAAC,OAAO,EAAE,CAAC;YACvC,cAAc;YACd,MAAM,cAAc,GAAG,WAAW,CAAC,OAAO,CAAC,UAAU;gBACnD,CAAC,CAAC,SAAS,qBAAqB,CAAC,WAAW,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE;gBAClE,CAAC,CAAC,EAAE,CAAA;YAEN,OAAO,CAAC,cAAc,CACpB,cAAc,IAAI,CAAC,UAAU,EAAE,MAAM,WAAW,CAAC,IAAI,KAAK,cAAc,EAAE,EAC1E,mCAAmC,EACnC,8BAA8B,EAC9B,gGAAgG,EAChG,gBAAgB,EAChB,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,mCAAmC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CACjE,CAAA;YAED,kBAAkB;YAClB,IAAI,IAAI,CAAC,KAAK,IAAI,YAAY,CAAC,KAAK,EAAE,CAAC;gBACrC,OAAO,CAAC,GAAG,CAAC,YAAY,EAAE,mCAAmC,CAAC,CAAA;gBAC9D,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,OAAO,CAAC,CAAA;YAClC,CAAC;YAED,SAAS;YACT,IAAI,WAAW,CAAC,kBAAkB,EAAE,CAAC;gBACnC,OAAO,CAAC,GAAG,CAAC,kBAAkB,EAAE,iCAAiC,CAAC,CAAA;YACpE,CAAC;YAED,OAAO,CAAC,QAAQ,EAAE,CAAA;QACpB,CAAC;IACH,CAAC;IAED;;OAEG;IACH,sBAAsB,CAAC,WAA8B,EAAE,MAAc;QACnE,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,IAAI,CAAC;YAAE,OAAM;QAE/C,eAAe;QACf,IAAI,IAAI,CAAC,KAAK,IAAI,YAAY,CAAC,OAAO,EAAE,CAAC;YACvC,cAAc;YACd,MAAM,cAAc,GAAG,WAAW,CAAC,OAAO,CAAC,UAAU;gBACnD,CAAC,CAAC,SAAS,qBAAqB,CAAC,WAAW,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE;gBAClE,CAAC,CAAC,EAAE,CAAA;YAEN,uBAAuB;YACvB,OAAO,CAAC,KAAK,CACX,cAAc,IAAI,CAAC,UAAU,EAAE,MAAM,WAAW,CAAC,IAAI,KAAK,cAAc,EAAE,EAC1E,mCAAmC,EACnC,8BAA8B,EAC9B,gGAAgG,EAChG,gBAAgB,EAChB,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,mCAAmC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CACjE,CAAA;YAED,SAAS;YACT,OAAO,CAAC,GAAG,CAAC,YAAY,EAAE,mCAAmC,CAAC,CAAA;YAC9D,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;YAEnB,SAAS;YACT,OAAO,CAAC,GAAG,CAAC,YAAY,EAAE,mCAAmC,CAAC,CAAA;YAC9D,OAAO,CAAC,KAAK,CAAC;gBACZ,gBAAgB,EAAE,WAAW,CAAC,EAAE;gBAChC,gBAAgB,EAAE,WAAW,CAAC,OAAO,CAAC,aAAa;gBACnD,MAAM,EAAE,WAAW,CAAC,IAAI;aACzB,CAAC,CAAA;YAEF,OAAO,CAAC,QAAQ,EAAE,CAAA;QACpB,CAAC;IACH,CAAC;IAED;;OAEG;IACH,mBAAmB,CACjB,WAA8B,EAC9B,eAAyB,EACzB,QAAgB;QAEhB,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,IAAI,CAAC;YAAE,OAAM;QAE/C,IAAI,IAAI,CAAC,KAAK,IAAI,YAAY,CAAC,OAAO,EAAE,CAAC;YACvC,OAAO,CAAC,GAAG,CAAC,SAAS,IAAI,CAAC,UAAU,EAAE,YAAY,QAAQ,IAAI,EAAE,gBAAgB,EAAE;gBAChF,aAAa,EAAE,WAAW,CAAC,EAAE;gBAC7B,eAAe;aAChB,CAAC,CAAA;QACJ,CAAC;IACH,CAAC;IAED;;OAEG;IACH,gBAAgB,CAAC,WAA8B,EAAE,MAAc,EAAE,GAAW;QAC1E,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,IAAI,CAAC;YAAE,OAAM;QAE/C,IAAI,IAAI,CAAC,KAAK,IAAI,YAAY,CAAC,KAAK,EAAE,CAAC;YACrC,OAAO,CAAC,GAAG,CAAC,UAAU,IAAI,CAAC,UAAU,EAAE,IAAI,MAAM,IAAI,GAAG,EAAE,EAAE,gBAAgB,EAAE;gBAC5E,aAAa,EAAE,WAAW,CAAC,EAAE;gBAC7B,aAAa,EAAE,WAAW,CAAC,OAAO,CAAC,aAAa;aACjD,CAAC,CAAA;QACJ,CAAC;IACH,CAAC;IAED;;OAEG;IACH,iBAAiB,CAAC,WAA8B,EAAE,MAAc,EAAE,OAAe;QAC/E,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,IAAI,CAAC;YAAE,OAAM;QAE/C,IAAI,IAAI,CAAC,KAAK,IAAI,YAAY,CAAC,KAAK,EAAE,CAAC;YACrC,MAAM,WAAW,GAAG,MAAM,IAAI,GAAG,IAAI,MAAM,GAAG,GAAG,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAA;YACzE,OAAO,CAAC,GAAG,CACT,SAAS,IAAI,CAAC,UAAU,EAAE,SAAS,MAAM,KAAK,OAAO,KAAK,EAC1D,UAAU,WAAW,EAAE,EACvB;gBACE,aAAa,EAAE,WAAW,CAAC,EAAE;aAC9B,CACF,CAAA;QACH,CAAC;IACH,CAAC;IAED,iDAAiD;IAEjD;;OAEG;IACK,mBAAmB,CAAC,WAA8B;QACxD,MAAM,UAAU,GAAG,WAAW,CAAC,UAAU,CAAA;QAEzC,OAAO,CAAC,GAAG,CAAC,UAAU,EAAE,gCAAgC,CAAC,CAAA;QAEzD,aAAa;QACb,MAAM,WAAW,GAAG,EAAE,CAAA;QAEtB,IAAI,UAAU,CAAC,EAAE,IAAI,UAAU,CAAC,GAAG,EAAE,CAAC;YACpC,WAAW,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,UAAU,CAAC,GAAG,GAAG,UAAU,CAAC,EAAE,EAAE,CAAC,CAAA;QACjF,CAAC;QACD,IAAI,UAAU,CAAC,GAAG,IAAI,UAAU,CAAC,EAAE,EAAE,CAAC;YACpC,WAAW,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,UAAU,CAAC,EAAE,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,CAAA;QACjF,CAAC;QACD,IAAI,UAAU,CAAC,EAAE,IAAI,UAAU,CAAC,EAAE,EAAE,CAAC;YACnC,WAAW,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,UAAU,CAAC,EAAE,GAAG,UAAU,CAAC,EAAE,EAAE,CAAC,CAAA;QAC/E,CAAC;QAED,KAAK,MAAM,UAAU,IAAI,WAAW,EAAE,CAAC;YACrC,MAAM,GAAG,GAAG,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAA;YACvD,OAAO,CAAC,GAAG,CACT,OAAO,UAAU,CAAC,KAAK,MAAM,GAAG,MAAM,UAAU,CAAC,QAAQ,IAAI,EAC7D,mCAAmC,EACnC,aAAa,EACb,gCAAgC,CACjC,CAAA;QACH,CAAC;QAED,QAAQ;QACR,IAAI,UAAU,CAAC,EAAE,IAAI,UAAU,CAAC,EAAE,EAAE,CAAC;YACnC,MAAM,KAAK,GAAG,UAAU,CAAC,EAAE,GAAG,UAAU,CAAC,EAAE,CAAA;YAC3C,OAAO,CAAC,GAAG,CACT,cAAc,KAAK,IAAI,EACvB,gCAAgC,EAChC,oDAAoD,CACrD,CAAA;QACH,CAAC;QAED,OAAO;QACP,IAAI,WAAW,CAAC,kBAAkB,EAAE,CAAC;YACnC,OAAO,CAAC,GAAG,CAAC,YAAY,EAAE,gBAAgB,CAAC,CAAA;QAC7C,CAAC;IACH,CAAC;IAED;;OAEG;IACK,uBAAuB,CAAC,WAA8B;QAC5D,OAAO,CAAC,GAAG,CAAC,SAAS,EAAE,gCAAgC,CAAC,CAAA;QACxD,OAAO,CAAC,KAAK,CAAC;YACZ,gBAAgB,EAAE,WAAW,CAAC,EAAE;YAChC,gBAAgB,EAAE,WAAW,CAAC,OAAO,CAAC,aAAa;YACnD,IAAI,EAAE,WAAW,CAAC,IAAI;YACtB,MAAM,EAAE,WAAW,CAAC,MAAM;YAC1B,YAAY,EAAE,WAAW,CAAC,UAAU,CAAC,EAAE;gBACrC,CAAC,CAAC,IAAI,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,WAAW,EAAE;gBACnD,CAAC,CAAC,KAAK;SACV,CAAC,CAAA;QAEF,IAAI,IAAI,CAAC,KAAK,IAAI,YAAY,CAAC,KAAK,EAAE,CAAC;YACrC,OAAO,CAAC,GAAG,CAAC,YAAY,EAAE,gCAAgC,EAAE,WAAW,CAAC,OAAO,CAAC,CAAA;YAEhF,IAAI,WAAW,CAAC,MAAM,EAAE,CAAC;gBACvB,OAAO,CAAC,GAAG,CAAC,WAAW,EAAE,gCAAgC,EAAE,WAAW,CAAC,MAAM,CAAC,CAAA;YAChF,CAAC;QACH,CAAC;IACH,CAAC;IAED;;OAEG;IACK,gBAAgB,CAAC,WAA8B,EAAE,KAAY;QACnE,MAAM,WAAW,GAAa,EAAE,CAAA;QAEhC,aAAa;QACb,IAAI,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAAC,EAAE,CAAC;YACjD,WAAW,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAA;QAC1C,CAAC;QAED,IAAI,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE,CAAC;YACtC,WAAW,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAA;QACrC,CAAC;QAED,IAAI,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE,CAAC;YACtC,WAAW,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAA;QAC1C,CAAC;QAED,aAAa;QACb,MAAM,QAAQ,GACZ,WAAW,CAAC,UAAU,CAAC,EAAE,IAAI,WAAW,CAAC,UAAU,CAAC,EAAE;YACpD,CAAC,CAAC,WAAW,CAAC,UAAU,CAAC,EAAE,GAAG,WAAW,CAAC,UAAU,CAAC,EAAE;YACvD,CAAC,CAAC,CAAC,CAAA;QAEP,IAAI,QAAQ,GAAG,IAAI,EAAE,CAAC;YACpB,WAAW,CAAC,IAAI,CAAC,QAAQ,QAAQ,sBAAsB,CAAC,CAAA;QAC1D,CAAC;QAED,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC3B,OAAO,CAAC,GAAG,CAAC,UAAU,EAAE,mCAAmC,CAAC,CAAA;YAC5D,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;gBACxB,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,CAAA;YACzB,CAAC,CAAC,CAAA;QACJ,CAAC;IACH,CAAC;IAED;;OAEG;IACK,iBAAiB,CAAC,QAAgB;QACxC,MAAM,QAAQ,GAAG,EAAE,CAAA;QACnB,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,EAAE,CAAC,EAAE,QAAQ,CAAC,CAAA;QAC3D,MAAM,GAAG,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;QAE7B,OAAO,GAAG,CAAA;IACZ,CAAC;IAED;;OAEG;IACK,UAAU;QAChB,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAA;QACtB,OAAO,GAAG,CAAC,kBAAkB,CAAC,OAAO,EAAE;YACrC,MAAM,EAAE,KAAK;YACb,IAAI,EAAE,SAAS;YACf,MAAM,EAAE,SAAS;YACjB,MAAM,EAAE,SAAS;YACjB,sBAAsB,EAAE,CAAC;SACnB,CAAC,CAAA;IACX,CAAC;IAED;;OAEG;IACK,WAAW,CAAC,eAAuB;QACzC,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,OAAO,KAAK,CAAA;QAC/B,IAAI,IAAI,CAAC,KAAK,KAAK,YAAY,CAAC,MAAM;YAAE,OAAO,KAAK,CAAA;QACpD,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,eAAe,CAAC;YAAE,OAAO,KAAK,CAAA;QAC3E,OAAO,IAAI,CAAA;IACb,CAAC;IAED,iDAAiD;IAEjD;;OAEG;IACH,cAAc,CAAC,KAAc;QAC3B,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,OAAM;QAEzB,IAAI,KAAK,EAAE,CAAC;YACV,OAAO,CAAC,GAAG,CACT,gCAAgC,KAAK,6BAA6B,EAClE,gCAAgC,CACjC,CAAA;QACH,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,GAAG,CAAC,gEAAgE,EAAE,aAAa,CAAC,CAAA;QAC9F,CAAC;IACH,CAAC;IAED;;OAEG;IACH,UAAU,CAAC,KAA6E;QACtF,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,OAAM;QAEzB,OAAO,CAAC,KAAK,CAAC,YAAY,EAAE,oDAAoD,CAAC,CAAA;QAEjF,OAAO,CAAC,GAAG,CAAC,aAAa,KAAK,CAAC,KAAK,EAAE,EAAE,mCAAmC,CAAC,CAAA;QAE5E,OAAO,CAAC,GAAG,CACT,WAAW,KAAK,CAAC,OAAO,OAAO,CAAC,CAAC,KAAK,CAAC,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,EACnF,mCAAmC,EACnC,aAAa,CACd,CAAA;QAED,OAAO,CAAC,GAAG,CACT,WAAW,KAAK,CAAC,MAAM,OAAO,CAAC,CAAC,KAAK,CAAC,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,EACjF,mCAAmC,EACnC,aAAa,CACd,CAAA;QAED,OAAO,CAAC,GAAG,CAAC,aAAa,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,EAAE,gCAAgC,CAAC,CAAA;QAE3F,OAAO,CAAC,QAAQ,EAAE,CAAA;IACpB,CAAC;CACF;AAED,SAAS;AACT,MAAM,CAAC,MAAM,UAAU,GAAG,IAAI,UAAU,EAAE,CAAA;AAE1C,OAAO;AACP,OAAO,EAAE,YAAY,EAAE,CAAA"}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* CPU 调试器
|
|
3
|
+
*
|
|
4
|
+
* 职责:
|
|
5
|
+
* 1. 提供调试器 API
|
|
6
|
+
* 2. 支持时间旅行调试
|
|
7
|
+
* 3. 支持指令重放
|
|
8
|
+
*/
|
|
9
|
+
import { type CPUEvent } from './types';
|
|
10
|
+
export declare class CPUDebugger {
|
|
11
|
+
/**
|
|
12
|
+
* 查询:执行最慢的指令
|
|
13
|
+
*/
|
|
14
|
+
getSlowestInstructions(limit?: number): Array<{
|
|
15
|
+
instructionId: string;
|
|
16
|
+
instructionType: string;
|
|
17
|
+
duration: number;
|
|
18
|
+
events: CPUEvent[];
|
|
19
|
+
}>;
|
|
20
|
+
/**
|
|
21
|
+
* 查询:失败的指令
|
|
22
|
+
*/
|
|
23
|
+
getFailedInstructions(): Array<{
|
|
24
|
+
instructionId: string;
|
|
25
|
+
instructionType: string;
|
|
26
|
+
error: string;
|
|
27
|
+
events: CPUEvent[];
|
|
28
|
+
}>;
|
|
29
|
+
/**
|
|
30
|
+
* 查询:触发回滚的指令
|
|
31
|
+
*/
|
|
32
|
+
getRolledBackInstructions(): Array<{
|
|
33
|
+
instructionId: string;
|
|
34
|
+
instructionType: string;
|
|
35
|
+
reason: string;
|
|
36
|
+
events: CPUEvent[];
|
|
37
|
+
}>;
|
|
38
|
+
/**
|
|
39
|
+
* 查询:资源冲突链
|
|
40
|
+
*/
|
|
41
|
+
getResourceConflictChain(instructionId: string): Array<{
|
|
42
|
+
instructionId: string;
|
|
43
|
+
instructionType: string;
|
|
44
|
+
blockedBy: string[];
|
|
45
|
+
waitTime: number;
|
|
46
|
+
}>;
|
|
47
|
+
/**
|
|
48
|
+
* 时间旅行:重放指令
|
|
49
|
+
*/
|
|
50
|
+
replayInstruction(instructionId: string): {
|
|
51
|
+
success: boolean;
|
|
52
|
+
events: CPUEvent[];
|
|
53
|
+
timeline: Array<{
|
|
54
|
+
time: number;
|
|
55
|
+
stage: string;
|
|
56
|
+
event: string;
|
|
57
|
+
}>;
|
|
58
|
+
};
|
|
59
|
+
/**
|
|
60
|
+
* 诊断:分析指令为什么慢
|
|
61
|
+
*/
|
|
62
|
+
diagnoseSlowInstruction(instructionId: string): {
|
|
63
|
+
instructionId: string;
|
|
64
|
+
totalDuration: number;
|
|
65
|
+
bottleneck: {
|
|
66
|
+
stage: string;
|
|
67
|
+
duration: number;
|
|
68
|
+
percentage: number;
|
|
69
|
+
};
|
|
70
|
+
breakdown: Array<{
|
|
71
|
+
stage: string;
|
|
72
|
+
duration: number;
|
|
73
|
+
percentage: number;
|
|
74
|
+
}>;
|
|
75
|
+
suggestions: string[];
|
|
76
|
+
};
|
|
77
|
+
/**
|
|
78
|
+
* 实时监控:获取最近 N 秒的统计
|
|
79
|
+
*/
|
|
80
|
+
getRealtimeStats(windowSeconds?: number): {
|
|
81
|
+
instructionsPerSecond: number;
|
|
82
|
+
avgLatency: number;
|
|
83
|
+
errorRate: number;
|
|
84
|
+
topInstructionTypes: Array<{
|
|
85
|
+
type: string;
|
|
86
|
+
count: number;
|
|
87
|
+
}>;
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
export declare const cpuDebugger: CPUDebugger;
|
|
91
|
+
//# sourceMappingURL=CPUDebugger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CPUDebugger.d.ts","sourceRoot":"","sources":["../../src/logging/CPUDebugger.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAGH,OAAO,EAAgB,KAAK,QAAQ,EAAE,MAAM,SAAS,CAAA;AAErD,qBAAa,WAAW;IACtB;;OAEG;IACH,sBAAsB,CAAC,KAAK,GAAE,MAAW,GAAG,KAAK,CAAC;QAChD,aAAa,EAAE,MAAM,CAAA;QACrB,eAAe,EAAE,MAAM,CAAA;QACvB,QAAQ,EAAE,MAAM,CAAA;QAChB,MAAM,EAAE,QAAQ,EAAE,CAAA;KACnB,CAAC;IAsBF;;OAEG;IACH,qBAAqB,IAAI,KAAK,CAAC;QAC7B,aAAa,EAAE,MAAM,CAAA;QACrB,eAAe,EAAE,MAAM,CAAA;QACvB,KAAK,EAAE,MAAM,CAAA;QACb,MAAM,EAAE,QAAQ,EAAE,CAAA;KACnB,CAAC;IAWF;;OAEG;IACH,yBAAyB,IAAI,KAAK,CAAC;QACjC,aAAa,EAAE,MAAM,CAAA;QACrB,eAAe,EAAE,MAAM,CAAA;QACvB,MAAM,EAAE,MAAM,CAAA;QACd,MAAM,EAAE,QAAQ,EAAE,CAAA;KACnB,CAAC;IAWF;;OAEG;IACH,wBAAwB,CAAC,aAAa,EAAE,MAAM,GAAG,KAAK,CAAC;QACrD,aAAa,EAAE,MAAM,CAAA;QACrB,eAAe,EAAE,MAAM,CAAA;QACvB,SAAS,EAAE,MAAM,EAAE,CAAA;QACnB,QAAQ,EAAE,MAAM,CAAA;KACjB,CAAC;IAcF;;OAEG;IACH,iBAAiB,CAAC,aAAa,EAAE,MAAM,GAAG;QACxC,OAAO,EAAE,OAAO,CAAA;QAChB,MAAM,EAAE,QAAQ,EAAE,CAAA;QAClB,QAAQ,EAAE,KAAK,CAAC;YAAE,IAAI,EAAE,MAAM,CAAC;YAAC,KAAK,EAAE,MAAM,CAAC;YAAC,KAAK,EAAE,MAAM,CAAA;SAAE,CAAC,CAAA;KAChE;IAgBD;;OAEG;IACH,uBAAuB,CAAC,aAAa,EAAE,MAAM,GAAG;QAC9C,aAAa,EAAE,MAAM,CAAA;QACrB,aAAa,EAAE,MAAM,CAAA;QACrB,UAAU,EAAE;YAAE,KAAK,EAAE,MAAM,CAAC;YAAC,QAAQ,EAAE,MAAM,CAAC;YAAC,UAAU,EAAE,MAAM,CAAA;SAAE,CAAA;QACnE,SAAS,EAAE,KAAK,CAAC;YAAE,KAAK,EAAE,MAAM,CAAC;YAAC,QAAQ,EAAE,MAAM,CAAC;YAAC,UAAU,EAAE,MAAM,CAAA;SAAE,CAAC,CAAA;QACzE,WAAW,EAAE,MAAM,EAAE,CAAA;KACtB;IAqDD;;OAEG;IACH,gBAAgB,CAAC,aAAa,GAAE,MAAU,GAAG;QAC3C,qBAAqB,EAAE,MAAM,CAAA;QAC7B,UAAU,EAAE,MAAM,CAAA;QAClB,SAAS,EAAE,MAAM,CAAA;QACjB,mBAAmB,EAAE,KAAK,CAAC;YAAE,IAAI,EAAE,MAAM,CAAC;YAAC,KAAK,EAAE,MAAM,CAAA;SAAE,CAAC,CAAA;KAC5D;CAmCF;AAED,eAAO,MAAM,WAAW,aAAoB,CAAA"}
|