cap-pro 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (275) hide show
  1. package/.claude-plugin/README.md +26 -0
  2. package/.claude-plugin/marketplace.json +24 -0
  3. package/.claude-plugin/plugin.json +24 -0
  4. package/LICENSE +21 -0
  5. package/README.ja-JP.md +834 -0
  6. package/README.ko-KR.md +823 -0
  7. package/README.md +806 -0
  8. package/README.pt-BR.md +452 -0
  9. package/README.zh-CN.md +800 -0
  10. package/agents/cap-architect.md +269 -0
  11. package/agents/cap-brainstormer.md +207 -0
  12. package/agents/cap-curator.md +276 -0
  13. package/agents/cap-debugger.md +365 -0
  14. package/agents/cap-designer.md +246 -0
  15. package/agents/cap-historian.md +464 -0
  16. package/agents/cap-migrator.md +291 -0
  17. package/agents/cap-prototyper.md +197 -0
  18. package/agents/cap-validator.md +308 -0
  19. package/bin/install.js +5433 -0
  20. package/cap/bin/cap-tools.cjs +853 -0
  21. package/cap/bin/lib/arc-scanner.cjs +344 -0
  22. package/cap/bin/lib/cap-affinity-engine.cjs +862 -0
  23. package/cap/bin/lib/cap-anchor.cjs +228 -0
  24. package/cap/bin/lib/cap-annotation-writer.cjs +340 -0
  25. package/cap/bin/lib/cap-checkpoint.cjs +434 -0
  26. package/cap/bin/lib/cap-cluster-detect.cjs +945 -0
  27. package/cap/bin/lib/cap-cluster-display.cjs +52 -0
  28. package/cap/bin/lib/cap-cluster-format.cjs +245 -0
  29. package/cap/bin/lib/cap-cluster-helpers.cjs +295 -0
  30. package/cap/bin/lib/cap-cluster-io.cjs +212 -0
  31. package/cap/bin/lib/cap-completeness.cjs +540 -0
  32. package/cap/bin/lib/cap-deps.cjs +583 -0
  33. package/cap/bin/lib/cap-design-families.cjs +332 -0
  34. package/cap/bin/lib/cap-design.cjs +966 -0
  35. package/cap/bin/lib/cap-divergence-detector.cjs +400 -0
  36. package/cap/bin/lib/cap-doctor.cjs +752 -0
  37. package/cap/bin/lib/cap-feature-map-internals.cjs +19 -0
  38. package/cap/bin/lib/cap-feature-map-migrate.cjs +335 -0
  39. package/cap/bin/lib/cap-feature-map-monorepo.cjs +885 -0
  40. package/cap/bin/lib/cap-feature-map-shard.cjs +315 -0
  41. package/cap/bin/lib/cap-feature-map.cjs +1943 -0
  42. package/cap/bin/lib/cap-fitness-score.cjs +1075 -0
  43. package/cap/bin/lib/cap-impact-analysis.cjs +652 -0
  44. package/cap/bin/lib/cap-learn-review.cjs +1072 -0
  45. package/cap/bin/lib/cap-learning-signals.cjs +627 -0
  46. package/cap/bin/lib/cap-loader.cjs +227 -0
  47. package/cap/bin/lib/cap-logger.cjs +57 -0
  48. package/cap/bin/lib/cap-memory-bridge.cjs +764 -0
  49. package/cap/bin/lib/cap-memory-confidence.cjs +452 -0
  50. package/cap/bin/lib/cap-memory-dir.cjs +987 -0
  51. package/cap/bin/lib/cap-memory-engine.cjs +698 -0
  52. package/cap/bin/lib/cap-memory-extends.cjs +398 -0
  53. package/cap/bin/lib/cap-memory-graph.cjs +790 -0
  54. package/cap/bin/lib/cap-memory-migrate.cjs +2015 -0
  55. package/cap/bin/lib/cap-memory-pin.cjs +183 -0
  56. package/cap/bin/lib/cap-memory-platform.cjs +490 -0
  57. package/cap/bin/lib/cap-memory-prune.cjs +707 -0
  58. package/cap/bin/lib/cap-memory-schema.cjs +812 -0
  59. package/cap/bin/lib/cap-migrate-tags.cjs +309 -0
  60. package/cap/bin/lib/cap-migrate.cjs +540 -0
  61. package/cap/bin/lib/cap-pattern-apply.cjs +1203 -0
  62. package/cap/bin/lib/cap-pattern-pipeline.cjs +1034 -0
  63. package/cap/bin/lib/cap-plugin-manifest.cjs +80 -0
  64. package/cap/bin/lib/cap-realtime-affinity.cjs +399 -0
  65. package/cap/bin/lib/cap-reconcile.cjs +570 -0
  66. package/cap/bin/lib/cap-research-gate.cjs +218 -0
  67. package/cap/bin/lib/cap-scope-filter.cjs +402 -0
  68. package/cap/bin/lib/cap-semantic-pipeline.cjs +1038 -0
  69. package/cap/bin/lib/cap-session-extract.cjs +987 -0
  70. package/cap/bin/lib/cap-session.cjs +445 -0
  71. package/cap/bin/lib/cap-snapshot-linkage.cjs +963 -0
  72. package/cap/bin/lib/cap-stack-docs.cjs +646 -0
  73. package/cap/bin/lib/cap-tag-observer.cjs +371 -0
  74. package/cap/bin/lib/cap-tag-scanner.cjs +1766 -0
  75. package/cap/bin/lib/cap-telemetry.cjs +466 -0
  76. package/cap/bin/lib/cap-test-audit.cjs +1438 -0
  77. package/cap/bin/lib/cap-thread-migrator.cjs +307 -0
  78. package/cap/bin/lib/cap-thread-synthesis.cjs +545 -0
  79. package/cap/bin/lib/cap-thread-tracker.cjs +519 -0
  80. package/cap/bin/lib/cap-trace.cjs +399 -0
  81. package/cap/bin/lib/cap-trust-mode.cjs +336 -0
  82. package/cap/bin/lib/cap-ui-design-editor.cjs +642 -0
  83. package/cap/bin/lib/cap-ui-mind-map.cjs +712 -0
  84. package/cap/bin/lib/cap-ui-thread-nav.cjs +693 -0
  85. package/cap/bin/lib/cap-ui.cjs +1245 -0
  86. package/cap/bin/lib/cap-upgrade.cjs +1028 -0
  87. package/cap/bin/lib/cli/arg-helpers.cjs +49 -0
  88. package/cap/bin/lib/cli/frontmatter-router.cjs +31 -0
  89. package/cap/bin/lib/cli/init-router.cjs +68 -0
  90. package/cap/bin/lib/cli/phase-router.cjs +102 -0
  91. package/cap/bin/lib/cli/state-router.cjs +61 -0
  92. package/cap/bin/lib/cli/template-router.cjs +37 -0
  93. package/cap/bin/lib/cli/uat-router.cjs +29 -0
  94. package/cap/bin/lib/cli/validation-router.cjs +26 -0
  95. package/cap/bin/lib/cli/verification-router.cjs +31 -0
  96. package/cap/bin/lib/cli/workstream-router.cjs +39 -0
  97. package/cap/bin/lib/commands.cjs +961 -0
  98. package/cap/bin/lib/config.cjs +467 -0
  99. package/cap/bin/lib/convention-reader.cjs +258 -0
  100. package/cap/bin/lib/core.cjs +1241 -0
  101. package/cap/bin/lib/feature-aggregator.cjs +423 -0
  102. package/cap/bin/lib/frontmatter.cjs +337 -0
  103. package/cap/bin/lib/init.cjs +1443 -0
  104. package/cap/bin/lib/manifest-generator.cjs +383 -0
  105. package/cap/bin/lib/milestone.cjs +253 -0
  106. package/cap/bin/lib/model-profiles.cjs +69 -0
  107. package/cap/bin/lib/monorepo-context.cjs +226 -0
  108. package/cap/bin/lib/monorepo-migrator.cjs +509 -0
  109. package/cap/bin/lib/phase.cjs +889 -0
  110. package/cap/bin/lib/profile-output.cjs +989 -0
  111. package/cap/bin/lib/profile-pipeline.cjs +540 -0
  112. package/cap/bin/lib/roadmap.cjs +330 -0
  113. package/cap/bin/lib/security.cjs +394 -0
  114. package/cap/bin/lib/session-manager.cjs +292 -0
  115. package/cap/bin/lib/skeleton-generator.cjs +179 -0
  116. package/cap/bin/lib/state.cjs +1032 -0
  117. package/cap/bin/lib/template.cjs +231 -0
  118. package/cap/bin/lib/test-detector.cjs +62 -0
  119. package/cap/bin/lib/uat.cjs +283 -0
  120. package/cap/bin/lib/verify.cjs +889 -0
  121. package/cap/bin/lib/workspace-detector.cjs +371 -0
  122. package/cap/bin/lib/workstream.cjs +492 -0
  123. package/cap/commands/gsd/workstreams.md +63 -0
  124. package/cap/references/arc-standard.md +315 -0
  125. package/cap/references/cap-agent-architecture.md +101 -0
  126. package/cap/references/cap-gitignore-template +9 -0
  127. package/cap/references/cap-zero-deps.md +158 -0
  128. package/cap/references/checkpoints.md +778 -0
  129. package/cap/references/continuation-format.md +249 -0
  130. package/cap/references/contract-test-templates.md +312 -0
  131. package/cap/references/feature-map-template.md +25 -0
  132. package/cap/references/git-integration.md +295 -0
  133. package/cap/references/git-planning-commit.md +38 -0
  134. package/cap/references/model-profiles.md +174 -0
  135. package/cap/references/phase-numbering.md +126 -0
  136. package/cap/references/planning-config.md +202 -0
  137. package/cap/references/property-test-templates.md +316 -0
  138. package/cap/references/security-test-templates.md +347 -0
  139. package/cap/references/session-template.json +8 -0
  140. package/cap/references/tdd.md +263 -0
  141. package/cap/references/user-profiling.md +681 -0
  142. package/cap/references/verification-patterns.md +612 -0
  143. package/cap/templates/UAT.md +265 -0
  144. package/cap/templates/claude-md.md +175 -0
  145. package/cap/templates/codebase/architecture.md +255 -0
  146. package/cap/templates/codebase/concerns.md +310 -0
  147. package/cap/templates/codebase/conventions.md +307 -0
  148. package/cap/templates/codebase/integrations.md +280 -0
  149. package/cap/templates/codebase/stack.md +186 -0
  150. package/cap/templates/codebase/structure.md +285 -0
  151. package/cap/templates/codebase/testing.md +480 -0
  152. package/cap/templates/config.json +44 -0
  153. package/cap/templates/context.md +352 -0
  154. package/cap/templates/continue-here.md +78 -0
  155. package/cap/templates/copilot-instructions.md +7 -0
  156. package/cap/templates/debug-subagent-prompt.md +91 -0
  157. package/cap/templates/discussion-log.md +63 -0
  158. package/cap/templates/milestone-archive.md +123 -0
  159. package/cap/templates/milestone.md +115 -0
  160. package/cap/templates/phase-prompt.md +610 -0
  161. package/cap/templates/planner-subagent-prompt.md +117 -0
  162. package/cap/templates/project.md +186 -0
  163. package/cap/templates/requirements.md +231 -0
  164. package/cap/templates/research-project/ARCHITECTURE.md +204 -0
  165. package/cap/templates/research-project/FEATURES.md +147 -0
  166. package/cap/templates/research-project/PITFALLS.md +200 -0
  167. package/cap/templates/research-project/STACK.md +120 -0
  168. package/cap/templates/research-project/SUMMARY.md +170 -0
  169. package/cap/templates/research.md +552 -0
  170. package/cap/templates/roadmap.md +202 -0
  171. package/cap/templates/state.md +176 -0
  172. package/cap/templates/summary.md +364 -0
  173. package/cap/templates/user-preferences.md +498 -0
  174. package/cap/templates/verification-report.md +322 -0
  175. package/cap/workflows/add-phase.md +112 -0
  176. package/cap/workflows/add-tests.md +351 -0
  177. package/cap/workflows/add-todo.md +158 -0
  178. package/cap/workflows/audit-milestone.md +340 -0
  179. package/cap/workflows/audit-uat.md +109 -0
  180. package/cap/workflows/autonomous.md +891 -0
  181. package/cap/workflows/check-todos.md +177 -0
  182. package/cap/workflows/cleanup.md +152 -0
  183. package/cap/workflows/complete-milestone.md +767 -0
  184. package/cap/workflows/diagnose-issues.md +231 -0
  185. package/cap/workflows/discovery-phase.md +289 -0
  186. package/cap/workflows/discuss-phase-assumptions.md +653 -0
  187. package/cap/workflows/discuss-phase.md +1049 -0
  188. package/cap/workflows/do.md +104 -0
  189. package/cap/workflows/execute-phase.md +846 -0
  190. package/cap/workflows/execute-plan.md +514 -0
  191. package/cap/workflows/fast.md +105 -0
  192. package/cap/workflows/forensics.md +265 -0
  193. package/cap/workflows/health.md +181 -0
  194. package/cap/workflows/help.md +660 -0
  195. package/cap/workflows/insert-phase.md +130 -0
  196. package/cap/workflows/list-phase-assumptions.md +178 -0
  197. package/cap/workflows/list-workspaces.md +56 -0
  198. package/cap/workflows/manager.md +362 -0
  199. package/cap/workflows/map-codebase.md +377 -0
  200. package/cap/workflows/milestone-summary.md +223 -0
  201. package/cap/workflows/new-milestone.md +486 -0
  202. package/cap/workflows/new-project.md +1250 -0
  203. package/cap/workflows/new-workspace.md +237 -0
  204. package/cap/workflows/next.md +97 -0
  205. package/cap/workflows/node-repair.md +92 -0
  206. package/cap/workflows/note.md +156 -0
  207. package/cap/workflows/pause-work.md +176 -0
  208. package/cap/workflows/plan-milestone-gaps.md +273 -0
  209. package/cap/workflows/plan-phase.md +857 -0
  210. package/cap/workflows/plant-seed.md +169 -0
  211. package/cap/workflows/pr-branch.md +129 -0
  212. package/cap/workflows/profile-user.md +449 -0
  213. package/cap/workflows/progress.md +507 -0
  214. package/cap/workflows/quick.md +757 -0
  215. package/cap/workflows/remove-phase.md +155 -0
  216. package/cap/workflows/remove-workspace.md +90 -0
  217. package/cap/workflows/research-phase.md +82 -0
  218. package/cap/workflows/resume-project.md +326 -0
  219. package/cap/workflows/review.md +228 -0
  220. package/cap/workflows/session-report.md +146 -0
  221. package/cap/workflows/settings.md +283 -0
  222. package/cap/workflows/ship.md +228 -0
  223. package/cap/workflows/stats.md +60 -0
  224. package/cap/workflows/transition.md +671 -0
  225. package/cap/workflows/ui-phase.md +298 -0
  226. package/cap/workflows/ui-review.md +161 -0
  227. package/cap/workflows/update.md +323 -0
  228. package/cap/workflows/validate-phase.md +170 -0
  229. package/cap/workflows/verify-phase.md +254 -0
  230. package/cap/workflows/verify-work.md +637 -0
  231. package/commands/cap/annotate.md +165 -0
  232. package/commands/cap/brainstorm.md +393 -0
  233. package/commands/cap/checkpoint.md +106 -0
  234. package/commands/cap/completeness.md +94 -0
  235. package/commands/cap/continue.md +72 -0
  236. package/commands/cap/debug.md +588 -0
  237. package/commands/cap/deps.md +169 -0
  238. package/commands/cap/design.md +479 -0
  239. package/commands/cap/init.md +354 -0
  240. package/commands/cap/iterate.md +249 -0
  241. package/commands/cap/learn.md +459 -0
  242. package/commands/cap/memory.md +275 -0
  243. package/commands/cap/migrate-feature-map.md +91 -0
  244. package/commands/cap/migrate-memory.md +108 -0
  245. package/commands/cap/migrate-tags.md +91 -0
  246. package/commands/cap/migrate.md +131 -0
  247. package/commands/cap/prototype.md +510 -0
  248. package/commands/cap/reconcile.md +121 -0
  249. package/commands/cap/review.md +360 -0
  250. package/commands/cap/save.md +72 -0
  251. package/commands/cap/scan.md +404 -0
  252. package/commands/cap/start.md +356 -0
  253. package/commands/cap/status.md +118 -0
  254. package/commands/cap/test-audit.md +262 -0
  255. package/commands/cap/test.md +394 -0
  256. package/commands/cap/trace.md +133 -0
  257. package/commands/cap/ui.md +167 -0
  258. package/hooks/dist/cap-check-update.js +115 -0
  259. package/hooks/dist/cap-context-monitor.js +185 -0
  260. package/hooks/dist/cap-learn-review-hook.js +114 -0
  261. package/hooks/dist/cap-learning-hook.js +192 -0
  262. package/hooks/dist/cap-memory.js +299 -0
  263. package/hooks/dist/cap-prompt-guard.js +97 -0
  264. package/hooks/dist/cap-statusline.js +157 -0
  265. package/hooks/dist/cap-tag-observer.js +115 -0
  266. package/hooks/dist/cap-version-check.js +112 -0
  267. package/hooks/dist/cap-workflow-guard.js +175 -0
  268. package/hooks/hooks.json +55 -0
  269. package/package.json +58 -0
  270. package/scripts/base64-scan.sh +262 -0
  271. package/scripts/build-hooks.js +93 -0
  272. package/scripts/cap-removal-checklist.md +202 -0
  273. package/scripts/prompt-injection-scan.sh +199 -0
  274. package/scripts/run-tests.cjs +181 -0
  275. package/scripts/secret-scan.sh +227 -0
@@ -0,0 +1,449 @@
1
+ <purpose>
2
+ Orchestrate the full developer profiling flow: consent, session analysis (or questionnaire fallback), profile generation, result display, and artifact creation.
3
+
4
+ This workflow wires Phase 1 (session pipeline) and Phase 2 (profiling engine) into a cohesive user-facing experience. All heavy lifting is done by existing cap-tools.cjs subcommands and the gsd-user-profiler agent -- this workflow orchestrates the sequence, handles branching, and provides the UX.
5
+ </purpose>
6
+
7
+ <required_reading>
8
+ Read all files referenced by the invoking prompt's execution_context before starting.
9
+
10
+ Key references:
11
+ - @$HOME/.claude/cap/agents/gsd-user-profiler.md (profiler agent definition)
12
+ - @$HOME/.claude/cap/references/user-profiling.md (profiling reference doc)
13
+ </required_reading>
14
+
15
+ <process>
16
+
17
+ ## 1. Initialize
18
+
19
+ Parse flags from $ARGUMENTS:
20
+ - Detect `--questionnaire` flag (skip session analysis, questionnaire-only)
21
+ - Detect `--refresh` flag (rebuild profile even when one exists)
22
+
23
+ Check for existing profile:
24
+
25
+ ```bash
26
+ PROFILE_PATH="$HOME/.claude/cap/USER-PROFILE.md"
27
+ [ -f "$PROFILE_PATH" ] && echo "EXISTS" || echo "NOT_FOUND"
28
+ ```
29
+
30
+ **If profile exists AND --refresh NOT set AND --questionnaire NOT set:**
31
+
32
+ Use AskUserQuestion:
33
+ - header: "Existing Profile"
34
+ - question: "You already have a profile. What would you like to do?"
35
+ - options:
36
+ - "View it" -- Display summary card from existing profile data, then exit
37
+ - "Refresh it" -- Continue with --refresh behavior
38
+ - "Cancel" -- Exit workflow
39
+
40
+ If "View it": Read USER-PROFILE.md, display its content formatted as a summary card, then exit.
41
+ If "Refresh it": Set --refresh behavior and continue.
42
+ If "Cancel": Display "No changes made." and exit.
43
+
44
+ **If profile exists AND --refresh IS set:**
45
+
46
+ Backup existing profile:
47
+ ```bash
48
+ cp "$HOME/.claude/cap/USER-PROFILE.md" "$HOME/.claude/cap/USER-PROFILE.backup.md"
49
+ ```
50
+
51
+ Display: "Re-analyzing your sessions to update your profile."
52
+ Continue to step 2.
53
+
54
+ **If no profile exists:** Continue to step 2.
55
+
56
+ ---
57
+
58
+ ## 2. Consent Gate (ACTV-06)
59
+
60
+ **Skip if** `--questionnaire` flag is set (no JSONL reading occurs -- jump directly to step 4b).
61
+
62
+ Display consent screen:
63
+
64
+ ```
65
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
66
+ GSD > PROFILE YOUR CODING STYLE
67
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
68
+
69
+ Claude starts every conversation generic. A profile teaches Claude
70
+ how YOU actually work -- not how you think you work.
71
+
72
+ ## What We'll Analyze
73
+
74
+ Your recent Claude Code sessions, looking for patterns in these
75
+ 8 behavioral dimensions:
76
+
77
+ | Dimension | What It Measures |
78
+ |----------------------|---------------------------------------------|
79
+ | Communication Style | How you phrase requests (terse vs. detailed) |
80
+ | Decision Speed | How you choose between options |
81
+ | Explanation Depth | How much explanation you want with code |
82
+ | Debugging Approach | How you tackle errors and bugs |
83
+ | UX Philosophy | How much you care about design vs. function |
84
+ | Vendor Philosophy | How you evaluate libraries and tools |
85
+ | Frustration Triggers | What makes you correct Claude |
86
+ | Learning Style | How you prefer to learn new things |
87
+
88
+ ## Data Handling
89
+
90
+ ✓ Reads session files locally (read-only, nothing modified)
91
+ ✓ Analyzes message patterns (not content meaning)
92
+ ✓ Stores profile at $HOME/.claude/cap/USER-PROFILE.md
93
+ ✗ Nothing is sent to external services
94
+ ✗ Sensitive content (API keys, passwords) is automatically excluded
95
+ ```
96
+
97
+ **If --refresh path:**
98
+ Show abbreviated consent instead:
99
+
100
+ ```
101
+ Re-analyzing your sessions to update your profile.
102
+ Your existing profile has been backed up to USER-PROFILE.backup.md.
103
+ ```
104
+
105
+ Use AskUserQuestion:
106
+ - header: "Refresh"
107
+ - question: "Continue with profile refresh?"
108
+ - options:
109
+ - "Continue" -- Proceed to step 3
110
+ - "Cancel" -- Exit workflow
111
+
112
+ **If default (no --refresh) path:**
113
+
114
+ Use AskUserQuestion:
115
+ - header: "Ready?"
116
+ - question: "Ready to analyze your sessions?"
117
+ - options:
118
+ - "Let's go" -- Proceed to step 3 (session analysis)
119
+ - "Use questionnaire instead" -- Jump to step 4b (questionnaire path)
120
+ - "Not now" -- Display "No worries. Run /gsd:profile-user when ready." and exit
121
+
122
+ ---
123
+
124
+ ## 3. Session Scan
125
+
126
+ Display: "◆ Scanning sessions..."
127
+
128
+ Run session scan:
129
+ ```bash
130
+ SCAN_RESULT=$(node $HOME/.claude/cap/bin/cap-tools.cjs scan-sessions --json 2>/dev/null)
131
+ ```
132
+
133
+ Parse the JSON output to get session count and project count.
134
+
135
+ Display: "✓ Found N sessions across M projects"
136
+
137
+ **Determine data sufficiency:**
138
+ - Count total messages available from the scan result (sum sessions across projects)
139
+ - If 0 sessions found: Display "No sessions found. Switching to questionnaire." and jump to step 4b
140
+ - If sessions found: Continue to step 4a
141
+
142
+ ---
143
+
144
+ ## 4a. Session Analysis Path
145
+
146
+ Display: "◆ Sampling messages..."
147
+
148
+ Run profile sampling:
149
+ ```bash
150
+ SAMPLE_RESULT=$(node $HOME/.claude/cap/bin/cap-tools.cjs profile-sample --json 2>/dev/null)
151
+ ```
152
+
153
+ Parse the JSON output to get the temp directory path and message count.
154
+
155
+ Display: "✓ Sampled N messages from M projects"
156
+
157
+ Display: "◆ Analyzing patterns..."
158
+
159
+ **Spawn gsd-user-profiler agent using Task tool:**
160
+
161
+ Use the Task tool to spawn the `gsd-user-profiler` agent. Provide it with:
162
+ - The sampled JSONL file path from profile-sample output
163
+ - The user-profiling reference doc at `$HOME/.claude/cap/references/user-profiling.md`
164
+
165
+ The agent prompt should follow this structure:
166
+ ```
167
+ Read the profiling reference document and the sampled session messages, then analyze the developer's behavioral patterns across all 8 dimensions.
168
+
169
+ Reference: @$HOME/.claude/cap/references/user-profiling.md
170
+ Session data: @{temp_dir}/profile-sample.jsonl
171
+
172
+ Analyze these messages and return your analysis in the <analysis> JSON format specified in the reference document.
173
+ ```
174
+
175
+ **Parse the agent's output:**
176
+ - Extract the `<analysis>` JSON block from the agent's response
177
+ - Save analysis JSON to a temp file (in the same temp directory created by profile-sample)
178
+
179
+ ```bash
180
+ ANALYSIS_PATH="{temp_dir}/analysis.json"
181
+ ```
182
+
183
+ Write the analysis JSON to `$ANALYSIS_PATH`.
184
+
185
+ Display: "✓ Analysis complete (N dimensions scored)"
186
+
187
+ **Check for thin data:**
188
+ - Read the analysis JSON and check the total message count
189
+ - If < 50 messages were analyzed: Note that a questionnaire supplement could improve accuracy. Display: "Note: Limited session data (N messages). Results may have lower confidence."
190
+
191
+ Continue to step 5.
192
+
193
+ ---
194
+
195
+ ## 4b. Questionnaire Path
196
+
197
+ Display: "Using questionnaire to build your profile."
198
+
199
+ **Get questions:**
200
+ ```bash
201
+ QUESTIONS=$(node $HOME/.claude/cap/bin/cap-tools.cjs profile-questionnaire --json 2>/dev/null)
202
+ ```
203
+
204
+ Parse the questions JSON. It contains 8 questions, one per dimension.
205
+
206
+ **Present each question to the user via AskUserQuestion:**
207
+
208
+ For each question in the questions array:
209
+ - header: The dimension name (e.g., "Communication Style")
210
+ - question: The question text
211
+ - options: The answer options from the question definition
212
+
213
+ Collect all answers into an answers JSON object mapping dimension keys to selected answer values.
214
+
215
+ **Save answers to temp file:**
216
+ ```bash
217
+ ANSWERS_PATH=$(mktemp /tmp/gsd-profile-answers-XXXXXX.json)
218
+ ```
219
+
220
+ Write the answers JSON to `$ANSWERS_PATH`.
221
+
222
+ **Convert answers to analysis:**
223
+ ```bash
224
+ ANALYSIS_RESULT=$(node $HOME/.claude/cap/bin/cap-tools.cjs profile-questionnaire --answers "$ANSWERS_PATH" --json 2>/dev/null)
225
+ ```
226
+
227
+ Parse the analysis JSON from the result.
228
+
229
+ Save analysis JSON to a temp file:
230
+ ```bash
231
+ ANALYSIS_PATH=$(mktemp /tmp/gsd-profile-analysis-XXXXXX.json)
232
+ ```
233
+
234
+ Write the analysis JSON to `$ANALYSIS_PATH`.
235
+
236
+ Continue to step 5 (skip split resolution since questionnaire handles ambiguity internally).
237
+
238
+ ---
239
+
240
+ ## 5. Split Resolution
241
+
242
+ **Skip if** questionnaire-only path (splits already handled internally).
243
+
244
+ Read the analysis JSON from `$ANALYSIS_PATH`.
245
+
246
+ Check each dimension for `cross_project_consistent: false`.
247
+
248
+ **For each split detected:**
249
+
250
+ Use AskUserQuestion:
251
+ - header: The dimension name (e.g., "Communication Style")
252
+ - question: "Your sessions show different patterns:" followed by the split context (e.g., "CLI/backend projects -> terse-direct, Frontend/UI projects -> detailed-structured")
253
+ - options:
254
+ - Rating option A (e.g., "terse-direct")
255
+ - Rating option B (e.g., "detailed-structured")
256
+ - "Context-dependent (keep both)"
257
+
258
+ **If user picks a specific rating:** Update the dimension's `rating` field in the analysis JSON to the selected value.
259
+
260
+ **If user picks "Context-dependent":** Keep the dominant rating in the `rating` field. Add a `context_note` to the dimension's summary describing the split (e.g., "Context-dependent: terse in CLI projects, detailed in frontend projects").
261
+
262
+ Write updated analysis JSON back to `$ANALYSIS_PATH`.
263
+
264
+ ---
265
+
266
+ ## 6. Profile Write
267
+
268
+ Display: "◆ Writing profile..."
269
+
270
+ ```bash
271
+ node $HOME/.claude/cap/bin/cap-tools.cjs write-profile --input "$ANALYSIS_PATH" --json 2>/dev/null
272
+ ```
273
+
274
+ Display: "✓ Profile written to $HOME/.claude/cap/USER-PROFILE.md"
275
+
276
+ ---
277
+
278
+ ## 7. Result Display
279
+
280
+ Read the analysis JSON from `$ANALYSIS_PATH` to build the display.
281
+
282
+ **Show report card table:**
283
+
284
+ ```
285
+ ## Your Profile
286
+
287
+ | Dimension | Rating | Confidence |
288
+ |----------------------|----------------------|------------|
289
+ | Communication Style | detailed-structured | HIGH |
290
+ | Decision Speed | deliberate-informed | MEDIUM |
291
+ | Explanation Depth | concise | HIGH |
292
+ | Debugging Approach | hypothesis-driven | MEDIUM |
293
+ | UX Philosophy | pragmatic | LOW |
294
+ | Vendor Philosophy | thorough-evaluator | HIGH |
295
+ | Frustration Triggers | scope-creep | MEDIUM |
296
+ | Learning Style | self-directed | HIGH |
297
+ ```
298
+
299
+ (Populate with actual values from the analysis JSON.)
300
+
301
+ **Show highlight reel:**
302
+
303
+ Pick 3-4 dimensions with the highest confidence and most evidence signals. Format as:
304
+
305
+ ```
306
+ ## Highlights
307
+
308
+ - **Communication (HIGH):** You consistently provide structured context with
309
+ headers and problem statements before making requests
310
+ - **Vendor Choices (HIGH):** You research alternatives thoroughly -- comparing
311
+ docs, GitHub activity, and bundle sizes before committing
312
+ - **Frustrations (MEDIUM):** You correct Claude most often for doing things
313
+ you didn't ask for -- scope creep is your primary trigger
314
+ ```
315
+
316
+ Build highlights from the `evidence` array and `summary` fields in the analysis JSON. Use the most compelling evidence quotes. Format each as "You tend to..." or "You consistently..." with evidence attribution.
317
+
318
+ **Offer full profile view:**
319
+
320
+ Use AskUserQuestion:
321
+ - header: "Profile"
322
+ - question: "Want to see the full profile?"
323
+ - options:
324
+ - "Yes" -- Read and display the full USER-PROFILE.md content, then continue to step 8
325
+ - "Continue to artifacts" -- Proceed directly to step 8
326
+
327
+ ---
328
+
329
+ ## 8. Artifact Selection (ACTV-05)
330
+
331
+ Use AskUserQuestion with multiSelect:
332
+ - header: "Artifacts"
333
+ - question: "Which artifacts should I generate?"
334
+ - options (ALL pre-selected by default):
335
+ - "/gsd:dev-preferences command file" -- "Load your preferences in any session"
336
+ - "CLAUDE.md profile section" -- "Add profile to this project's CLAUDE.md"
337
+ - "Global CLAUDE.md" -- "Add profile to $HOME/.claude/CLAUDE.md for all projects"
338
+
339
+ **If no artifacts selected:** Display "No artifacts generated. Your profile is saved at $HOME/.claude/cap/USER-PROFILE.md" and jump to step 10.
340
+
341
+ ---
342
+
343
+ ## 9. Artifact Generation
344
+
345
+ Generate selected artifacts sequentially (file I/O is fast, no benefit from parallel agents):
346
+
347
+ **For /gsd:dev-preferences (if selected):**
348
+
349
+ ```bash
350
+ node $HOME/.claude/cap/bin/cap-tools.cjs generate-dev-preferences --analysis "$ANALYSIS_PATH" --json 2>/dev/null
351
+ ```
352
+
353
+ Display: "✓ Generated /gsd:dev-preferences at $HOME/.claude/commands/gsd/dev-preferences.md"
354
+
355
+ **For CLAUDE.md profile section (if selected):**
356
+
357
+ ```bash
358
+ node $HOME/.claude/cap/bin/cap-tools.cjs generate-claude-profile --analysis "$ANALYSIS_PATH" --json 2>/dev/null
359
+ ```
360
+
361
+ Display: "✓ Added profile section to CLAUDE.md"
362
+
363
+ **For Global CLAUDE.md (if selected):**
364
+
365
+ ```bash
366
+ node $HOME/.claude/cap/bin/cap-tools.cjs generate-claude-profile --analysis "$ANALYSIS_PATH" --global --json 2>/dev/null
367
+ ```
368
+
369
+ Display: "✓ Added profile section to $HOME/.claude/CLAUDE.md"
370
+
371
+ **Error handling:** If any cap-tools.cjs call fails, display the error message and use AskUserQuestion to offer "Retry" or "Skip this artifact". On retry, re-run the command. On skip, continue to next artifact.
372
+
373
+ ---
374
+
375
+ ## 10. Summary & Refresh Diff
376
+
377
+ **If --refresh path:**
378
+
379
+ Read both old backup and new analysis to compare dimension ratings/confidence.
380
+
381
+ Read the backed-up profile:
382
+ ```bash
383
+ BACKUP_PATH="$HOME/.claude/cap/USER-PROFILE.backup.md"
384
+ ```
385
+
386
+ Compare each dimension's rating and confidence between old and new. Display diff table showing only changed dimensions:
387
+
388
+ ```
389
+ ## Changes
390
+
391
+ | Dimension | Before | After |
392
+ |-----------------|-----------------------------|-----------------------------|
393
+ | Communication | terse-direct (LOW) | detailed-structured (HIGH) |
394
+ | Debugging | fix-first (MEDIUM) | hypothesis-driven (MEDIUM) |
395
+ ```
396
+
397
+ If nothing changed: Display "No changes detected -- your profile is already up to date."
398
+
399
+ **Display final summary:**
400
+
401
+ ```
402
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
403
+ GSD > PROFILE COMPLETE ✓
404
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
405
+
406
+ Your profile: $HOME/.claude/cap/USER-PROFILE.md
407
+ ```
408
+
409
+ Then list paths for each generated artifact:
410
+ ```
411
+ Artifacts:
412
+ ✓ /gsd:dev-preferences $HOME/.claude/commands/gsd/dev-preferences.md
413
+ ✓ CLAUDE.md section ./CLAUDE.md
414
+ ✓ Global CLAUDE.md $HOME/.claude/CLAUDE.md
415
+ ```
416
+
417
+ (Only show artifacts that were actually generated.)
418
+
419
+ **Clean up temp files:**
420
+
421
+ Remove the temp directory created by profile-sample (contains sample JSONL and analysis JSON):
422
+ ```bash
423
+ rm -rf "$TEMP_DIR"
424
+ ```
425
+
426
+ Also remove any standalone temp files created for questionnaire answers:
427
+ ```bash
428
+ rm -f "$ANSWERS_PATH" 2>/dev/null
429
+ rm -f "$ANALYSIS_PATH" 2>/dev/null
430
+ ```
431
+
432
+ (Only clean up temp paths that were actually created during this workflow run.)
433
+
434
+ </process>
435
+
436
+ <success_criteria>
437
+ - [ ] Initialization detects existing profile and handles all three responses (view/refresh/cancel)
438
+ - [ ] Consent gate shown for session analysis path, skipped for questionnaire path
439
+ - [ ] Session scan discovers sessions and reports statistics
440
+ - [ ] Session analysis path: samples messages, spawns profiler agent, extracts analysis JSON
441
+ - [ ] Questionnaire path: presents 8 questions, collects answers, converts to analysis JSON
442
+ - [ ] Split resolution presents context-dependent splits with user resolution options
443
+ - [ ] Profile written to USER-PROFILE.md via write-profile subcommand
444
+ - [ ] Result display shows report card table and highlight reel with evidence
445
+ - [ ] Artifact selection uses multiSelect with all options pre-selected
446
+ - [ ] Artifacts generated sequentially via cap-tools.cjs subcommands
447
+ - [ ] Refresh diff shows changed dimensions when --refresh was used
448
+ - [ ] Temp files cleaned up on completion
449
+ </success_criteria>