@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.
- package/README.md +329 -77
- package/dist/cli/commands/aspire.d.ts.map +1 -1
- package/dist/cli/commands/aspire.js +3 -0
- package/dist/cli/commands/aspire.js.map +1 -1
- package/dist/cli/commands/build.js +3 -3
- package/dist/cli/commands/build.js.map +1 -1
- package/dist/cli/commands/cast.d.ts +13 -0
- package/dist/cli/commands/cast.d.ts.map +1 -0
- package/dist/cli/commands/cast.js +77 -0
- package/dist/cli/commands/cast.js.map +1 -0
- package/dist/cli/commands/cost.d.ts +2 -0
- package/dist/cli/commands/cost.d.ts.map +1 -0
- package/dist/cli/commands/cost.js +170 -0
- package/dist/cli/commands/cost.js.map +1 -0
- package/dist/cli/commands/cross-squad.d.ts +12 -0
- package/dist/cli/commands/cross-squad.d.ts.map +1 -0
- package/dist/cli/commands/cross-squad.js +80 -0
- package/dist/cli/commands/cross-squad.js.map +1 -0
- package/dist/cli/commands/doctor.d.ts +5 -0
- package/dist/cli/commands/doctor.d.ts.map +1 -1
- package/dist/cli/commands/doctor.js +156 -0
- package/dist/cli/commands/doctor.js.map +1 -1
- package/dist/cli/commands/economy.d.ts +10 -0
- package/dist/cli/commands/economy.d.ts.map +1 -0
- package/dist/cli/commands/economy.js +64 -0
- package/dist/cli/commands/economy.js.map +1 -0
- package/dist/cli/commands/export.d.ts.map +1 -1
- package/dist/cli/commands/export.js +11 -4
- package/dist/cli/commands/export.js.map +1 -1
- package/dist/cli/commands/import.js +2 -2
- package/dist/cli/commands/import.js.map +1 -1
- package/dist/cli/commands/personal.d.ts +16 -0
- package/dist/cli/commands/personal.d.ts.map +1 -0
- package/dist/cli/commands/personal.js +213 -0
- package/dist/cli/commands/personal.js.map +1 -0
- package/dist/cli/commands/roles.d.ts +2 -0
- package/dist/cli/commands/roles.d.ts.map +1 -0
- package/dist/cli/commands/roles.js +54 -0
- package/dist/cli/commands/roles.js.map +1 -0
- package/dist/cli/commands/schedule.d.ts +14 -0
- package/dist/cli/commands/schedule.d.ts.map +1 -0
- package/dist/cli/commands/schedule.js +208 -0
- package/dist/cli/commands/schedule.js.map +1 -0
- package/dist/cli/commands/watch.d.ts.map +1 -1
- package/dist/cli/commands/watch.js +17 -5
- package/dist/cli/commands/watch.js.map +1 -1
- package/dist/cli/core/cast.d.ts +9 -0
- package/dist/cli/core/cast.d.ts.map +1 -1
- package/dist/cli/core/cast.js +170 -60
- package/dist/cli/core/cast.js.map +1 -1
- package/dist/cli/core/detect-squad-dir.d.ts +10 -0
- package/dist/cli/core/detect-squad-dir.d.ts.map +1 -1
- package/dist/cli/core/detect-squad-dir.js +47 -0
- package/dist/cli/core/detect-squad-dir.js.map +1 -1
- package/dist/cli/core/init.d.ts +8 -0
- package/dist/cli/core/init.d.ts.map +1 -1
- package/dist/cli/core/init.js +115 -2
- package/dist/cli/core/init.js.map +1 -1
- package/dist/cli/core/migrations.d.ts.map +1 -1
- package/dist/cli/core/migrations.js +21 -0
- package/dist/cli/core/migrations.js.map +1 -1
- package/dist/cli/core/team-md.js +34 -34
- package/dist/cli/core/templates.d.ts.map +1 -1
- package/dist/cli/core/templates.js +8 -1
- package/dist/cli/core/templates.js.map +1 -1
- package/dist/cli/core/upgrade.d.ts +14 -0
- package/dist/cli/core/upgrade.d.ts.map +1 -1
- package/dist/cli/core/upgrade.js +182 -48
- package/dist/cli/core/upgrade.js.map +1 -1
- package/dist/cli/core/version.js +2 -2
- package/dist/cli/core/version.js.map +1 -1
- package/dist/cli/index.d.ts +2 -0
- package/dist/cli/index.d.ts.map +1 -1
- package/dist/cli/index.js +2 -0
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/self-update.d.ts +21 -0
- package/dist/cli/self-update.d.ts.map +1 -0
- package/dist/cli/self-update.js +113 -0
- package/dist/cli/self-update.js.map +1 -0
- package/dist/cli/shell/autocomplete.d.ts.map +1 -1
- package/dist/cli/shell/autocomplete.js +5 -0
- package/dist/cli/shell/autocomplete.js.map +1 -1
- package/dist/cli/shell/commands.d.ts.map +1 -1
- package/dist/cli/shell/commands.js +55 -24
- package/dist/cli/shell/commands.js.map +1 -1
- package/dist/cli/shell/components/AgentPanel.d.ts.map +1 -1
- package/dist/cli/shell/components/AgentPanel.js +21 -6
- package/dist/cli/shell/components/AgentPanel.js.map +1 -1
- package/dist/cli/shell/components/App.d.ts.map +1 -1
- package/dist/cli/shell/components/App.js +33 -15
- package/dist/cli/shell/components/App.js.map +1 -1
- package/dist/cli/shell/components/InputPrompt.js +1 -1
- package/dist/cli/shell/components/InputPrompt.js.map +1 -1
- package/dist/cli/shell/components/MessageStream.d.ts +2 -0
- package/dist/cli/shell/components/MessageStream.d.ts.map +1 -1
- package/dist/cli/shell/components/MessageStream.js +20 -20
- package/dist/cli/shell/components/MessageStream.js.map +1 -1
- package/dist/cli/shell/components/ThinkingIndicator.d.ts +4 -0
- package/dist/cli/shell/components/ThinkingIndicator.d.ts.map +1 -1
- package/dist/cli/shell/components/ThinkingIndicator.js +23 -4
- package/dist/cli/shell/components/ThinkingIndicator.js.map +1 -1
- package/dist/cli/shell/coordinator.d.ts +7 -0
- package/dist/cli/shell/coordinator.d.ts.map +1 -1
- package/dist/cli/shell/coordinator.js +206 -88
- package/dist/cli/shell/coordinator.js.map +1 -1
- package/dist/cli/shell/error-messages.d.ts +14 -0
- package/dist/cli/shell/error-messages.d.ts.map +1 -1
- package/dist/cli/shell/error-messages.js +65 -1
- package/dist/cli/shell/error-messages.js.map +1 -1
- package/dist/cli/shell/index.d.ts +1 -1
- package/dist/cli/shell/index.d.ts.map +1 -1
- package/dist/cli/shell/index.js +83 -12
- package/dist/cli/shell/index.js.map +1 -1
- package/dist/cli/shell/router.d.ts.map +1 -1
- package/dist/cli/shell/router.js +21 -2
- package/dist/cli/shell/router.js.map +1 -1
- package/dist/cli/shell/stream-bridge.d.ts +2 -0
- package/dist/cli/shell/stream-bridge.d.ts.map +1 -1
- package/dist/cli/shell/stream-bridge.js +11 -2
- package/dist/cli/shell/stream-bridge.js.map +1 -1
- package/dist/cli/shell/terminal.d.ts +5 -5
- package/dist/cli/shell/terminal.d.ts.map +1 -1
- package/dist/cli/shell/terminal.js +35 -26
- package/dist/cli/shell/terminal.js.map +1 -1
- package/dist/cli-entry.js +124 -42
- package/dist/cli-entry.js.map +1 -1
- package/package.json +20 -4
- package/scripts/patch-esm-imports.mjs +106 -77
- package/scripts/patch-ink-rendering.mjs +115 -0
- package/templates/casting/Futurama.json +10 -0
- package/templates/casting-history.json +4 -4
- package/templates/casting-policy.json +37 -35
- package/templates/casting-reference.md +104 -0
- package/templates/casting-registry.json +3 -3
- package/templates/ceremonies.md +41 -41
- package/templates/charter.md +53 -53
- package/templates/constraint-tracking.md +38 -38
- package/templates/cooperative-rate-limiting.md +229 -0
- package/templates/copilot-instructions.md +46 -46
- package/templates/history.md +10 -10
- package/templates/identity/now.md +9 -9
- package/templates/identity/wisdom.md +15 -15
- package/templates/issue-lifecycle.md +412 -0
- package/templates/keda-scaler.md +164 -0
- package/templates/machine-capabilities.md +75 -0
- package/templates/mcp-config.md +90 -90
- package/templates/multi-agent-format.md +28 -28
- package/templates/orchestration-log.md +27 -27
- package/templates/plugin-marketplace.md +49 -49
- package/templates/ralph-circuit-breaker.md +313 -0
- package/templates/raw-agent-output.md +37 -37
- package/templates/roster.md +60 -60
- package/templates/routing.md +39 -54
- package/templates/run-output.md +50 -50
- package/templates/scribe-charter.md +119 -119
- package/templates/skill.md +24 -24
- package/templates/skills/agent-collaboration/SKILL.md +42 -0
- package/templates/skills/agent-conduct/SKILL.md +24 -0
- package/templates/skills/architectural-proposals/SKILL.md +151 -0
- package/templates/skills/ci-validation-gates/SKILL.md +84 -0
- package/templates/skills/cli-wiring/SKILL.md +47 -0
- package/templates/skills/client-compatibility/SKILL.md +89 -0
- package/templates/skills/cross-squad/SKILL.md +114 -0
- package/templates/skills/distributed-mesh/SKILL.md +287 -0
- package/templates/skills/distributed-mesh/mesh.json.example +30 -0
- package/templates/skills/distributed-mesh/sync-mesh.ps1 +111 -0
- package/templates/skills/distributed-mesh/sync-mesh.sh +104 -0
- package/templates/skills/docs-standards/SKILL.md +71 -0
- package/templates/skills/economy-mode/SKILL.md +114 -0
- package/templates/skills/external-comms/SKILL.md +329 -0
- package/templates/skills/gh-auth-isolation/SKILL.md +183 -0
- package/templates/skills/git-workflow/SKILL.md +204 -0
- package/templates/skills/github-multi-account/SKILL.md +95 -0
- package/templates/skills/history-hygiene/SKILL.md +36 -0
- package/templates/skills/humanizer/SKILL.md +105 -0
- package/templates/skills/init-mode/SKILL.md +102 -0
- package/templates/skills/model-selection/SKILL.md +117 -0
- package/templates/skills/nap/SKILL.md +24 -0
- package/templates/skills/personal-squad/SKILL.md +57 -0
- package/templates/skills/release-process/SKILL.md +423 -0
- package/templates/skills/reskill/SKILL.md +92 -0
- package/templates/skills/reviewer-protocol/SKILL.md +79 -0
- package/templates/skills/secret-handling/SKILL.md +200 -0
- package/templates/skills/session-recovery/SKILL.md +155 -0
- package/templates/skills/squad-conventions/SKILL.md +69 -69
- package/templates/skills/test-discipline/SKILL.md +37 -0
- package/templates/skills/windows-compatibility/SKILL.md +74 -0
- package/templates/squad.agent.md +1287 -1146
- package/templates/workflows/squad-ci.yml +24 -24
- package/templates/workflows/squad-docs.yml +54 -50
- package/templates/workflows/squad-heartbeat.yml +3 -4
- package/templates/workflows/squad-insider-release.yml +61 -61
- package/templates/workflows/squad-issue-assign.yml +161 -161
- package/templates/workflows/squad-label-enforce.yml +181 -181
- package/templates/workflows/squad-preview.yml +55 -55
- package/templates/workflows/squad-promote.yml +120 -120
- package/templates/workflows/squad-release.yml +77 -77
- package/templates/workflows/squad-triage.yml +260 -260
- 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.
|