@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,395 @@
1
+ /**
2
+ * Directory Discovery
3
+ *
4
+ * 智能发现项目源码目录
5
+ */
6
+
7
+ import fs from 'fs';
8
+ import path from 'path';
9
+
10
+ /**
11
+ * 目录发现器
12
+ * 自动检测项目中的源码目录、技术栈等
13
+ */
14
+ export class DirectoryDiscovery {
15
+ constructor(projectDir, config = {}) {
16
+ this.projectDir = projectDir;
17
+ this.config = config;
18
+ }
19
+
20
+ /**
21
+ * 发现所有源码目录
22
+ */
23
+ discoverSourceDirectories() {
24
+ const dirs = [];
25
+
26
+ // 1. 从 config.json 的 subsystems 中获取
27
+ if (this.config.subsystems) {
28
+ for (const sub of this.config.subsystems) {
29
+ dirs.push({
30
+ path: sub.path,
31
+ type: sub.type,
32
+ techStack: sub.techStack,
33
+ language: this.detectLanguage(sub.techStack),
34
+ build: sub.build,
35
+ test: sub.test,
36
+ });
37
+ }
38
+ }
39
+
40
+ // 2. 自动扫描常见源码目录
41
+ const commonDirs = this.getCommonSourceDirs();
42
+ for (const dir of commonDirs) {
43
+ const fullPath = path.join(this.projectDir, dir);
44
+ if (fs.existsSync(fullPath) && !dirs.find(d => d.path === dir)) {
45
+ const techStack = this.detectTechStack(fullPath);
46
+ dirs.push({
47
+ path: dir,
48
+ type: this.inferType(dir),
49
+ techStack,
50
+ language: this.detectLanguage(techStack),
51
+ });
52
+ }
53
+ }
54
+
55
+ // 3. 扫描根目录的直接子目录(可能是 monorepo)
56
+ const monorepoDirs = this.detectMonorepoDirs();
57
+ for (const dir of monorepoDirs) {
58
+ if (!dirs.find(d => d.path === dir)) {
59
+ const fullPath = path.join(this.projectDir, dir);
60
+ dirs.push({
61
+ path: dir,
62
+ type: this.inferType(dir),
63
+ techStack: this.detectTechStack(fullPath),
64
+ language: null,
65
+ });
66
+ }
67
+ }
68
+
69
+ return dirs;
70
+ }
71
+
72
+ /**
73
+ * 获取常见源码目录名
74
+ */
75
+ getCommonSourceDirs() {
76
+ return [
77
+ 'src',
78
+ 'lib',
79
+ 'app',
80
+ 'server',
81
+ 'backend',
82
+ 'frontend',
83
+ 'api',
84
+ 'web',
85
+ 'client',
86
+ 'mobile',
87
+ 'ml',
88
+ 'ai',
89
+ 'model',
90
+ 'models',
91
+ 'data',
92
+ 'warehouse',
93
+ 'datalake',
94
+ 'pipeline',
95
+ 'etl',
96
+ 'airflow',
97
+ 'lambda',
98
+ 'functions',
99
+ 'services',
100
+ 'packages',
101
+ ];
102
+ }
103
+
104
+ /**
105
+ * 检测 monorepo 目录
106
+ */
107
+ detectMonorepoDirs() {
108
+ const dirs = [];
109
+
110
+ // 检查是否是 monorepo
111
+ const lernaPath = path.join(this.projectDir, 'lerna.json');
112
+ const pnpmWorkspacePath = path.join(this.projectDir, 'pnpm-workspace.yaml');
113
+ const nxPath = path.join(this.projectDir, 'nx.json');
114
+
115
+ if (fs.existsSync(lernaPath) || fs.existsSync(pnpmWorkspacePath) || fs.existsSync(nxPath)) {
116
+ // 扫描 packages/ 目录
117
+ const packagesDir = path.join(this.projectDir, 'packages');
118
+ if (fs.existsSync(packagesDir)) {
119
+ const entries = fs.readdirSync(packagesDir, { withFileTypes: true });
120
+ for (const entry of entries) {
121
+ if (entry.isDirectory() && !entry.name.startsWith('.')) {
122
+ dirs.push(`packages/${entry.name}`);
123
+ }
124
+ }
125
+ }
126
+
127
+ // 扫描 apps/ 目录
128
+ const appsDir = path.join(this.projectDir, 'apps');
129
+ if (fs.existsSync(appsDir)) {
130
+ const entries = fs.readdirSync(appsDir, { withFileTypes: true });
131
+ for (const entry of entries) {
132
+ if (entry.isDirectory() && !entry.name.startsWith('.')) {
133
+ dirs.push(`apps/${entry.name}`);
134
+ }
135
+ }
136
+ }
137
+ }
138
+
139
+ return dirs;
140
+ }
141
+
142
+ /**
143
+ * 推断目录类型
144
+ */
145
+ inferType(dirName) {
146
+ const typeMap = {
147
+ 'backend': 'backend',
148
+ 'server': 'backend',
149
+ 'api': 'backend',
150
+ 'frontend': 'frontend',
151
+ 'web': 'frontend',
152
+ 'client': 'frontend',
153
+ 'mobile': 'mobile',
154
+ 'app': 'mobile',
155
+ 'ml': 'ai',
156
+ 'ai': 'ai',
157
+ 'model': 'ai',
158
+ 'models': 'ai',
159
+ 'data': 'data',
160
+ 'warehouse': 'data',
161
+ 'datalake': 'data',
162
+ 'pipeline': 'data',
163
+ 'etl': 'data',
164
+ 'airflow': 'data',
165
+ 'lambda': 'backend',
166
+ 'functions': 'backend',
167
+ 'services': 'backend',
168
+ };
169
+
170
+ // 处理路径中的目录名
171
+ const parts = dirName.split('/');
172
+ const lastPart = parts[parts.length - 1].toLowerCase();
173
+
174
+ return typeMap[lastPart] || 'unknown';
175
+ }
176
+
177
+ /**
178
+ * 检测技术栈
179
+ */
180
+ detectTechStack(dirPath) {
181
+ const indicators = [
182
+ { file: 'package.json', tech: 'Node.js', detector: this.detectNodeFramework.bind(this) },
183
+ { file: 'pom.xml', tech: 'Java Maven' },
184
+ { file: 'build.gradle', tech: 'Java Gradle' },
185
+ { file: 'build.gradle.kts', tech: 'Java Gradle (Kotlin DSL)' },
186
+ { file: 'go.mod', tech: 'Go' },
187
+ { file: 'requirements.txt', tech: 'Python' },
188
+ { file: 'pyproject.toml', tech: 'Python', detector: this.detectPythonFramework.bind(this) },
189
+ { file: 'Cargo.toml', tech: 'Rust' },
190
+ { file: 'composer.json', tech: 'PHP' },
191
+ { file: 'Gemfile', tech: 'Ruby' },
192
+ { file: 'pubspec.yaml', tech: 'Dart/Flutter' },
193
+ { file: 'build.sbt', tech: 'Scala' },
194
+ ];
195
+
196
+ for (const ind of indicators) {
197
+ const filePath = path.join(dirPath, ind.file);
198
+ if (fs.existsSync(filePath)) {
199
+ if (ind.detector) {
200
+ const detailed = ind.detector(filePath);
201
+ return detailed || ind.tech;
202
+ }
203
+ return ind.tech;
204
+ }
205
+ }
206
+
207
+ return 'Unknown';
208
+ }
209
+
210
+ /**
211
+ * 检测 Node.js 框架
212
+ */
213
+ detectNodeFramework(packageJsonPath) {
214
+ try {
215
+ const pkg = JSON.parse(fs.readFileSync(packageJsonPath, 'utf-8'));
216
+ const deps = { ...pkg.dependencies, ...pkg.devDependencies };
217
+
218
+ if (deps['@nestjs/core']) return 'NestJS';
219
+ if (deps['express']) return 'Express';
220
+ if (deps['koa']) return 'Koa';
221
+ if (deps['fastify']) return 'Fastify';
222
+ if (deps['next']) return 'Next.js';
223
+ if (deps['nuxt']) return 'Nuxt.js';
224
+ if (deps['react']) return 'React';
225
+ if (deps['vue']) return 'Vue';
226
+ if (deps['angular']) return 'Angular';
227
+ if (deps['@angular/core']) return 'Angular';
228
+ if (deps['svelte']) return 'Svelte';
229
+
230
+ return 'Node.js';
231
+ } catch (e) {
232
+ return 'Node.js';
233
+ }
234
+ }
235
+
236
+ /**
237
+ * 检测 Python 框架
238
+ */
239
+ detectPythonFramework(pyprojectPath) {
240
+ try {
241
+ const content = fs.readFileSync(pyprojectPath, 'utf-8');
242
+
243
+ if (content.includes('django')) return 'Django';
244
+ if (content.includes('flask')) return 'Flask';
245
+ if (content.includes('fastapi')) return 'FastAPI';
246
+ if (content.includes('tornado')) return 'Tornado';
247
+ if (content.includes('pytorch') || content.includes('torch')) return 'PyTorch';
248
+ if (content.includes('tensorflow')) return 'TensorFlow';
249
+
250
+ return 'Python';
251
+ } catch (e) {
252
+ return 'Python';
253
+ }
254
+ }
255
+
256
+ /**
257
+ * 从技术栈推断语言
258
+ */
259
+ detectLanguage(techStack) {
260
+ if (!techStack) return null;
261
+
262
+ const languageMap = {
263
+ 'Node.js': 'JavaScript',
264
+ 'Express': 'JavaScript',
265
+ 'NestJS': 'TypeScript',
266
+ 'Koa': 'JavaScript',
267
+ 'Fastify': 'JavaScript',
268
+ 'Next.js': 'JavaScript',
269
+ 'Nuxt.js': 'JavaScript',
270
+ 'React': 'JavaScript',
271
+ 'Vue': 'JavaScript',
272
+ 'Angular': 'TypeScript',
273
+ 'Svelte': 'JavaScript',
274
+ 'Java Maven': 'Java',
275
+ 'Java Gradle': 'Java',
276
+ 'Java Gradle (Kotlin DSL)': 'Java',
277
+ 'Go': 'Go',
278
+ 'Python': 'Python',
279
+ 'Django': 'Python',
280
+ 'Flask': 'Python',
281
+ 'FastAPI': 'Python',
282
+ 'PyTorch': 'Python',
283
+ 'TensorFlow': 'Python',
284
+ 'Rust': 'Rust',
285
+ 'PHP': 'PHP',
286
+ 'Ruby': 'Ruby',
287
+ 'Dart/Flutter': 'Dart',
288
+ 'Scala': 'Scala',
289
+ };
290
+
291
+ for (const [key, lang] of Object.entries(languageMap)) {
292
+ if (techStack.includes(key)) {
293
+ return lang;
294
+ }
295
+ }
296
+
297
+ return null;
298
+ }
299
+
300
+ /**
301
+ * 获取项目的所有配置文件
302
+ */
303
+ discoverConfigFiles() {
304
+ const configs = [];
305
+
306
+ const configPatterns = [
307
+ { name: 'package.json', type: 'npm' },
308
+ { name: 'requirements.txt', type: 'pip' },
309
+ { name: 'pyproject.toml', type: 'pip' },
310
+ { name: 'pom.xml', type: 'maven' },
311
+ { name: 'build.gradle', type: 'gradle' },
312
+ { name: 'go.mod', type: 'go' },
313
+ { name: 'Cargo.toml', type: 'cargo' },
314
+ { name: 'composer.json', type: 'composer' },
315
+ { name: 'Gemfile', type: 'bundler' },
316
+ { name: 'docker-compose.yml', type: 'docker-compose' },
317
+ { name: 'docker-compose.yaml', type: 'docker-compose' },
318
+ { name: 'Dockerfile', type: 'docker' },
319
+ { name: '.env', type: 'env' },
320
+ { name: '.env.example', type: 'env-example' },
321
+ { name: 'k8s/', type: 'kubernetes' },
322
+ { name: 'kubernetes/', type: 'kubernetes' },
323
+ { name: '.github/workflows/', type: 'github-actions' },
324
+ { name: '.gitlab-ci.yml', type: 'gitlab-ci' },
325
+ { name: 'Jenkinsfile', type: 'jenkins' },
326
+ ];
327
+
328
+ for (const pattern of configPatterns) {
329
+ const fullPath = path.join(this.projectDir, pattern.name);
330
+ if (fs.existsSync(fullPath)) {
331
+ configs.push({
332
+ name: pattern.name,
333
+ type: pattern.type,
334
+ path: pattern.name,
335
+ });
336
+ }
337
+ }
338
+
339
+ return configs;
340
+ }
341
+
342
+ /**
343
+ * 获取项目的环境变量文件
344
+ */
345
+ discoverEnvFiles() {
346
+ const envFiles = [];
347
+
348
+ const envPatterns = [
349
+ '.env',
350
+ '.env.local',
351
+ '.env.development',
352
+ '.env.test',
353
+ '.env.staging',
354
+ '.env.production',
355
+ '.env.example',
356
+ ];
357
+
358
+ for (const pattern of envPatterns) {
359
+ const fullPath = path.join(this.projectDir, pattern);
360
+ if (fs.existsSync(fullPath)) {
361
+ envFiles.push({
362
+ name: pattern,
363
+ path: pattern,
364
+ });
365
+ }
366
+ }
367
+
368
+ return envFiles;
369
+ }
370
+
371
+ /**
372
+ * 分析项目结构
373
+ */
374
+ analyzeProjectStructure() {
375
+ const sourceDirs = this.discoverSourceDirectories();
376
+ const configFiles = this.discoverConfigFiles();
377
+ const envFiles = this.discoverEnvFiles();
378
+
379
+ return {
380
+ sourceDirs,
381
+ configFiles,
382
+ envFiles,
383
+ isMonorepo: sourceDirs.some(d => d.path.startsWith('packages/') || d.path.startsWith('apps/')),
384
+ hasBackend: sourceDirs.some(d => d.type === 'backend'),
385
+ hasFrontend: sourceDirs.some(d => d.type === 'frontend'),
386
+ hasMobile: sourceDirs.some(d => d.type === 'mobile'),
387
+ hasAI: sourceDirs.some(d => d.type === 'ai'),
388
+ hasData: sourceDirs.some(d => d.type === 'data'),
389
+ techStacks: [...new Set(sourceDirs.map(d => d.techStack).filter(Boolean))],
390
+ languages: [...new Set(sourceDirs.map(d => d.language).filter(Boolean))],
391
+ };
392
+ }
393
+ }
394
+
395
+ export default DirectoryDiscovery;