claude-flow-novice 1.3.0 → 1.3.2

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 (305) hide show
  1. package/.claude-flow-novice/preferences/generation.json +147 -0
  2. package/.claude-flow-novice/preferences/language-configs/javascript.json +51 -0
  3. package/.claude-flow-novice/preferences/language-configs/python.json +50 -0
  4. package/.claude-flow-novice/preferences/language-configs/rust.json +237 -0
  5. package/.claude-flow-novice/preferences/language-configs/typescript.json +54 -0
  6. package/.claude-flow-novice/preferences/project-local.json +91 -0
  7. package/.claude-flow-novice/preferences/resource-delegation.json +120 -0
  8. package/.claude-flow-novice/preferences/team-shared.json +195 -0
  9. package/.claude-flow-novice/preferences/user-global.json +247 -0
  10. package/.claude-flow-novice/templates/claude-md-templates/CLAUDE-JAVASCRIPT.md +769 -0
  11. package/.claude-flow-novice/templates/claude-md-templates/CLAUDE-PYTHON.md +1214 -0
  12. package/.claude-flow-novice/templates/claude-md-templates/CLAUDE-RUST.md +475 -0
  13. package/.claude-flow-novice/templates/claude-md-templates/CLAUDE-TYPESCRIPT.md +851 -0
  14. package/.claude-flow-novice/templates/claude-md-templates/README.md +263 -0
  15. package/CLAUDE.md +81 -0
  16. package/README-NPM.md +0 -0
  17. package/package.json +11 -7
  18. package/scripts/build/README.md +167 -0
  19. package/scripts/build/build-config.js +27 -0
  20. package/scripts/build/build-prompt-copier.sh +30 -0
  21. package/scripts/build/performance-monitor.js +869 -0
  22. package/scripts/build/prepare-publish.js +150 -0
  23. package/scripts/build/typescript-fixer.js +621 -0
  24. package/scripts/build/unified-builder.sh +428 -0
  25. package/scripts/build/update-bin-version.js +32 -0
  26. package/scripts/dev/README.md +264 -0
  27. package/scripts/dev/claude-flow-wrapper.sh +35 -0
  28. package/scripts/dev/claude-monitor.py +419 -0
  29. package/scripts/dev/claude-sparc.sh +562 -0
  30. package/scripts/dev/claude-wrapper.sh +17 -0
  31. package/scripts/dev/demo-phase3-compliance.js +172 -0
  32. package/scripts/dev/demo-task-system.ts +224 -0
  33. package/scripts/dev/deployment-validator.js +315 -0
  34. package/scripts/dev/spawn-claude-terminal.sh +32 -0
  35. package/scripts/dev/start-portal.sh +506 -0
  36. package/scripts/dev/start-web-ui.js +15 -0
  37. package/scripts/dev/stop-portal.sh +311 -0
  38. package/scripts/dev/validate-examples.ts +288 -0
  39. package/scripts/dev/validate-phase2.cjs +451 -0
  40. package/scripts/dev/validate-phase2.js +785 -0
  41. package/scripts/dev/validate-phase3.cjs +208 -0
  42. package/scripts/dev/validate-security-remediation.js +1 -0
  43. package/scripts/legacy/README.md +272 -0
  44. package/scripts/legacy/batch-fix-ts.sh +54 -0
  45. package/scripts/legacy/build-migration.sh +105 -0
  46. package/scripts/legacy/build-monitor.js +209 -0
  47. package/scripts/legacy/build-with-filter.sh +84 -0
  48. package/scripts/legacy/build-workaround.sh +71 -0
  49. package/scripts/legacy/fix-ts-advanced.js +358 -0
  50. package/scripts/legacy/fix-ts-final.sh +50 -0
  51. package/scripts/legacy/fix-ts-targeted.sh +49 -0
  52. package/scripts/legacy/fix-typescript-errors.js +305 -0
  53. package/scripts/legacy/force-build.sh +63 -0
  54. package/scripts/legacy/optimize-performance.js +400 -0
  55. package/scripts/legacy/performance-monitor.js +263 -0
  56. package/scripts/legacy/performance-monitoring.js +532 -0
  57. package/scripts/legacy/performance-test-runner.js +645 -0
  58. package/scripts/legacy/quick-fix-ts.js +281 -0
  59. package/scripts/legacy/safe-build.sh +63 -0
  60. package/scripts/migration/README.md +434 -0
  61. package/scripts/migration/install-arm64.js +78 -0
  62. package/scripts/migration/install.js +83 -0
  63. package/scripts/migration/migrate-hooks.js +173 -0
  64. package/scripts/migration/migration-examples.ts +318 -0
  65. package/scripts/optimization/build-optimizer.js +438 -0
  66. package/scripts/optimization/config-validator.js +761 -0
  67. package/scripts/optimization/test-optimization.js +432 -0
  68. package/scripts/optimization/unified-activation.js +839 -0
  69. package/scripts/performance/ACTIVATION_COMMANDS.md +292 -0
  70. package/scripts/performance/sqlite-enhanced-activation.sh +583 -0
  71. package/scripts/performance/test-enhanced-backend.sh +504 -0
  72. package/scripts/performance-test-runner.js +698 -0
  73. package/scripts/security/README.md +339 -0
  74. package/scripts/security/install-git-hooks.sh +132 -0
  75. package/scripts/security/ruv-swarm-safe.js +74 -0
  76. package/scripts/test/README.md +236 -0
  77. package/scripts/test/check-links.ts +274 -0
  78. package/scripts/test/check-performance-regression.ts +168 -0
  79. package/scripts/test/coverage-report.ts +692 -0
  80. package/scripts/test/generate-swarm-tests.js +633 -0
  81. package/scripts/test/integration-test-validation.cjs +253 -0
  82. package/scripts/test/load-test-swarm.js +576 -0
  83. package/scripts/test/run-phase3-compliance-tests.js +427 -0
  84. package/scripts/test/test-batch-tasks.ts +29 -0
  85. package/scripts/test/test-byzantine-resolution.js +246 -0
  86. package/scripts/test/test-claude-spawn-options.sh +63 -0
  87. package/scripts/test/test-cli-wizard.js +331 -0
  88. package/scripts/test/test-comprehensive.js +401 -0
  89. package/scripts/test/test-coordination-features.ts +238 -0
  90. package/scripts/test/test-fallback-systems.js +276 -0
  91. package/scripts/test/test-init-command.ts +302 -0
  92. package/scripts/test/test-mcp.ts +251 -0
  93. package/scripts/test/test-runner.ts +568 -0
  94. package/scripts/test/test-swarm-integration.sh +92 -0
  95. package/scripts/test/test-swarm.ts +142 -0
  96. package/scripts/test/validation-summary.ts +408 -0
  97. package/scripts/utils/README.md +261 -0
  98. package/scripts/utils/clean-build-artifacts.sh +94 -0
  99. package/scripts/utils/cleanup-root.sh +69 -0
  100. package/scripts/utils/fix-cliffy-imports.js +307 -0
  101. package/scripts/utils/fix-duplicate-imports.js +114 -0
  102. package/scripts/utils/fix-error-handling.cjs +70 -0
  103. package/scripts/utils/fix-import-paths.js +104 -0
  104. package/scripts/utils/fix-imports.js +116 -0
  105. package/scripts/utils/fix-shebang.js +78 -0
  106. package/scripts/utils/fix-test-modules.js +27 -0
  107. package/scripts/utils/fix-timezone-issue-246.js +200 -0
  108. package/scripts/utils/fix-ts-comprehensive.py +182 -0
  109. package/scripts/utils/fix-ts-targeted-batch.js +250 -0
  110. package/scripts/utils/remove-benchmark-conflicts.sh +140 -0
  111. package/scripts/utils/simple-test-fixer.js +190 -0
  112. package/scripts/utils/validate-metrics-structure.cjs +144 -0
  113. package/scripts/verify-mcp-server.js +86 -0
  114. package/src/cli/simple-commands/__tests__/agent.test.js +291 -0
  115. package/src/cli/simple-commands/__tests__/memory.test.js +8 -0
  116. package/src/cli/simple-commands/__tests__/swarm.test.js +371 -0
  117. package/src/cli/simple-commands/__tests__/task.test.js +8 -0
  118. package/src/cli/simple-commands/agent.js +216 -0
  119. package/src/cli/simple-commands/analysis.js +570 -0
  120. package/src/cli/simple-commands/automation-executor.js +1603 -0
  121. package/src/cli/simple-commands/automation.js +627 -0
  122. package/src/cli/simple-commands/batch-manager.js +338 -0
  123. package/src/cli/simple-commands/claude-telemetry.js +311 -0
  124. package/src/cli/simple-commands/claude-track.js +102 -0
  125. package/src/cli/simple-commands/concurrent-display.js +348 -0
  126. package/src/cli/simple-commands/config.js +319 -0
  127. package/src/cli/simple-commands/coordination.js +307 -0
  128. package/src/cli/simple-commands/enhanced-ui-views.js +654 -0
  129. package/src/cli/simple-commands/enhanced-webui-complete.js +1038 -0
  130. package/src/cli/simple-commands/fix-hook-variables.js +363 -0
  131. package/src/cli/simple-commands/github/gh-coordinator.js +605 -0
  132. package/src/cli/simple-commands/github/github-api.js +624 -0
  133. package/src/cli/simple-commands/github/init.js +543 -0
  134. package/src/cli/simple-commands/github.js +377 -0
  135. package/src/cli/simple-commands/goal.js +145 -0
  136. package/src/cli/simple-commands/hive-mind/auto-save-middleware.js +311 -0
  137. package/src/cli/simple-commands/hive-mind/communication.js +740 -0
  138. package/src/cli/simple-commands/hive-mind/core.js +1031 -0
  139. package/src/cli/simple-commands/hive-mind/db-optimizer.js +872 -0
  140. package/src/cli/simple-commands/hive-mind/mcp-wrapper.js +1364 -0
  141. package/src/cli/simple-commands/hive-mind/memory.js +1292 -0
  142. package/src/cli/simple-commands/hive-mind/performance-optimizer.js +618 -0
  143. package/src/cli/simple-commands/hive-mind/performance-test.js +373 -0
  144. package/src/cli/simple-commands/hive-mind/queen.js +809 -0
  145. package/src/cli/simple-commands/hive-mind/session-manager.js +1223 -0
  146. package/src/cli/simple-commands/hive-mind-optimize.js +361 -0
  147. package/src/cli/simple-commands/hive-mind-wizard.js +281 -0
  148. package/src/cli/simple-commands/hive-mind.js +3112 -0
  149. package/src/cli/simple-commands/hive.js +140 -0
  150. package/src/cli/simple-commands/hook-safety.js +671 -0
  151. package/src/cli/simple-commands/hooks.js +1268 -0
  152. package/src/cli/simple-commands/init/.claude/checkpoints/1756224542.json +7 -0
  153. package/src/cli/simple-commands/init/.claude/checkpoints/1756224544.json +8 -0
  154. package/src/cli/simple-commands/init/README.md +106 -0
  155. package/src/cli/simple-commands/init/VALIDATION_ROLLBACK.md +488 -0
  156. package/src/cli/simple-commands/init/agent-copier.js +347 -0
  157. package/src/cli/simple-commands/init/batch-init.js +663 -0
  158. package/src/cli/simple-commands/init/claude-commands/claude-flow-commands.js +438 -0
  159. package/src/cli/simple-commands/init/claude-commands/optimized-claude-flow-commands.js +876 -0
  160. package/src/cli/simple-commands/init/claude-commands/optimized-slash-commands.js +356 -0
  161. package/src/cli/simple-commands/init/claude-commands/optimized-sparc-commands.js +501 -0
  162. package/src/cli/simple-commands/init/claude-commands/slash-commands.js +57 -0
  163. package/src/cli/simple-commands/init/claude-commands/sparc-commands.js +296 -0
  164. package/src/cli/simple-commands/init/copy-revised-templates.js +175 -0
  165. package/src/cli/simple-commands/init/executable-wrapper.js +122 -0
  166. package/src/cli/simple-commands/init/gitignore-updater.js +137 -0
  167. package/src/cli/simple-commands/init/help.js +110 -0
  168. package/src/cli/simple-commands/init/hive-mind-init.js +749 -0
  169. package/src/cli/simple-commands/init/index.js +1953 -0
  170. package/src/cli/simple-commands/init/performance-monitor.js +344 -0
  171. package/src/cli/simple-commands/init/rollback/backup-manager.js +542 -0
  172. package/src/cli/simple-commands/init/rollback/index.js +399 -0
  173. package/src/cli/simple-commands/init/rollback/recovery-manager.js +778 -0
  174. package/src/cli/simple-commands/init/rollback/rollback-executor.js +521 -0
  175. package/src/cli/simple-commands/init/rollback/state-tracker.js +486 -0
  176. package/src/cli/simple-commands/init/sparc/roo-readme.js +61 -0
  177. package/src/cli/simple-commands/init/sparc/roomodes-config.js +102 -0
  178. package/src/cli/simple-commands/init/sparc/workflows.js +40 -0
  179. package/src/cli/simple-commands/init/sparc-structure.js +68 -0
  180. package/src/cli/simple-commands/init/template-copier.js +640 -0
  181. package/src/cli/simple-commands/init/templates/CLAUDE.md +1185 -0
  182. package/src/cli/simple-commands/init/templates/CLAUDE.md.optimized +265 -0
  183. package/src/cli/simple-commands/init/templates/claude-flow-universal +81 -0
  184. package/src/cli/simple-commands/init/templates/claude-flow.bat +18 -0
  185. package/src/cli/simple-commands/init/templates/claude-flow.ps1 +24 -0
  186. package/src/cli/simple-commands/init/templates/claude-md.js +1101 -0
  187. package/src/cli/simple-commands/init/templates/commands/analysis/bottleneck-detect.md +162 -0
  188. package/src/cli/simple-commands/init/templates/commands/automation/auto-agent.md +122 -0
  189. package/src/cli/simple-commands/init/templates/commands/coordination/swarm-init.md +85 -0
  190. package/src/cli/simple-commands/init/templates/commands/github/github-swarm.md +121 -0
  191. package/src/cli/simple-commands/init/templates/commands/helpers/standard-checkpoint-hooks.sh +179 -0
  192. package/src/cli/simple-commands/init/templates/commands/hooks/notification.md +113 -0
  193. package/src/cli/simple-commands/init/templates/commands/hooks/post-command.md +116 -0
  194. package/src/cli/simple-commands/init/templates/commands/hooks/post-edit.md +117 -0
  195. package/src/cli/simple-commands/init/templates/commands/hooks/post-task.md +112 -0
  196. package/src/cli/simple-commands/init/templates/commands/hooks/pre-command.md +113 -0
  197. package/src/cli/simple-commands/init/templates/commands/hooks/pre-edit.md +113 -0
  198. package/src/cli/simple-commands/init/templates/commands/hooks/pre-search.md +112 -0
  199. package/src/cli/simple-commands/init/templates/commands/hooks/pre-task.md +111 -0
  200. package/src/cli/simple-commands/init/templates/commands/hooks/session-end.md +118 -0
  201. package/src/cli/simple-commands/init/templates/commands/hooks/session-restore.md +118 -0
  202. package/src/cli/simple-commands/init/templates/commands/hooks/session-start.md +117 -0
  203. package/src/cli/simple-commands/init/templates/coordination-md.js +340 -0
  204. package/src/cli/simple-commands/init/templates/coordination.md +16 -0
  205. package/src/cli/simple-commands/init/templates/enhanced-templates.js +2347 -0
  206. package/src/cli/simple-commands/init/templates/github-safe-enhanced.js +331 -0
  207. package/src/cli/simple-commands/init/templates/github-safe.js +106 -0
  208. package/src/cli/simple-commands/init/templates/memory-bank-md.js +259 -0
  209. package/src/cli/simple-commands/init/templates/memory-bank.md +16 -0
  210. package/src/cli/simple-commands/init/templates/readme-files.js +72 -0
  211. package/src/cli/simple-commands/init/templates/safe-hook-patterns.js +430 -0
  212. package/src/cli/simple-commands/init/templates/settings.json +109 -0
  213. package/src/cli/simple-commands/init/templates/settings.json.enhanced +35 -0
  214. package/src/cli/simple-commands/init/templates/sparc-modes.js +1401 -0
  215. package/src/cli/simple-commands/init/templates/verification-claude-md.js +432 -0
  216. package/src/cli/simple-commands/init/validation/config-validator.js +354 -0
  217. package/src/cli/simple-commands/init/validation/health-checker.js +599 -0
  218. package/src/cli/simple-commands/init/validation/index.js +388 -0
  219. package/src/cli/simple-commands/init/validation/mode-validator.js +387 -0
  220. package/src/cli/simple-commands/init/validation/post-init-validator.js +390 -0
  221. package/src/cli/simple-commands/init/validation/pre-init-validator.js +290 -0
  222. package/src/cli/simple-commands/init/validation/test-runner.js +488 -0
  223. package/src/cli/simple-commands/init.js +4 -0
  224. package/src/cli/simple-commands/mcp-health.js +163 -0
  225. package/src/cli/simple-commands/mcp-integration-layer.js +689 -0
  226. package/src/cli/simple-commands/mcp.js +420 -0
  227. package/src/cli/simple-commands/memory-consolidation.js +631 -0
  228. package/src/cli/simple-commands/memory.js +345 -0
  229. package/src/cli/simple-commands/migrate-hooks.js +63 -0
  230. package/src/cli/simple-commands/monitor.js +417 -0
  231. package/src/cli/simple-commands/neural.js +148 -0
  232. package/src/cli/simple-commands/pair-autofix-only.js +755 -0
  233. package/src/cli/simple-commands/pair-basic.js +751 -0
  234. package/src/cli/simple-commands/pair-old.js +623 -0
  235. package/src/cli/simple-commands/pair-working.js +849 -0
  236. package/src/cli/simple-commands/pair.js +849 -0
  237. package/src/cli/simple-commands/performance-hooks.js +149 -0
  238. package/src/cli/simple-commands/performance-metrics.js +601 -0
  239. package/src/cli/simple-commands/process-ui-enhanced.js +821 -0
  240. package/src/cli/simple-commands/process-ui.js +274 -0
  241. package/src/cli/simple-commands/realtime-update-system.js +659 -0
  242. package/src/cli/simple-commands/sparc/architecture.js +1750 -0
  243. package/src/cli/simple-commands/sparc/commands.js +575 -0
  244. package/src/cli/simple-commands/sparc/completion.js +1831 -0
  245. package/src/cli/simple-commands/sparc/coordinator.js +1045 -0
  246. package/src/cli/simple-commands/sparc/index.js +321 -0
  247. package/src/cli/simple-commands/sparc/phase-base.js +430 -0
  248. package/src/cli/simple-commands/sparc/pseudocode.js +984 -0
  249. package/src/cli/simple-commands/sparc/refinement.js +1856 -0
  250. package/src/cli/simple-commands/sparc/specification.js +736 -0
  251. package/src/cli/simple-commands/sparc-modes/architect.js +125 -0
  252. package/src/cli/simple-commands/sparc-modes/ask.js +126 -0
  253. package/src/cli/simple-commands/sparc-modes/code.js +148 -0
  254. package/src/cli/simple-commands/sparc-modes/debug.js +112 -0
  255. package/src/cli/simple-commands/sparc-modes/devops.js +137 -0
  256. package/src/cli/simple-commands/sparc-modes/docs-writer.js +38 -0
  257. package/src/cli/simple-commands/sparc-modes/generic.js +34 -0
  258. package/src/cli/simple-commands/sparc-modes/index.js +201 -0
  259. package/src/cli/simple-commands/sparc-modes/integration.js +55 -0
  260. package/src/cli/simple-commands/sparc-modes/mcp.js +38 -0
  261. package/src/cli/simple-commands/sparc-modes/monitoring.js +38 -0
  262. package/src/cli/simple-commands/sparc-modes/optimization.js +38 -0
  263. package/src/cli/simple-commands/sparc-modes/security-review.js +130 -0
  264. package/src/cli/simple-commands/sparc-modes/sparc-orchestrator.js +167 -0
  265. package/src/cli/simple-commands/sparc-modes/spec-pseudocode.js +38 -0
  266. package/src/cli/simple-commands/sparc-modes/supabase-admin.js +149 -0
  267. package/src/cli/simple-commands/sparc-modes/swarm.js +436 -0
  268. package/src/cli/simple-commands/sparc-modes/tdd.js +112 -0
  269. package/src/cli/simple-commands/sparc-modes/tutorial.js +277 -0
  270. package/src/cli/simple-commands/sparc.js +530 -0
  271. package/src/cli/simple-commands/start-ui.js +147 -0
  272. package/src/cli/simple-commands/start-wrapper.js +285 -0
  273. package/src/cli/simple-commands/start.js +2 -0
  274. package/src/cli/simple-commands/status.js +303 -0
  275. package/src/cli/simple-commands/stream-chain-clean.js +221 -0
  276. package/src/cli/simple-commands/stream-chain-fixed.js +89 -0
  277. package/src/cli/simple-commands/stream-chain-real.js +408 -0
  278. package/src/cli/simple-commands/stream-chain-working.js +323 -0
  279. package/src/cli/simple-commands/stream-chain.js +491 -0
  280. package/src/cli/simple-commands/stream-processor.js +340 -0
  281. package/src/cli/simple-commands/swarm-executor.js +253 -0
  282. package/src/cli/simple-commands/swarm-metrics-integration.js +371 -0
  283. package/src/cli/simple-commands/swarm-ui.js +741 -0
  284. package/src/cli/simple-commands/swarm-webui-integration.js +311 -0
  285. package/src/cli/simple-commands/swarm.js +2277 -0
  286. package/src/cli/simple-commands/task.js +228 -0
  287. package/src/cli/simple-commands/templates/mle-star-workflow.json +294 -0
  288. package/src/cli/simple-commands/timestamp-fix.js +104 -0
  289. package/src/cli/simple-commands/token-tracker.js +372 -0
  290. package/src/cli/simple-commands/tool-execution-framework.js +555 -0
  291. package/src/cli/simple-commands/train-and-stream.js +354 -0
  292. package/src/cli/simple-commands/training-pipeline.js +874 -0
  293. package/src/cli/simple-commands/training.js +288 -0
  294. package/src/cli/simple-commands/verification-hooks.js +336 -0
  295. package/src/cli/simple-commands/verification-integration.js +464 -0
  296. package/src/cli/simple-commands/verification-training-integration.js +646 -0
  297. package/src/cli/simple-commands/verification.js +551 -0
  298. package/src/cli/simple-commands/web-server.js +929 -0
  299. package/src/cli/simple-commands/webui-validator.js +136 -0
  300. package/src/language/README.md +503 -0
  301. package/src/language/claude-md-generator.js +618 -0
  302. package/src/language/cli.js +422 -0
  303. package/src/language/example.js +347 -0
  304. package/src/language/integration-system.js +619 -0
  305. package/src/language/language-detector.js +581 -0
@@ -0,0 +1,581 @@
1
+ import fs from 'fs/promises';
2
+ import path from 'path';
3
+ import pkg from 'glob';
4
+ const { glob } = pkg;
5
+
6
+ /**
7
+ * Language Detection System
8
+ *
9
+ * Scans project files to detect programming languages, frameworks, and dependencies
10
+ * Provides confidence scoring and detailed analysis for CLAUDE.md generation
11
+ */
12
+ export class LanguageDetector {
13
+ constructor(projectPath = process.cwd()) {
14
+ this.projectPath = projectPath;
15
+ this.detectionResults = {
16
+ languages: {},
17
+ frameworks: {},
18
+ dependencies: {},
19
+ projectType: null,
20
+ confidence: 0,
21
+ metadata: {},
22
+ };
23
+
24
+ // Language patterns and scoring weights
25
+ this.languagePatterns = {
26
+ javascript: {
27
+ extensions: ['.js', '.mjs', '.cjs'],
28
+ files: ['package.json', '.eslintrc*', 'babel.config.*'],
29
+ patterns: [/require\(/, /import\s+.*from/, /module\.exports/, /export\s+(default\s+)?/],
30
+ weight: 1.0,
31
+ },
32
+ typescript: {
33
+ extensions: ['.ts', '.tsx'],
34
+ files: ['tsconfig.json', 'tslint.json', '.tsconfig.json'],
35
+ patterns: [/interface\s+\w+/, /type\s+\w+\s*=/, /:\s*\w+(\[\])?/, /import.*from.*\.ts/],
36
+ weight: 1.2,
37
+ },
38
+ python: {
39
+ extensions: ['.py', '.pyx', '.pyw'],
40
+ files: ['requirements.txt', 'setup.py', 'pyproject.toml', 'Pipfile', '__init__.py'],
41
+ patterns: [/def\s+\w+\s*\(/, /import\s+\w+/, /from\s+\w+\s+import/, /class\s+\w+/],
42
+ weight: 1.0,
43
+ },
44
+ java: {
45
+ extensions: ['.java'],
46
+ files: ['pom.xml', 'build.gradle', '.gradle'],
47
+ patterns: [/public\s+class/, /package\s+[\w.]+/, /import\s+[\w.]+/],
48
+ weight: 1.0,
49
+ },
50
+ go: {
51
+ extensions: ['.go'],
52
+ files: ['go.mod', 'go.sum'],
53
+ patterns: [/package\s+main/, /func\s+\w+/, /import\s*\(/, /var\s+\w+\s+\w+/],
54
+ weight: 1.0,
55
+ },
56
+ rust: {
57
+ extensions: ['.rs'],
58
+ files: ['Cargo.toml', 'Cargo.lock'],
59
+ patterns: [/fn\s+\w+/, /struct\s+\w+/, /impl\s+\w+/, /use\s+[\w:]+/],
60
+ weight: 1.0,
61
+ },
62
+ };
63
+
64
+ // Framework detection patterns
65
+ this.frameworkPatterns = {
66
+ react: {
67
+ dependencies: ['react', '@types/react', 'react-dom'],
68
+ patterns: [/import.*React/, /from\s+['"]react['"]/, /jsx?/, /\.tsx?$/],
69
+ files: ['.babelrc', 'next.config.js'],
70
+ weight: 1.5,
71
+ },
72
+ nextjs: {
73
+ dependencies: ['next'],
74
+ patterns: [/from\s+['"]next\//, /export.*getServerSideProps/, /export.*getStaticProps/],
75
+ files: ['next.config.js', 'pages/', 'app/'],
76
+ weight: 1.8,
77
+ },
78
+ vue: {
79
+ dependencies: ['vue', '@vue/cli'],
80
+ patterns: [/import.*Vue/, /<template>/, /<script>/, /\.vue$/],
81
+ files: ['vue.config.js'],
82
+ weight: 1.5,
83
+ },
84
+ angular: {
85
+ dependencies: ['@angular/core', '@angular/cli'],
86
+ patterns: [/import.*@angular/, /@Component/, /@Injectable/, /\.component\.ts$/],
87
+ files: ['angular.json', '.angular-cli.json'],
88
+ weight: 1.5,
89
+ },
90
+ express: {
91
+ dependencies: ['express'],
92
+ patterns: [/require\(['"]express['"]/, /app\.get/, /app\.post/, /app\.listen/],
93
+ files: [],
94
+ weight: 1.3,
95
+ },
96
+ fastify: {
97
+ dependencies: ['fastify'],
98
+ patterns: [/require\(['"]fastify['"]/, /fastify\.register/, /fastify\.listen/],
99
+ files: [],
100
+ weight: 1.3,
101
+ },
102
+ django: {
103
+ dependencies: ['django'],
104
+ patterns: [/from\s+django/, /django\./, /INSTALLED_APPS/, /urls\.py$/],
105
+ files: ['manage.py', 'settings.py', 'wsgi.py'],
106
+ weight: 1.5,
107
+ },
108
+ flask: {
109
+ dependencies: ['flask'],
110
+ patterns: [/from\s+flask/, /Flask\(__name__\)/, /app\.route/, /@app\.route/],
111
+ files: ['app.py', 'wsgi.py'],
112
+ weight: 1.3,
113
+ },
114
+ fastapi: {
115
+ dependencies: ['fastapi'],
116
+ patterns: [/from\s+fastapi/, /FastAPI\(\)/, /@app\.get/, /@app\.post/],
117
+ files: ['main.py'],
118
+ weight: 1.4,
119
+ },
120
+ spring: {
121
+ dependencies: ['spring-boot-starter'],
122
+ patterns: [/@SpringBootApplication/, /@RestController/, /@Service/],
123
+ files: ['application.properties', 'application.yml'],
124
+ weight: 1.5,
125
+ },
126
+ };
127
+ }
128
+
129
+ /**
130
+ * Main detection method - analyzes the entire project
131
+ */
132
+ async detectProject() {
133
+ console.log(`🔍 Scanning project at: ${this.projectPath}`);
134
+
135
+ try {
136
+ // Parallel detection for better performance
137
+ await Promise.all([
138
+ this.scanPackageFiles(),
139
+ this.scanSourceFiles(),
140
+ this.analyzeProjectStructure(),
141
+ this.detectBuildTools(),
142
+ ]);
143
+
144
+ // Calculate confidence scores
145
+ this.calculateConfidenceScores();
146
+
147
+ // Determine primary project type
148
+ this.determinePrimaryProjectType();
149
+
150
+ console.log(
151
+ `✅ Detection complete. Found ${Object.keys(this.detectionResults.languages).length} languages`,
152
+ );
153
+ return this.detectionResults;
154
+ } catch (error) {
155
+ console.error(`❌ Detection failed: ${error.message}`);
156
+ throw error;
157
+ }
158
+ }
159
+
160
+ /**
161
+ * Scan package management files (package.json, requirements.txt, etc.)
162
+ */
163
+ async scanPackageFiles() {
164
+ const packageFiles = [
165
+ 'package.json',
166
+ 'requirements.txt',
167
+ 'pyproject.toml',
168
+ 'Pipfile',
169
+ 'pom.xml',
170
+ 'build.gradle',
171
+ 'Cargo.toml',
172
+ 'go.mod',
173
+ ];
174
+
175
+ for (const file of packageFiles) {
176
+ const filePath = path.join(this.projectPath, file);
177
+
178
+ try {
179
+ const content = await fs.readFile(filePath, 'utf8');
180
+ await this.analyzePackageFile(file, content);
181
+ } catch (error) {
182
+ // File doesn't exist, continue
183
+ continue;
184
+ }
185
+ }
186
+ }
187
+
188
+ /**
189
+ * Analyze specific package files for dependencies and metadata
190
+ */
191
+ async analyzePackageFile(filename, content) {
192
+ switch (filename) {
193
+ case 'package.json':
194
+ await this.analyzePackageJson(content);
195
+ break;
196
+ case 'requirements.txt':
197
+ await this.analyzeRequirementsTxt(content);
198
+ break;
199
+ case 'pyproject.toml':
200
+ await this.analyzePyprojectToml(content);
201
+ break;
202
+ case 'pom.xml':
203
+ await this.analyzePomXml(content);
204
+ break;
205
+ case 'Cargo.toml':
206
+ await this.analyzeCargoToml(content);
207
+ break;
208
+ case 'go.mod':
209
+ await this.analyzeGoMod(content);
210
+ break;
211
+ }
212
+ }
213
+
214
+ async analyzePackageJson(content) {
215
+ try {
216
+ const pkg = JSON.parse(content);
217
+ const allDeps = {
218
+ ...pkg.dependencies,
219
+ ...pkg.devDependencies,
220
+ ...pkg.peerDependencies,
221
+ };
222
+
223
+ // Detect JavaScript/TypeScript
224
+ this.incrementLanguageScore('javascript', 0.8);
225
+
226
+ if (allDeps.typescript || allDeps['@types/node']) {
227
+ this.incrementLanguageScore('typescript', 1.2);
228
+ }
229
+
230
+ // Detect frameworks
231
+ for (const [framework, config] of Object.entries(this.frameworkPatterns)) {
232
+ const hasFramework = config.dependencies.some((dep) =>
233
+ Object.keys(allDeps).some(
234
+ (installedDep) => installedDep.includes(dep) || dep.includes(installedDep),
235
+ ),
236
+ );
237
+
238
+ if (hasFramework) {
239
+ this.incrementFrameworkScore(framework, config.weight);
240
+ }
241
+ }
242
+
243
+ // Store metadata
244
+ this.detectionResults.metadata.packageManager = 'npm';
245
+ this.detectionResults.metadata.projectName = pkg.name;
246
+ this.detectionResults.metadata.scripts = pkg.scripts || {};
247
+ this.detectionResults.dependencies = { ...this.detectionResults.dependencies, ...allDeps };
248
+ } catch (error) {
249
+ console.warn(`Failed to parse package.json: ${error.message}`);
250
+ }
251
+ }
252
+
253
+ async analyzeRequirementsTxt(content) {
254
+ const lines = content.split('\n').filter((line) => line.trim() && !line.startsWith('#'));
255
+
256
+ this.incrementLanguageScore('python', 0.9);
257
+ this.detectionResults.metadata.packageManager = 'pip';
258
+
259
+ // Extract package names and detect frameworks
260
+ for (const line of lines) {
261
+ const packageName = line
262
+ .split(/[>=<~!]/)[0]
263
+ .toLowerCase()
264
+ .trim();
265
+ this.detectionResults.dependencies[packageName] = line;
266
+
267
+ // Check for Python frameworks
268
+ for (const [framework, config] of Object.entries(this.frameworkPatterns)) {
269
+ if (config.dependencies.some((dep) => packageName.includes(dep.toLowerCase()))) {
270
+ this.incrementFrameworkScore(framework, config.weight);
271
+ }
272
+ }
273
+ }
274
+ }
275
+
276
+ async analyzePyprojectToml(content) {
277
+ this.incrementLanguageScore('python', 0.8);
278
+ this.detectionResults.metadata.packageManager = 'poetry';
279
+
280
+ // Basic TOML parsing for dependencies
281
+ const depMatches = content.match(/\[tool\.poetry\.dependencies\]([\s\S]*?)(?=\[|$)/);
282
+ if (depMatches) {
283
+ const depSection = depMatches[1];
284
+ const deps = depSection.match(/^(\w+)\s*=/gm);
285
+ if (deps) {
286
+ deps.forEach((dep) => {
287
+ const name = dep.split('=')[0].trim();
288
+ this.detectionResults.dependencies[name] = dep;
289
+ });
290
+ }
291
+ }
292
+ }
293
+
294
+ async analyzePomXml(content) {
295
+ this.incrementLanguageScore('java', 1.0);
296
+ this.detectionResults.metadata.packageManager = 'maven';
297
+
298
+ // Extract Spring Boot detection
299
+ if (content.includes('spring-boot')) {
300
+ this.incrementFrameworkScore('spring', 1.5);
301
+ }
302
+ }
303
+
304
+ async analyzeCargoToml(content) {
305
+ this.incrementLanguageScore('rust', 1.0);
306
+ this.detectionResults.metadata.packageManager = 'cargo';
307
+ }
308
+
309
+ async analyzeGoMod(content) {
310
+ this.incrementLanguageScore('go', 1.0);
311
+ this.detectionResults.metadata.packageManager = 'go';
312
+ }
313
+
314
+ /**
315
+ * Scan source files for language patterns
316
+ */
317
+ async scanSourceFiles() {
318
+ const sourceFiles = await glob('**/*.{js,ts,tsx,jsx,py,java,go,rs,vue}', {
319
+ cwd: this.projectPath,
320
+ ignore: ['node_modules/**', 'dist/**', 'build/**', '.git/**', 'vendor/**', 'target/**'],
321
+ });
322
+
323
+ console.log(`📁 Found ${sourceFiles.length} source files to analyze`);
324
+
325
+ // Process files in batches for performance
326
+ const batchSize = 50;
327
+ for (let i = 0; i < sourceFiles.length; i += batchSize) {
328
+ const batch = sourceFiles.slice(i, i + batchSize);
329
+ await Promise.all(batch.map((file) => this.analyzeSourceFile(file)));
330
+ }
331
+ }
332
+
333
+ /**
334
+ * Analyze individual source file
335
+ */
336
+ async analyzeSourceFile(relativePath) {
337
+ const filePath = path.join(this.projectPath, relativePath);
338
+ const ext = path.extname(relativePath);
339
+
340
+ try {
341
+ const content = await fs.readFile(filePath, 'utf8');
342
+
343
+ // Detect language by extension
344
+ for (const [lang, config] of Object.entries(this.languagePatterns)) {
345
+ if (config.extensions.includes(ext)) {
346
+ this.incrementLanguageScore(lang, 0.5);
347
+
348
+ // Check for language-specific patterns
349
+ config.patterns.forEach((pattern) => {
350
+ if (pattern.test(content)) {
351
+ this.incrementLanguageScore(lang, 0.3);
352
+ }
353
+ });
354
+ }
355
+ }
356
+
357
+ // Check for framework patterns
358
+ for (const [framework, config] of Object.entries(this.frameworkPatterns)) {
359
+ config.patterns.forEach((pattern) => {
360
+ if (pattern.test(content) || pattern.test(relativePath)) {
361
+ this.incrementFrameworkScore(framework, 0.4);
362
+ }
363
+ });
364
+ }
365
+ } catch (error) {
366
+ console.warn(`Could not analyze ${relativePath}: ${error.message}`);
367
+ }
368
+ }
369
+
370
+ /**
371
+ * Analyze project structure for additional clues
372
+ */
373
+ async analyzeProjectStructure() {
374
+ const directories = [
375
+ 'src',
376
+ 'lib',
377
+ 'app',
378
+ 'pages',
379
+ 'components',
380
+ 'views',
381
+ 'models',
382
+ 'controllers',
383
+ 'routes',
384
+ ];
385
+
386
+ for (const dir of directories) {
387
+ const dirPath = path.join(this.projectPath, dir);
388
+ try {
389
+ const stat = await fs.stat(dirPath);
390
+ if (stat.isDirectory()) {
391
+ this.detectionResults.metadata.directories =
392
+ this.detectionResults.metadata.directories || [];
393
+ this.detectionResults.metadata.directories.push(dir);
394
+
395
+ // Specific directory patterns
396
+ if (dir === 'pages' || dir === 'app') {
397
+ this.incrementFrameworkScore('nextjs', 0.5);
398
+ }
399
+ if (dir === 'components') {
400
+ this.incrementFrameworkScore('react', 0.3);
401
+ this.incrementFrameworkScore('vue', 0.3);
402
+ }
403
+ }
404
+ } catch (error) {
405
+ // Directory doesn't exist
406
+ continue;
407
+ }
408
+ }
409
+ }
410
+
411
+ /**
412
+ * Detect build tools and configuration files
413
+ */
414
+ async detectBuildTools() {
415
+ const buildFiles = {
416
+ 'webpack.config.js': { tool: 'webpack', score: 0.5 },
417
+ 'vite.config.js': { tool: 'vite', score: 0.5 },
418
+ 'rollup.config.js': { tool: 'rollup', score: 0.5 },
419
+ 'gulpfile.js': { tool: 'gulp', score: 0.5 },
420
+ Makefile: { tool: 'make', score: 0.5 },
421
+ 'docker-compose.yml': { tool: 'docker', score: 0.7 },
422
+ Dockerfile: { tool: 'docker', score: 0.7 },
423
+ };
424
+
425
+ for (const [file, config] of Object.entries(buildFiles)) {
426
+ try {
427
+ await fs.access(path.join(this.projectPath, file));
428
+ this.detectionResults.metadata.buildTools = this.detectionResults.metadata.buildTools || {};
429
+ this.detectionResults.metadata.buildTools[config.tool] = config.score;
430
+ } catch (error) {
431
+ // File doesn't exist
432
+ continue;
433
+ }
434
+ }
435
+ }
436
+
437
+ /**
438
+ * Helper methods for scoring
439
+ */
440
+ incrementLanguageScore(language, score) {
441
+ this.detectionResults.languages[language] =
442
+ (this.detectionResults.languages[language] || 0) + score;
443
+ }
444
+
445
+ incrementFrameworkScore(framework, score) {
446
+ this.detectionResults.frameworks[framework] =
447
+ (this.detectionResults.frameworks[framework] || 0) + score;
448
+ }
449
+
450
+ /**
451
+ * Calculate confidence scores for all detected technologies
452
+ */
453
+ calculateConfidenceScores() {
454
+ // Normalize language scores
455
+ const maxLangScore = Math.max(...Object.values(this.detectionResults.languages));
456
+ if (maxLangScore > 0) {
457
+ for (const lang in this.detectionResults.languages) {
458
+ this.detectionResults.languages[lang] = Math.min(
459
+ this.detectionResults.languages[lang] / maxLangScore,
460
+ 1.0,
461
+ );
462
+ }
463
+ }
464
+
465
+ // Normalize framework scores
466
+ const maxFrameworkScore = Math.max(...Object.values(this.detectionResults.frameworks), 1);
467
+ for (const framework in this.detectionResults.frameworks) {
468
+ this.detectionResults.frameworks[framework] = Math.min(
469
+ this.detectionResults.frameworks[framework] / maxFrameworkScore,
470
+ 1.0,
471
+ );
472
+ }
473
+
474
+ // Calculate overall confidence
475
+ const totalLanguages = Object.keys(this.detectionResults.languages).length;
476
+ const totalFrameworks = Object.keys(this.detectionResults.frameworks).length;
477
+ this.detectionResults.confidence = Math.min(
478
+ (totalLanguages * 0.6 + totalFrameworks * 0.4) / 2,
479
+ 1.0,
480
+ );
481
+ }
482
+
483
+ /**
484
+ * Determine the primary project type based on scores
485
+ */
486
+ determinePrimaryProjectType() {
487
+ const languages = this.detectionResults.languages;
488
+ const frameworks = this.detectionResults.frameworks;
489
+
490
+ const primaryLang = Object.keys(languages).reduce(
491
+ (a, b) => (languages[a] > languages[b] ? a : b),
492
+ Object.keys(languages)[0],
493
+ );
494
+
495
+ const primaryFramework = Object.keys(frameworks).reduce(
496
+ (a, b) => (frameworks[a] > frameworks[b] ? a : b),
497
+ Object.keys(frameworks)[0],
498
+ );
499
+
500
+ // Determine project type
501
+ if (frameworks.react && languages.typescript) {
502
+ this.detectionResults.projectType = 'react-typescript';
503
+ } else if (frameworks.react) {
504
+ this.detectionResults.projectType = 'react';
505
+ } else if (frameworks.nextjs) {
506
+ this.detectionResults.projectType = 'nextjs';
507
+ } else if (frameworks.vue) {
508
+ this.detectionResults.projectType = 'vue';
509
+ } else if (frameworks.express) {
510
+ this.detectionResults.projectType = 'express-api';
511
+ } else if (frameworks.django) {
512
+ this.detectionResults.projectType = 'django';
513
+ } else if (frameworks.flask) {
514
+ this.detectionResults.projectType = 'flask';
515
+ } else if (frameworks.fastapi) {
516
+ this.detectionResults.projectType = 'fastapi';
517
+ } else if (primaryLang) {
518
+ this.detectionResults.projectType = primaryLang;
519
+ } else {
520
+ this.detectionResults.projectType = 'unknown';
521
+ }
522
+
523
+ this.detectionResults.metadata.primaryLanguage = primaryLang;
524
+ this.detectionResults.metadata.primaryFramework = primaryFramework;
525
+ }
526
+
527
+ /**
528
+ * Get recommendations for tooling and best practices
529
+ */
530
+ getRecommendations() {
531
+ const recommendations = {
532
+ linting: [],
533
+ testing: [],
534
+ building: [],
535
+ deployment: [],
536
+ };
537
+
538
+ const { languages, frameworks } = this.detectionResults;
539
+
540
+ // Linting recommendations
541
+ if (languages.javascript || languages.typescript) {
542
+ recommendations.linting.push('ESLint', 'Prettier');
543
+ }
544
+ if (languages.python) {
545
+ recommendations.linting.push('Black', 'Flake8', 'mypy');
546
+ }
547
+
548
+ // Testing recommendations
549
+ if (frameworks.react || frameworks.nextjs) {
550
+ recommendations.testing.push('Jest', 'React Testing Library');
551
+ } else if (languages.javascript || languages.typescript) {
552
+ recommendations.testing.push('Jest', 'Vitest');
553
+ }
554
+ if (languages.python) {
555
+ recommendations.testing.push('pytest', 'unittest');
556
+ }
557
+
558
+ // Build recommendations
559
+ if (frameworks.react && !frameworks.nextjs) {
560
+ recommendations.building.push('Vite', 'Create React App');
561
+ }
562
+ if (languages.typescript) {
563
+ recommendations.building.push('tsc', 'esbuild');
564
+ }
565
+
566
+ return recommendations;
567
+ }
568
+
569
+ /**
570
+ * Export results for use by other systems
571
+ */
572
+ exportResults() {
573
+ return {
574
+ ...this.detectionResults,
575
+ timestamp: new Date().toISOString(),
576
+ recommendations: this.getRecommendations(),
577
+ };
578
+ }
579
+ }
580
+
581
+ export default LanguageDetector;