@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.
Files changed (276) hide show
  1. package/README.en.md +522 -0
  2. package/README.md +566 -0
  3. package/dist/bin/sds.d.ts +3 -0
  4. package/dist/bin/sds.d.ts.map +1 -0
  5. package/dist/bin/sds.js +50 -0
  6. package/dist/bin/sds.js.map +1 -0
  7. package/dist/src/__tests__/cli.test.d.ts +2 -0
  8. package/dist/src/__tests__/cli.test.d.ts.map +1 -0
  9. package/dist/src/__tests__/cli.test.js +37 -0
  10. package/dist/src/__tests__/cli.test.js.map +1 -0
  11. package/dist/src/__tests__/e2e.test.d.ts +5 -0
  12. package/dist/src/__tests__/e2e.test.d.ts.map +1 -0
  13. package/dist/src/__tests__/e2e.test.js +143 -0
  14. package/dist/src/__tests__/e2e.test.js.map +1 -0
  15. package/dist/src/__tests__/graph.test.d.ts +5 -0
  16. package/dist/src/__tests__/graph.test.d.ts.map +1 -0
  17. package/dist/src/__tests__/graph.test.js +423 -0
  18. package/dist/src/__tests__/graph.test.js.map +1 -0
  19. package/dist/src/__tests__/openspec.test.d.ts +5 -0
  20. package/dist/src/__tests__/openspec.test.d.ts.map +1 -0
  21. package/dist/src/__tests__/openspec.test.js +172 -0
  22. package/dist/src/__tests__/openspec.test.js.map +1 -0
  23. package/dist/src/commands/apply.d.ts +4 -0
  24. package/dist/src/commands/apply.d.ts.map +1 -0
  25. package/dist/src/commands/apply.js +14 -0
  26. package/dist/src/commands/apply.js.map +1 -0
  27. package/dist/src/commands/archive.d.ts +4 -0
  28. package/dist/src/commands/archive.d.ts.map +1 -0
  29. package/dist/src/commands/archive.js +20 -0
  30. package/dist/src/commands/archive.js.map +1 -0
  31. package/dist/src/commands/cache.d.ts +4 -0
  32. package/dist/src/commands/cache.d.ts.map +1 -0
  33. package/dist/src/commands/cache.js +31 -0
  34. package/dist/src/commands/cache.js.map +1 -0
  35. package/dist/src/commands/config.d.ts +4 -0
  36. package/dist/src/commands/config.d.ts.map +1 -0
  37. package/dist/src/commands/config.js +29 -0
  38. package/dist/src/commands/config.js.map +1 -0
  39. package/dist/src/commands/e2e.d.ts +4 -0
  40. package/dist/src/commands/e2e.d.ts.map +1 -0
  41. package/dist/src/commands/e2e.js +65 -0
  42. package/dist/src/commands/e2e.js.map +1 -0
  43. package/dist/src/commands/graph.d.ts +4 -0
  44. package/dist/src/commands/graph.d.ts.map +1 -0
  45. package/dist/src/commands/graph.js +783 -0
  46. package/dist/src/commands/graph.js.map +1 -0
  47. package/dist/src/commands/init.d.ts +4 -0
  48. package/dist/src/commands/init.d.ts.map +1 -0
  49. package/dist/src/commands/init.js +15 -0
  50. package/dist/src/commands/init.js.map +1 -0
  51. package/dist/src/commands/project.d.ts +4 -0
  52. package/dist/src/commands/project.d.ts.map +1 -0
  53. package/dist/src/commands/project.js +6 -0
  54. package/dist/src/commands/project.js.map +1 -0
  55. package/dist/src/commands/propose.d.ts +4 -0
  56. package/dist/src/commands/propose.d.ts.map +1 -0
  57. package/dist/src/commands/propose.js +26 -0
  58. package/dist/src/commands/propose.js.map +1 -0
  59. package/dist/src/commands/registry.d.ts +4 -0
  60. package/dist/src/commands/registry.d.ts.map +1 -0
  61. package/dist/src/commands/registry.js +6 -0
  62. package/dist/src/commands/registry.js.map +1 -0
  63. package/dist/src/commands/skills-install.d.ts +4 -0
  64. package/dist/src/commands/skills-install.d.ts.map +1 -0
  65. package/dist/src/commands/skills-install.js +158 -0
  66. package/dist/src/commands/skills-install.js.map +1 -0
  67. package/dist/src/commands/skills.d.ts +4 -0
  68. package/dist/src/commands/skills.d.ts.map +1 -0
  69. package/dist/src/commands/skills.js +19 -0
  70. package/dist/src/commands/skills.js.map +1 -0
  71. package/dist/src/commands/verify.d.ts +4 -0
  72. package/dist/src/commands/verify.d.ts.map +1 -0
  73. package/dist/src/commands/verify.js +31 -0
  74. package/dist/src/commands/verify.js.map +1 -0
  75. package/dist/src/core/engine.d.ts +33 -0
  76. package/dist/src/core/engine.d.ts.map +1 -0
  77. package/dist/src/core/engine.js +87 -0
  78. package/dist/src/core/engine.js.map +1 -0
  79. package/dist/src/core/engine.test.d.ts +2 -0
  80. package/dist/src/core/engine.test.d.ts.map +1 -0
  81. package/dist/src/core/engine.test.js +13 -0
  82. package/dist/src/core/engine.test.js.map +1 -0
  83. package/dist/src/core/session-state.d.ts +18 -0
  84. package/dist/src/core/session-state.d.ts.map +1 -0
  85. package/dist/src/core/session-state.js +55 -0
  86. package/dist/src/core/session-state.js.map +1 -0
  87. package/dist/src/core/session-state.test.d.ts +2 -0
  88. package/dist/src/core/session-state.test.d.ts.map +1 -0
  89. package/dist/src/core/session-state.test.js +90 -0
  90. package/dist/src/core/session-state.test.js.map +1 -0
  91. package/dist/src/core/subagent-timeout.d.ts +18 -0
  92. package/dist/src/core/subagent-timeout.d.ts.map +1 -0
  93. package/dist/src/core/subagent-timeout.js +61 -0
  94. package/dist/src/core/subagent-timeout.js.map +1 -0
  95. package/dist/src/core/subagent-timeout.test.d.ts +2 -0
  96. package/dist/src/core/subagent-timeout.test.d.ts.map +1 -0
  97. package/dist/src/core/subagent-timeout.test.js +57 -0
  98. package/dist/src/core/subagent-timeout.test.js.map +1 -0
  99. package/dist/src/core/task-sync.d.ts +19 -0
  100. package/dist/src/core/task-sync.d.ts.map +1 -0
  101. package/dist/src/core/task-sync.js +62 -0
  102. package/dist/src/core/task-sync.js.map +1 -0
  103. package/dist/src/core/task-sync.test.d.ts +2 -0
  104. package/dist/src/core/task-sync.test.d.ts.map +1 -0
  105. package/dist/src/core/task-sync.test.js +84 -0
  106. package/dist/src/core/task-sync.test.js.map +1 -0
  107. package/dist/src/graph/advanced-performance.d.ts +137 -0
  108. package/dist/src/graph/advanced-performance.d.ts.map +1 -0
  109. package/dist/src/graph/advanced-performance.js +375 -0
  110. package/dist/src/graph/advanced-performance.js.map +1 -0
  111. package/dist/src/graph/database.d.ts +79 -0
  112. package/dist/src/graph/database.d.ts.map +1 -0
  113. package/dist/src/graph/database.js +305 -0
  114. package/dist/src/graph/database.js.map +1 -0
  115. package/dist/src/graph/engine.d.ts +43 -0
  116. package/dist/src/graph/engine.d.ts.map +1 -0
  117. package/dist/src/graph/engine.js +334 -0
  118. package/dist/src/graph/engine.js.map +1 -0
  119. package/dist/src/graph/exporter.d.ts +56 -0
  120. package/dist/src/graph/exporter.d.ts.map +1 -0
  121. package/dist/src/graph/exporter.js +273 -0
  122. package/dist/src/graph/exporter.js.map +1 -0
  123. package/dist/src/graph/index.d.ts +21 -0
  124. package/dist/src/graph/index.d.ts.map +1 -0
  125. package/dist/src/graph/index.js +14 -0
  126. package/dist/src/graph/index.js.map +1 -0
  127. package/dist/src/graph/layouts.d.ts +77 -0
  128. package/dist/src/graph/layouts.d.ts.map +1 -0
  129. package/dist/src/graph/layouts.js +368 -0
  130. package/dist/src/graph/layouts.js.map +1 -0
  131. package/dist/src/graph/parser.d.ts +47 -0
  132. package/dist/src/graph/parser.d.ts.map +1 -0
  133. package/dist/src/graph/parser.js +228 -0
  134. package/dist/src/graph/parser.js.map +1 -0
  135. package/dist/src/graph/performance.d.ts +90 -0
  136. package/dist/src/graph/performance.d.ts.map +1 -0
  137. package/dist/src/graph/performance.js +275 -0
  138. package/dist/src/graph/performance.js.map +1 -0
  139. package/dist/src/graph/semantic.d.ts +151 -0
  140. package/dist/src/graph/semantic.d.ts.map +1 -0
  141. package/dist/src/graph/semantic.js +402 -0
  142. package/dist/src/graph/semantic.js.map +1 -0
  143. package/dist/src/graph/types.d.ts +114 -0
  144. package/dist/src/graph/types.d.ts.map +1 -0
  145. package/dist/src/graph/types.js +5 -0
  146. package/dist/src/graph/types.js.map +1 -0
  147. package/dist/src/graph/visualizer.d.ts +50 -0
  148. package/dist/src/graph/visualizer.d.ts.map +1 -0
  149. package/dist/src/graph/visualizer.js +869 -0
  150. package/dist/src/graph/visualizer.js.map +1 -0
  151. package/dist/src/openspec/apply.d.ts +16 -0
  152. package/dist/src/openspec/apply.d.ts.map +1 -0
  153. package/dist/src/openspec/apply.js +140 -0
  154. package/dist/src/openspec/apply.js.map +1 -0
  155. package/dist/src/openspec/archive.d.ts +3 -0
  156. package/dist/src/openspec/archive.d.ts.map +1 -0
  157. package/dist/src/openspec/archive.js +17 -0
  158. package/dist/src/openspec/archive.js.map +1 -0
  159. package/dist/src/openspec/e2e-generate.d.ts +39 -0
  160. package/dist/src/openspec/e2e-generate.d.ts.map +1 -0
  161. package/dist/src/openspec/e2e-generate.js +315 -0
  162. package/dist/src/openspec/e2e-generate.js.map +1 -0
  163. package/dist/src/openspec/e2e-runner.d.ts +32 -0
  164. package/dist/src/openspec/e2e-runner.d.ts.map +1 -0
  165. package/dist/src/openspec/e2e-runner.js +208 -0
  166. package/dist/src/openspec/e2e-runner.js.map +1 -0
  167. package/dist/src/openspec/explore.d.ts +3 -0
  168. package/dist/src/openspec/explore.d.ts.map +1 -0
  169. package/dist/src/openspec/explore.js +20 -0
  170. package/dist/src/openspec/explore.js.map +1 -0
  171. package/dist/src/openspec/propose.d.ts +8 -0
  172. package/dist/src/openspec/propose.d.ts.map +1 -0
  173. package/dist/src/openspec/propose.js +124 -0
  174. package/dist/src/openspec/propose.js.map +1 -0
  175. package/dist/src/openspec/verify.d.ts +13 -0
  176. package/dist/src/openspec/verify.d.ts.map +1 -0
  177. package/dist/src/openspec/verify.js +156 -0
  178. package/dist/src/openspec/verify.js.map +1 -0
  179. package/dist/src/platform/claudecode.d.ts +2 -0
  180. package/dist/src/platform/claudecode.d.ts.map +1 -0
  181. package/dist/src/platform/claudecode.js +7 -0
  182. package/dist/src/platform/claudecode.js.map +1 -0
  183. package/dist/src/platform/codex.d.ts +2 -0
  184. package/dist/src/platform/codex.d.ts.map +1 -0
  185. package/dist/src/platform/codex.js +7 -0
  186. package/dist/src/platform/codex.js.map +1 -0
  187. package/dist/src/platform/opencode.d.ts +2 -0
  188. package/dist/src/platform/opencode.d.ts.map +1 -0
  189. package/dist/src/platform/opencode.js +7 -0
  190. package/dist/src/platform/opencode.js.map +1 -0
  191. package/dist/src/platform/router.d.ts +13 -0
  192. package/dist/src/platform/router.d.ts.map +1 -0
  193. package/dist/src/platform/router.js +57 -0
  194. package/dist/src/platform/router.js.map +1 -0
  195. package/dist/src/skills/cache.d.ts +16 -0
  196. package/dist/src/skills/cache.d.ts.map +1 -0
  197. package/dist/src/skills/cache.js +53 -0
  198. package/dist/src/skills/cache.js.map +1 -0
  199. package/dist/src/skills/discovery.d.ts +12 -0
  200. package/dist/src/skills/discovery.d.ts.map +1 -0
  201. package/dist/src/skills/discovery.js +61 -0
  202. package/dist/src/skills/discovery.js.map +1 -0
  203. package/dist/src/skills/loader.d.ts +12 -0
  204. package/dist/src/skills/loader.d.ts.map +1 -0
  205. package/dist/src/skills/loader.js +69 -0
  206. package/dist/src/skills/loader.js.map +1 -0
  207. package/dist/src/skills/registry.d.ts +23 -0
  208. package/dist/src/skills/registry.d.ts.map +1 -0
  209. package/dist/src/skills/registry.js +68 -0
  210. package/dist/src/skills/registry.js.map +1 -0
  211. package/dist/src/utils/fs.d.ts +5 -0
  212. package/dist/src/utils/fs.d.ts.map +1 -0
  213. package/dist/src/utils/fs.js +23 -0
  214. package/dist/src/utils/fs.js.map +1 -0
  215. package/dist/src/utils/logger.d.ts +7 -0
  216. package/dist/src/utils/logger.d.ts.map +1 -0
  217. package/dist/src/utils/logger.js +8 -0
  218. package/dist/src/utils/logger.js.map +1 -0
  219. package/dist/src/utils/yaml.d.ts +3 -0
  220. package/dist/src/utils/yaml.d.ts.map +1 -0
  221. package/dist/src/utils/yaml.js +8 -0
  222. package/dist/src/utils/yaml.js.map +1 -0
  223. package/package.json +62 -0
  224. package/registry/skills-registry.yaml +218 -0
  225. package/skills/core/brainstorming/SKILL.md +259 -0
  226. package/skills/core/brainstorming/scripts/frame-template.html +214 -0
  227. package/skills/core/brainstorming/scripts/helper.js +88 -0
  228. package/skills/core/brainstorming/scripts/server.cjs +338 -0
  229. package/skills/core/brainstorming/scripts/start-server.sh +153 -0
  230. package/skills/core/brainstorming/scripts/stop-server.sh +55 -0
  231. package/skills/core/brainstorming/skill.yaml +12 -0
  232. package/skills/core/brainstorming/spec-document-reviewer-prompt.md +48 -0
  233. package/skills/core/brainstorming/visual-companion.md +286 -0
  234. package/skills/core/claude-code-core/SKILL.md +164 -0
  235. package/skills/core/claude-code-core/skill.yaml +14 -0
  236. package/skills/core/claude-code-prompt/SKILL.md +283 -0
  237. package/skills/core/claude-code-prompt/skill.yaml +14 -0
  238. package/skills/core/claude-code-subagent/SKILL.md +168 -0
  239. package/skills/core/claude-code-subagent/skill.yaml +14 -0
  240. package/skills/core/e2e-generate/SKILL.md +147 -0
  241. package/skills/core/e2e-generate/skill.yaml +12 -0
  242. package/skills/core/ecc-agents-md-router/SKILL.md +90 -0
  243. package/skills/core/ecc-agents-md-router/skill.yaml +12 -0
  244. package/skills/core/ecc-context-injector/SKILL.md +69 -0
  245. package/skills/core/ecc-context-injector/skill.yaml +12 -0
  246. package/skills/core/existing-code-caveman/SKILL.md +340 -0
  247. package/skills/core/existing-code-caveman/skill.yaml +12 -0
  248. package/skills/core/opsx-apply/SKILL.md +121 -0
  249. package/skills/core/opsx-apply/skill.yaml +12 -0
  250. package/skills/core/opsx-archive/SKILL.md +83 -0
  251. package/skills/core/opsx-archive/skill.yaml +12 -0
  252. package/skills/core/opsx-explore/SKILL.md +101 -0
  253. package/skills/core/opsx-explore/skill.yaml +12 -0
  254. package/skills/core/opsx-propose/SKILL.md +131 -0
  255. package/skills/core/opsx-propose/skill.yaml +16 -0
  256. package/skills/core/opsx-verify/SKILL.md +109 -0
  257. package/skills/core/opsx-verify/skill.yaml +12 -0
  258. package/skills/core/subagent-driven-development/SKILL.md +157 -0
  259. package/skills/core/subagent-driven-development/code-quality-reviewer-prompt.md +64 -0
  260. package/skills/core/subagent-driven-development/implementer-prompt.md +122 -0
  261. package/skills/core/subagent-driven-development/skill.yaml +12 -0
  262. package/skills/core/subagent-driven-development/spec-reviewer-prompt.md +61 -0
  263. package/skills/core/writing-plans/SKILL.md +268 -0
  264. package/skills/core/writing-plans/plan-document-reviewer-prompt.md +63 -0
  265. package/skills/core/writing-plans/skill.yaml +12 -0
  266. package/skills/locale/chinese-code-review/SKILL.md +17 -0
  267. package/skills/locale/chinese-code-review/skill.yaml +16 -0
  268. package/skills/locale/chinese-commit-conventions/SKILL.md +17 -0
  269. package/skills/locale/chinese-commit-conventions/skill.yaml +16 -0
  270. package/skills/locale/chinese-documentation/SKILL.md +17 -0
  271. package/skills/locale/chinese-documentation/skill.yaml +16 -0
  272. package/skills/locale/chinese-git-workflow/SKILL.md +17 -0
  273. package/skills/locale/chinese-git-workflow/skill.yaml +16 -0
  274. package/templates/agents-md.md +42 -0
  275. package/templates/claude-md.md +44 -0
  276. 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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"}