@mycodemap/mycodemap 0.1.1 → 0.3.4

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 (328) hide show
  1. package/CHANGELOG.md +163 -0
  2. package/README.md +241 -67
  3. package/dist/cli/commands/ci.d.ts +7 -1
  4. package/dist/cli/commands/ci.d.ts.map +1 -1
  5. package/dist/cli/commands/ci.js +38 -0
  6. package/dist/cli/commands/ci.js.map +1 -1
  7. package/dist/cli/commands/export.d.ts +6 -0
  8. package/dist/cli/commands/export.d.ts.map +1 -0
  9. package/dist/cli/commands/export.js +108 -0
  10. package/dist/cli/commands/export.js.map +1 -0
  11. package/dist/cli/commands/generate.d.ts.map +1 -1
  12. package/dist/cli/commands/generate.js +96 -0
  13. package/dist/cli/commands/generate.js.map +1 -1
  14. package/dist/cli/commands/server.d.ts +9 -0
  15. package/dist/cli/commands/server.d.ts.map +1 -0
  16. package/dist/cli/commands/server.js +68 -0
  17. package/dist/cli/commands/server.js.map +1 -0
  18. package/dist/cli/commands/ship/analyzer.d.ts +26 -0
  19. package/dist/cli/commands/ship/analyzer.d.ts.map +1 -0
  20. package/dist/cli/commands/ship/analyzer.js +143 -0
  21. package/dist/cli/commands/ship/analyzer.js.map +1 -0
  22. package/dist/cli/commands/ship/checker.d.ts +20 -0
  23. package/dist/cli/commands/ship/checker.d.ts.map +1 -0
  24. package/dist/cli/commands/ship/checker.js +86 -0
  25. package/dist/cli/commands/ship/checker.js.map +1 -0
  26. package/dist/cli/commands/ship/index.d.ts +17 -0
  27. package/dist/cli/commands/ship/index.d.ts.map +1 -0
  28. package/dist/cli/commands/ship/index.js +51 -0
  29. package/dist/cli/commands/ship/index.js.map +1 -0
  30. package/dist/cli/commands/ship/monitor.d.ts +19 -0
  31. package/dist/cli/commands/ship/monitor.d.ts.map +1 -0
  32. package/dist/cli/commands/ship/monitor.js +105 -0
  33. package/dist/cli/commands/ship/monitor.js.map +1 -0
  34. package/dist/cli/commands/ship/pipeline.d.ts +23 -0
  35. package/dist/cli/commands/ship/pipeline.d.ts.map +1 -0
  36. package/dist/cli/commands/ship/pipeline.js +146 -0
  37. package/dist/cli/commands/ship/pipeline.js.map +1 -0
  38. package/dist/cli/commands/ship/publisher.d.ts +11 -0
  39. package/dist/cli/commands/ship/publisher.d.ts.map +1 -0
  40. package/dist/cli/commands/ship/publisher.js +75 -0
  41. package/dist/cli/commands/ship/publisher.js.map +1 -0
  42. package/dist/cli/commands/ship/rules/confidence-rules.d.ts +48 -0
  43. package/dist/cli/commands/ship/rules/confidence-rules.d.ts.map +1 -0
  44. package/dist/cli/commands/ship/rules/confidence-rules.js +122 -0
  45. package/dist/cli/commands/ship/rules/confidence-rules.js.map +1 -0
  46. package/dist/cli/commands/ship/rules/quality-rules.d.ts +25 -0
  47. package/dist/cli/commands/ship/rules/quality-rules.d.ts.map +1 -0
  48. package/dist/cli/commands/ship/rules/quality-rules.js +134 -0
  49. package/dist/cli/commands/ship/rules/quality-rules.js.map +1 -0
  50. package/dist/cli/commands/ship/rules/version-rules.d.ts +24 -0
  51. package/dist/cli/commands/ship/rules/version-rules.d.ts.map +1 -0
  52. package/dist/cli/commands/ship/rules/version-rules.js +75 -0
  53. package/dist/cli/commands/ship/rules/version-rules.js.map +1 -0
  54. package/dist/cli/commands/ship/versioner.d.ts +12 -0
  55. package/dist/cli/commands/ship/versioner.d.ts.map +1 -0
  56. package/dist/cli/commands/ship/versioner.js +92 -0
  57. package/dist/cli/commands/ship/versioner.js.map +1 -0
  58. package/dist/cli/index.js +31 -1
  59. package/dist/cli/index.js.map +1 -1
  60. package/dist/cli-new/commands/export.d.ts +15 -0
  61. package/dist/cli-new/commands/export.d.ts.map +1 -0
  62. package/dist/cli-new/commands/export.js +107 -0
  63. package/dist/cli-new/commands/export.js.map +1 -0
  64. package/dist/cli-new/commands/query.d.ts +14 -0
  65. package/dist/cli-new/commands/query.d.ts.map +1 -0
  66. package/dist/cli-new/commands/query.js +120 -0
  67. package/dist/cli-new/commands/query.js.map +1 -0
  68. package/dist/cli-new/commands/server.d.ts +13 -0
  69. package/dist/cli-new/commands/server.d.ts.map +1 -0
  70. package/dist/cli-new/commands/server.js +94 -0
  71. package/dist/cli-new/commands/server.js.map +1 -0
  72. package/dist/cli-new/index.d.ts +11 -0
  73. package/dist/cli-new/index.d.ts.map +1 -0
  74. package/dist/cli-new/index.js +63 -0
  75. package/dist/cli-new/index.js.map +1 -0
  76. package/dist/cli-new/types/index.d.ts +88 -0
  77. package/dist/cli-new/types/index.d.ts.map +1 -0
  78. package/dist/cli-new/types/index.js +7 -0
  79. package/dist/cli-new/types/index.js.map +1 -0
  80. package/dist/domain/entities/CodeGraph.d.ts +134 -0
  81. package/dist/domain/entities/CodeGraph.d.ts.map +1 -0
  82. package/dist/domain/entities/CodeGraph.js +316 -0
  83. package/dist/domain/entities/CodeGraph.js.map +1 -0
  84. package/dist/domain/entities/Dependency.d.ts +78 -0
  85. package/dist/domain/entities/Dependency.d.ts.map +1 -0
  86. package/dist/domain/entities/Dependency.js +132 -0
  87. package/dist/domain/entities/Dependency.js.map +1 -0
  88. package/dist/domain/entities/Module.d.ts +75 -0
  89. package/dist/domain/entities/Module.d.ts.map +1 -0
  90. package/dist/domain/entities/Module.js +151 -0
  91. package/dist/domain/entities/Module.js.map +1 -0
  92. package/dist/domain/entities/Project.d.ts +50 -0
  93. package/dist/domain/entities/Project.d.ts.map +1 -0
  94. package/dist/domain/entities/Project.js +99 -0
  95. package/dist/domain/entities/Project.js.map +1 -0
  96. package/dist/domain/entities/Symbol.d.ts +75 -0
  97. package/dist/domain/entities/Symbol.d.ts.map +1 -0
  98. package/dist/domain/entities/Symbol.js +130 -0
  99. package/dist/domain/entities/Symbol.js.map +1 -0
  100. package/dist/domain/events/DomainEvent.d.ts +76 -0
  101. package/dist/domain/events/DomainEvent.d.ts.map +1 -0
  102. package/dist/domain/events/DomainEvent.js +153 -0
  103. package/dist/domain/events/DomainEvent.js.map +1 -0
  104. package/dist/domain/index.d.ts +10 -0
  105. package/dist/domain/index.d.ts.map +1 -0
  106. package/dist/domain/index.js +18 -0
  107. package/dist/domain/index.js.map +1 -0
  108. package/dist/domain/repositories/CodeGraphRepository.d.ts +58 -0
  109. package/dist/domain/repositories/CodeGraphRepository.d.ts.map +1 -0
  110. package/dist/domain/repositories/CodeGraphRepository.js +37 -0
  111. package/dist/domain/repositories/CodeGraphRepository.js.map +1 -0
  112. package/dist/domain/services/CodeGraphBuilder.d.ts +50 -0
  113. package/dist/domain/services/CodeGraphBuilder.d.ts.map +1 -0
  114. package/dist/domain/services/CodeGraphBuilder.js +121 -0
  115. package/dist/domain/services/CodeGraphBuilder.js.map +1 -0
  116. package/dist/infrastructure/parser/implementations/GoParser.d.ts +25 -0
  117. package/dist/infrastructure/parser/implementations/GoParser.d.ts.map +1 -0
  118. package/dist/infrastructure/parser/implementations/GoParser.js +158 -0
  119. package/dist/infrastructure/parser/implementations/GoParser.js.map +1 -0
  120. package/dist/infrastructure/parser/implementations/PythonParser.d.ts +30 -0
  121. package/dist/infrastructure/parser/implementations/PythonParser.d.ts.map +1 -0
  122. package/dist/infrastructure/parser/implementations/PythonParser.js +201 -0
  123. package/dist/infrastructure/parser/implementations/PythonParser.js.map +1 -0
  124. package/dist/infrastructure/parser/implementations/TypeScriptParser.d.ts +63 -0
  125. package/dist/infrastructure/parser/implementations/TypeScriptParser.d.ts.map +1 -0
  126. package/dist/infrastructure/parser/implementations/TypeScriptParser.js +420 -0
  127. package/dist/infrastructure/parser/implementations/TypeScriptParser.js.map +1 -0
  128. package/dist/infrastructure/parser/index.d.ts +13 -0
  129. package/dist/infrastructure/parser/index.d.ts.map +1 -0
  130. package/dist/infrastructure/parser/index.js +32 -0
  131. package/dist/infrastructure/parser/index.js.map +1 -0
  132. package/dist/infrastructure/parser/interfaces/ParserBase.d.ts +124 -0
  133. package/dist/infrastructure/parser/interfaces/ParserBase.d.ts.map +1 -0
  134. package/dist/infrastructure/parser/interfaces/ParserBase.js +200 -0
  135. package/dist/infrastructure/parser/interfaces/ParserBase.js.map +1 -0
  136. package/dist/infrastructure/parser/registry/ParserRegistry.d.ts +68 -0
  137. package/dist/infrastructure/parser/registry/ParserRegistry.d.ts.map +1 -0
  138. package/dist/infrastructure/parser/registry/ParserRegistry.js +116 -0
  139. package/dist/infrastructure/parser/registry/ParserRegistry.js.map +1 -0
  140. package/dist/infrastructure/repositories/CodeGraphRepositoryImpl.d.ts +44 -0
  141. package/dist/infrastructure/repositories/CodeGraphRepositoryImpl.d.ts.map +1 -0
  142. package/dist/infrastructure/repositories/CodeGraphRepositoryImpl.js +129 -0
  143. package/dist/infrastructure/repositories/CodeGraphRepositoryImpl.js.map +1 -0
  144. package/dist/infrastructure/repositories/index.d.ts +3 -0
  145. package/dist/infrastructure/repositories/index.d.ts.map +1 -0
  146. package/dist/infrastructure/repositories/index.js +7 -0
  147. package/dist/infrastructure/repositories/index.js.map +1 -0
  148. package/dist/infrastructure/storage/StorageFactory.d.ts +53 -0
  149. package/dist/infrastructure/storage/StorageFactory.d.ts.map +1 -0
  150. package/dist/infrastructure/storage/StorageFactory.js +150 -0
  151. package/dist/infrastructure/storage/StorageFactory.js.map +1 -0
  152. package/dist/infrastructure/storage/adapters/FileSystemStorage.d.ts +52 -0
  153. package/dist/infrastructure/storage/adapters/FileSystemStorage.d.ts.map +1 -0
  154. package/dist/infrastructure/storage/adapters/FileSystemStorage.js +315 -0
  155. package/dist/infrastructure/storage/adapters/FileSystemStorage.js.map +1 -0
  156. package/dist/infrastructure/storage/adapters/KuzuDBStorage.d.ts +52 -0
  157. package/dist/infrastructure/storage/adapters/KuzuDBStorage.d.ts.map +1 -0
  158. package/dist/infrastructure/storage/adapters/KuzuDBStorage.js +235 -0
  159. package/dist/infrastructure/storage/adapters/KuzuDBStorage.js.map +1 -0
  160. package/dist/infrastructure/storage/adapters/MemoryStorage.d.ts +37 -0
  161. package/dist/infrastructure/storage/adapters/MemoryStorage.d.ts.map +1 -0
  162. package/dist/infrastructure/storage/adapters/MemoryStorage.js +229 -0
  163. package/dist/infrastructure/storage/adapters/MemoryStorage.js.map +1 -0
  164. package/dist/infrastructure/storage/adapters/Neo4jStorage.d.ts +49 -0
  165. package/dist/infrastructure/storage/adapters/Neo4jStorage.d.ts.map +1 -0
  166. package/dist/infrastructure/storage/adapters/Neo4jStorage.js +222 -0
  167. package/dist/infrastructure/storage/adapters/Neo4jStorage.js.map +1 -0
  168. package/dist/infrastructure/storage/index.d.ts +6 -0
  169. package/dist/infrastructure/storage/index.d.ts.map +1 -0
  170. package/dist/infrastructure/storage/index.js +13 -0
  171. package/dist/infrastructure/storage/index.js.map +1 -0
  172. package/dist/infrastructure/storage/interfaces/StorageBase.d.ts +76 -0
  173. package/dist/infrastructure/storage/interfaces/StorageBase.d.ts.map +1 -0
  174. package/dist/infrastructure/storage/interfaces/StorageBase.js +116 -0
  175. package/dist/infrastructure/storage/interfaces/StorageBase.js.map +1 -0
  176. package/dist/interface/config/index.d.ts +102 -0
  177. package/dist/interface/config/index.d.ts.map +1 -0
  178. package/dist/interface/config/index.js +7 -0
  179. package/dist/interface/config/index.js.map +1 -0
  180. package/dist/interface/types/index.d.ts +425 -0
  181. package/dist/interface/types/index.d.ts.map +1 -0
  182. package/dist/interface/types/index.js +8 -0
  183. package/dist/interface/types/index.js.map +1 -0
  184. package/dist/interface/types/parser.d.ts +103 -0
  185. package/dist/interface/types/parser.d.ts.map +1 -0
  186. package/dist/interface/types/parser.js +7 -0
  187. package/dist/interface/types/parser.js.map +1 -0
  188. package/dist/interface/types/storage.d.ts +98 -0
  189. package/dist/interface/types/storage.d.ts.map +1 -0
  190. package/dist/interface/types/storage.js +7 -0
  191. package/dist/interface/types/storage.js.map +1 -0
  192. package/dist/orchestrator/test-linker.js +1 -1
  193. package/dist/orchestrator/test-linker.js.map +1 -1
  194. package/dist/server/CodeMapServer.d.ts +51 -0
  195. package/dist/server/CodeMapServer.d.ts.map +1 -0
  196. package/dist/server/CodeMapServer.js +146 -0
  197. package/dist/server/CodeMapServer.js.map +1 -0
  198. package/dist/server/handlers/AnalysisHandler.d.ts +82 -0
  199. package/dist/server/handlers/AnalysisHandler.d.ts.map +1 -0
  200. package/dist/server/handlers/AnalysisHandler.js +196 -0
  201. package/dist/server/handlers/AnalysisHandler.js.map +1 -0
  202. package/dist/server/handlers/QueryHandler.d.ts +57 -0
  203. package/dist/server/handlers/QueryHandler.d.ts.map +1 -0
  204. package/dist/server/handlers/QueryHandler.js +260 -0
  205. package/dist/server/handlers/QueryHandler.js.map +1 -0
  206. package/dist/server/index.d.ts +7 -0
  207. package/dist/server/index.d.ts.map +1 -0
  208. package/dist/server/index.js +13 -0
  209. package/dist/server/index.js.map +1 -0
  210. package/dist/server/routes/api.d.ts +8 -0
  211. package/dist/server/routes/api.d.ts.map +1 -0
  212. package/dist/server/routes/api.js +372 -0
  213. package/dist/server/routes/api.js.map +1 -0
  214. package/dist/server/types/index.d.ts +171 -0
  215. package/dist/server/types/index.d.ts.map +1 -0
  216. package/dist/server/types/index.js +7 -0
  217. package/dist/server/types/index.js.map +1 -0
  218. package/dist/types/index.d.ts +6 -372
  219. package/dist/types/index.d.ts.map +1 -1
  220. package/dist/types/index.js +9 -3
  221. package/dist/types/index.js.map +1 -1
  222. package/docs/AI_ASSISTANT_SETUP.md +68 -0
  223. package/docs/PUBLISHING.md +472 -0
  224. package/docs/README.md +37 -0
  225. package/docs/SETUP_GUIDE.md +91 -5
  226. package/docs/ai-guide/COMMANDS.md +403 -0
  227. package/docs/ai-guide/INTEGRATION.md +513 -0
  228. package/docs/ai-guide/OUTPUT.md +465 -0
  229. package/docs/ai-guide/PATTERNS.md +409 -0
  230. package/docs/ai-guide/PROMPTS.md +414 -0
  231. package/docs/ai-guide/QUICKSTART.md +114 -0
  232. package/docs/ai-guide/README.md +66 -0
  233. package/docs/archive/AI_INTEGRATION_GUIDE_ARCHIVED.md +7 -1
  234. package/docs/archive/ARCHIVE.md +39 -0
  235. package/docs/archive/MYCLAUDE_GUIDE.md +305 -0
  236. package/docs/archive/PUBLISH_NPM_DESIGN_V1.md +6 -0
  237. package/docs/archive/PUBLISH_NPM_DESIGN_V2.md +6 -0
  238. package/docs/archive/README.md +29 -0
  239. package/docs/archive/TASK_DESIGN_COVERAGE_REPORT.md +6 -0
  240. package/docs/archive/TEST_SUMMARY.md +140 -0
  241. package/docs/archive/comprehensive_test_report.md +337 -0
  242. package/docs/{CI_GATEWAY_DESIGN.md → archive/design-docs/CI_GATEWAY_DESIGN.md} +6 -0
  243. package/docs/{PUBLISH_NPM_DESIGN_FINAL.md → archive/design-docs/PUBLISH_NPM_DESIGN_FINAL.md} +7 -1
  244. package/docs/{REFACTOR_ARCHITECTURE_OVERVIEW.md → archive/design-docs/REFACTOR_ARCHITECTURE_OVERVIEW.md} +8 -2
  245. package/docs/{REFACTOR_CONFIDENCE_DESIGN.md → archive/design-docs/REFACTOR_CONFIDENCE_DESIGN.md} +6 -0
  246. package/docs/{REFACTOR_GIT_ANALYZER_DESIGN.md → archive/design-docs/REFACTOR_GIT_ANALYZER_DESIGN.md} +8 -2
  247. package/docs/{REFACTOR_ORCHESTRATOR_DESIGN.md → archive/design-docs/REFACTOR_ORCHESTRATOR_DESIGN.md} +6 -0
  248. package/docs/{REFACTOR_RESULT_FUSION_DESIGN.md → archive/design-docs/REFACTOR_RESULT_FUSION_DESIGN.md} +6 -0
  249. package/docs/{REFACTOR_TEST_LINKER_DESIGN.md → archive/design-docs/REFACTOR_TEST_LINKER_DESIGN.md} +6 -0
  250. package/docs/archive/myclaude.md +1084 -0
  251. package/docs/archive/plans/2026-03-14-go-language-support-design.md +92 -0
  252. package/docs/{REFACTOR_REQUIREMENTS.md → archive/product-specs/REFACTOR_REQUIREMENTS.md} +11 -5
  253. package/docs/archive/scenario-2-deps-analysis.md +353 -0
  254. package/docs/design-docs/README.md +26 -0
  255. package/docs/exec-plans/MVP3-IMPLEMENTATION-ROADMAP.md +524 -0
  256. package/docs/exec-plans/README.md +29 -0
  257. package/docs/exec-plans/active/.gitkeep +0 -0
  258. package/docs/exec-plans/completed/.gitkeep +0 -0
  259. package/docs/{plans/POST_TASK_PLAN.md → exec-plans/completed/2026-03-03-post-task-plan.md} +9 -3
  260. package/docs/exec-plans/completed/harness-engineering-rollout.md +184 -0
  261. package/docs/exec-plans/tech-debt/.gitkeep +0 -0
  262. package/docs/exec-plans/tech-debt/2026-03-15-lint-guardrail-gap.md +30 -0
  263. package/docs/generated/README.md +19 -0
  264. package/docs/product-specs/MVP3-ARCHITECTURE-COMPARISON.md +504 -0
  265. package/docs/product-specs/MVP3-ARCHITECTURE-REDESIGN-PRD.md +322 -0
  266. package/docs/product-specs/MVP3-ARCHITECTURE-REDESIGN-TECH-PRD.md +1374 -0
  267. package/docs/product-specs/README.md +22 -0
  268. package/docs/references/README.md +15 -0
  269. package/docs/references/tmp.md +527 -0
  270. package/docs/rules/README.md +16 -0
  271. package/docs/rules/architecture-guardrails.md +349 -0
  272. package/docs/rules/code-quality-redlines.md +321 -0
  273. package/docs/rules/deployment.md +23 -0
  274. package/docs/rules/engineering-with-codex-openai.md +202 -0
  275. package/docs/rules/pre-release-checklist.md +426 -0
  276. package/docs/rules/testing.md +73 -0
  277. package/docs/rules/validation.md +39 -0
  278. package/package.json +26 -7
  279. package/scripts/.githooks/commit-msg +31 -0
  280. package/scripts/.githooks/pre-commit +55 -0
  281. package/scripts/benchmark.ts +209 -0
  282. package/scripts/hooks/commit-msg +24 -0
  283. package/scripts/hooks/install-hooks.sh +29 -0
  284. package/scripts/hooks/pre-commit +60 -0
  285. package/scripts/pre-release-check.js +717 -0
  286. package/scripts/release.sh +142 -0
  287. package/scripts/run-benchmark.sh +29 -0
  288. package/scripts/validate-ai-docs.js +294 -0
  289. package/scripts/validate-docs.js +238 -0
  290. package/scripts/validate-pack.js +86 -0
  291. package/dist/ai/claude.d.ts +0 -38
  292. package/dist/ai/claude.d.ts.map +0 -1
  293. package/dist/ai/claude.js +0 -169
  294. package/dist/ai/claude.js.map +0 -1
  295. package/dist/ai/codex.d.ts +0 -38
  296. package/dist/ai/codex.d.ts.map +0 -1
  297. package/dist/ai/codex.js +0 -169
  298. package/dist/ai/codex.js.map +0 -1
  299. package/dist/ai/factory.d.ts +0 -48
  300. package/dist/ai/factory.d.ts.map +0 -1
  301. package/dist/ai/factory.js +0 -95
  302. package/dist/ai/factory.js.map +0 -1
  303. package/dist/ai/index.d.ts +0 -12
  304. package/dist/ai/index.d.ts.map +0 -1
  305. package/dist/ai/index.js +0 -29
  306. package/dist/ai/index.js.map +0 -1
  307. package/dist/ai/provider.d.ts +0 -70
  308. package/dist/ai/provider.d.ts.map +0 -1
  309. package/dist/ai/provider.js +0 -31
  310. package/dist/ai/provider.js.map +0 -1
  311. package/dist/ai/subagent-caller.d.ts +0 -90
  312. package/dist/ai/subagent-caller.d.ts.map +0 -1
  313. package/dist/ai/subagent-caller.js +0 -280
  314. package/dist/ai/subagent-caller.js.map +0 -1
  315. package/dist/ai/types.d.ts +0 -70
  316. package/dist/ai/types.d.ts.map +0 -1
  317. package/dist/ai/types.js +0 -5
  318. package/dist/ai/types.js.map +0 -1
  319. package/dist/generator/ai-overview.d.ts +0 -51
  320. package/dist/generator/ai-overview.d.ts.map +0 -1
  321. package/dist/generator/ai-overview.js +0 -160
  322. package/dist/generator/ai-overview.js.map +0 -1
  323. package/dist/orchestrator/ai-feed-generator.d.ts +0 -210
  324. package/dist/orchestrator/ai-feed-generator.d.ts.map +0 -1
  325. package/dist/orchestrator/ai-feed-generator.js +0 -377
  326. package/dist/orchestrator/ai-feed-generator.js.map +0 -1
  327. package/docs/OMC_TEAM_DEBUG_REPORT.md +0 -285
  328. /package/docs/{plans/archive → exec-plans/completed}/2026-03-03-deps-path-extension-fix.md +0 -0
@@ -0,0 +1,414 @@
1
+ # AI Guide - 提示词模板库
2
+
3
+ > 即用型提示词模板,可直接使用或根据场景改编
4
+
5
+ ---
6
+
7
+ ## 模板 1: 项目理解
8
+
9
+ **适用场景**: 首次接触项目,需要快速了解整体结构
10
+
11
+ ```markdown
12
+ 我需要理解这个 TypeScript 项目的结构。
13
+
14
+ 请执行以下步骤:
15
+
16
+ 1. **生成代码地图**
17
+ ```bash
18
+ node dist/cli/index.js generate
19
+ ```
20
+
21
+ 2. **阅读项目概览**
22
+ 阅读 `.mycodemap/AI_MAP.md` 文件
23
+
24
+ 3. **获取详细信息**
25
+ ```bash
26
+ node dist/cli/index.js analyze -i overview -t "src/" --json
27
+ ```
28
+
29
+ 4. **回答以下问题**
30
+ - 项目的主要模块有哪些?
31
+ - 模块之间的依赖关系是什么?
32
+ - 核心功能入口在哪里?
33
+ - 有哪些关键类/接口?
34
+ - 项目使用什么架构模式?
35
+
36
+ 请以结构化方式输出分析结果,包括:
37
+ - 项目基本信息
38
+ - 架构图(文字描述)
39
+ - 关键模块说明
40
+ - 入口点列表
41
+ ```
42
+
43
+ ---
44
+
45
+ ## 模板 2: 变更影响分析
46
+
47
+ **适用场景**: 修改某个文件前,评估影响范围
48
+
49
+ ```markdown
50
+ 我需要修改文件 {{FILE_PATH}},请帮我分析影响范围。
51
+
52
+ 请执行以下步骤:
53
+
54
+ 1. **影响分析**
55
+ ```bash
56
+ node dist/cli/index.js analyze -i impact -t "{{FILE_PATH}}" --transitive --include-tests --json
57
+ ```
58
+
59
+ 2. **分析结果**
60
+ 从 JSON 输出中提取:
61
+ - 直接依赖的文件有哪些?
62
+ - 传递依赖的文件有哪些?
63
+ - 可能受影响的测试文件?
64
+ - 置信度评分如何?
65
+
66
+ 3. **风险评估**
67
+ - 影响范围大吗?(文件数量、涉及模块)
68
+ - 是否有高风险文件?(核心模块、频繁修改)
69
+ - 是否需要拆分修改?
70
+
71
+ 4. **给出建议**
72
+ - 修改时需要注意什么?
73
+ - 需要更新哪些测试?
74
+ - 是否有替代方案?
75
+ - 推荐的修改顺序?
76
+
77
+ 请以表格形式列出受影响的文件,按相关度排序。
78
+ ```
79
+
80
+ **变量**:
81
+ - `{{FILE_PATH}}`: 要修改的文件路径,例如 `src/cli/index.ts`
82
+
83
+ ---
84
+
85
+ ## 模板 3: 代码搜索
86
+
87
+ **适用场景**: 查找与特定关键词相关的代码
88
+
89
+ ```markdown
90
+ 我需要找到与 "{{KEYWORD}}" 相关的所有代码。
91
+
92
+ 请执行以下步骤:
93
+
94
+ 1. **精确查询**
95
+ ```bash
96
+ node dist/cli/index.js query -s "{{KEYWORD}}" -j
97
+ ```
98
+
99
+ 2. **如果结果不足,进行模糊搜索**
100
+ ```bash
101
+ node dist/cli/index.js query -S "{{KEYWORD}}" -l 20 -j
102
+ ```
103
+
104
+ 3. **如果仍不足,使用统一搜索**
105
+ ```bash
106
+ node dist/cli/index.js analyze -i search -k "{{KEYWORD}}" --topK 15 --json
107
+ ```
108
+
109
+ 4. **汇总结果**
110
+ 按以下类别分组输出:
111
+ - 精确匹配(符号名完全一致)
112
+ - 模糊匹配(包含关键词)
113
+ - 相关引用(导入/使用了相关符号)
114
+
115
+ 对于每个结果,提供:
116
+ - 文件路径
117
+ - 行号
118
+ - 符号类型(类/函数/接口等)
119
+ - 相关度评分
120
+ - 简短描述
121
+ ```
122
+
123
+ **变量**:
124
+ - `{{KEYWORD}}`: 搜索关键词,例如 `IntentRouter` 或 `CacheManager`
125
+
126
+ ---
127
+
128
+ ## 模板 4: 重构评估
129
+
130
+ **适用场景**: 评估重构某个模块的可行性
131
+
132
+ ```markdown
133
+ 我需要评估重构 {{MODULE_PATH}} 的可行性。
134
+
135
+ 请执行以下步骤:
136
+
137
+ 1. **检测现有问题**
138
+ ```bash
139
+ node dist/cli/index.js cycles -j
140
+ node dist/cli/index.js analyze -i complexity -t "{{MODULE_PATH}}" --json
141
+ ```
142
+
143
+ 2. **获取重构建议**
144
+ ```bash
145
+ node dist/cli/index.js analyze -i refactor -t "{{MODULE_PATH}}" --json
146
+ ```
147
+
148
+ 3. **评估影响范围**
149
+ ```bash
150
+ node dist/cli/index.js analyze -i impact -t "{{MODULE_PATH}}" --scope transitive --json
151
+ ```
152
+
153
+ 4. **生成评估报告**
154
+ 包括以下内容:
155
+
156
+ ## 当前架构问题
157
+ - 存在的循环依赖
158
+ - 复杂度过高的文件/函数
159
+ - 代码质量问题
160
+
161
+ ## 重构建议
162
+ - 推荐的重构策略
163
+ - 目标架构设计
164
+ - 重构步骤分解
165
+
166
+ ## 风险评估
167
+ - 影响范围(文件数、模块数)
168
+ - 风险等级(高/中/低)
169
+ - 回滚难度
170
+
171
+ ## 实施计划
172
+ - 步骤 1: ...
173
+ - 步骤 2: ...
174
+ - ...
175
+
176
+ ## 测试策略
177
+ - 需要更新的测试
178
+ - 建议新增的测试
179
+ ```
180
+
181
+ **变量**:
182
+ - `{{MODULE_PATH}}`: 模块路径,例如 `src/domain/services`
183
+
184
+ ---
185
+
186
+ ## 模板 5: 代码审查
187
+
188
+ **适用场景**: 审查代码变更是否符合规范
189
+
190
+ ```markdown
191
+ 请帮我审查这次代码变更。
192
+
193
+ 请执行以下步骤:
194
+
195
+ 1. **提交格式检查**
196
+ ```bash
197
+ node dist/cli/index.js ci check-commits
198
+ ```
199
+
200
+ 2. **文件头检查**
201
+ ```bash
202
+ node dist/cli/index.js ci check-headers
203
+ ```
204
+
205
+ 3. **风险评估**
206
+ ```bash
207
+ node dist/cli/index.js ci assess-risk
208
+ ```
209
+
210
+ 4. **输出契约检查**(如果修改了 analyze 命令)
211
+ ```bash
212
+ node dist/cli/index.js ci check-output-contract
213
+ ```
214
+
215
+ 5. **文档同步检查**
216
+ ```bash
217
+ node dist/cli/index.js ci check-docs-sync
218
+ ```
219
+
220
+ 6. **生成审查报告**
221
+
222
+ ## 审查结果
223
+
224
+ ### 提交规范
225
+ - [ ] 提交格式正确([TAG] scope: message)
226
+ - [ ] 单次提交文件数 ≤ 10
227
+
228
+ ### 代码规范
229
+ - [ ] 文件头包含 [META] 和 [WHY]
230
+ - [ ] 无敏感信息硬编码
231
+ - [ ] 函数长度 ≤ 50 行
232
+ - [ ] 无未处理 Promise
233
+
234
+ ### 风险评估
235
+ - 风险等级:高/中/低
236
+ - 风险因素:...
237
+
238
+ ### 建议
239
+ - 需要改进的地方
240
+ - 可选的优化建议
241
+ ```
242
+
243
+ ---
244
+
245
+ ## 模板 6: 依赖分析
246
+
247
+ **适用场景**: 分析模块依赖关系,优化架构
248
+
249
+ ```markdown
250
+ 请分析 {{MODULE_PATH}} 的依赖关系。
251
+
252
+ 请执行以下步骤:
253
+
254
+ 1. **依赖分析**
255
+ ```bash
256
+ node dist/cli/index.js analyze -i dependency -t "{{MODULE_PATH}}" --json
257
+ ```
258
+
259
+ 2. **循环依赖检测**
260
+ ```bash
261
+ node dist/cli/index.js cycles -j
262
+ ```
263
+
264
+ 3. **影响范围评估**
265
+ ```bash
266
+ node dist/cli/index.js deps -m "{{MODULE_PATH}}" -j
267
+ ```
268
+
269
+ 4. **生成依赖报告**
270
+
271
+ ## 依赖图
272
+ (文字描述或 Mermaid 图)
273
+
274
+ ## 直接依赖
275
+ | 模块 | 类型 | 说明 |
276
+ |------|------|------|
277
+
278
+ ## 被依赖模块
279
+ | 模块 | 类型 | 说明 |
280
+ |------|------|------|
281
+
282
+ ## 循环依赖
283
+ (如果有,列出循环路径)
284
+
285
+ ## 架构建议
286
+ - 依赖是否合理?
287
+ - 是否存在循环依赖?
288
+ - 是否需要调整依赖方向?
289
+ ```
290
+
291
+ ---
292
+
293
+ ## 模板 7: 复杂度分析
294
+
295
+ **适用场景**: 识别复杂代码,指导重构优先级
296
+
297
+ ```markdown
298
+ 请分析项目的代码复杂度。
299
+
300
+ 请执行以下步骤:
301
+
302
+ 1. **整体复杂度分析**
303
+ ```bash
304
+ node dist/cli/index.js analyze -i complexity -t "src/" --json
305
+ ```
306
+
307
+ 2. **函数级复杂度**(针对复杂文件)
308
+ ```bash
309
+ node dist/cli/index.js complexity -f "{{COMPLEX_FILE}}" -d -j
310
+ ```
311
+
312
+ 3. **生成复杂度报告**
313
+
314
+ ## 整体统计
315
+ - 平均复杂度:
316
+ - 最大复杂度:
317
+ - 可维护性指数:
318
+
319
+ ## 最复杂的文件(Top 10)
320
+ | 排名 | 文件 | 复杂度 | 可维护性 |
321
+ |------|------|--------|----------|
322
+
323
+ ## 最复杂的函数(Top 10)
324
+ | 排名 | 函数 | 文件 | 圈复杂度 | 认知复杂度 |
325
+ |------|------|------|----------|------------|
326
+
327
+ ## 重构建议
328
+ - 优先重构的文件
329
+ - 重构策略建议
330
+ ```
331
+
332
+ ---
333
+
334
+ ## 模板 8: 新功能实现
335
+
336
+ **适用场景**: 从零开始实现一个新功能
337
+
338
+ ```markdown
339
+ 我需要实现新功能:{{FEATURE_DESCRIPTION}}
340
+
341
+ 请执行以下步骤:
342
+
343
+ 1. **相关代码搜索**
344
+ ```bash
345
+ node dist/cli/index.js analyze -i search -k "{{RELATED_KEYWORD}}" --topK 10 --json
346
+ ```
347
+
348
+ 2. **参考现有实现**
349
+ 分析类似功能的实现方式
350
+
351
+ 3. **确定实现位置**
352
+ ```bash
353
+ node dist/cli/index.js analyze -i complexity -t "候选目录" --json
354
+ ```
355
+ 选择复杂度最低的模块
356
+
357
+ 4. **影响分析**(如果需要修改现有代码)
358
+ ```bash
359
+ node dist/cli/index.js analyze -i impact -t "目标文件" --json
360
+ ```
361
+
362
+ 5. **实现步骤**
363
+ - [ ] 创建新文件(添加 [META] [WHY] 头)
364
+ - [ ] 实现核心功能
365
+ - [ ] 添加单元测试
366
+ - [ ] 运行测试验证
367
+
368
+ 6. **验证**
369
+ ```bash
370
+ node dist/cli/index.js ci check-headers -f "新文件.ts"
371
+ npm test
372
+ ```
373
+
374
+ 请提供:
375
+ - 推荐的实现位置
376
+ - 参考的现有代码
377
+ - 实现步骤分解
378
+ - 测试建议
379
+ ```
380
+
381
+ ---
382
+
383
+ ## 模板使用指南
384
+
385
+ ### 如何选择模板
386
+
387
+ | 场景 | 推荐模板 |
388
+ |------|---------|
389
+ | 第一次看项目 | 模板 1: 项目理解 |
390
+ | 要修改代码 | 模板 2: 变更影响分析 |
391
+ | 找某个功能 | 模板 3: 代码搜索 |
392
+ | 要重构 | 模板 4: 重构评估 |
393
+ | 提交前检查 | 模板 5: 代码审查 |
394
+ | 看模块关系 | 模板 6: 依赖分析 |
395
+ | 找复杂代码 | 模板 7: 复杂度分析 |
396
+ | 做新功能 | 模板 8: 新功能实现 |
397
+
398
+ ### 如何自定义模板
399
+
400
+ 1. **替换变量**: 将 `{{VARIABLE}}` 替换为实际值
401
+ 2. **调整命令**: 根据实际需要添加/删除命令
402
+ 3. **修改输出**: 调整期望的输出格式和内容
403
+ 4. **添加约束**: 添加项目特定的约束条件
404
+
405
+ ### 组合使用
406
+
407
+ 复杂任务可以组合多个模板:
408
+
409
+ ```
410
+ 项目理解 (模板 1)
411
+ → 代码搜索 (模板 3)
412
+ → 变更影响分析 (模板 2)
413
+ → 代码审查 (模板 5)
414
+ ```
@@ -0,0 +1,114 @@
1
+ # AI Guide - 快速开始
2
+
3
+ > AI/Agent 使用 CodeMap 的快速入门和决策指南
4
+
5
+ ---
6
+
7
+ ## 快速开始
8
+
9
+ ```bash
10
+ # Step 1: 生成代码地图(必须在其他命令之前执行)
11
+ node dist/cli/index.js generate
12
+
13
+ # Step 2: 阅读生成的 AI_MAP.md 获取项目概览
14
+ cat .mycodemap/AI_MAP.md
15
+
16
+ # Step 3: 根据任务选择命令...
17
+ ```
18
+
19
+ ---
20
+
21
+ ## 命令选择决策树
22
+
23
+ ```
24
+ 开始任务
25
+
26
+ 是否需要理解项目整体结构?
27
+ ├── 是 → mycodemap generate → 阅读 .mycodemap/AI_MAP.md
28
+ ↓ 否
29
+ 需要查找特定符号/函数/类?
30
+ ├── 是 → mycodemap query -s "SymbolName"
31
+ ↓ 否
32
+ 需要修改某个文件?
33
+ ├── 是 → mycodemap impact -f "path/to/file" --transitive
34
+ ↓ 否
35
+ 需要理解模块依赖关系?
36
+ ├── 是 → mycodemap analyze -i dependency -t "src/module"
37
+ ↓ 否
38
+ 需要评估代码质量/复杂度?
39
+ ├── 是 → mycodemap analyze -i complexity -t "src/"
40
+ ↓ 否
41
+ 需要搜索包含特定关键词的代码?
42
+ ├── 是 → mycodemap analyze -i search -k "keyword"
43
+ ↓ 否
44
+ 需要执行复杂的多步骤任务?
45
+ ├── 是 → mycodemap workflow start "任务描述"
46
+ ↓ 否
47
+ 需要验证代码是否符合规范?
48
+ └── 是 → mycodemap ci check-headers
49
+ ```
50
+
51
+ ---
52
+
53
+ ## 场景-命令映射表
54
+
55
+ | 用户意图 | 推荐命令 | 备选命令 | 输出格式 |
56
+ |---------|---------|---------|---------|
57
+ | "项目结构是什么" | `generate` + 读 `AI_MAP.md` | `analyze -i overview` | 文本 |
58
+ | "XXX 在哪里定义" | `query -s "XXX"` | `query -S "XXX"` | 文本 |
59
+ | "修改 XXX 会影响什么" | `impact -f "XXX" -t` | `analyze -i impact -t "XXX"` | JSON |
60
+ | "XXX 模块依赖什么" | `analyze -i dependency -t "XXX"` | `deps -m "XXX"` | JSON |
61
+ | "代码质量如何" | `analyze -i complexity -t "src/"` | `complexity` | JSON |
62
+ | "查找与 XXX 相关的代码" | `analyze -i search -k "XXX"` | `query -S "XXX"` | JSON |
63
+ | "这个改动安全吗" | `ci assess-risk` | `analyze -i impact` | 文本 |
64
+ | "需要重构建议" | `analyze -i refactor -t "src/"` | `cycles` + `complexity` | JSON |
65
+ | "查找循环依赖" | `cycles` | - | 文本 |
66
+ | "有哪些测试文件" | `query -S ".test.ts"` | - | 文本 |
67
+
68
+ ---
69
+
70
+ ## 参数选择指南
71
+
72
+ ### 何时使用 `--json`
73
+
74
+ | 场景 | 使用 `--json` | 原因 |
75
+ |------|--------------|------|
76
+ | 需要解析结果进行进一步处理 | ✅ 是 | 结构化数据便于解析 |
77
+ | 向用户展示结果 | ❌ 否 | 人类可读格式更好 |
78
+ | 需要提取文件路径列表 | ✅ 是 | 便于正则提取 |
79
+ | 需要计算统计数据 | ✅ 是 | JSON 可直接计算 |
80
+ | 简单查询确认存在性 | ❌ 否 | 文本输出更直观 |
81
+
82
+ ### 何时使用 `--transitive` / `--scope transitive`
83
+
84
+ | 场景 | 使用 | 说明 |
85
+ |------|------|------|
86
+ | 评估变更影响范围 | ✅ 是 | 包含间接依赖 |
87
+ | 查找所有相关代码 | ✅ 是 | 完整的依赖链 |
88
+ | 仅查看直接依赖 | ❌ 否 | 默认就是 direct |
89
+ | 结果太多需要简化 | ❌ 否 | 缩小范围 |
90
+
91
+ ---
92
+
93
+ ## 核心能力矩阵
94
+
95
+ | 能力 | 命令 | 典型场景 |
96
+ |------|------|---------|
97
+ | 代码地图生成 | `generate` | 首次理解项目结构 |
98
+ | 符号查询 | `query -s` | 查找类/函数定义位置 |
99
+ | 依赖分析 | `deps` / `analyze -i dependency` | 理解模块关系 |
100
+ | 影响分析 | `impact` / `analyze -i impact` | 评估变更范围 |
101
+ | 复杂度分析 | `complexity` / `analyze -i complexity` | 识别复杂代码 |
102
+ | 循环依赖检测 | `cycles` | 发现架构问题 |
103
+ | 统一分析 | `analyze` | 多意图智能路由 |
104
+ | CI 门禁 | `ci` | 代码质量检查 |
105
+ | 工作流编排 | `workflow` | 复杂任务管理 |
106
+ | HTTP API | `server` | 远程访问分析能力 |
107
+
108
+ ---
109
+
110
+ ## 下一步
111
+
112
+ - 需要完整命令参数?查看 [COMMANDS.md](./COMMANDS.md)
113
+ - 需要解析 JSON 输出?查看 [OUTPUT.md](./OUTPUT.md)
114
+ - 需要即用型提示词?查看 [PROMPTS.md](./PROMPTS.md)
@@ -0,0 +1,66 @@
1
+ # AI Guide 文档目录
2
+
3
+ > 专为 AI 大模型和 Agent 设计的 CodeMap 使用指南
4
+
5
+ ---
6
+
7
+ ## 文档导航
8
+
9
+ | 文档 | 内容 | 阅读顺序 |
10
+ |------|------|---------|
11
+ | [QUICKSTART.md](./QUICKSTART.md) | 快速开始、决策树、场景映射 | **第 1** |
12
+ | [COMMANDS.md](./COMMANDS.md) | 完整 CLI 命令参考 | 需要时查阅 |
13
+ | [OUTPUT.md](./OUTPUT.md) | JSON 输出结构解析 | 解析输出时查阅 |
14
+ | [PATTERNS.md](./PATTERNS.md) | 使用模式、最佳实践 | 实现复杂任务时 |
15
+ | [PROMPTS.md](./PROMPTS.md) | 即用型提示词模板 | 直接使用 |
16
+ | [INTEGRATION.md](./INTEGRATION.md) | 集成和错误处理 | 集成到 Agent 时 |
17
+
18
+ ---
19
+
20
+ ## 快速开始
21
+
22
+ ### 如果你是 AI/Agent
23
+
24
+ 1. **首先阅读**: `QUICKSTART.md` - 了解如何使用决策树选择命令
25
+ 2. **然后参考**: `PROMPTS.md` - 使用提示词模板开始任务
26
+ 3. **遇到问题时**: `INTEGRATION.md` - 查看错误处理方法
27
+
28
+ ### 如果你是开发者
29
+
30
+ 1. **查看**: `PROMPTS.md` - 选择适合场景的提示词模板
31
+ 2. **复制**: 模板中的提示词到你的 AI 工具
32
+ 3. **替换**: 模板变量(如 `{{FILE_PATH}}`)
33
+ 4. **执行**: 让 AI 按照提示词步骤执行
34
+
35
+ ---
36
+
37
+ ## 文档统计
38
+
39
+ | 文档 | 行数 | 核心内容 |
40
+ |------|------|---------|
41
+ | QUICKSTART.md | ~120 | 决策树、场景映射 |
42
+ | COMMANDS.md | ~350 | 16个命令完整参数 |
43
+ | OUTPUT.md | ~320 | JSON 结构、解析工具 |
44
+ | PATTERNS.md | ~290 | 6种工作流模式 |
45
+ | PROMPTS.md | ~300 | 8个提示词模板 |
46
+ | INTEGRATION.md | ~420 | MCP、Skill、错误处理 |
47
+ | **总计** | **~1800** | **完整 AI 使用指南** |
48
+
49
+ ---
50
+
51
+ ## 主索引
52
+
53
+ 项目根目录的 `AI_GUIDE.md` 是主索引文档,包含:
54
+ - 项目速览
55
+ - 命令选择速查表
56
+ - 文档导航
57
+ - 提示词模板速用
58
+ - 关键类型定义
59
+
60
+ **建议**: AI 首次接触项目时,先读取 `AI_GUIDE.md` 获取概览。
61
+
62
+ ---
63
+
64
+ ## 更新记录
65
+
66
+ - **2026-03-22**: 创建 AI Guide 文档体系 (v0.2.0 MVP3)
@@ -1,5 +1,11 @@
1
1
  # MyCodeMap AI 集成配置指南
2
2
 
3
+ > 归档时间:2026-03-15
4
+ > 归档原因:旧版 AI 集成指南,已被当前仓库的统一 AI 助手接入说明替代。
5
+ > 当前依据:`docs/AI_ASSISTANT_SETUP.md`
6
+ > 状态:仅供历史对照,不作为当前执行依据。
7
+
8
+
3
9
  > 让 AI 大模型(如 Claude、Copilot、Cursor)更好地理解和使用 CodeMap
4
10
 
5
11
  ## 目录
@@ -382,4 +388,4 @@ codemap generate
382
388
 
383
389
  - [CodeMap GitHub](https://github.com/stark020/codemap)
384
390
  - [CodeMap npm](https://www.npmjs.com/package/@mycodemap/mycodemap)
385
- - [完整 CLI 文档](./README.md)
391
+ - [完整 CLI 文档](../../README.md)
@@ -0,0 +1,39 @@
1
+ # 测试报告归档说明
2
+
3
+ **归档时间**: 2026-03-03
4
+ **归档文件**: `comprehensive_test_report.md`
5
+
6
+ ---
7
+
8
+ ## 归档原因
9
+
10
+ 该综合测试报告在验证过程中发现**部分关键数据与实际情况不符**,需要归档处理:
11
+
12
+ ### 数据错误
13
+
14
+ | 项目 | 报告值 | 实际值 |
15
+ |------|--------|--------|
16
+ | TypeScript 文件数 | 104 | 108 |
17
+ | 代码总行数 | 28,878 | 30,846 |
18
+ | 可维护性指数 | 全部为 100 | 实际为 0 (极低) |
19
+ | GitAnalyzer 搜索 | 遗漏 | **已找到** (报告错误) |
20
+
21
+ ### 仍有效的发现
22
+
23
+ - ✅ 性能问题:比 rg 慢约 90 倍
24
+ - ✅ re-export 依赖遗漏
25
+ - ✅ JSON 输出格式不一致
26
+ - ✅ 路径显示 .js 而非 .ts
27
+
28
+ ---
29
+
30
+ ## 后续建议
31
+
32
+ 1. **重新生成报告**:使用更新后的 CodeMap 版本重新测试
33
+ 2. **修正数据**:基于实际运行结果更新数值
34
+ 3. **保留方法论**:P0/P1/P2 问题分类方式仍可参考
35
+ 4. **跟踪修复**:根据报告中的修复计划验证问题是否解决
36
+
37
+ ---
38
+
39
+ *归档操作由 Claude Code 执行*