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:
YHH
2025-12-01 22:28:51 +08:00
committed by GitHub
parent 189714c727
commit b42a7b4e43
468 changed files with 18301 additions and 9075 deletions

View File

@@ -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);