@chongyan/autospec 1.0.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.
Files changed (243) hide show
  1. package/LICENSE +21 -0
  2. package/README.en.md +472 -0
  3. package/README.md +476 -0
  4. package/bin/autospec.js +3 -0
  5. package/knowledge/README.md +144 -0
  6. package/knowledge/checklists/code.md +182 -0
  7. package/knowledge/checklists/design.md +196 -0
  8. package/knowledge/checklists/release.md +70 -0
  9. package/knowledge/checklists/requirement.md +169 -0
  10. package/knowledge/checklists/test.md +46 -0
  11. package/knowledge/config/README.en.md +44 -0
  12. package/knowledge/config/README.md +44 -0
  13. package/knowledge/config/role-composition.yaml +98 -0
  14. package/knowledge/config/role-extensions.yaml +140 -0
  15. package/knowledge/config/skill-compositions.yaml +142 -0
  16. package/knowledge/config/team-stage.yaml +95 -0
  17. package/knowledge/config/team-tasks.yaml +139 -0
  18. package/knowledge/config/team-triggers.yaml +198 -0
  19. package/knowledge/config/validation-patterns.yaml +137 -0
  20. package/knowledge/domain/README.md +115 -0
  21. package/knowledge/domain/flows/README.md +194 -0
  22. package/knowledge/domain/glossary.md +143 -0
  23. package/knowledge/domain/rules.md +138 -0
  24. package/knowledge/environment/README.en.md +36 -0
  25. package/knowledge/environment/README.md +87 -0
  26. package/knowledge/environment/component-knowledge.md +316 -0
  27. package/knowledge/environment/detection-patterns.yaml +502 -0
  28. package/knowledge/environment/middleware-knowledge.md +237 -0
  29. package/knowledge/environment/template-registry.md +321 -0
  30. package/knowledge/guides/domain-driven-design.md +345 -0
  31. package/knowledge/guides/knowledge-management.md +369 -0
  32. package/knowledge/guides/requirement-engineering.md +329 -0
  33. package/knowledge/guides/stages/ai-effect-evaluator.md +93 -0
  34. package/knowledge/guides/stages/code-implementer.md +205 -0
  35. package/knowledge/guides/stages/code-reviewer.md +111 -0
  36. package/knowledge/guides/stages/consistency-checker.md +177 -0
  37. package/knowledge/guides/stages/design-planner.md +401 -0
  38. package/knowledge/guides/stages/design-reviewer.md +83 -0
  39. package/knowledge/guides/stages/integration-test-runner.md +105 -0
  40. package/knowledge/guides/stages/release-checker.md +205 -0
  41. package/knowledge/guides/stages/requirement-analyzer.md +195 -0
  42. package/knowledge/guides/stages/requirement-reviewer.md +83 -0
  43. package/knowledge/guides/stages/security-reviewer.md +89 -0
  44. package/knowledge/guides/stages/test-context-analyzer.md +250 -0
  45. package/knowledge/guides/stages/test-generator.md +241 -0
  46. package/knowledge/guides/stages/test-planner.md +183 -0
  47. package/knowledge/guides/stages/test-reviewer.md +76 -0
  48. package/knowledge/guides/stages/unit-test-runner.md +83 -0
  49. package/knowledge/guides/support/ai-agent-analyzer.md +362 -0
  50. package/knowledge/guides/support/ai-anomaly-analyzer.md +213 -0
  51. package/knowledge/guides/support/ai-artifact-evaluator.md +192 -0
  52. package/knowledge/guides/support/ai-capability-analyzer.md +193 -0
  53. package/knowledge/guides/support/ai-component-analyzer.md +169 -0
  54. package/knowledge/guides/support/ai-data-validator.md +276 -0
  55. package/knowledge/guides/support/ai-evaluation-planner.md +374 -0
  56. package/knowledge/guides/support/ai-path-evaluator.md +274 -0
  57. package/knowledge/guides/support/ai-pipeline-evaluator.md +219 -0
  58. package/knowledge/guides/support/ai-rag-analyzer.md +339 -0
  59. package/knowledge/guides/support/ai-task-assessor.md +418 -0
  60. package/knowledge/guides/support/ai-test-diagnostics.md +133 -0
  61. package/knowledge/guides/support/complexity-assessor.md +268 -0
  62. package/knowledge/guides/support/component-discovery.md +183 -0
  63. package/knowledge/guides/support/environment-scanner.md +207 -0
  64. package/knowledge/guides/support/environment-validator.md +207 -0
  65. package/knowledge/guides/support/knowledge-generator.md +234 -0
  66. package/knowledge/guides/support/methodology-extractor.md +55 -0
  67. package/knowledge/guides/support/pipeline-protocol.md +438 -0
  68. package/knowledge/guides/support/practice-logger.md +359 -0
  69. package/knowledge/guides/support/scope-inference.md +174 -0
  70. package/knowledge/guides/support/skill-distiller.md +91 -0
  71. package/knowledge/guides/support/skill-updater.md +45 -0
  72. package/knowledge/guides/support/skill-validator.md +72 -0
  73. package/knowledge/guides/support/team-orchestrator.md +323 -0
  74. package/knowledge/guides/support/tech-stack-analyzer.md +139 -0
  75. package/knowledge/guides/support/test-runner.md +254 -0
  76. package/knowledge/guides/system-design.md +352 -0
  77. package/knowledge/organization/ai-native-team.md +318 -0
  78. package/knowledge/organization/team-metrics.md +228 -0
  79. package/knowledge/principles/constitution.md +134 -0
  80. package/knowledge/principles/core-principles.md +368 -0
  81. package/knowledge/principles/design-philosophy.md +877 -0
  82. package/knowledge/principles/evolution.md +553 -0
  83. package/knowledge/process/01-requirement.md +113 -0
  84. package/knowledge/process/02-design.md +123 -0
  85. package/knowledge/process/03-implementation.md +90 -0
  86. package/knowledge/process/04-review.md +80 -0
  87. package/knowledge/process/05-testing.md +90 -0
  88. package/knowledge/process/06-delivery.md +88 -0
  89. package/knowledge/process/README.en.md +38 -0
  90. package/knowledge/process/README.md +48 -0
  91. package/knowledge/process/ai-sdlc.md +475 -0
  92. package/knowledge/process/overview.md +319 -0
  93. package/knowledge/standards/code-review.md +876 -0
  94. package/knowledge/standards/coding-style.md +940 -0
  95. package/knowledge/standards/data-consistency.md +1085 -0
  96. package/knowledge/standards/document-versioning.md +210 -0
  97. package/knowledge/standards/risk-detection.md +186 -0
  98. package/knowledge/templates/ai-evaluation.md +150 -0
  99. package/knowledge/templates/api-design.md +117 -0
  100. package/knowledge/templates/database-design.md +132 -0
  101. package/knowledge/templates/domain-driven-design.md +321 -0
  102. package/knowledge/templates/product-proposal.md +201 -0
  103. package/knowledge/templates/system-design.md +227 -0
  104. package/knowledge/templates/task-breakdown.md +107 -0
  105. package/knowledge/templates/test-case.md +170 -0
  106. package/package.json +53 -0
  107. package/plugins/.claude-plugin/plugin.json +134 -0
  108. package/plugins/agents/roles/ai-engineer.md +129 -0
  109. package/plugins/agents/roles/backend-engineer.md +165 -0
  110. package/plugins/agents/roles/ceo.md +94 -0
  111. package/plugins/agents/roles/data-engineer.md +135 -0
  112. package/plugins/agents/roles/devops-engineer.md +181 -0
  113. package/plugins/agents/roles/frontend-engineer.md +129 -0
  114. package/plugins/agents/roles/product-owner.md +98 -0
  115. package/plugins/agents/roles/quality-engineer.md +129 -0
  116. package/plugins/agents/roles/security-engineer.md +180 -0
  117. package/plugins/agents/roles/tech-lead.md +97 -0
  118. package/plugins/agents/support/blind-comparator.md +88 -0
  119. package/plugins/agents/support/consistency-checker.md +103 -0
  120. package/plugins/agents/support/failure-diagnostician.md +141 -0
  121. package/plugins/agents/support/independent-reviewer.md +80 -0
  122. package/plugins/agents/support/safety-auditor.md +121 -0
  123. package/plugins/agents/support/skill-benchmarker.md +86 -0
  124. package/plugins/agents/support/skill-forger.md +105 -0
  125. package/plugins/agents/support/stage-gate-evaluator.md +121 -0
  126. package/plugins/agents/support/test-coverage-reviewer.md +73 -0
  127. package/plugins/benchmarks/templates/README.md +44 -0
  128. package/plugins/benchmarks/templates/commands/explore-template.yaml +48 -0
  129. package/plugins/benchmarks/templates/pipeline/agile-template.yaml +84 -0
  130. package/plugins/benchmarks/templates/pipeline/waterfall-template.yaml +106 -0
  131. package/plugins/benchmarks/templates/skills/requirement-analyzer-template.yaml +48 -0
  132. package/plugins/commands/README.en.md +96 -0
  133. package/plugins/commands/README.md +96 -0
  134. package/plugins/commands/apply.md +191 -0
  135. package/plugins/commands/archive.md +76 -0
  136. package/plugins/commands/env-export.md +79 -0
  137. package/plugins/commands/env-sync.md +640 -0
  138. package/plugins/commands/env-template.md +223 -0
  139. package/plugins/commands/env-update.md +264 -0
  140. package/plugins/commands/env-validate.md +176 -0
  141. package/plugins/commands/env.md +79 -0
  142. package/plugins/commands/explore.md +76 -0
  143. package/plugins/commands/field-evolve.md +536 -0
  144. package/plugins/commands/memory.md +249 -0
  145. package/plugins/commands/project-evolve.md +821 -0
  146. package/plugins/commands/propose.md +93 -0
  147. package/plugins/commands/review.md +140 -0
  148. package/plugins/commands/run.md +224 -0
  149. package/plugins/commands/status.md +62 -0
  150. package/plugins/commands/validate.md +108 -0
  151. package/plugins/hooks/README.en.md +56 -0
  152. package/plugins/hooks/README.md +56 -0
  153. package/plugins/hooks/ai-project-guard.js +329 -0
  154. package/plugins/hooks/artifact-evaluation-hook.js +237 -0
  155. package/plugins/hooks/constitution-guard.js +211 -0
  156. package/plugins/hooks/environment-autocommit.js +264 -0
  157. package/plugins/hooks/environment-manager.js +778 -0
  158. package/plugins/hooks/execution-tracker.js +354 -0
  159. package/plugins/hooks/frozen-zone-guard.js +140 -0
  160. package/plugins/hooks/layer1-validator.js +423 -0
  161. package/plugins/hooks/lib/artifact-evaluator.js +414 -0
  162. package/plugins/hooks/lib/benchmarks/change-detector.js +390 -0
  163. package/plugins/hooks/lib/benchmarks/evaluator.js +605 -0
  164. package/plugins/hooks/lib/benchmarks/integration-example.js +169 -0
  165. package/plugins/hooks/lib/data-and-ai-detector.js +275 -0
  166. package/plugins/hooks/lib/detection-pattern-loader.js +865 -0
  167. package/plugins/hooks/lib/directory-discovery.js +395 -0
  168. package/plugins/hooks/lib/environment-config-loader.js +341 -0
  169. package/plugins/hooks/lib/environment-detector.js +553 -0
  170. package/plugins/hooks/lib/environment-evolver.js +564 -0
  171. package/plugins/hooks/lib/environment-registry.js +813 -0
  172. package/plugins/hooks/lib/execution-path.js +427 -0
  173. package/plugins/hooks/lib/hook-error-recorder.js +245 -0
  174. package/plugins/hooks/lib/hook-logger.js +538 -0
  175. package/plugins/hooks/lib/hook-runner.js +97 -0
  176. package/plugins/hooks/lib/hook-runner.sh +44 -0
  177. package/plugins/hooks/lib/hook-state-manager.js +480 -0
  178. package/plugins/hooks/lib/memory-extractor.js +377 -0
  179. package/plugins/hooks/lib/memory-manager.js +673 -0
  180. package/plugins/hooks/lib/metrics-analyzer.js +489 -0
  181. package/plugins/hooks/lib/project-evolution/auto-fixer.js +511 -0
  182. package/plugins/hooks/lib/project-evolution/memory-manager.js +346 -0
  183. package/plugins/hooks/lib/project-evolution/pattern-detector.js +476 -0
  184. package/plugins/hooks/lib/project-evolution/semantic-indexer.js +480 -0
  185. package/plugins/hooks/lib/project-structure-detector.js +326 -0
  186. package/plugins/hooks/lib/rollback-tracker.js +346 -0
  187. package/plugins/hooks/lib/source-code-scanner.js +596 -0
  188. package/plugins/hooks/lib/technology-stack-detector.js +374 -0
  189. package/plugins/hooks/lib/test-failure-analyzer.js +375 -0
  190. package/plugins/hooks/lib/test-failure-fixer.js +268 -0
  191. package/plugins/hooks/lib/trace-context.js +277 -0
  192. package/plugins/hooks/lib/validation-patterns.js +415 -0
  193. package/plugins/hooks/memory-sync.js +171 -0
  194. package/plugins/hooks/pipeline-observer.js +413 -0
  195. package/plugins/hooks/scope-sentinel.js +204 -0
  196. package/plugins/hooks/trace-initialization.js +169 -0
  197. package/plugins/memory/templates/code-quality.yaml +149 -0
  198. package/plugins/memory/templates/multi-system.yaml +155 -0
  199. package/plugins/memory/templates/team-habits.yaml +119 -0
  200. package/plugins/memory/templates/testing.yaml +121 -0
  201. package/plugins/skills/README.en.md +47 -0
  202. package/plugins/skills/README.md +104 -0
  203. package/plugins/skills/benchmark-executor/README.md +93 -0
  204. package/plugins/skills/benchmark-executor/SKILL.md +647 -0
  205. package/plugins/skills/benchmark-generator/SKILL.md +349 -0
  206. package/plugins/skills/delivery-stage/SKILL.md +203 -0
  207. package/plugins/skills/design-stage/SKILL.md +216 -0
  208. package/plugins/skills/evolution-process/SKILL.md +291 -0
  209. package/plugins/skills/exploration-phase/SKILL.md +133 -0
  210. package/plugins/skills/implementation-stage/SKILL.md +179 -0
  211. package/plugins/skills/layer1-validation/SKILL.md +79 -0
  212. package/plugins/skills/pending-dashboard/SKILL.md +109 -0
  213. package/plugins/skills/project-evolution/SKILL.md +847 -0
  214. package/plugins/skills/requirement-stage/SKILL.md +183 -0
  215. package/plugins/skills/skill-forge/SKILL.md +223 -0
  216. package/plugins/skills/skill-forge/references/description-guide.md +92 -0
  217. package/plugins/skills/skill-forge/references/quality-rubric.md +104 -0
  218. package/plugins/skills/skill-forge/references/skill-template.md +106 -0
  219. package/plugins/skills/startup-guard/SKILL.md +38 -0
  220. package/plugins/skills/testing-stage/SKILL.md +195 -0
  221. package/scripts/cli/global-init.js +288 -0
  222. package/scripts/cli/global.js +324 -0
  223. package/scripts/cli/index.js +55 -0
  224. package/scripts/cli/init.js +382 -0
  225. package/scripts/cli/list.js +69 -0
  226. package/scripts/cli/org.js +340 -0
  227. package/scripts/cli/update.js +44 -0
  228. package/scripts/config/commands.config.js +145 -0
  229. package/scripts/config/hooks.config.js +197 -0
  230. package/scripts/evolution/evolution-router.js +273 -0
  231. package/scripts/evolution/evolution-signal-collector.js +307 -0
  232. package/scripts/evolution/knowledge-loader.js +346 -0
  233. package/scripts/evolution/marketplace.js +317 -0
  234. package/scripts/evolution/version-manager.js +371 -0
  235. package/scripts/install/agents.js +106 -0
  236. package/scripts/install/commands.js +133 -0
  237. package/scripts/install/constants.js +424 -0
  238. package/scripts/install/hook-logger.js +536 -0
  239. package/scripts/install/hooks.js +110 -0
  240. package/scripts/install/index.js +39 -0
  241. package/scripts/install/skills.js +95 -0
  242. package/scripts/postinstall.js +25 -0
  243. package/scripts/state.js +376 -0
@@ -0,0 +1,374 @@
1
+ /**
2
+ * 技术栈检测模块(配置驱动)
3
+ *
4
+ * 通过分析构建文件识别技术栈,规则从配置文件加载。
5
+ */
6
+
7
+ import fs from 'fs';
8
+ import path from 'path';
9
+ import { getBuildFileRules, getFrameworkRules, getIgnoreDirectories } from './environment-config-loader.js';
10
+
11
+ /**
12
+ * 获取构建文件规则(从配置加载)
13
+ */
14
+ function getBuildFileRulesWithParsers() {
15
+ const rules = getBuildFileRules();
16
+ const rulesWithParsers = {};
17
+
18
+ for (const [filename, rule] of Object.entries(rules)) {
19
+ rulesWithParsers[filename] = {
20
+ ...rule,
21
+ parser: getParserForFile(filename)
22
+ };
23
+ }
24
+
25
+ return rulesWithParsers;
26
+ }
27
+
28
+ /**
29
+ * 获取文件对应的解析器
30
+ */
31
+ function getParserForFile(filename) {
32
+ const parserMap = {
33
+ 'package.json': parsePackageJson,
34
+ 'pom.xml': parsePomXml,
35
+ 'build.gradle': parseBuildGradle,
36
+ 'build.gradle.kts': parseBuildGradle,
37
+ 'go.mod': parseGoMod,
38
+ 'Cargo.toml': parseCargoToml,
39
+ 'pyproject.toml': parsePyprojectToml,
40
+ 'requirements.txt': parseRequirements,
41
+ 'setup.py': parseSetupPy,
42
+ 'dbt_project.yml': parseDbtProject,
43
+ 'pubspec.yaml': parsePubspec,
44
+ 'composer.json': parseComposer,
45
+ 'Gemfile': parseGemfile
46
+ };
47
+
48
+ return parserMap[filename] || parseGeneric;
49
+ }
50
+
51
+ /**
52
+ * 检测技术栈
53
+ * @param {string} projectDir - 项目根目录
54
+ * @returns {Array} 技术栈列表
55
+ */
56
+ export function detectTechStacks(projectDir) {
57
+ const techStacks = [];
58
+ const buildFileRules = getBuildFileRulesWithParsers();
59
+ const frameworkRules = getFrameworkRules();
60
+
61
+ // 扫描所有构建文件
62
+ const buildFiles = scanBuildFiles(projectDir, Object.keys(buildFileRules));
63
+
64
+ for (const file of buildFiles) {
65
+ const rule = buildFileRules[file.name];
66
+ if (!rule) continue;
67
+
68
+ const content = fs.readFileSync(file.absolutePath, 'utf-8');
69
+ const details = rule.parser(content, file.relativePath, frameworkRules);
70
+
71
+ if (details) {
72
+ techStacks.push({
73
+ buildFile: file.relativePath,
74
+ path: path.dirname(file.relativePath) || '.',
75
+ buildTool: rule.buildTool,
76
+ lang: rule.lang,
77
+ framework: details.framework,
78
+ type: details.type,
79
+ dependencies: details.dependencies || [],
80
+ confidence: 'high' // 基于构建文件的检测是高置信度
81
+ });
82
+ }
83
+ }
84
+
85
+ return techStacks;
86
+ }
87
+
88
+ /**
89
+ * 扫描构建文件
90
+ */
91
+ function scanBuildFiles(projectDir, buildFileNames) {
92
+ const buildFiles = [];
93
+ const ignoreDirs = getIgnoreDirectories();
94
+
95
+ function scan(dir, depth) {
96
+ if (depth > 3) return; // 最多扫描 3 层
97
+
98
+ try {
99
+ const entries = fs.readdirSync(dir, { withFileTypes: true });
100
+
101
+ for (const entry of entries) {
102
+ const fullPath = path.join(dir, entry.name);
103
+
104
+ if (entry.isDirectory()) {
105
+ // 跳过忽略目录
106
+ if (!shouldIgnoreDir(entry.name, ignoreDirs)) {
107
+ scan(fullPath, depth + 1);
108
+ }
109
+ } else if (entry.isFile()) {
110
+ // 检查是否是构建文件
111
+ if (buildFileNames.includes(entry.name)) {
112
+ buildFiles.push({
113
+ name: entry.name,
114
+ relativePath: path.relative(projectDir, fullPath),
115
+ absolutePath: fullPath
116
+ });
117
+ }
118
+ }
119
+ }
120
+ } catch (e) {
121
+ // 忽略无权限目录
122
+ }
123
+ }
124
+
125
+ scan(projectDir, 0);
126
+ return buildFiles;
127
+ }
128
+
129
+ /**
130
+ * 判断是否应该忽略的目录
131
+ */
132
+ function shouldIgnoreDir(name, ignoreDirs) {
133
+ return ignoreDirs.includes(name) || name.startsWith('.');
134
+ }
135
+
136
+ // ============================================================
137
+ // 构建文件解析器
138
+ // ============================================================
139
+
140
+ /**
141
+ * 解析 package.json
142
+ */
143
+ function parsePackageJson(content, filePath, frameworkRules) {
144
+ try {
145
+ const pkg = JSON.parse(content);
146
+ const deps = { ...pkg.dependencies, ...pkg.devDependencies };
147
+ const depNames = Object.keys(deps);
148
+
149
+ // 匹配框架(优先使用传入的规则)
150
+ const rules = frameworkRules?.javascript || [];
151
+ for (const rule of rules) {
152
+ if (rule.deps.some(d => depNames.includes(d))) {
153
+ return {
154
+ framework: rule.framework,
155
+ type: rule.type,
156
+ dependencies: depNames
157
+ };
158
+ }
159
+ }
160
+
161
+ // 默认
162
+ return {
163
+ framework: pkg.name || 'Node.js',
164
+ type: inferTypeFromDeps(depNames, 'javascript'),
165
+ dependencies: depNames
166
+ };
167
+ } catch (e) {
168
+ return { framework: 'Node.js', type: 'unknown' };
169
+ }
170
+ }
171
+
172
+ /**
173
+ * 解析 pom.xml
174
+ */
175
+ function parsePomXml(content, filePath, frameworkRules) {
176
+ const rules = frameworkRules?.java || [];
177
+
178
+ for (const rule of rules) {
179
+ if (rule.deps.some(d => content.includes(d))) {
180
+ return { framework: rule.framework, type: rule.type };
181
+ }
182
+ }
183
+
184
+ return { framework: 'Java', type: 'backend' };
185
+ }
186
+
187
+ /**
188
+ * 解析 build.gradle
189
+ */
190
+ function parseBuildGradle(content, filePath, frameworkRules) {
191
+ return parsePomXml(content, filePath, frameworkRules);
192
+ }
193
+
194
+ /**
195
+ * 解析 go.mod
196
+ */
197
+ function parseGoMod(content, filePath, frameworkRules) {
198
+ const rules = frameworkRules?.go || [];
199
+
200
+ for (const rule of rules) {
201
+ if (rule.deps.some(d => content.includes(d))) {
202
+ return { framework: rule.framework, type: rule.type };
203
+ }
204
+ }
205
+
206
+ // 提取模块名
207
+ const moduleMatch = content.match(/module\s+(\S+)/);
208
+ const moduleName = moduleMatch ? moduleMatch[1] : 'Go';
209
+
210
+ return { framework: moduleName, type: 'backend' };
211
+ }
212
+
213
+ /**
214
+ * 解析 Cargo.toml
215
+ */
216
+ function parseCargoToml(content, filePath, frameworkRules) {
217
+ const rules = frameworkRules?.rust || [];
218
+
219
+ for (const rule of rules) {
220
+ if (rule.deps.some(d => content.includes(d))) {
221
+ return { framework: rule.framework, type: rule.type };
222
+ }
223
+ }
224
+
225
+ return { framework: 'Rust', type: 'backend' };
226
+ }
227
+
228
+ /**
229
+ * 解析 pyproject.toml
230
+ */
231
+ function parsePyprojectToml(content, filePath, frameworkRules) {
232
+ return parsePythonDeps(content, filePath, frameworkRules);
233
+ }
234
+
235
+ /**
236
+ * 解析 requirements.txt
237
+ */
238
+ function parseRequirements(content, filePath, frameworkRules) {
239
+ return parsePythonDeps(content, filePath, frameworkRules);
240
+ }
241
+
242
+ /**
243
+ * 解析 setup.py
244
+ */
245
+ function parseSetupPy(content, filePath, frameworkRules) {
246
+ return parsePythonDeps(content, filePath, frameworkRules);
247
+ }
248
+
249
+ /**
250
+ * 解析 Python 依赖
251
+ */
252
+ function parsePythonDeps(content, filePath, frameworkRules) {
253
+ const rules = frameworkRules?.python || [];
254
+
255
+ for (const rule of rules) {
256
+ if (rule.deps.some(d => content.toLowerCase().includes(d.toLowerCase()))) {
257
+ return {
258
+ framework: rule.framework,
259
+ type: rule.type,
260
+ dependencies: extractDependencies(content)
261
+ };
262
+ }
263
+ }
264
+
265
+ return {
266
+ framework: 'Python',
267
+ type: inferTypeFromDeps(extractDependencies(content), 'python'),
268
+ dependencies: extractDependencies(content)
269
+ };
270
+ }
271
+
272
+ /**
273
+ * 解析 dbt_project.yml
274
+ */
275
+ function parseDbtProject(content, filePath, frameworkRules) {
276
+ return {
277
+ framework: 'DBT',
278
+ type: 'data'
279
+ };
280
+ }
281
+
282
+ /**
283
+ * 解析 pubspec.yaml
284
+ */
285
+ function parsePubspec(content, filePath, frameworkRules) {
286
+ const hasFlutter = content.includes('flutter');
287
+
288
+ return {
289
+ framework: hasFlutter ? 'Flutter' : 'Dart',
290
+ type: hasFlutter ? 'mobile' : 'unknown'
291
+ };
292
+ }
293
+
294
+ /**
295
+ * 解析 composer.json
296
+ */
297
+ function parseComposer(content, filePath, frameworkRules) {
298
+ try {
299
+ const pkg = JSON.parse(content);
300
+ const deps = { ...pkg.require, ...pkg['require-dev'] };
301
+ const depNames = Object.keys(deps);
302
+
303
+ // 检查常见 PHP 框架
304
+ if (depNames.some(d => d.includes('laravel'))) {
305
+ return { framework: 'Laravel', type: 'backend', dependencies: depNames };
306
+ }
307
+ if (depNames.some(d => d.includes('symfony'))) {
308
+ return { framework: 'Symfony', type: 'backend', dependencies: depNames };
309
+ }
310
+
311
+ return { framework: 'PHP', type: 'backend', dependencies: depNames };
312
+ } catch (e) {
313
+ return { framework: 'PHP', type: 'unknown' };
314
+ }
315
+ }
316
+
317
+ /**
318
+ * 解析 Gemfile
319
+ */
320
+ function parseGemfile(content, filePath, frameworkRules) {
321
+ if (content.includes('rails')) {
322
+ return { framework: 'Rails', type: 'backend' };
323
+ }
324
+ if (content.includes('sinatra')) {
325
+ return { framework: 'Sinatra', type: 'backend' };
326
+ }
327
+ return { framework: 'Ruby', type: 'backend' };
328
+ }
329
+
330
+ /**
331
+ * 通用解析器(fallback)
332
+ */
333
+ function parseGeneric(content, filePath, frameworkRules) {
334
+ return { framework: 'Unknown', type: 'unknown' };
335
+ }
336
+
337
+ // ============================================================
338
+ // 辅助函数
339
+ // ============================================================
340
+
341
+ /**
342
+ * 从内容中提取依赖名
343
+ */
344
+ function extractDependencies(content) {
345
+ const deps = [];
346
+
347
+ // 匹配 pip 格式:package==version 或 package>=version
348
+ const pipMatches = content.match(/^[a-zA-Z0-9_-]+/gm);
349
+ if (pipMatches) {
350
+ deps.push(...pipMatches.filter(d => d && !d.startsWith('#')));
351
+ }
352
+
353
+ return [...new Set(deps)];
354
+ }
355
+
356
+ /**
357
+ * 根据依赖推断类型
358
+ */
359
+ function inferTypeFromDeps(deps, lang) {
360
+ const backendIndicators = ['api', 'server', 'web', 'http', 'rest', 'grpc'];
361
+ const frontendIndicators = ['react', 'vue', 'angular', 'svelte', 'ui', 'css'];
362
+
363
+ const depStr = deps.join(' ').toLowerCase();
364
+
365
+ if (frontendIndicators.some(i => depStr.includes(i))) {
366
+ return 'frontend';
367
+ }
368
+
369
+ if (backendIndicators.some(i => depStr.includes(i))) {
370
+ return 'backend';
371
+ }
372
+
373
+ return 'unknown';
374
+ }