@bradygaster/squad-cli 0.8.25 → 0.9.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (199) hide show
  1. package/README.md +329 -77
  2. package/dist/cli/commands/aspire.d.ts.map +1 -1
  3. package/dist/cli/commands/aspire.js +3 -0
  4. package/dist/cli/commands/aspire.js.map +1 -1
  5. package/dist/cli/commands/build.js +3 -3
  6. package/dist/cli/commands/build.js.map +1 -1
  7. package/dist/cli/commands/cast.d.ts +13 -0
  8. package/dist/cli/commands/cast.d.ts.map +1 -0
  9. package/dist/cli/commands/cast.js +77 -0
  10. package/dist/cli/commands/cast.js.map +1 -0
  11. package/dist/cli/commands/cost.d.ts +2 -0
  12. package/dist/cli/commands/cost.d.ts.map +1 -0
  13. package/dist/cli/commands/cost.js +170 -0
  14. package/dist/cli/commands/cost.js.map +1 -0
  15. package/dist/cli/commands/cross-squad.d.ts +12 -0
  16. package/dist/cli/commands/cross-squad.d.ts.map +1 -0
  17. package/dist/cli/commands/cross-squad.js +80 -0
  18. package/dist/cli/commands/cross-squad.js.map +1 -0
  19. package/dist/cli/commands/doctor.d.ts +5 -0
  20. package/dist/cli/commands/doctor.d.ts.map +1 -1
  21. package/dist/cli/commands/doctor.js +156 -0
  22. package/dist/cli/commands/doctor.js.map +1 -1
  23. package/dist/cli/commands/economy.d.ts +10 -0
  24. package/dist/cli/commands/economy.d.ts.map +1 -0
  25. package/dist/cli/commands/economy.js +64 -0
  26. package/dist/cli/commands/economy.js.map +1 -0
  27. package/dist/cli/commands/export.d.ts.map +1 -1
  28. package/dist/cli/commands/export.js +11 -4
  29. package/dist/cli/commands/export.js.map +1 -1
  30. package/dist/cli/commands/import.js +2 -2
  31. package/dist/cli/commands/import.js.map +1 -1
  32. package/dist/cli/commands/personal.d.ts +16 -0
  33. package/dist/cli/commands/personal.d.ts.map +1 -0
  34. package/dist/cli/commands/personal.js +213 -0
  35. package/dist/cli/commands/personal.js.map +1 -0
  36. package/dist/cli/commands/roles.d.ts +2 -0
  37. package/dist/cli/commands/roles.d.ts.map +1 -0
  38. package/dist/cli/commands/roles.js +54 -0
  39. package/dist/cli/commands/roles.js.map +1 -0
  40. package/dist/cli/commands/schedule.d.ts +14 -0
  41. package/dist/cli/commands/schedule.d.ts.map +1 -0
  42. package/dist/cli/commands/schedule.js +208 -0
  43. package/dist/cli/commands/schedule.js.map +1 -0
  44. package/dist/cli/commands/watch.d.ts.map +1 -1
  45. package/dist/cli/commands/watch.js +17 -5
  46. package/dist/cli/commands/watch.js.map +1 -1
  47. package/dist/cli/core/cast.d.ts +9 -0
  48. package/dist/cli/core/cast.d.ts.map +1 -1
  49. package/dist/cli/core/cast.js +170 -60
  50. package/dist/cli/core/cast.js.map +1 -1
  51. package/dist/cli/core/detect-squad-dir.d.ts +10 -0
  52. package/dist/cli/core/detect-squad-dir.d.ts.map +1 -1
  53. package/dist/cli/core/detect-squad-dir.js +47 -0
  54. package/dist/cli/core/detect-squad-dir.js.map +1 -1
  55. package/dist/cli/core/init.d.ts +8 -0
  56. package/dist/cli/core/init.d.ts.map +1 -1
  57. package/dist/cli/core/init.js +115 -2
  58. package/dist/cli/core/init.js.map +1 -1
  59. package/dist/cli/core/migrations.d.ts.map +1 -1
  60. package/dist/cli/core/migrations.js +21 -0
  61. package/dist/cli/core/migrations.js.map +1 -1
  62. package/dist/cli/core/team-md.js +34 -34
  63. package/dist/cli/core/templates.d.ts.map +1 -1
  64. package/dist/cli/core/templates.js +8 -1
  65. package/dist/cli/core/templates.js.map +1 -1
  66. package/dist/cli/core/upgrade.d.ts +14 -0
  67. package/dist/cli/core/upgrade.d.ts.map +1 -1
  68. package/dist/cli/core/upgrade.js +182 -48
  69. package/dist/cli/core/upgrade.js.map +1 -1
  70. package/dist/cli/core/version.js +2 -2
  71. package/dist/cli/core/version.js.map +1 -1
  72. package/dist/cli/index.d.ts +2 -0
  73. package/dist/cli/index.d.ts.map +1 -1
  74. package/dist/cli/index.js +2 -0
  75. package/dist/cli/index.js.map +1 -1
  76. package/dist/cli/self-update.d.ts +21 -0
  77. package/dist/cli/self-update.d.ts.map +1 -0
  78. package/dist/cli/self-update.js +113 -0
  79. package/dist/cli/self-update.js.map +1 -0
  80. package/dist/cli/shell/autocomplete.d.ts.map +1 -1
  81. package/dist/cli/shell/autocomplete.js +5 -0
  82. package/dist/cli/shell/autocomplete.js.map +1 -1
  83. package/dist/cli/shell/commands.d.ts.map +1 -1
  84. package/dist/cli/shell/commands.js +55 -24
  85. package/dist/cli/shell/commands.js.map +1 -1
  86. package/dist/cli/shell/components/AgentPanel.d.ts.map +1 -1
  87. package/dist/cli/shell/components/AgentPanel.js +21 -6
  88. package/dist/cli/shell/components/AgentPanel.js.map +1 -1
  89. package/dist/cli/shell/components/App.d.ts.map +1 -1
  90. package/dist/cli/shell/components/App.js +33 -15
  91. package/dist/cli/shell/components/App.js.map +1 -1
  92. package/dist/cli/shell/components/InputPrompt.js +1 -1
  93. package/dist/cli/shell/components/InputPrompt.js.map +1 -1
  94. package/dist/cli/shell/components/MessageStream.d.ts +2 -0
  95. package/dist/cli/shell/components/MessageStream.d.ts.map +1 -1
  96. package/dist/cli/shell/components/MessageStream.js +20 -20
  97. package/dist/cli/shell/components/MessageStream.js.map +1 -1
  98. package/dist/cli/shell/components/ThinkingIndicator.d.ts +4 -0
  99. package/dist/cli/shell/components/ThinkingIndicator.d.ts.map +1 -1
  100. package/dist/cli/shell/components/ThinkingIndicator.js +23 -4
  101. package/dist/cli/shell/components/ThinkingIndicator.js.map +1 -1
  102. package/dist/cli/shell/coordinator.d.ts +7 -0
  103. package/dist/cli/shell/coordinator.d.ts.map +1 -1
  104. package/dist/cli/shell/coordinator.js +206 -88
  105. package/dist/cli/shell/coordinator.js.map +1 -1
  106. package/dist/cli/shell/error-messages.d.ts +14 -0
  107. package/dist/cli/shell/error-messages.d.ts.map +1 -1
  108. package/dist/cli/shell/error-messages.js +65 -1
  109. package/dist/cli/shell/error-messages.js.map +1 -1
  110. package/dist/cli/shell/index.d.ts +1 -1
  111. package/dist/cli/shell/index.d.ts.map +1 -1
  112. package/dist/cli/shell/index.js +83 -12
  113. package/dist/cli/shell/index.js.map +1 -1
  114. package/dist/cli/shell/router.d.ts.map +1 -1
  115. package/dist/cli/shell/router.js +21 -2
  116. package/dist/cli/shell/router.js.map +1 -1
  117. package/dist/cli/shell/stream-bridge.d.ts +2 -0
  118. package/dist/cli/shell/stream-bridge.d.ts.map +1 -1
  119. package/dist/cli/shell/stream-bridge.js +11 -2
  120. package/dist/cli/shell/stream-bridge.js.map +1 -1
  121. package/dist/cli/shell/terminal.d.ts +5 -5
  122. package/dist/cli/shell/terminal.d.ts.map +1 -1
  123. package/dist/cli/shell/terminal.js +35 -26
  124. package/dist/cli/shell/terminal.js.map +1 -1
  125. package/dist/cli-entry.js +124 -42
  126. package/dist/cli-entry.js.map +1 -1
  127. package/package.json +20 -4
  128. package/scripts/patch-esm-imports.mjs +106 -77
  129. package/scripts/patch-ink-rendering.mjs +115 -0
  130. package/templates/casting/Futurama.json +10 -0
  131. package/templates/casting-history.json +4 -4
  132. package/templates/casting-policy.json +37 -35
  133. package/templates/casting-reference.md +104 -0
  134. package/templates/casting-registry.json +3 -3
  135. package/templates/ceremonies.md +41 -41
  136. package/templates/charter.md +53 -53
  137. package/templates/constraint-tracking.md +38 -38
  138. package/templates/cooperative-rate-limiting.md +229 -0
  139. package/templates/copilot-instructions.md +46 -46
  140. package/templates/history.md +10 -10
  141. package/templates/identity/now.md +9 -9
  142. package/templates/identity/wisdom.md +15 -15
  143. package/templates/issue-lifecycle.md +412 -0
  144. package/templates/keda-scaler.md +164 -0
  145. package/templates/machine-capabilities.md +75 -0
  146. package/templates/mcp-config.md +90 -90
  147. package/templates/multi-agent-format.md +28 -28
  148. package/templates/orchestration-log.md +27 -27
  149. package/templates/plugin-marketplace.md +49 -49
  150. package/templates/ralph-circuit-breaker.md +313 -0
  151. package/templates/raw-agent-output.md +37 -37
  152. package/templates/roster.md +60 -60
  153. package/templates/routing.md +39 -54
  154. package/templates/run-output.md +50 -50
  155. package/templates/scribe-charter.md +119 -119
  156. package/templates/skill.md +24 -24
  157. package/templates/skills/agent-collaboration/SKILL.md +42 -0
  158. package/templates/skills/agent-conduct/SKILL.md +24 -0
  159. package/templates/skills/architectural-proposals/SKILL.md +151 -0
  160. package/templates/skills/ci-validation-gates/SKILL.md +84 -0
  161. package/templates/skills/cli-wiring/SKILL.md +47 -0
  162. package/templates/skills/client-compatibility/SKILL.md +89 -0
  163. package/templates/skills/cross-squad/SKILL.md +114 -0
  164. package/templates/skills/distributed-mesh/SKILL.md +287 -0
  165. package/templates/skills/distributed-mesh/mesh.json.example +30 -0
  166. package/templates/skills/distributed-mesh/sync-mesh.ps1 +111 -0
  167. package/templates/skills/distributed-mesh/sync-mesh.sh +104 -0
  168. package/templates/skills/docs-standards/SKILL.md +71 -0
  169. package/templates/skills/economy-mode/SKILL.md +114 -0
  170. package/templates/skills/external-comms/SKILL.md +329 -0
  171. package/templates/skills/gh-auth-isolation/SKILL.md +183 -0
  172. package/templates/skills/git-workflow/SKILL.md +204 -0
  173. package/templates/skills/github-multi-account/SKILL.md +95 -0
  174. package/templates/skills/history-hygiene/SKILL.md +36 -0
  175. package/templates/skills/humanizer/SKILL.md +105 -0
  176. package/templates/skills/init-mode/SKILL.md +102 -0
  177. package/templates/skills/model-selection/SKILL.md +117 -0
  178. package/templates/skills/nap/SKILL.md +24 -0
  179. package/templates/skills/personal-squad/SKILL.md +57 -0
  180. package/templates/skills/release-process/SKILL.md +423 -0
  181. package/templates/skills/reskill/SKILL.md +92 -0
  182. package/templates/skills/reviewer-protocol/SKILL.md +79 -0
  183. package/templates/skills/secret-handling/SKILL.md +200 -0
  184. package/templates/skills/session-recovery/SKILL.md +155 -0
  185. package/templates/skills/squad-conventions/SKILL.md +69 -69
  186. package/templates/skills/test-discipline/SKILL.md +37 -0
  187. package/templates/skills/windows-compatibility/SKILL.md +74 -0
  188. package/templates/squad.agent.md +1287 -1146
  189. package/templates/workflows/squad-ci.yml +24 -24
  190. package/templates/workflows/squad-docs.yml +54 -50
  191. package/templates/workflows/squad-heartbeat.yml +3 -4
  192. package/templates/workflows/squad-insider-release.yml +61 -61
  193. package/templates/workflows/squad-issue-assign.yml +161 -161
  194. package/templates/workflows/squad-label-enforce.yml +181 -181
  195. package/templates/workflows/squad-preview.yml +55 -55
  196. package/templates/workflows/squad-promote.yml +120 -120
  197. package/templates/workflows/squad-release.yml +77 -77
  198. package/templates/workflows/squad-triage.yml +260 -260
  199. package/templates/workflows/sync-squad-labels.yml +169 -169
@@ -0,0 +1,111 @@
1
+ # sync-mesh.ps1 — Materialize remote squad state locally
2
+ #
3
+ # Reads mesh.json, fetches remote squads into local directories.
4
+ # Run before agent reads. No daemon. No service. ~40 lines.
5
+ #
6
+ # Usage: .\sync-mesh.ps1 [path-to-mesh.json]
7
+ # .\sync-mesh.ps1 -Init [path-to-mesh.json]
8
+ # Requires: git
9
+ param(
10
+ [switch]$Init,
11
+ [string]$MeshJson = "mesh.json"
12
+ )
13
+ $ErrorActionPreference = "Stop"
14
+
15
+ # Handle -Init mode
16
+ if ($Init) {
17
+ if (-not (Test-Path $MeshJson)) {
18
+ Write-Host "❌ $MeshJson not found"
19
+ exit 1
20
+ }
21
+
22
+ Write-Host "🚀 Initializing mesh state repository..."
23
+ $config = Get-Content $MeshJson -Raw | ConvertFrom-Json
24
+ $squads = $config.squads.PSObject.Properties.Name
25
+
26
+ # Create squad directories with placeholder SUMMARY.md
27
+ foreach ($squad in $squads) {
28
+ if (-not (Test-Path $squad)) {
29
+ New-Item -ItemType Directory -Path $squad | Out-Null
30
+ Write-Host " ✓ Created $squad/"
31
+ } else {
32
+ Write-Host " • $squad/ exists (skipped)"
33
+ }
34
+
35
+ $summaryPath = "$squad/SUMMARY.md"
36
+ if (-not (Test-Path $summaryPath)) {
37
+ "# $squad`n`n_No state published yet._" | Set-Content $summaryPath
38
+ Write-Host " ✓ Created $summaryPath"
39
+ } else {
40
+ Write-Host " • $summaryPath exists (skipped)"
41
+ }
42
+ }
43
+
44
+ # Generate root README.md
45
+ if (-not (Test-Path "README.md")) {
46
+ $readme = @"
47
+ # Squad Mesh State Repository
48
+
49
+ This repository tracks published state from participating squads.
50
+
51
+ ## Participating Squads
52
+
53
+ "@
54
+ foreach ($squad in $squads) {
55
+ $zone = $config.squads.$squad.zone
56
+ $readme += "- **$squad** (Zone: $zone)`n"
57
+ }
58
+ $readme += @"
59
+
60
+ Each squad directory contains a ``SUMMARY.md`` with their latest published state.
61
+ State is synchronized using ``sync-mesh.sh`` or ``sync-mesh.ps1``.
62
+ "@
63
+ $readme | Set-Content "README.md"
64
+ Write-Host " ✓ Created README.md"
65
+ } else {
66
+ Write-Host " • README.md exists (skipped)"
67
+ }
68
+
69
+ Write-Host ""
70
+ Write-Host "✅ Mesh state repository initialized"
71
+ exit 0
72
+ }
73
+
74
+ $config = Get-Content $MeshJson -Raw | ConvertFrom-Json
75
+
76
+ # Zone 2: Remote-trusted — git clone/pull
77
+ foreach ($entry in $config.squads.PSObject.Properties | Where-Object { $_.Value.zone -eq "remote-trusted" }) {
78
+ $squad = $entry.Name
79
+ $source = $entry.Value.source
80
+ $ref = if ($entry.Value.ref) { $entry.Value.ref } else { "main" }
81
+ $target = $entry.Value.sync_to
82
+
83
+ if (Test-Path "$target/.git") {
84
+ git -C $target pull --rebase --quiet 2>$null
85
+ if ($LASTEXITCODE -ne 0) { Write-Host "⚠ ${squad}: pull failed (using stale)" }
86
+ } else {
87
+ New-Item -ItemType Directory -Force -Path (Split-Path $target -Parent) | Out-Null
88
+ git clone --quiet --depth 1 --branch $ref $source $target 2>$null
89
+ if ($LASTEXITCODE -ne 0) { Write-Host "⚠ ${squad}: clone failed (unavailable)" }
90
+ }
91
+ }
92
+
93
+ # Zone 3: Remote-opaque — fetch published contracts
94
+ foreach ($entry in $config.squads.PSObject.Properties | Where-Object { $_.Value.zone -eq "remote-opaque" }) {
95
+ $squad = $entry.Name
96
+ $source = $entry.Value.source
97
+ $target = $entry.Value.sync_to
98
+ $auth = $entry.Value.auth
99
+
100
+ New-Item -ItemType Directory -Force -Path $target | Out-Null
101
+ $params = @{ Uri = $source; OutFile = "$target/SUMMARY.md"; UseBasicParsing = $true }
102
+ if ($auth -eq "bearer") {
103
+ $tokenVar = ($squad.ToUpper() -replace '-', '_') + "_TOKEN"
104
+ $token = [Environment]::GetEnvironmentVariable($tokenVar)
105
+ if ($token) { $params.Headers = @{ Authorization = "Bearer $token" } }
106
+ }
107
+ try { Invoke-WebRequest @params -ErrorAction Stop }
108
+ catch { "# ${squad} — unavailable ($(Get-Date))" | Set-Content "$target/SUMMARY.md" }
109
+ }
110
+
111
+ Write-Host "✓ Mesh sync complete"
@@ -0,0 +1,104 @@
1
+ #!/bin/bash
2
+ # sync-mesh.sh — Materialize remote squad state locally
3
+ #
4
+ # Reads mesh.json, fetches remote squads into local directories.
5
+ # Run before agent reads. No daemon. No service. ~40 lines.
6
+ #
7
+ # Usage: ./sync-mesh.sh [path-to-mesh.json]
8
+ # ./sync-mesh.sh --init [path-to-mesh.json]
9
+ # Requires: jq (https://github.com/jqlang/jq), git, curl
10
+
11
+ set -euo pipefail
12
+
13
+ # Handle --init mode
14
+ if [ "${1:-}" = "--init" ]; then
15
+ MESH_JSON="${2:-mesh.json}"
16
+
17
+ if [ ! -f "$MESH_JSON" ]; then
18
+ echo "❌ $MESH_JSON not found"
19
+ exit 1
20
+ fi
21
+
22
+ echo "🚀 Initializing mesh state repository..."
23
+ squads=$(jq -r '.squads | keys[]' "$MESH_JSON")
24
+
25
+ # Create squad directories with placeholder SUMMARY.md
26
+ for squad in $squads; do
27
+ if [ ! -d "$squad" ]; then
28
+ mkdir -p "$squad"
29
+ echo " ✓ Created $squad/"
30
+ else
31
+ echo " • $squad/ exists (skipped)"
32
+ fi
33
+
34
+ if [ ! -f "$squad/SUMMARY.md" ]; then
35
+ echo -e "# $squad\n\n_No state published yet._" > "$squad/SUMMARY.md"
36
+ echo " ✓ Created $squad/SUMMARY.md"
37
+ else
38
+ echo " • $squad/SUMMARY.md exists (skipped)"
39
+ fi
40
+ done
41
+
42
+ # Generate root README.md
43
+ if [ ! -f "README.md" ]; then
44
+ {
45
+ echo "# Squad Mesh State Repository"
46
+ echo ""
47
+ echo "This repository tracks published state from participating squads."
48
+ echo ""
49
+ echo "## Participating Squads"
50
+ echo ""
51
+ for squad in $squads; do
52
+ zone=$(jq -r ".squads.\"$squad\".zone" "$MESH_JSON")
53
+ echo "- **$squad** (Zone: $zone)"
54
+ done
55
+ echo ""
56
+ echo "Each squad directory contains a \`SUMMARY.md\` with their latest published state."
57
+ echo "State is synchronized using \`sync-mesh.sh\` or \`sync-mesh.ps1\`."
58
+ } > README.md
59
+ echo " ✓ Created README.md"
60
+ else
61
+ echo " • README.md exists (skipped)"
62
+ fi
63
+
64
+ echo ""
65
+ echo "✅ Mesh state repository initialized"
66
+ exit 0
67
+ fi
68
+
69
+ MESH_JSON="${1:-mesh.json}"
70
+
71
+ # Zone 2: Remote-trusted — git clone/pull
72
+ for squad in $(jq -r '.squads | to_entries[] | select(.value.zone == "remote-trusted") | .key' "$MESH_JSON"); do
73
+ source=$(jq -r ".squads.\"$squad\".source" "$MESH_JSON")
74
+ ref=$(jq -r ".squads.\"$squad\".ref // \"main\"" "$MESH_JSON")
75
+ target=$(jq -r ".squads.\"$squad\".sync_to" "$MESH_JSON")
76
+
77
+ if [ -d "$target/.git" ]; then
78
+ git -C "$target" pull --rebase --quiet 2>/dev/null \
79
+ || echo "⚠ $squad: pull failed (using stale)"
80
+ else
81
+ mkdir -p "$(dirname "$target")"
82
+ git clone --quiet --depth 1 --branch "$ref" "$source" "$target" 2>/dev/null \
83
+ || echo "⚠ $squad: clone failed (unavailable)"
84
+ fi
85
+ done
86
+
87
+ # Zone 3: Remote-opaque — fetch published contracts
88
+ for squad in $(jq -r '.squads | to_entries[] | select(.value.zone == "remote-opaque") | .key' "$MESH_JSON"); do
89
+ source=$(jq -r ".squads.\"$squad\".source" "$MESH_JSON")
90
+ target=$(jq -r ".squads.\"$squad\".sync_to" "$MESH_JSON")
91
+ auth=$(jq -r ".squads.\"$squad\".auth // \"\"" "$MESH_JSON")
92
+
93
+ mkdir -p "$target"
94
+ auth_flag=""
95
+ if [ "$auth" = "bearer" ]; then
96
+ token_var="$(echo "${squad}" | tr '[:lower:]-' '[:upper:]_')_TOKEN"
97
+ [ -n "${!token_var:-}" ] && auth_flag="--header \"Authorization: Bearer ${!token_var}\""
98
+ fi
99
+
100
+ eval curl --silent --fail $auth_flag "$source" -o "$target/SUMMARY.md" 2>/dev/null \
101
+ || echo "# ${squad} — unavailable ($(date))" > "$target/SUMMARY.md"
102
+ done
103
+
104
+ echo "✓ Mesh sync complete"
@@ -0,0 +1,71 @@
1
+ ---
2
+ name: "docs-standards"
3
+ description: "Microsoft Style Guide + Squad-specific documentation patterns"
4
+ domain: "documentation"
5
+ confidence: "high"
6
+ source: "earned (PAO charter, multiple doc PR reviews)"
7
+ ---
8
+
9
+ ## Context
10
+
11
+ Squad documentation follows the Microsoft Style Guide with Squad-specific conventions. Consistency across docs builds trust and improves discoverability.
12
+
13
+ ## Patterns
14
+
15
+ ### Microsoft Style Guide Rules
16
+ - **Sentence-case headings:** "Getting started" not "Getting Started"
17
+ - **Active voice:** "Run the command" not "The command should be run"
18
+ - **Second person:** "You can configure..." not "Users can configure..."
19
+ - **Present tense:** "The system routes..." not "The system will route..."
20
+ - **No ampersands in prose:** "and" not "&" (except in code, brand names, or UI elements)
21
+
22
+ ### Squad Formatting Patterns
23
+ - **Scannability first:** Paragraphs for narrative (3-4 sentences max), bullets for scannable lists, tables for structured data
24
+ - **"Try this" prompts at top:** Start feature/scenario pages with practical prompts users can copy
25
+ - **Experimental warnings:** Features in preview get callout at top
26
+ - **Cross-references at bottom:** Related pages linked after main content
27
+
28
+ ### Structure
29
+ - **Title (H1)** → **Warning/callout** → **Try this code** → **Overview** → **HR** → **Content (H2 sections)**
30
+
31
+ ### Test Sync Rule
32
+ - **Always update test assertions:** When adding docs pages to `features/`, `scenarios/`, `guides/`, update corresponding `EXPECTED_*` arrays in `test/docs-build.test.ts` in the same commit
33
+
34
+ ## Examples
35
+
36
+ ✓ **Correct:**
37
+ ```markdown
38
+ # Getting started with Squad
39
+
40
+ > ⚠️ **Experimental:** This feature is in preview.
41
+
42
+ Try this:
43
+ \`\`\`bash
44
+ squad init
45
+ \`\`\`
46
+
47
+ Squad helps you build AI teams...
48
+
49
+ ---
50
+
51
+ ## Install Squad
52
+
53
+ Run the following command...
54
+ ```
55
+
56
+ ✗ **Incorrect:**
57
+ ```markdown
58
+ # Getting Started With Squad // Title case
59
+
60
+ Squad is a tool which will help users... // Third person, future tense
61
+
62
+ You can install Squad with npm & configure it... // Ampersand in prose
63
+ ```
64
+
65
+ ## Anti-Patterns
66
+
67
+ - Title-casing headings because "it looks nicer"
68
+ - Writing in passive voice or third person
69
+ - Long paragraphs of dense text (breaks scannability)
70
+ - Adding doc pages without updating test assertions
71
+ - Using ampersands outside code blocks
@@ -0,0 +1,114 @@
1
+ ---
2
+ name: "economy-mode"
3
+ description: "Shifts Layer 3 model selection to cost-optimized alternatives when economy mode is active."
4
+ domain: "model-selection"
5
+ confidence: "low"
6
+ source: "manual"
7
+ ---
8
+
9
+ ## SCOPE
10
+
11
+ ✅ THIS SKILL PRODUCES:
12
+ - A modified Layer 3 model selection table applied when economy mode is active
13
+ - `economyMode: true` written to `.squad/config.json` when activated persistently
14
+ - Spawn acknowledgments with `💰` indicator when economy mode is active
15
+
16
+ ❌ THIS SKILL DOES NOT PRODUCE:
17
+ - Code, tests, or documentation
18
+ - Cost reports or billing artifacts
19
+ - Changes to Layer 0, Layer 1, or Layer 2 resolution (user intent always wins)
20
+
21
+ ## Context
22
+
23
+ Economy mode shifts Layer 3 (Task-Aware Auto-Selection) to lower-cost alternatives. It does NOT override persistent config (`defaultModel`, `agentModelOverrides`) or per-agent charter preferences — those represent explicit user intent and always take priority.
24
+
25
+ Use this skill when the user wants to reduce costs across an entire session or permanently, without manually specifying models for each agent.
26
+
27
+ ## Activation Methods
28
+
29
+ | Method | How |
30
+ |--------|-----|
31
+ | Session phrase | "use economy mode", "save costs", "go cheap", "reduce costs" |
32
+ | Persistent config | `"economyMode": true` in `.squad/config.json` |
33
+ | CLI flag | `squad --economy` |
34
+
35
+ **Deactivation:** "turn off economy mode", "disable economy mode", or remove `economyMode` from `config.json`.
36
+
37
+ ## Economy Model Selection Table
38
+
39
+ When economy mode is **active**, Layer 3 auto-selection uses this table instead of the normal defaults:
40
+
41
+ | Task Output | Normal Mode | Economy Mode |
42
+ |-------------|-------------|--------------|
43
+ | Writing code (implementation, refactoring, bug fixes) | `claude-sonnet-4.5` | `gpt-4.1` or `gpt-5-mini` |
44
+ | Writing prompts or agent designs | `claude-sonnet-4.5` | `gpt-4.1` or `gpt-5-mini` |
45
+ | Docs, planning, triage, changelogs, mechanical ops | `claude-haiku-4.5` | `gpt-4.1` or `gpt-5-mini` |
46
+ | Architecture, code review, security audits | `claude-opus-4.5` | `claude-sonnet-4.5` |
47
+ | Scribe / logger / mechanical file ops | `claude-haiku-4.5` | `gpt-4.1` |
48
+
49
+ **Prefer `gpt-4.1` over `gpt-5-mini`** when the task involves structured output or agentic tool use. Prefer `gpt-5-mini` for pure text generation tasks where latency matters.
50
+
51
+ ## AGENT WORKFLOW
52
+
53
+ ### On Session Start
54
+
55
+ 1. READ `.squad/config.json`
56
+ 2. CHECK for `economyMode: true` — if present, activate economy mode for the session
57
+ 3. STORE economy mode state in session context
58
+
59
+ ### On User Phrase Trigger
60
+
61
+ **Session-only (no config change):** "use economy mode", "save costs", "go cheap"
62
+
63
+ 1. SET economy mode active for this session
64
+ 2. ACKNOWLEDGE: `✅ Economy mode active — using cost-optimized models this session. (Layer 0 and Layer 2 preferences still apply)`
65
+
66
+ **Persistent:** "always use economy mode", "save economy mode"
67
+
68
+ 1. WRITE `economyMode: true` to `.squad/config.json` (merge, don't overwrite other fields)
69
+ 2. ACKNOWLEDGE: `✅ Economy mode saved — cost-optimized models will be used until disabled.`
70
+
71
+ ### On Every Agent Spawn (Economy Mode Active)
72
+
73
+ 1. CHECK Layer 0a/0b first (agentModelOverrides, defaultModel) — if set, use that. Economy mode does NOT override Layer 0.
74
+ 2. CHECK Layer 1 (session directive for a specific model) — if set, use that. Economy mode does NOT override explicit session directives.
75
+ 3. CHECK Layer 2 (charter preference) — if set, use that. Economy mode does NOT override charter preferences.
76
+ 4. APPLY economy table at Layer 3 instead of normal table.
77
+ 5. INCLUDE `💰` in spawn acknowledgment: `🔧 {Name} ({model} · 💰 economy) — {task}`
78
+
79
+ ### On Deactivation
80
+
81
+ **Trigger phrases:** "turn off economy mode", "disable economy mode", "use normal models"
82
+
83
+ 1. REMOVE `economyMode` from `.squad/config.json` (if it was persisted)
84
+ 2. CLEAR session economy mode state
85
+ 3. ACKNOWLEDGE: `✅ Economy mode disabled — returning to standard model selection.`
86
+
87
+ ### STOP
88
+
89
+ After updating economy mode state and including the `💰` indicator in spawn acknowledgments, this skill is done. Do NOT:
90
+ - Change Layer 0, Layer 1, or Layer 2 model choices
91
+ - Override charter-specified models
92
+ - Generate cost reports or comparisons
93
+ - Fall back to premium models via economy mode (economy mode never bumps UP)
94
+
95
+ ## Config Schema
96
+
97
+ `.squad/config.json` economy-related fields:
98
+
99
+ ```json
100
+ {
101
+ "version": 1,
102
+ "economyMode": true
103
+ }
104
+ ```
105
+
106
+ - `economyMode` — when `true`, Layer 3 uses the economy table. Optional; absent = economy mode off.
107
+ - Combines with `defaultModel` and `agentModelOverrides` — Layer 0 always wins.
108
+
109
+ ## Anti-Patterns
110
+
111
+ - **Don't override Layer 0 in economy mode.** If the user set `defaultModel: "claude-opus-4.6"`, they want quality. Economy mode only affects Layer 3 auto-selection.
112
+ - **Don't silently apply economy mode.** Always acknowledge when activated or deactivated.
113
+ - **Don't treat economy mode as permanent by default.** Session phrases activate session-only; only "always" or `config.json` persist it.
114
+ - **Don't bump premium tasks down too far.** Architecture and security reviews shift from opus to sonnet in economy mode — they do NOT go to fast/cheap models.