Feature/editor optimization (#251)
* refactor: 编辑器/运行时架构拆分与构建系统升级 * feat(core): 层级系统重构与UI变换矩阵修复 * refactor: 移除 ecs-components 聚合包并修复跨包组件查找问题 * fix(physics): 修复跨包组件类引用问题 * feat: 统一运行时架构与浏览器运行支持 * feat(asset): 实现浏览器运行时资产加载系统 * fix: 修复文档、CodeQL安全问题和CI类型检查错误 * fix: 修复文档、CodeQL安全问题和CI类型检查错误 * fix: 修复文档、CodeQL安全问题、CI类型检查和测试错误 * test: 补齐核心模块测试用例,修复CI构建配置 * fix: 修复测试用例中的类型错误和断言问题 * fix: 修复 turbo build:npm 任务的依赖顺序问题 * fix: 修复 CI 构建错误并优化构建性能
This commit is contained in:
@@ -8,6 +8,7 @@ export interface LogEntry {
|
||||
source: string;
|
||||
message: string;
|
||||
args: unknown[];
|
||||
stack?: string; // 调用堆栈
|
||||
clientId?: string; // 远程客户端ID
|
||||
}
|
||||
|
||||
@@ -59,12 +60,12 @@ export class LogService implements IService {
|
||||
};
|
||||
|
||||
console.warn = (...args: unknown[]) => {
|
||||
this.addLog(LogLevel.Warn, 'console', this.formatMessage(args), args);
|
||||
this.addLog(LogLevel.Warn, 'console', this.formatMessage(args), args, true);
|
||||
this.originalConsole.warn(...args);
|
||||
};
|
||||
|
||||
console.error = (...args: unknown[]) => {
|
||||
this.addLog(LogLevel.Error, 'console', this.formatMessage(args), args);
|
||||
this.addLog(LogLevel.Error, 'console', this.formatMessage(args), args, true);
|
||||
this.originalConsole.error(...args);
|
||||
};
|
||||
|
||||
@@ -93,7 +94,10 @@ export class LogService implements IService {
|
||||
private formatMessage(args: unknown[]): string {
|
||||
return args.map((arg) => {
|
||||
if (typeof arg === 'string') return arg;
|
||||
if (arg instanceof Error) return arg.message;
|
||||
if (arg instanceof Error) {
|
||||
// 包含错误消息和堆栈
|
||||
return arg.stack || arg.message;
|
||||
}
|
||||
try {
|
||||
return JSON.stringify(arg);
|
||||
} catch {
|
||||
@@ -102,17 +106,30 @@ export class LogService implements IService {
|
||||
}).join(' ');
|
||||
}
|
||||
|
||||
/**
|
||||
* 捕获当前调用堆栈
|
||||
*/
|
||||
private captureStack(): string {
|
||||
const stack = new Error().stack;
|
||||
if (!stack) return '';
|
||||
|
||||
// 移除前几行(Error、captureStack、addLog、console.xxx)
|
||||
const lines = stack.split('\n');
|
||||
return lines.slice(4).join('\n');
|
||||
}
|
||||
|
||||
/**
|
||||
* 添加日志
|
||||
*/
|
||||
private addLog(level: LogLevel, source: string, message: string, args: unknown[]): void {
|
||||
private addLog(level: LogLevel, source: string, message: string, args: unknown[], includeStack = false): void {
|
||||
const entry: LogEntry = {
|
||||
id: this.nextId++,
|
||||
timestamp: new Date(),
|
||||
level,
|
||||
source,
|
||||
message,
|
||||
args
|
||||
args,
|
||||
stack: includeStack ? this.captureStack() : undefined
|
||||
};
|
||||
|
||||
this.logs.push(entry);
|
||||
|
||||
Reference in New Issue
Block a user