@trench-craft/sds 1.0.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/README.en.md +522 -0
- package/README.md +566 -0
- package/dist/bin/sds.d.ts +3 -0
- package/dist/bin/sds.d.ts.map +1 -0
- package/dist/bin/sds.js +50 -0
- package/dist/bin/sds.js.map +1 -0
- package/dist/src/__tests__/cli.test.d.ts +2 -0
- package/dist/src/__tests__/cli.test.d.ts.map +1 -0
- package/dist/src/__tests__/cli.test.js +37 -0
- package/dist/src/__tests__/cli.test.js.map +1 -0
- package/dist/src/__tests__/e2e.test.d.ts +5 -0
- package/dist/src/__tests__/e2e.test.d.ts.map +1 -0
- package/dist/src/__tests__/e2e.test.js +143 -0
- package/dist/src/__tests__/e2e.test.js.map +1 -0
- package/dist/src/__tests__/graph.test.d.ts +5 -0
- package/dist/src/__tests__/graph.test.d.ts.map +1 -0
- package/dist/src/__tests__/graph.test.js +423 -0
- package/dist/src/__tests__/graph.test.js.map +1 -0
- package/dist/src/__tests__/openspec.test.d.ts +5 -0
- package/dist/src/__tests__/openspec.test.d.ts.map +1 -0
- package/dist/src/__tests__/openspec.test.js +172 -0
- package/dist/src/__tests__/openspec.test.js.map +1 -0
- package/dist/src/commands/apply.d.ts +4 -0
- package/dist/src/commands/apply.d.ts.map +1 -0
- package/dist/src/commands/apply.js +14 -0
- package/dist/src/commands/apply.js.map +1 -0
- package/dist/src/commands/archive.d.ts +4 -0
- package/dist/src/commands/archive.d.ts.map +1 -0
- package/dist/src/commands/archive.js +20 -0
- package/dist/src/commands/archive.js.map +1 -0
- package/dist/src/commands/cache.d.ts +4 -0
- package/dist/src/commands/cache.d.ts.map +1 -0
- package/dist/src/commands/cache.js +31 -0
- package/dist/src/commands/cache.js.map +1 -0
- package/dist/src/commands/config.d.ts +4 -0
- package/dist/src/commands/config.d.ts.map +1 -0
- package/dist/src/commands/config.js +29 -0
- package/dist/src/commands/config.js.map +1 -0
- package/dist/src/commands/e2e.d.ts +4 -0
- package/dist/src/commands/e2e.d.ts.map +1 -0
- package/dist/src/commands/e2e.js +65 -0
- package/dist/src/commands/e2e.js.map +1 -0
- package/dist/src/commands/graph.d.ts +4 -0
- package/dist/src/commands/graph.d.ts.map +1 -0
- package/dist/src/commands/graph.js +783 -0
- package/dist/src/commands/graph.js.map +1 -0
- package/dist/src/commands/init.d.ts +4 -0
- package/dist/src/commands/init.d.ts.map +1 -0
- package/dist/src/commands/init.js +15 -0
- package/dist/src/commands/init.js.map +1 -0
- package/dist/src/commands/project.d.ts +4 -0
- package/dist/src/commands/project.d.ts.map +1 -0
- package/dist/src/commands/project.js +6 -0
- package/dist/src/commands/project.js.map +1 -0
- package/dist/src/commands/propose.d.ts +4 -0
- package/dist/src/commands/propose.d.ts.map +1 -0
- package/dist/src/commands/propose.js +26 -0
- package/dist/src/commands/propose.js.map +1 -0
- package/dist/src/commands/registry.d.ts +4 -0
- package/dist/src/commands/registry.d.ts.map +1 -0
- package/dist/src/commands/registry.js +6 -0
- package/dist/src/commands/registry.js.map +1 -0
- package/dist/src/commands/skills-install.d.ts +4 -0
- package/dist/src/commands/skills-install.d.ts.map +1 -0
- package/dist/src/commands/skills-install.js +158 -0
- package/dist/src/commands/skills-install.js.map +1 -0
- package/dist/src/commands/skills.d.ts +4 -0
- package/dist/src/commands/skills.d.ts.map +1 -0
- package/dist/src/commands/skills.js +19 -0
- package/dist/src/commands/skills.js.map +1 -0
- package/dist/src/commands/verify.d.ts +4 -0
- package/dist/src/commands/verify.d.ts.map +1 -0
- package/dist/src/commands/verify.js +31 -0
- package/dist/src/commands/verify.js.map +1 -0
- package/dist/src/core/engine.d.ts +33 -0
- package/dist/src/core/engine.d.ts.map +1 -0
- package/dist/src/core/engine.js +87 -0
- package/dist/src/core/engine.js.map +1 -0
- package/dist/src/core/engine.test.d.ts +2 -0
- package/dist/src/core/engine.test.d.ts.map +1 -0
- package/dist/src/core/engine.test.js +13 -0
- package/dist/src/core/engine.test.js.map +1 -0
- package/dist/src/core/session-state.d.ts +18 -0
- package/dist/src/core/session-state.d.ts.map +1 -0
- package/dist/src/core/session-state.js +55 -0
- package/dist/src/core/session-state.js.map +1 -0
- package/dist/src/core/session-state.test.d.ts +2 -0
- package/dist/src/core/session-state.test.d.ts.map +1 -0
- package/dist/src/core/session-state.test.js +90 -0
- package/dist/src/core/session-state.test.js.map +1 -0
- package/dist/src/core/subagent-timeout.d.ts +18 -0
- package/dist/src/core/subagent-timeout.d.ts.map +1 -0
- package/dist/src/core/subagent-timeout.js +61 -0
- package/dist/src/core/subagent-timeout.js.map +1 -0
- package/dist/src/core/subagent-timeout.test.d.ts +2 -0
- package/dist/src/core/subagent-timeout.test.d.ts.map +1 -0
- package/dist/src/core/subagent-timeout.test.js +57 -0
- package/dist/src/core/subagent-timeout.test.js.map +1 -0
- package/dist/src/core/task-sync.d.ts +19 -0
- package/dist/src/core/task-sync.d.ts.map +1 -0
- package/dist/src/core/task-sync.js +62 -0
- package/dist/src/core/task-sync.js.map +1 -0
- package/dist/src/core/task-sync.test.d.ts +2 -0
- package/dist/src/core/task-sync.test.d.ts.map +1 -0
- package/dist/src/core/task-sync.test.js +84 -0
- package/dist/src/core/task-sync.test.js.map +1 -0
- package/dist/src/graph/advanced-performance.d.ts +137 -0
- package/dist/src/graph/advanced-performance.d.ts.map +1 -0
- package/dist/src/graph/advanced-performance.js +375 -0
- package/dist/src/graph/advanced-performance.js.map +1 -0
- package/dist/src/graph/database.d.ts +79 -0
- package/dist/src/graph/database.d.ts.map +1 -0
- package/dist/src/graph/database.js +305 -0
- package/dist/src/graph/database.js.map +1 -0
- package/dist/src/graph/engine.d.ts +43 -0
- package/dist/src/graph/engine.d.ts.map +1 -0
- package/dist/src/graph/engine.js +334 -0
- package/dist/src/graph/engine.js.map +1 -0
- package/dist/src/graph/exporter.d.ts +56 -0
- package/dist/src/graph/exporter.d.ts.map +1 -0
- package/dist/src/graph/exporter.js +273 -0
- package/dist/src/graph/exporter.js.map +1 -0
- package/dist/src/graph/index.d.ts +21 -0
- package/dist/src/graph/index.d.ts.map +1 -0
- package/dist/src/graph/index.js +14 -0
- package/dist/src/graph/index.js.map +1 -0
- package/dist/src/graph/layouts.d.ts +77 -0
- package/dist/src/graph/layouts.d.ts.map +1 -0
- package/dist/src/graph/layouts.js +368 -0
- package/dist/src/graph/layouts.js.map +1 -0
- package/dist/src/graph/parser.d.ts +47 -0
- package/dist/src/graph/parser.d.ts.map +1 -0
- package/dist/src/graph/parser.js +228 -0
- package/dist/src/graph/parser.js.map +1 -0
- package/dist/src/graph/performance.d.ts +90 -0
- package/dist/src/graph/performance.d.ts.map +1 -0
- package/dist/src/graph/performance.js +275 -0
- package/dist/src/graph/performance.js.map +1 -0
- package/dist/src/graph/semantic.d.ts +151 -0
- package/dist/src/graph/semantic.d.ts.map +1 -0
- package/dist/src/graph/semantic.js +402 -0
- package/dist/src/graph/semantic.js.map +1 -0
- package/dist/src/graph/types.d.ts +114 -0
- package/dist/src/graph/types.d.ts.map +1 -0
- package/dist/src/graph/types.js +5 -0
- package/dist/src/graph/types.js.map +1 -0
- package/dist/src/graph/visualizer.d.ts +50 -0
- package/dist/src/graph/visualizer.d.ts.map +1 -0
- package/dist/src/graph/visualizer.js +869 -0
- package/dist/src/graph/visualizer.js.map +1 -0
- package/dist/src/openspec/apply.d.ts +16 -0
- package/dist/src/openspec/apply.d.ts.map +1 -0
- package/dist/src/openspec/apply.js +140 -0
- package/dist/src/openspec/apply.js.map +1 -0
- package/dist/src/openspec/archive.d.ts +3 -0
- package/dist/src/openspec/archive.d.ts.map +1 -0
- package/dist/src/openspec/archive.js +17 -0
- package/dist/src/openspec/archive.js.map +1 -0
- package/dist/src/openspec/e2e-generate.d.ts +39 -0
- package/dist/src/openspec/e2e-generate.d.ts.map +1 -0
- package/dist/src/openspec/e2e-generate.js +315 -0
- package/dist/src/openspec/e2e-generate.js.map +1 -0
- package/dist/src/openspec/e2e-runner.d.ts +32 -0
- package/dist/src/openspec/e2e-runner.d.ts.map +1 -0
- package/dist/src/openspec/e2e-runner.js +208 -0
- package/dist/src/openspec/e2e-runner.js.map +1 -0
- package/dist/src/openspec/explore.d.ts +3 -0
- package/dist/src/openspec/explore.d.ts.map +1 -0
- package/dist/src/openspec/explore.js +20 -0
- package/dist/src/openspec/explore.js.map +1 -0
- package/dist/src/openspec/propose.d.ts +8 -0
- package/dist/src/openspec/propose.d.ts.map +1 -0
- package/dist/src/openspec/propose.js +124 -0
- package/dist/src/openspec/propose.js.map +1 -0
- package/dist/src/openspec/verify.d.ts +13 -0
- package/dist/src/openspec/verify.d.ts.map +1 -0
- package/dist/src/openspec/verify.js +156 -0
- package/dist/src/openspec/verify.js.map +1 -0
- package/dist/src/platform/claudecode.d.ts +2 -0
- package/dist/src/platform/claudecode.d.ts.map +1 -0
- package/dist/src/platform/claudecode.js +7 -0
- package/dist/src/platform/claudecode.js.map +1 -0
- package/dist/src/platform/codex.d.ts +2 -0
- package/dist/src/platform/codex.d.ts.map +1 -0
- package/dist/src/platform/codex.js +7 -0
- package/dist/src/platform/codex.js.map +1 -0
- package/dist/src/platform/opencode.d.ts +2 -0
- package/dist/src/platform/opencode.d.ts.map +1 -0
- package/dist/src/platform/opencode.js +7 -0
- package/dist/src/platform/opencode.js.map +1 -0
- package/dist/src/platform/router.d.ts +13 -0
- package/dist/src/platform/router.d.ts.map +1 -0
- package/dist/src/platform/router.js +57 -0
- package/dist/src/platform/router.js.map +1 -0
- package/dist/src/skills/cache.d.ts +16 -0
- package/dist/src/skills/cache.d.ts.map +1 -0
- package/dist/src/skills/cache.js +53 -0
- package/dist/src/skills/cache.js.map +1 -0
- package/dist/src/skills/discovery.d.ts +12 -0
- package/dist/src/skills/discovery.d.ts.map +1 -0
- package/dist/src/skills/discovery.js +61 -0
- package/dist/src/skills/discovery.js.map +1 -0
- package/dist/src/skills/loader.d.ts +12 -0
- package/dist/src/skills/loader.d.ts.map +1 -0
- package/dist/src/skills/loader.js +69 -0
- package/dist/src/skills/loader.js.map +1 -0
- package/dist/src/skills/registry.d.ts +23 -0
- package/dist/src/skills/registry.d.ts.map +1 -0
- package/dist/src/skills/registry.js +68 -0
- package/dist/src/skills/registry.js.map +1 -0
- package/dist/src/utils/fs.d.ts +5 -0
- package/dist/src/utils/fs.d.ts.map +1 -0
- package/dist/src/utils/fs.js +23 -0
- package/dist/src/utils/fs.js.map +1 -0
- package/dist/src/utils/logger.d.ts +7 -0
- package/dist/src/utils/logger.d.ts.map +1 -0
- package/dist/src/utils/logger.js +8 -0
- package/dist/src/utils/logger.js.map +1 -0
- package/dist/src/utils/yaml.d.ts +3 -0
- package/dist/src/utils/yaml.d.ts.map +1 -0
- package/dist/src/utils/yaml.js +8 -0
- package/dist/src/utils/yaml.js.map +1 -0
- package/package.json +62 -0
- package/registry/skills-registry.yaml +218 -0
- package/skills/core/brainstorming/SKILL.md +259 -0
- package/skills/core/brainstorming/scripts/frame-template.html +214 -0
- package/skills/core/brainstorming/scripts/helper.js +88 -0
- package/skills/core/brainstorming/scripts/server.cjs +338 -0
- package/skills/core/brainstorming/scripts/start-server.sh +153 -0
- package/skills/core/brainstorming/scripts/stop-server.sh +55 -0
- package/skills/core/brainstorming/skill.yaml +12 -0
- package/skills/core/brainstorming/spec-document-reviewer-prompt.md +48 -0
- package/skills/core/brainstorming/visual-companion.md +286 -0
- package/skills/core/claude-code-core/SKILL.md +164 -0
- package/skills/core/claude-code-core/skill.yaml +14 -0
- package/skills/core/claude-code-prompt/SKILL.md +283 -0
- package/skills/core/claude-code-prompt/skill.yaml +14 -0
- package/skills/core/claude-code-subagent/SKILL.md +168 -0
- package/skills/core/claude-code-subagent/skill.yaml +14 -0
- package/skills/core/e2e-generate/SKILL.md +147 -0
- package/skills/core/e2e-generate/skill.yaml +12 -0
- package/skills/core/ecc-agents-md-router/SKILL.md +90 -0
- package/skills/core/ecc-agents-md-router/skill.yaml +12 -0
- package/skills/core/ecc-context-injector/SKILL.md +69 -0
- package/skills/core/ecc-context-injector/skill.yaml +12 -0
- package/skills/core/existing-code-caveman/SKILL.md +340 -0
- package/skills/core/existing-code-caveman/skill.yaml +12 -0
- package/skills/core/opsx-apply/SKILL.md +121 -0
- package/skills/core/opsx-apply/skill.yaml +12 -0
- package/skills/core/opsx-archive/SKILL.md +83 -0
- package/skills/core/opsx-archive/skill.yaml +12 -0
- package/skills/core/opsx-explore/SKILL.md +101 -0
- package/skills/core/opsx-explore/skill.yaml +12 -0
- package/skills/core/opsx-propose/SKILL.md +131 -0
- package/skills/core/opsx-propose/skill.yaml +16 -0
- package/skills/core/opsx-verify/SKILL.md +109 -0
- package/skills/core/opsx-verify/skill.yaml +12 -0
- package/skills/core/subagent-driven-development/SKILL.md +157 -0
- package/skills/core/subagent-driven-development/code-quality-reviewer-prompt.md +64 -0
- package/skills/core/subagent-driven-development/implementer-prompt.md +122 -0
- package/skills/core/subagent-driven-development/skill.yaml +12 -0
- package/skills/core/subagent-driven-development/spec-reviewer-prompt.md +61 -0
- package/skills/core/writing-plans/SKILL.md +268 -0
- package/skills/core/writing-plans/plan-document-reviewer-prompt.md +63 -0
- package/skills/core/writing-plans/skill.yaml +12 -0
- package/skills/locale/chinese-code-review/SKILL.md +17 -0
- package/skills/locale/chinese-code-review/skill.yaml +16 -0
- package/skills/locale/chinese-commit-conventions/SKILL.md +17 -0
- package/skills/locale/chinese-commit-conventions/skill.yaml +16 -0
- package/skills/locale/chinese-documentation/SKILL.md +17 -0
- package/skills/locale/chinese-documentation/skill.yaml +16 -0
- package/skills/locale/chinese-git-workflow/SKILL.md +17 -0
- package/skills/locale/chinese-git-workflow/skill.yaml +16 -0
- package/templates/agents-md.md +42 -0
- package/templates/claude-md.md +44 -0
- package/templates/codex-md.md +49 -0
|
@@ -0,0 +1,228 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tree-sitter 代码解析器
|
|
3
|
+
* 提取函数、类、导入、调用关系等符号信息
|
|
4
|
+
*/
|
|
5
|
+
import { extname } from 'path';
|
|
6
|
+
// 语言映射
|
|
7
|
+
const LANG_MAP = {
|
|
8
|
+
'.ts': 'typescript',
|
|
9
|
+
'.tsx': 'typescript',
|
|
10
|
+
'.js': 'javascript',
|
|
11
|
+
'.jsx': 'javascript',
|
|
12
|
+
'.py': 'python',
|
|
13
|
+
'.go': 'go',
|
|
14
|
+
'.rs': 'rust',
|
|
15
|
+
'.java': 'java',
|
|
16
|
+
'.rb': 'ruby',
|
|
17
|
+
'.php': 'php',
|
|
18
|
+
'.c': 'c',
|
|
19
|
+
'.cpp': 'cpp',
|
|
20
|
+
'.h': 'c',
|
|
21
|
+
'.hpp': 'cpp',
|
|
22
|
+
};
|
|
23
|
+
export class CodeParser {
|
|
24
|
+
parsers = new Map();
|
|
25
|
+
/**
|
|
26
|
+
* 初始化解析器
|
|
27
|
+
* 注意:Tree-sitter 需要原生模块,这里提供一个简化实现
|
|
28
|
+
*/
|
|
29
|
+
async initialize() {
|
|
30
|
+
// Tree-sitter 初始化将在实际使用时完成
|
|
31
|
+
// 这里提供一个基于正则表达式的简化实现作为 fallback
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* 检测文件语言
|
|
35
|
+
*/
|
|
36
|
+
detectLanguage(filePath) {
|
|
37
|
+
const ext = extname(filePath).toLowerCase();
|
|
38
|
+
return LANG_MAP[ext] || 'unknown';
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* 解析文件,提取符号信息
|
|
42
|
+
* 这是一个简化实现,使用正则表达式提取基本符号
|
|
43
|
+
* 完整实现应使用 Tree-sitter AST 解析
|
|
44
|
+
*/
|
|
45
|
+
parseFile(filePath, content) {
|
|
46
|
+
const lang = this.detectLanguage(filePath);
|
|
47
|
+
const lines = content.split('\n');
|
|
48
|
+
const symbols = [];
|
|
49
|
+
const imports = [];
|
|
50
|
+
// 根据语言选择解析策略
|
|
51
|
+
switch (lang) {
|
|
52
|
+
case 'typescript':
|
|
53
|
+
case 'javascript':
|
|
54
|
+
return this.parseJavaScript(content, lines);
|
|
55
|
+
case 'python':
|
|
56
|
+
return this.parsePython(content, lines);
|
|
57
|
+
default:
|
|
58
|
+
return this.parseGeneric(content, lines);
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* 解析 JavaScript/TypeScript 文件
|
|
63
|
+
*/
|
|
64
|
+
parseJavaScript(content, lines) {
|
|
65
|
+
const symbols = [];
|
|
66
|
+
const imports = [];
|
|
67
|
+
// 匹配函数声明
|
|
68
|
+
const functionRegex = /(?:export\s+)?(?:async\s+)?function\s+(\w+)\s*\([^)]*\)/g;
|
|
69
|
+
let match;
|
|
70
|
+
while ((match = functionRegex.exec(content)) !== null) {
|
|
71
|
+
const lineStart = content.substring(0, match.index).split('\n').length;
|
|
72
|
+
symbols.push({
|
|
73
|
+
name: match[1],
|
|
74
|
+
type: 'function',
|
|
75
|
+
lineStart,
|
|
76
|
+
lineEnd: lineStart, // 简化实现
|
|
77
|
+
signature: match[0]
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
// 匹配箭头函数
|
|
81
|
+
const arrowRegex = /(?:export\s+)?(?:const|let|var)\s+(\w+)\s*=\s*(?:async\s+)?\([^)]*\)\s*=>/g;
|
|
82
|
+
while ((match = arrowRegex.exec(content)) !== null) {
|
|
83
|
+
const lineStart = content.substring(0, match.index).split('\n').length;
|
|
84
|
+
symbols.push({
|
|
85
|
+
name: match[1],
|
|
86
|
+
type: 'function',
|
|
87
|
+
lineStart,
|
|
88
|
+
lineEnd: lineStart,
|
|
89
|
+
signature: match[0]
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
// 匹配类声明
|
|
93
|
+
const classRegex = /(?:export\s+)?(?:abstract\s+)?class\s+(\w+)(?:\s+extends\s+(\w+))?(?:\s+implements\s+(\w+))?/g;
|
|
94
|
+
while ((match = classRegex.exec(content)) !== null) {
|
|
95
|
+
const lineStart = content.substring(0, match.index).split('\n').length;
|
|
96
|
+
symbols.push({
|
|
97
|
+
name: match[1],
|
|
98
|
+
type: 'class',
|
|
99
|
+
lineStart,
|
|
100
|
+
lineEnd: lineStart,
|
|
101
|
+
signature: match[0]
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
// 匹配接口声明
|
|
105
|
+
const interfaceRegex = /(?:export\s+)?interface\s+(\w+)/g;
|
|
106
|
+
while ((match = interfaceRegex.exec(content)) !== null) {
|
|
107
|
+
const lineStart = content.substring(0, match.index).split('\n').length;
|
|
108
|
+
symbols.push({
|
|
109
|
+
name: match[1],
|
|
110
|
+
type: 'interface',
|
|
111
|
+
lineStart,
|
|
112
|
+
lineEnd: lineStart,
|
|
113
|
+
signature: match[0]
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
// 匹配类型声明
|
|
117
|
+
const typeRegex = /(?:export\s+)?type\s+(\w+)/g;
|
|
118
|
+
while ((match = typeRegex.exec(content)) !== null) {
|
|
119
|
+
const lineStart = content.substring(0, match.index).split('\n').length;
|
|
120
|
+
symbols.push({
|
|
121
|
+
name: match[1],
|
|
122
|
+
type: 'type',
|
|
123
|
+
lineStart,
|
|
124
|
+
lineEnd: lineStart,
|
|
125
|
+
signature: match[0]
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
// 匹配导入语句
|
|
129
|
+
const importRegex = /import\s+(?:{[^}]+}|[^;]+)\s+from\s+['"]([^'"]+)['"]/g;
|
|
130
|
+
while ((match = importRegex.exec(content)) !== null) {
|
|
131
|
+
imports.push(match[1]);
|
|
132
|
+
}
|
|
133
|
+
// 匹配 require 语句
|
|
134
|
+
const requireRegex = /require\s*\(\s*['"]([^'"]+)['"]\s*\)/g;
|
|
135
|
+
while ((match = requireRegex.exec(content)) !== null) {
|
|
136
|
+
imports.push(match[1]);
|
|
137
|
+
}
|
|
138
|
+
return { symbols, imports };
|
|
139
|
+
}
|
|
140
|
+
/**
|
|
141
|
+
* 解析 Python 文件
|
|
142
|
+
*/
|
|
143
|
+
parsePython(content, lines) {
|
|
144
|
+
const symbols = [];
|
|
145
|
+
const imports = [];
|
|
146
|
+
// 匹配函数声明
|
|
147
|
+
const functionRegex = /def\s+(\w+)\s*\([^)]*\)/g;
|
|
148
|
+
let match;
|
|
149
|
+
while ((match = functionRegex.exec(content)) !== null) {
|
|
150
|
+
const lineStart = content.substring(0, match.index).split('\n').length;
|
|
151
|
+
symbols.push({
|
|
152
|
+
name: match[1],
|
|
153
|
+
type: 'function',
|
|
154
|
+
lineStart,
|
|
155
|
+
lineEnd: lineStart,
|
|
156
|
+
signature: match[0]
|
|
157
|
+
});
|
|
158
|
+
}
|
|
159
|
+
// 匹配类声明
|
|
160
|
+
const classRegex = /class\s+(\w+)(?:\(([^)]+)\))?:/g;
|
|
161
|
+
while ((match = classRegex.exec(content)) !== null) {
|
|
162
|
+
const lineStart = content.substring(0, match.index).split('\n').length;
|
|
163
|
+
symbols.push({
|
|
164
|
+
name: match[1],
|
|
165
|
+
type: 'class',
|
|
166
|
+
lineStart,
|
|
167
|
+
lineEnd: lineStart,
|
|
168
|
+
signature: match[0]
|
|
169
|
+
});
|
|
170
|
+
}
|
|
171
|
+
// 匹配导入语句
|
|
172
|
+
const importRegex = /(?:from\s+(\S+)\s+)?import\s+([^#\n]+)/g;
|
|
173
|
+
while ((match = importRegex.exec(content)) !== null) {
|
|
174
|
+
if (match[1]) {
|
|
175
|
+
imports.push(match[1]);
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
return { symbols, imports };
|
|
179
|
+
}
|
|
180
|
+
/**
|
|
181
|
+
* 通用解析(基于正则表达式)
|
|
182
|
+
*/
|
|
183
|
+
parseGeneric(content, lines) {
|
|
184
|
+
const symbols = [];
|
|
185
|
+
const imports = [];
|
|
186
|
+
// 尝试匹配常见函数模式
|
|
187
|
+
const functionPatterns = [
|
|
188
|
+
/function\s+(\w+)/g,
|
|
189
|
+
/def\s+(\w+)/g,
|
|
190
|
+
/func\s+(\w+)/g,
|
|
191
|
+
/fn\s+(\w+)/g,
|
|
192
|
+
];
|
|
193
|
+
for (const pattern of functionPatterns) {
|
|
194
|
+
let match;
|
|
195
|
+
while ((match = pattern.exec(content)) !== null) {
|
|
196
|
+
const lineStart = content.substring(0, match.index).split('\n').length;
|
|
197
|
+
symbols.push({
|
|
198
|
+
name: match[1],
|
|
199
|
+
type: 'function',
|
|
200
|
+
lineStart,
|
|
201
|
+
lineEnd: lineStart,
|
|
202
|
+
signature: match[0]
|
|
203
|
+
});
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
return { symbols, imports };
|
|
207
|
+
}
|
|
208
|
+
/**
|
|
209
|
+
* 计算文件 hash
|
|
210
|
+
*/
|
|
211
|
+
computeHash(content) {
|
|
212
|
+
// 简单的 hash 实现,生产环境应使用 crypto
|
|
213
|
+
let hash = 0;
|
|
214
|
+
for (let i = 0; i < content.length; i++) {
|
|
215
|
+
const char = content.charCodeAt(i);
|
|
216
|
+
hash = ((hash << 5) - hash) + char;
|
|
217
|
+
hash = hash & hash; // 转换为 32 位整数
|
|
218
|
+
}
|
|
219
|
+
return hash.toString(16);
|
|
220
|
+
}
|
|
221
|
+
/**
|
|
222
|
+
* 统计文件行数
|
|
223
|
+
*/
|
|
224
|
+
countLines(content) {
|
|
225
|
+
return content.split('\n').length;
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
//# sourceMappingURL=parser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parser.js","sourceRoot":"","sources":["../../../src/graph/parser.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 性能优化模块
|
|
3
|
+
* 实现分层索引、并行处理、进度条等功能
|
|
4
|
+
*/
|
|
5
|
+
import { GraphDatabase } from './database.js';
|
|
6
|
+
import { CodeParser } from './parser.js';
|
|
7
|
+
import type { SymbolInfo, CallEdge, IndexStats } from './types.js';
|
|
8
|
+
export interface TieredIndexConfig {
|
|
9
|
+
core: {
|
|
10
|
+
patterns: string[];
|
|
11
|
+
maxFiles: number;
|
|
12
|
+
};
|
|
13
|
+
extended: {
|
|
14
|
+
patterns: string[];
|
|
15
|
+
maxFiles: number;
|
|
16
|
+
sampleRate: number;
|
|
17
|
+
};
|
|
18
|
+
peripheral: {
|
|
19
|
+
patterns: string[];
|
|
20
|
+
maxFiles: number;
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
export interface ParallelIndexConfig {
|
|
24
|
+
workers: number;
|
|
25
|
+
batchSize: number;
|
|
26
|
+
queueSize: number;
|
|
27
|
+
}
|
|
28
|
+
export interface ProgressInfo {
|
|
29
|
+
phase: string;
|
|
30
|
+
current: number;
|
|
31
|
+
total: number;
|
|
32
|
+
percentage: number;
|
|
33
|
+
speed: number;
|
|
34
|
+
eta: number;
|
|
35
|
+
currentFile?: string;
|
|
36
|
+
}
|
|
37
|
+
export type ProgressCallback = (progress: ProgressInfo) => void;
|
|
38
|
+
export declare class PerformanceOptimizer {
|
|
39
|
+
private db;
|
|
40
|
+
private parser;
|
|
41
|
+
private projectDir;
|
|
42
|
+
private tieredConfig;
|
|
43
|
+
private parallelConfig;
|
|
44
|
+
private progressCallback?;
|
|
45
|
+
constructor(projectDir: string, db: GraphDatabase, parser: CodeParser, options?: {
|
|
46
|
+
tieredConfig?: Partial<TieredIndexConfig>;
|
|
47
|
+
parallelConfig?: Partial<ParallelIndexConfig>;
|
|
48
|
+
progressCallback?: ProgressCallback;
|
|
49
|
+
});
|
|
50
|
+
/**
|
|
51
|
+
* 分层索引
|
|
52
|
+
*/
|
|
53
|
+
tieredIndex(): Promise<IndexStats>;
|
|
54
|
+
/**
|
|
55
|
+
* 并行索引
|
|
56
|
+
*/
|
|
57
|
+
parallelIndex(files: string[]): Promise<{
|
|
58
|
+
symbols: Omit<SymbolInfo, 'id'>[];
|
|
59
|
+
edges: Omit<CallEdge, 'id'>[];
|
|
60
|
+
}>;
|
|
61
|
+
/**
|
|
62
|
+
* 处理批次队列
|
|
63
|
+
*/
|
|
64
|
+
private processBatchQueue;
|
|
65
|
+
/**
|
|
66
|
+
* 扫描分层文件
|
|
67
|
+
*/
|
|
68
|
+
private scanTierFiles;
|
|
69
|
+
/**
|
|
70
|
+
* 采样文件
|
|
71
|
+
*/
|
|
72
|
+
private sampleFiles;
|
|
73
|
+
/**
|
|
74
|
+
* 索引文件批次
|
|
75
|
+
*/
|
|
76
|
+
private indexFiles;
|
|
77
|
+
/**
|
|
78
|
+
* 批量插入
|
|
79
|
+
*/
|
|
80
|
+
private batchInsert;
|
|
81
|
+
/**
|
|
82
|
+
* 解析导入路径
|
|
83
|
+
*/
|
|
84
|
+
private resolveImportPath;
|
|
85
|
+
/**
|
|
86
|
+
* 报告进度
|
|
87
|
+
*/
|
|
88
|
+
private reportProgress;
|
|
89
|
+
}
|
|
90
|
+
//# sourceMappingURL=performance.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"performance.d.ts","sourceRoot":"","sources":["../../../src/graph/performance.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAKH,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAC9C,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AACzC,OAAO,KAAK,EAAY,UAAU,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAG7E,MAAM,WAAW,iBAAiB;IAEhC,IAAI,EAAE;QACJ,QAAQ,EAAE,MAAM,EAAE,CAAC;QACnB,QAAQ,EAAE,MAAM,CAAC;KAClB,CAAC;IAEF,QAAQ,EAAE;QACR,QAAQ,EAAE,MAAM,EAAE,CAAC;QACnB,QAAQ,EAAE,MAAM,CAAC;QACjB,UAAU,EAAE,MAAM,CAAC;KACpB,CAAC;IAEF,UAAU,EAAE;QACV,QAAQ,EAAE,MAAM,EAAE,CAAC;QACnB,QAAQ,EAAE,MAAM,CAAC;KAClB,CAAC;CACH;AAGD,MAAM,WAAW,mBAAmB;IAClC,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;CACnB;AAGD,MAAM,WAAW,YAAY;IAC3B,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,EAAE,MAAM,CAAC;IACnB,KAAK,EAAE,MAAM,CAAC;IACd,GAAG,EAAE,MAAM,CAAC;IACZ,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAGD,MAAM,MAAM,gBAAgB,GAAG,CAAC,QAAQ,EAAE,YAAY,KAAK,IAAI,CAAC;AA0BhE,qBAAa,oBAAoB;IAC/B,OAAO,CAAC,EAAE,CAAgB;IAC1B,OAAO,CAAC,MAAM,CAAa;IAC3B,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,YAAY,CAAoB;IACxC,OAAO,CAAC,cAAc,CAAsB;IAC5C,OAAO,CAAC,gBAAgB,CAAC,CAAmB;gBAG1C,UAAU,EAAE,MAAM,EAClB,EAAE,EAAE,aAAa,EACjB,MAAM,EAAE,UAAU,EAClB,OAAO,GAAE;QACP,YAAY,CAAC,EAAE,OAAO,CAAC,iBAAiB,CAAC,CAAC;QAC1C,cAAc,CAAC,EAAE,OAAO,CAAC,mBAAmB,CAAC,CAAC;QAC9C,gBAAgB,CAAC,EAAE,gBAAgB,CAAC;KAChC;IAUR;;OAEG;IACG,WAAW,IAAI,OAAO,CAAC,UAAU,CAAC;IA0CxC;;OAEG;IACG,aAAa,CAAC,KAAK,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC;QAC5C,OAAO,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,EAAE,CAAC;QAClC,KAAK,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC;KAC/B,CAAC;IAiCF;;OAEG;YACW,iBAAiB;IAqB/B;;OAEG;YACW,aAAa;IAoB3B;;OAEG;IACH,OAAO,CAAC,WAAW;IAMnB;;OAEG;YACW,UAAU;IA0ExB;;OAEG;YACW,WAAW;IAgBzB;;OAEG;YACW,iBAAiB;IA8B/B;;OAEG;IACH,OAAO,CAAC,cAAc;CAgBvB"}
|
|
@@ -0,0 +1,275 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 性能优化模块
|
|
3
|
+
* 实现分层索引、并行处理、进度条等功能
|
|
4
|
+
*/
|
|
5
|
+
import { resolve, relative } from 'path';
|
|
6
|
+
import { readFile, stat, access } from 'fs/promises';
|
|
7
|
+
import { glob } from 'glob';
|
|
8
|
+
// 默认分层配置
|
|
9
|
+
const DEFAULT_TIERED_CONFIG = {
|
|
10
|
+
core: {
|
|
11
|
+
patterns: ['src/**/*'],
|
|
12
|
+
maxFiles: 10000,
|
|
13
|
+
},
|
|
14
|
+
extended: {
|
|
15
|
+
patterns: ['lib/**/*', 'packages/**/*', 'app/**/*'],
|
|
16
|
+
maxFiles: 5000,
|
|
17
|
+
sampleRate: 0.3,
|
|
18
|
+
},
|
|
19
|
+
peripheral: {
|
|
20
|
+
patterns: ['node_modules/**/*', 'dist/**/*', 'build/**/*'],
|
|
21
|
+
maxFiles: 1000,
|
|
22
|
+
},
|
|
23
|
+
};
|
|
24
|
+
// 默认并行配置
|
|
25
|
+
const DEFAULT_PARALLEL_CONFIG = {
|
|
26
|
+
workers: 4,
|
|
27
|
+
batchSize: 100,
|
|
28
|
+
queueSize: 1000,
|
|
29
|
+
};
|
|
30
|
+
export class PerformanceOptimizer {
|
|
31
|
+
db;
|
|
32
|
+
parser;
|
|
33
|
+
projectDir;
|
|
34
|
+
tieredConfig;
|
|
35
|
+
parallelConfig;
|
|
36
|
+
progressCallback;
|
|
37
|
+
constructor(projectDir, db, parser, options = {}) {
|
|
38
|
+
this.projectDir = projectDir;
|
|
39
|
+
this.db = db;
|
|
40
|
+
this.parser = parser;
|
|
41
|
+
this.tieredConfig = { ...DEFAULT_TIERED_CONFIG, ...options.tieredConfig };
|
|
42
|
+
this.parallelConfig = { ...DEFAULT_PARALLEL_CONFIG, ...options.parallelConfig };
|
|
43
|
+
this.progressCallback = options.progressCallback;
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* 分层索引
|
|
47
|
+
*/
|
|
48
|
+
async tieredIndex() {
|
|
49
|
+
const startTime = Date.now();
|
|
50
|
+
const allFiles = [];
|
|
51
|
+
const allSymbols = [];
|
|
52
|
+
const allEdges = [];
|
|
53
|
+
// Phase 1: 核心层索引
|
|
54
|
+
this.reportProgress('核心层索引', 0, 0);
|
|
55
|
+
const coreFiles = await this.scanTierFiles('core');
|
|
56
|
+
const coreResult = await this.indexFiles(coreFiles, 'core');
|
|
57
|
+
allFiles.push(...coreFiles);
|
|
58
|
+
allSymbols.push(...coreResult.symbols);
|
|
59
|
+
allEdges.push(...coreResult.edges);
|
|
60
|
+
// Phase 2: 扩展层索引(采样)
|
|
61
|
+
this.reportProgress('扩展层索引', 0, 0);
|
|
62
|
+
const extendedFiles = await this.scanTierFiles('extended');
|
|
63
|
+
const sampledExtended = this.sampleFiles(extendedFiles, this.tieredConfig.extended.sampleRate);
|
|
64
|
+
const extendedResult = await this.indexFiles(sampledExtended, 'extended');
|
|
65
|
+
allFiles.push(...sampledExtended);
|
|
66
|
+
allSymbols.push(...extendedResult.symbols);
|
|
67
|
+
allEdges.push(...extendedResult.edges);
|
|
68
|
+
// Phase 3: 外围层索引(仅记录)
|
|
69
|
+
this.reportProgress('外围层索引', 0, 0);
|
|
70
|
+
const peripheralFiles = await this.scanTierFiles('peripheral');
|
|
71
|
+
const peripheralResult = await this.indexFiles(peripheralFiles.slice(0, this.tieredConfig.peripheral.maxFiles), 'peripheral');
|
|
72
|
+
allFiles.push(...peripheralFiles.slice(0, this.tieredConfig.peripheral.maxFiles));
|
|
73
|
+
allSymbols.push(...peripheralResult.symbols);
|
|
74
|
+
allEdges.push(...peripheralResult.edges);
|
|
75
|
+
// 批量插入
|
|
76
|
+
this.reportProgress('写入数据库', 0, 0);
|
|
77
|
+
await this.batchInsert(allFiles, allSymbols, allEdges);
|
|
78
|
+
const durationMs = Date.now() - startTime;
|
|
79
|
+
const stats = this.db.getStats();
|
|
80
|
+
stats.durationMs = durationMs;
|
|
81
|
+
return stats;
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* 并行索引
|
|
85
|
+
*/
|
|
86
|
+
async parallelIndex(files) {
|
|
87
|
+
const batchSize = this.parallelConfig.batchSize;
|
|
88
|
+
const batches = [];
|
|
89
|
+
// 分批
|
|
90
|
+
for (let i = 0; i < files.length; i += batchSize) {
|
|
91
|
+
batches.push(files.slice(i, i + batchSize));
|
|
92
|
+
}
|
|
93
|
+
const allSymbols = [];
|
|
94
|
+
const allEdges = [];
|
|
95
|
+
// 并行处理批次
|
|
96
|
+
const workerCount = Math.min(this.parallelConfig.workers, batches.length);
|
|
97
|
+
const batchPromises = [];
|
|
98
|
+
for (let i = 0; i < workerCount; i++) {
|
|
99
|
+
batchPromises.push(this.processBatchQueue(batches, i, workerCount));
|
|
100
|
+
}
|
|
101
|
+
const results = await Promise.all(batchPromises);
|
|
102
|
+
for (const result of results) {
|
|
103
|
+
allSymbols.push(...result.symbols);
|
|
104
|
+
allEdges.push(...result.edges);
|
|
105
|
+
}
|
|
106
|
+
return { symbols: allSymbols, edges: allEdges };
|
|
107
|
+
}
|
|
108
|
+
/**
|
|
109
|
+
* 处理批次队列
|
|
110
|
+
*/
|
|
111
|
+
async processBatchQueue(batches, workerId, workerCount) {
|
|
112
|
+
const symbols = [];
|
|
113
|
+
const edges = [];
|
|
114
|
+
for (let i = workerId; i < batches.length; i += workerCount) {
|
|
115
|
+
const batch = batches[i];
|
|
116
|
+
const result = await this.indexFiles(batch, 'core');
|
|
117
|
+
symbols.push(...result.symbols);
|
|
118
|
+
edges.push(...result.edges);
|
|
119
|
+
}
|
|
120
|
+
return { symbols, edges };
|
|
121
|
+
}
|
|
122
|
+
/**
|
|
123
|
+
* 扫描分层文件
|
|
124
|
+
*/
|
|
125
|
+
async scanTierFiles(tier) {
|
|
126
|
+
const config = this.tieredConfig[tier];
|
|
127
|
+
const files = [];
|
|
128
|
+
for (const pattern of config.patterns) {
|
|
129
|
+
const matched = await glob(pattern, {
|
|
130
|
+
cwd: this.projectDir,
|
|
131
|
+
ignore: ['**/node_modules/**', '**/.git/**'],
|
|
132
|
+
absolute: true,
|
|
133
|
+
});
|
|
134
|
+
files.push(...matched);
|
|
135
|
+
}
|
|
136
|
+
// 过滤支持的语言文件
|
|
137
|
+
return files.filter(file => {
|
|
138
|
+
const lang = this.parser.detectLanguage(file);
|
|
139
|
+
return lang !== 'unknown';
|
|
140
|
+
}).slice(0, config.maxFiles);
|
|
141
|
+
}
|
|
142
|
+
/**
|
|
143
|
+
* 采样文件
|
|
144
|
+
*/
|
|
145
|
+
sampleFiles(files, rate) {
|
|
146
|
+
const count = Math.ceil(files.length * rate);
|
|
147
|
+
const shuffled = [...files].sort(() => Math.random() - 0.5);
|
|
148
|
+
return shuffled.slice(0, count);
|
|
149
|
+
}
|
|
150
|
+
/**
|
|
151
|
+
* 索引文件批次
|
|
152
|
+
*/
|
|
153
|
+
async indexFiles(files, tier) {
|
|
154
|
+
const symbols = [];
|
|
155
|
+
const edges = [];
|
|
156
|
+
let processed = 0;
|
|
157
|
+
for (const filePath of files) {
|
|
158
|
+
try {
|
|
159
|
+
const relativePath = relative(this.projectDir, filePath);
|
|
160
|
+
const content = await readFile(filePath, 'utf-8');
|
|
161
|
+
const fileStat = await stat(filePath);
|
|
162
|
+
const hash = this.parser.computeHash(content);
|
|
163
|
+
const lang = this.parser.detectLanguage(filePath);
|
|
164
|
+
const lines = this.parser.countLines(content);
|
|
165
|
+
// 插入文件记录
|
|
166
|
+
const fileInfo = {
|
|
167
|
+
path: relativePath,
|
|
168
|
+
lang,
|
|
169
|
+
lines,
|
|
170
|
+
hash,
|
|
171
|
+
lastModified: Math.floor(fileStat.mtimeMs / 1000),
|
|
172
|
+
inDegree: 0,
|
|
173
|
+
outDegree: 0,
|
|
174
|
+
};
|
|
175
|
+
const fileId = this.db.upsertFile(fileInfo);
|
|
176
|
+
// 解析符号
|
|
177
|
+
const { symbols: fileSymbols, imports } = this.parser.parseFile(filePath, content);
|
|
178
|
+
// 插入符号
|
|
179
|
+
for (const symbol of fileSymbols) {
|
|
180
|
+
symbols.push({
|
|
181
|
+
...symbol,
|
|
182
|
+
fileId,
|
|
183
|
+
});
|
|
184
|
+
}
|
|
185
|
+
// 处理导入关系
|
|
186
|
+
for (const importPath of imports) {
|
|
187
|
+
const resolvedPath = await this.resolveImportPath(filePath, importPath);
|
|
188
|
+
if (resolvedPath) {
|
|
189
|
+
const importRelativePath = relative(this.projectDir, resolvedPath);
|
|
190
|
+
const importFile = this.db.getFile(importRelativePath);
|
|
191
|
+
if (importFile) {
|
|
192
|
+
edges.push({
|
|
193
|
+
callerFileId: fileId,
|
|
194
|
+
callerSymbolId: 0,
|
|
195
|
+
calleeFileId: importFile.id,
|
|
196
|
+
calleeSymbolId: 0,
|
|
197
|
+
relationType: 'import',
|
|
198
|
+
lineNumber: 0,
|
|
199
|
+
});
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
processed++;
|
|
204
|
+
this.reportProgress(`${tier} 层索引`, processed, files.length);
|
|
205
|
+
}
|
|
206
|
+
catch (error) {
|
|
207
|
+
// 静默跳过错误文件
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
return { symbols, edges };
|
|
211
|
+
}
|
|
212
|
+
/**
|
|
213
|
+
* 批量插入
|
|
214
|
+
*/
|
|
215
|
+
async batchInsert(files, symbols, edges) {
|
|
216
|
+
// 批量插入符号
|
|
217
|
+
if (symbols.length > 0) {
|
|
218
|
+
this.db.insertSymbols(symbols);
|
|
219
|
+
}
|
|
220
|
+
// 批量插入边
|
|
221
|
+
if (edges.length > 0) {
|
|
222
|
+
this.db.insertCallEdges(edges);
|
|
223
|
+
}
|
|
224
|
+
}
|
|
225
|
+
/**
|
|
226
|
+
* 解析导入路径
|
|
227
|
+
*/
|
|
228
|
+
async resolveImportPath(fromFile, importPath) {
|
|
229
|
+
if (importPath.startsWith('.')) {
|
|
230
|
+
const fromDir = fromFile.substring(0, fromFile.lastIndexOf('/'));
|
|
231
|
+
const resolved = resolve(fromDir, importPath);
|
|
232
|
+
const extensions = ['.ts', '.tsx', '.js', '.jsx', '.py', '.go'];
|
|
233
|
+
for (const ext of extensions) {
|
|
234
|
+
const withExt = resolved + ext;
|
|
235
|
+
try {
|
|
236
|
+
await access(withExt);
|
|
237
|
+
return withExt;
|
|
238
|
+
}
|
|
239
|
+
catch {
|
|
240
|
+
// 继续尝试
|
|
241
|
+
}
|
|
242
|
+
}
|
|
243
|
+
for (const ext of extensions) {
|
|
244
|
+
const indexPath = resolve(resolved, `index${ext}`);
|
|
245
|
+
try {
|
|
246
|
+
await access(indexPath);
|
|
247
|
+
return indexPath;
|
|
248
|
+
}
|
|
249
|
+
catch {
|
|
250
|
+
// 继续尝试
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
return null;
|
|
255
|
+
}
|
|
256
|
+
/**
|
|
257
|
+
* 报告进度
|
|
258
|
+
*/
|
|
259
|
+
reportProgress(phase, current, total) {
|
|
260
|
+
if (!this.progressCallback)
|
|
261
|
+
return;
|
|
262
|
+
const percentage = total > 0 ? Math.round((current / total) * 100) : 0;
|
|
263
|
+
const speed = current > 0 ? current / (Date.now() / 1000) : 0;
|
|
264
|
+
const eta = speed > 0 ? Math.round((total - current) / speed) : 0;
|
|
265
|
+
this.progressCallback({
|
|
266
|
+
phase,
|
|
267
|
+
current,
|
|
268
|
+
total,
|
|
269
|
+
percentage,
|
|
270
|
+
speed,
|
|
271
|
+
eta,
|
|
272
|
+
});
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
//# sourceMappingURL=performance.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"performance.js","sourceRoot":"","sources":["../../../src/graph/performance.ts"],"names":[],"mappings":"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"}
|