@runchr/gstack-antigravity 0.1.1 → 0.1.3

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.

Potentially problematic release.


This version of @runchr/gstack-antigravity might be problematic. Click here for more details.

Files changed (229) hide show
  1. package/.agents/skills/gstack/.agents/skills/gstack/SKILL.md +651 -0
  2. package/.agents/skills/gstack/.agents/skills/gstack-autoplan/SKILL.md +678 -0
  3. package/.agents/skills/gstack/.agents/skills/gstack-benchmark/SKILL.md +482 -0
  4. package/.agents/skills/gstack/.agents/skills/gstack-browse/SKILL.md +511 -0
  5. package/.agents/skills/gstack/.agents/skills/gstack-canary/SKILL.md +486 -0
  6. package/.agents/skills/gstack/.agents/skills/gstack-careful/SKILL.md +50 -0
  7. package/.agents/skills/gstack/.agents/skills/gstack-cso/SKILL.md +607 -0
  8. package/.agents/skills/gstack/.agents/skills/gstack-design-consultation/SKILL.md +615 -0
  9. package/.agents/skills/gstack/.agents/skills/gstack-design-review/SKILL.md +988 -0
  10. package/.agents/skills/gstack/.agents/skills/gstack-document-release/SKILL.md +604 -0
  11. package/.agents/skills/gstack/.agents/skills/gstack-freeze/SKILL.md +67 -0
  12. package/.agents/skills/gstack/.agents/skills/gstack-guard/SKILL.md +62 -0
  13. package/.agents/skills/gstack/.agents/skills/gstack-investigate/SKILL.md +415 -0
  14. package/.agents/skills/gstack/.agents/skills/gstack-land-and-deploy/SKILL.md +873 -0
  15. package/.agents/skills/gstack/.agents/skills/gstack-office-hours/SKILL.md +986 -0
  16. package/.agents/skills/gstack/.agents/skills/gstack-plan-ceo-review/SKILL.md +1268 -0
  17. package/.agents/skills/gstack/.agents/skills/gstack-plan-design-review/SKILL.md +668 -0
  18. package/.agents/skills/gstack/.agents/skills/gstack-plan-eng-review/SKILL.md +826 -0
  19. package/.agents/skills/gstack/.agents/skills/gstack-qa/SKILL.md +1006 -0
  20. package/.agents/skills/gstack/.agents/skills/gstack-qa-only/SKILL.md +626 -0
  21. package/.agents/skills/gstack/.agents/skills/gstack-retro/SKILL.md +1065 -0
  22. package/.agents/skills/gstack/.agents/skills/gstack-review/SKILL.md +704 -0
  23. package/.agents/skills/gstack/.agents/skills/gstack-setup-browser-cookies/SKILL.md +325 -0
  24. package/.agents/skills/gstack/.agents/skills/gstack-setup-deploy/SKILL.md +450 -0
  25. package/.agents/skills/gstack/.agents/skills/gstack-ship/SKILL.md +1312 -0
  26. package/.agents/skills/gstack/.agents/skills/gstack-unfreeze/SKILL.md +36 -0
  27. package/.agents/skills/gstack/.agents/skills/gstack-upgrade/SKILL.md +220 -0
  28. package/.agents/skills/gstack/.env.example +5 -0
  29. package/.agents/skills/gstack/.github/workflows/skill-docs.yml +17 -0
  30. package/.agents/skills/gstack/AGENTS.md +49 -0
  31. package/.agents/skills/gstack/ARCHITECTURE.md +359 -0
  32. package/.agents/skills/gstack/BROWSER.md +271 -0
  33. package/.agents/skills/gstack/CHANGELOG.md +800 -0
  34. package/.agents/skills/gstack/CLAUDE.md +284 -0
  35. package/.agents/skills/gstack/CONTRIBUTING.md +370 -0
  36. package/.agents/skills/gstack/ETHOS.md +129 -0
  37. package/.agents/skills/gstack/LICENSE +21 -0
  38. package/.agents/skills/gstack/README.md +228 -0
  39. package/.agents/skills/gstack/SKILL.md +657 -0
  40. package/.agents/skills/gstack/SKILL.md.tmpl +281 -0
  41. package/.agents/skills/gstack/TODOS.md +564 -0
  42. package/.agents/skills/gstack/VERSION +1 -0
  43. package/.agents/skills/gstack/autoplan/SKILL.md +689 -0
  44. package/.agents/skills/gstack/autoplan/SKILL.md.tmpl +416 -0
  45. package/.agents/skills/gstack/benchmark/SKILL.md +489 -0
  46. package/.agents/skills/gstack/benchmark/SKILL.md.tmpl +233 -0
  47. package/.agents/skills/gstack/bin/dev-setup +68 -0
  48. package/.agents/skills/gstack/bin/dev-teardown +56 -0
  49. package/.agents/skills/gstack/bin/gstack-analytics +191 -0
  50. package/.agents/skills/gstack/bin/gstack-community-dashboard +113 -0
  51. package/.agents/skills/gstack/bin/gstack-config +38 -0
  52. package/.agents/skills/gstack/bin/gstack-diff-scope +71 -0
  53. package/.agents/skills/gstack/bin/gstack-global-discover.ts +591 -0
  54. package/.agents/skills/gstack/bin/gstack-repo-mode +93 -0
  55. package/.agents/skills/gstack/bin/gstack-review-log +9 -0
  56. package/.agents/skills/gstack/bin/gstack-review-read +12 -0
  57. package/.agents/skills/gstack/bin/gstack-slug +15 -0
  58. package/.agents/skills/gstack/bin/gstack-telemetry-log +158 -0
  59. package/.agents/skills/gstack/bin/gstack-telemetry-sync +127 -0
  60. package/.agents/skills/gstack/bin/gstack-update-check +196 -0
  61. package/.agents/skills/gstack/browse/SKILL.md +517 -0
  62. package/.agents/skills/gstack/browse/SKILL.md.tmpl +141 -0
  63. package/.agents/skills/gstack/browse/bin/find-browse +21 -0
  64. package/.agents/skills/gstack/browse/bin/remote-slug +14 -0
  65. package/.agents/skills/gstack/browse/scripts/build-node-server.sh +48 -0
  66. package/.agents/skills/gstack/browse/src/browser-manager.ts +634 -0
  67. package/.agents/skills/gstack/browse/src/buffers.ts +137 -0
  68. package/.agents/skills/gstack/browse/src/bun-polyfill.cjs +109 -0
  69. package/.agents/skills/gstack/browse/src/cli.ts +420 -0
  70. package/.agents/skills/gstack/browse/src/commands.ts +111 -0
  71. package/.agents/skills/gstack/browse/src/config.ts +150 -0
  72. package/.agents/skills/gstack/browse/src/cookie-import-browser.ts +417 -0
  73. package/.agents/skills/gstack/browse/src/cookie-picker-routes.ts +207 -0
  74. package/.agents/skills/gstack/browse/src/cookie-picker-ui.ts +541 -0
  75. package/.agents/skills/gstack/browse/src/find-browse.ts +61 -0
  76. package/.agents/skills/gstack/browse/src/meta-commands.ts +269 -0
  77. package/.agents/skills/gstack/browse/src/platform.ts +17 -0
  78. package/.agents/skills/gstack/browse/src/read-commands.ts +335 -0
  79. package/.agents/skills/gstack/browse/src/server.ts +369 -0
  80. package/.agents/skills/gstack/browse/src/snapshot.ts +398 -0
  81. package/.agents/skills/gstack/browse/src/url-validation.ts +91 -0
  82. package/.agents/skills/gstack/browse/src/write-commands.ts +352 -0
  83. package/.agents/skills/gstack/browse/test/bun-polyfill.test.ts +72 -0
  84. package/.agents/skills/gstack/browse/test/commands.test.ts +1836 -0
  85. package/.agents/skills/gstack/browse/test/config.test.ts +250 -0
  86. package/.agents/skills/gstack/browse/test/cookie-import-browser.test.ts +397 -0
  87. package/.agents/skills/gstack/browse/test/cookie-picker-routes.test.ts +205 -0
  88. package/.agents/skills/gstack/browse/test/find-browse.test.ts +50 -0
  89. package/.agents/skills/gstack/browse/test/fixtures/basic.html +33 -0
  90. package/.agents/skills/gstack/browse/test/fixtures/cursor-interactive.html +22 -0
  91. package/.agents/skills/gstack/browse/test/fixtures/dialog.html +15 -0
  92. package/.agents/skills/gstack/browse/test/fixtures/empty.html +2 -0
  93. package/.agents/skills/gstack/browse/test/fixtures/forms.html +55 -0
  94. package/.agents/skills/gstack/browse/test/fixtures/qa-eval-checkout.html +108 -0
  95. package/.agents/skills/gstack/browse/test/fixtures/qa-eval-spa.html +98 -0
  96. package/.agents/skills/gstack/browse/test/fixtures/qa-eval.html +51 -0
  97. package/.agents/skills/gstack/browse/test/fixtures/responsive.html +49 -0
  98. package/.agents/skills/gstack/browse/test/fixtures/snapshot.html +55 -0
  99. package/.agents/skills/gstack/browse/test/fixtures/spa.html +24 -0
  100. package/.agents/skills/gstack/browse/test/fixtures/states.html +17 -0
  101. package/.agents/skills/gstack/browse/test/fixtures/upload.html +25 -0
  102. package/.agents/skills/gstack/browse/test/gstack-config.test.ts +125 -0
  103. package/.agents/skills/gstack/browse/test/gstack-update-check.test.ts +467 -0
  104. package/.agents/skills/gstack/browse/test/handoff.test.ts +235 -0
  105. package/.agents/skills/gstack/browse/test/path-validation.test.ts +63 -0
  106. package/.agents/skills/gstack/browse/test/platform.test.ts +37 -0
  107. package/.agents/skills/gstack/browse/test/snapshot.test.ts +467 -0
  108. package/.agents/skills/gstack/browse/test/test-server.ts +57 -0
  109. package/.agents/skills/gstack/browse/test/url-validation.test.ts +72 -0
  110. package/.agents/skills/gstack/canary/SKILL.md +493 -0
  111. package/.agents/skills/gstack/canary/SKILL.md.tmpl +220 -0
  112. package/.agents/skills/gstack/careful/SKILL.md +59 -0
  113. package/.agents/skills/gstack/careful/SKILL.md.tmpl +57 -0
  114. package/.agents/skills/gstack/careful/bin/check-careful.sh +112 -0
  115. package/.agents/skills/gstack/codex/SKILL.md +677 -0
  116. package/.agents/skills/gstack/codex/SKILL.md.tmpl +356 -0
  117. package/.agents/skills/gstack/conductor.json +6 -0
  118. package/.agents/skills/gstack/cso/SKILL.md +615 -0
  119. package/.agents/skills/gstack/cso/SKILL.md.tmpl +376 -0
  120. package/.agents/skills/gstack/design-consultation/SKILL.md +625 -0
  121. package/.agents/skills/gstack/design-consultation/SKILL.md.tmpl +369 -0
  122. package/.agents/skills/gstack/design-review/SKILL.md +998 -0
  123. package/.agents/skills/gstack/design-review/SKILL.md.tmpl +262 -0
  124. package/.agents/skills/gstack/docs/images/github-2013.png +0 -0
  125. package/.agents/skills/gstack/docs/images/github-2026.png +0 -0
  126. package/.agents/skills/gstack/docs/skills.md +877 -0
  127. package/.agents/skills/gstack/document-release/SKILL.md +613 -0
  128. package/.agents/skills/gstack/document-release/SKILL.md.tmpl +357 -0
  129. package/.agents/skills/gstack/freeze/SKILL.md +82 -0
  130. package/.agents/skills/gstack/freeze/SKILL.md.tmpl +80 -0
  131. package/.agents/skills/gstack/freeze/bin/check-freeze.sh +68 -0
  132. package/.agents/skills/gstack/gstack-upgrade/SKILL.md +226 -0
  133. package/.agents/skills/gstack/gstack-upgrade/SKILL.md.tmpl +224 -0
  134. package/.agents/skills/gstack/guard/SKILL.md +82 -0
  135. package/.agents/skills/gstack/guard/SKILL.md.tmpl +80 -0
  136. package/.agents/skills/gstack/investigate/SKILL.md +435 -0
  137. package/.agents/skills/gstack/investigate/SKILL.md.tmpl +196 -0
  138. package/.agents/skills/gstack/land-and-deploy/SKILL.md +880 -0
  139. package/.agents/skills/gstack/land-and-deploy/SKILL.md.tmpl +575 -0
  140. package/.agents/skills/gstack/office-hours/SKILL.md +996 -0
  141. package/.agents/skills/gstack/office-hours/SKILL.md.tmpl +624 -0
  142. package/.agents/skills/gstack/package.json +55 -0
  143. package/.agents/skills/gstack/plan-ceo-review/SKILL.md +1277 -0
  144. package/.agents/skills/gstack/plan-ceo-review/SKILL.md.tmpl +838 -0
  145. package/.agents/skills/gstack/plan-design-review/SKILL.md +676 -0
  146. package/.agents/skills/gstack/plan-design-review/SKILL.md.tmpl +314 -0
  147. package/.agents/skills/gstack/plan-eng-review/SKILL.md +836 -0
  148. package/.agents/skills/gstack/plan-eng-review/SKILL.md.tmpl +279 -0
  149. package/.agents/skills/gstack/qa/SKILL.md +1016 -0
  150. package/.agents/skills/gstack/qa/SKILL.md.tmpl +316 -0
  151. package/.agents/skills/gstack/qa/references/issue-taxonomy.md +85 -0
  152. package/.agents/skills/gstack/qa/templates/qa-report-template.md +126 -0
  153. package/.agents/skills/gstack/qa-only/SKILL.md +633 -0
  154. package/.agents/skills/gstack/qa-only/SKILL.md.tmpl +101 -0
  155. package/.agents/skills/gstack/retro/SKILL.md +1072 -0
  156. package/.agents/skills/gstack/retro/SKILL.md.tmpl +833 -0
  157. package/.agents/skills/gstack/review/SKILL.md +849 -0
  158. package/.agents/skills/gstack/review/SKILL.md.tmpl +259 -0
  159. package/.agents/skills/gstack/review/TODOS-format.md +62 -0
  160. package/.agents/skills/gstack/review/checklist.md +190 -0
  161. package/.agents/skills/gstack/review/design-checklist.md +132 -0
  162. package/.agents/skills/gstack/review/greptile-triage.md +220 -0
  163. package/.agents/skills/gstack/scripts/analytics.ts +190 -0
  164. package/.agents/skills/gstack/scripts/dev-skill.ts +82 -0
  165. package/.agents/skills/gstack/scripts/eval-compare.ts +96 -0
  166. package/.agents/skills/gstack/scripts/eval-list.ts +116 -0
  167. package/.agents/skills/gstack/scripts/eval-select.ts +86 -0
  168. package/.agents/skills/gstack/scripts/eval-summary.ts +187 -0
  169. package/.agents/skills/gstack/scripts/eval-watch.ts +172 -0
  170. package/.agents/skills/gstack/scripts/gen-skill-docs.ts +2414 -0
  171. package/.agents/skills/gstack/scripts/skill-check.ts +167 -0
  172. package/.agents/skills/gstack/setup +269 -0
  173. package/.agents/skills/gstack/setup-browser-cookies/SKILL.md +330 -0
  174. package/.agents/skills/gstack/setup-browser-cookies/SKILL.md.tmpl +74 -0
  175. package/.agents/skills/gstack/setup-deploy/SKILL.md +459 -0
  176. package/.agents/skills/gstack/setup-deploy/SKILL.md.tmpl +220 -0
  177. package/.agents/skills/gstack/ship/SKILL.md +1457 -0
  178. package/.agents/skills/gstack/ship/SKILL.md.tmpl +528 -0
  179. package/.agents/skills/gstack/supabase/config.sh +10 -0
  180. package/.agents/skills/gstack/supabase/functions/community-pulse/index.ts +59 -0
  181. package/.agents/skills/gstack/supabase/functions/telemetry-ingest/index.ts +135 -0
  182. package/.agents/skills/gstack/supabase/functions/update-check/index.ts +37 -0
  183. package/.agents/skills/gstack/supabase/migrations/001_telemetry.sql +89 -0
  184. package/.agents/skills/gstack/test/analytics.test.ts +277 -0
  185. package/.agents/skills/gstack/test/codex-e2e.test.ts +197 -0
  186. package/.agents/skills/gstack/test/fixtures/coverage-audit-fixture.ts +76 -0
  187. package/.agents/skills/gstack/test/fixtures/eval-baselines.json +7 -0
  188. package/.agents/skills/gstack/test/fixtures/qa-eval-checkout-ground-truth.json +43 -0
  189. package/.agents/skills/gstack/test/fixtures/qa-eval-ground-truth.json +43 -0
  190. package/.agents/skills/gstack/test/fixtures/qa-eval-spa-ground-truth.json +43 -0
  191. package/.agents/skills/gstack/test/fixtures/review-eval-design-slop.css +86 -0
  192. package/.agents/skills/gstack/test/fixtures/review-eval-design-slop.html +41 -0
  193. package/.agents/skills/gstack/test/fixtures/review-eval-enum-diff.rb +30 -0
  194. package/.agents/skills/gstack/test/fixtures/review-eval-enum.rb +27 -0
  195. package/.agents/skills/gstack/test/fixtures/review-eval-vuln.rb +14 -0
  196. package/.agents/skills/gstack/test/gemini-e2e.test.ts +173 -0
  197. package/.agents/skills/gstack/test/gen-skill-docs.test.ts +1049 -0
  198. package/.agents/skills/gstack/test/global-discover.test.ts +187 -0
  199. package/.agents/skills/gstack/test/helpers/codex-session-runner.ts +282 -0
  200. package/.agents/skills/gstack/test/helpers/e2e-helpers.ts +239 -0
  201. package/.agents/skills/gstack/test/helpers/eval-store.test.ts +548 -0
  202. package/.agents/skills/gstack/test/helpers/eval-store.ts +689 -0
  203. package/.agents/skills/gstack/test/helpers/gemini-session-runner.test.ts +104 -0
  204. package/.agents/skills/gstack/test/helpers/gemini-session-runner.ts +201 -0
  205. package/.agents/skills/gstack/test/helpers/llm-judge.ts +130 -0
  206. package/.agents/skills/gstack/test/helpers/observability.test.ts +283 -0
  207. package/.agents/skills/gstack/test/helpers/session-runner.test.ts +96 -0
  208. package/.agents/skills/gstack/test/helpers/session-runner.ts +357 -0
  209. package/.agents/skills/gstack/test/helpers/skill-parser.ts +206 -0
  210. package/.agents/skills/gstack/test/helpers/touchfiles.ts +260 -0
  211. package/.agents/skills/gstack/test/hook-scripts.test.ts +373 -0
  212. package/.agents/skills/gstack/test/skill-e2e-browse.test.ts +293 -0
  213. package/.agents/skills/gstack/test/skill-e2e-deploy.test.ts +279 -0
  214. package/.agents/skills/gstack/test/skill-e2e-design.test.ts +614 -0
  215. package/.agents/skills/gstack/test/skill-e2e-plan.test.ts +538 -0
  216. package/.agents/skills/gstack/test/skill-e2e-qa-bugs.test.ts +194 -0
  217. package/.agents/skills/gstack/test/skill-e2e-qa-workflow.test.ts +412 -0
  218. package/.agents/skills/gstack/test/skill-e2e-review.test.ts +535 -0
  219. package/.agents/skills/gstack/test/skill-e2e-workflow.test.ts +586 -0
  220. package/.agents/skills/gstack/test/skill-e2e.test.ts +3325 -0
  221. package/.agents/skills/gstack/test/skill-llm-eval.test.ts +787 -0
  222. package/.agents/skills/gstack/test/skill-parser.test.ts +179 -0
  223. package/.agents/skills/gstack/test/skill-routing-e2e.test.ts +605 -0
  224. package/.agents/skills/gstack/test/skill-validation.test.ts +1520 -0
  225. package/.agents/skills/gstack/test/telemetry.test.ts +278 -0
  226. package/.agents/skills/gstack/test/touchfiles.test.ts +262 -0
  227. package/.agents/skills/gstack/unfreeze/SKILL.md +40 -0
  228. package/.agents/skills/gstack/unfreeze/SKILL.md.tmpl +38 -0
  229. package/package.json +2 -1
@@ -0,0 +1,36 @@
1
+ ---
2
+ name: unfreeze
3
+ description: |
4
+ Clear the freeze boundary set by /freeze, allowing edits to all directories
5
+ again. Use when you want to widen edit scope without ending the session.
6
+ Use when asked to "unfreeze", "unlock edits", "remove freeze", or
7
+ "allow all edits".
8
+ ---
9
+ <!-- AUTO-GENERATED from SKILL.md.tmpl — do not edit directly -->
10
+ <!-- Regenerate: bun run gen:skill-docs -->
11
+
12
+ # /unfreeze — Clear Freeze Boundary
13
+
14
+ Remove the edit restriction set by `/freeze`, allowing edits to all directories.
15
+
16
+ ```bash
17
+ mkdir -p ~/.gstack/analytics
18
+ echo '{"skill":"unfreeze","ts":"'$(date -u +%Y-%m-%dT%H:%M:%SZ)'","repo":"'$(basename "$(git rev-parse --show-toplevel 2>/dev/null)" 2>/dev/null || echo "unknown")'"}' >> ~/.gstack/analytics/skill-usage.jsonl 2>/dev/null || true
19
+ ```
20
+
21
+ ## Clear the boundary
22
+
23
+ ```bash
24
+ STATE_DIR="${CLAUDE_PLUGIN_DATA:-$HOME/.gstack}"
25
+ if [ -f "$STATE_DIR/freeze-dir.txt" ]; then
26
+ PREV=$(cat "$STATE_DIR/freeze-dir.txt")
27
+ rm -f "$STATE_DIR/freeze-dir.txt"
28
+ echo "Freeze boundary cleared (was: $PREV). Edits are now allowed everywhere."
29
+ else
30
+ echo "No freeze boundary was set."
31
+ fi
32
+ ```
33
+
34
+ Tell the user the result. Note that `/freeze` hooks are still registered for the
35
+ session — they will just allow everything since no state file exists. To re-freeze,
36
+ run `/freeze` again.
@@ -0,0 +1,220 @@
1
+ ---
2
+ name: gstack-upgrade
3
+ description: |
4
+ Upgrade gstack to the latest version. Detects global vs vendored install,
5
+ runs the upgrade, and shows what's new. Use when asked to "upgrade gstack",
6
+ "update gstack", or "get latest version".
7
+ ---
8
+ <!-- AUTO-GENERATED from SKILL.md.tmpl — do not edit directly -->
9
+ <!-- Regenerate: bun run gen:skill-docs -->
10
+
11
+ # /gstack-upgrade
12
+
13
+ Upgrade gstack to the latest version and show what's new.
14
+
15
+ ## Inline upgrade flow
16
+
17
+ This section is referenced by all skill preambles when they detect `UPGRADE_AVAILABLE`.
18
+
19
+ ### Step 1: Ask the user (or auto-upgrade)
20
+
21
+ First, check if auto-upgrade is enabled:
22
+ ```bash
23
+ _AUTO=""
24
+ [ "${GSTACK_AUTO_UPGRADE:-}" = "1" ] && _AUTO="true"
25
+ [ -z "$_AUTO" ] && _AUTO=$(~/.codex/skills/gstack/bin/gstack-config get auto_upgrade 2>/dev/null || true)
26
+ echo "AUTO_UPGRADE=$_AUTO"
27
+ ```
28
+
29
+ **If `AUTO_UPGRADE=true` or `AUTO_UPGRADE=1`:** Skip AskUserQuestion. Log "Auto-upgrading gstack v{old} → v{new}..." and proceed directly to Step 2. If `./setup` fails during auto-upgrade, restore from backup (`.bak` directory) and warn the user: "Auto-upgrade failed — restored previous version. Run `/gstack-upgrade` manually to retry."
30
+
31
+ **Otherwise**, use AskUserQuestion:
32
+ - Question: "gstack **v{new}** is available (you're on v{old}). Upgrade now?"
33
+ - Options: ["Yes, upgrade now", "Always keep me up to date", "Not now", "Never ask again"]
34
+
35
+ **If "Yes, upgrade now":** Proceed to Step 2.
36
+
37
+ **If "Always keep me up to date":**
38
+ ```bash
39
+ ~/.codex/skills/gstack/bin/gstack-config set auto_upgrade true
40
+ ```
41
+ Tell user: "Auto-upgrade enabled. Future updates will install automatically." Then proceed to Step 2.
42
+
43
+ **If "Not now":** Write snooze state with escalating backoff (first snooze = 24h, second = 48h, third+ = 1 week), then continue with the current skill. Do not mention the upgrade again.
44
+ ```bash
45
+ _SNOOZE_FILE=~/.gstack/update-snoozed
46
+ _REMOTE_VER="{new}"
47
+ _CUR_LEVEL=0
48
+ if [ -f "$_SNOOZE_FILE" ]; then
49
+ _SNOOZED_VER=$(awk '{print $1}' "$_SNOOZE_FILE")
50
+ if [ "$_SNOOZED_VER" = "$_REMOTE_VER" ]; then
51
+ _CUR_LEVEL=$(awk '{print $2}' "$_SNOOZE_FILE")
52
+ case "$_CUR_LEVEL" in *[!0-9]*) _CUR_LEVEL=0 ;; esac
53
+ fi
54
+ fi
55
+ _NEW_LEVEL=$((_CUR_LEVEL + 1))
56
+ [ "$_NEW_LEVEL" -gt 3 ] && _NEW_LEVEL=3
57
+ echo "$_REMOTE_VER $_NEW_LEVEL $(date +%s)" > "$_SNOOZE_FILE"
58
+ ```
59
+ Note: `{new}` is the remote version from the `UPGRADE_AVAILABLE` output — substitute it from the update check result.
60
+
61
+ Tell user the snooze duration: "Next reminder in 24h" (or 48h or 1 week, depending on level). Tip: "Set `auto_upgrade: true` in `~/.gstack/config.yaml` for automatic upgrades."
62
+
63
+ **If "Never ask again":**
64
+ ```bash
65
+ ~/.codex/skills/gstack/bin/gstack-config set update_check false
66
+ ```
67
+ Tell user: "Update checks disabled. Run `~/.codex/skills/gstack/bin/gstack-config set update_check true` to re-enable."
68
+ Continue with the current skill.
69
+
70
+ ### Step 2: Detect install type
71
+
72
+ ```bash
73
+ if [ -d "$HOME/.agents/skills/gstack/.git" ]; then
74
+ INSTALL_TYPE="global-git"
75
+ INSTALL_DIR="$HOME/.agents/skills/gstack"
76
+ elif [ -d ".agents/skills/gstack/.git" ]; then
77
+ INSTALL_TYPE="local-git"
78
+ INSTALL_DIR=".agents/skills/gstack"
79
+ elif [ -d ".agents/skills/gstack" ]; then
80
+ INSTALL_TYPE="vendored"
81
+ INSTALL_DIR=".agents/skills/gstack"
82
+ elif [ -d "$HOME/.agents/skills/gstack" ]; then
83
+ INSTALL_TYPE="vendored-global"
84
+ INSTALL_DIR="$HOME/.agents/skills/gstack"
85
+ else
86
+ echo "ERROR: gstack not found"
87
+ exit 1
88
+ fi
89
+ echo "Install type: $INSTALL_TYPE at $INSTALL_DIR"
90
+ ```
91
+
92
+ The install type and directory path printed above will be used in all subsequent steps.
93
+
94
+ ### Step 3: Save old version
95
+
96
+ Use the install directory from Step 2's output below:
97
+
98
+ ```bash
99
+ OLD_VERSION=$(cat "$INSTALL_DIR/VERSION" 2>/dev/null || echo "unknown")
100
+ ```
101
+
102
+ ### Step 4: Upgrade
103
+
104
+ Use the install type and directory detected in Step 2:
105
+
106
+ **For git installs** (global-git, local-git):
107
+ ```bash
108
+ cd "$INSTALL_DIR"
109
+ STASH_OUTPUT=$(git stash 2>&1)
110
+ git fetch origin
111
+ git reset --hard origin/main
112
+ ./setup
113
+ ```
114
+ If `$STASH_OUTPUT` contains "Saved working directory", warn the user: "Note: local changes were stashed. Run `git stash pop` in the skill directory to restore them."
115
+
116
+ **For vendored installs** (vendored, vendored-global):
117
+ ```bash
118
+ PARENT=$(dirname "$INSTALL_DIR")
119
+ TMP_DIR=$(mktemp -d)
120
+ git clone --depth 1 https://github.com/garrytan/gstack.git "$TMP_DIR/gstack"
121
+ mv "$INSTALL_DIR" "$INSTALL_DIR.bak"
122
+ mv "$TMP_DIR/gstack" "$INSTALL_DIR"
123
+ cd "$INSTALL_DIR" && ./setup
124
+ rm -rf "$INSTALL_DIR.bak" "$TMP_DIR"
125
+ ```
126
+
127
+ ### Step 4.5: Sync local vendored copy
128
+
129
+ Use the install directory from Step 2. Check if there's also a local vendored copy that needs updating:
130
+
131
+ ```bash
132
+ _ROOT=$(git rev-parse --show-toplevel 2>/dev/null)
133
+ LOCAL_GSTACK=""
134
+ if [ -n "$_ROOT" ] && [ -d "$_ROOT/.agents/skills/gstack" ]; then
135
+ _RESOLVED_LOCAL=$(cd "$_ROOT/.agents/skills/gstack" && pwd -P)
136
+ _RESOLVED_PRIMARY=$(cd "$INSTALL_DIR" && pwd -P)
137
+ if [ "$_RESOLVED_LOCAL" != "$_RESOLVED_PRIMARY" ]; then
138
+ LOCAL_GSTACK="$_ROOT/.agents/skills/gstack"
139
+ fi
140
+ fi
141
+ echo "LOCAL_GSTACK=$LOCAL_GSTACK"
142
+ ```
143
+
144
+ If `LOCAL_GSTACK` is non-empty, update it by copying from the freshly-upgraded primary install (same approach as README vendored install):
145
+ ```bash
146
+ mv "$LOCAL_GSTACK" "$LOCAL_GSTACK.bak"
147
+ cp -Rf "$INSTALL_DIR" "$LOCAL_GSTACK"
148
+ rm -rf "$LOCAL_GSTACK/.git"
149
+ cd "$LOCAL_GSTACK" && ./setup
150
+ rm -rf "$LOCAL_GSTACK.bak"
151
+ ```
152
+ Tell user: "Also updated vendored copy at `$LOCAL_GSTACK` — commit `.agents/skills/gstack/` when you're ready."
153
+
154
+ If `./setup` fails, restore from backup and warn the user:
155
+ ```bash
156
+ rm -rf "$LOCAL_GSTACK"
157
+ mv "$LOCAL_GSTACK.bak" "$LOCAL_GSTACK"
158
+ ```
159
+ Tell user: "Sync failed — restored previous version at `$LOCAL_GSTACK`. Run `/gstack-upgrade` manually to retry."
160
+
161
+ ### Step 5: Write marker + clear cache
162
+
163
+ ```bash
164
+ mkdir -p ~/.gstack
165
+ echo "$OLD_VERSION" > ~/.gstack/just-upgraded-from
166
+ rm -f ~/.gstack/last-update-check
167
+ rm -f ~/.gstack/update-snoozed
168
+ ```
169
+
170
+ ### Step 6: Show What's New
171
+
172
+ Read `$INSTALL_DIR/CHANGELOG.md`. Find all version entries between the old version and the new version. Summarize as 5-7 bullets grouped by theme. Don't overwhelm — focus on user-facing changes. Skip internal refactors unless they're significant.
173
+
174
+ Format:
175
+ ```
176
+ gstack v{new} — upgraded from v{old}!
177
+
178
+ What's new:
179
+ - [bullet 1]
180
+ - [bullet 2]
181
+ - ...
182
+
183
+ Happy shipping!
184
+ ```
185
+
186
+ ### Step 7: Continue
187
+
188
+ After showing What's New, continue with whatever skill the user originally invoked. The upgrade is done — no further action needed.
189
+
190
+ ---
191
+
192
+ ## Standalone usage
193
+
194
+ When invoked directly as `/gstack-upgrade` (not from a preamble):
195
+
196
+ 1. Force a fresh update check (bypass cache):
197
+ ```bash
198
+ ~/.codex/skills/gstack/bin/gstack-update-check --force 2>/dev/null || \
199
+ .agents/skills/gstack/bin/gstack-update-check --force 2>/dev/null || true
200
+ ```
201
+ Use the output to determine if an upgrade is available.
202
+
203
+ 2. If `UPGRADE_AVAILABLE <old> <new>`: follow Steps 2-6 above.
204
+
205
+ 3. If no output (primary is up to date): check for a stale local vendored copy.
206
+
207
+ Run the Step 2 bash block above to detect the primary install type and directory (`INSTALL_TYPE` and `INSTALL_DIR`). Then run the Step 4.5 detection bash block above to check for a local vendored copy (`LOCAL_GSTACK`).
208
+
209
+ **If `LOCAL_GSTACK` is empty** (no local vendored copy): tell the user "You're already on the latest version (v{version})."
210
+
211
+ **If `LOCAL_GSTACK` is non-empty**, compare versions:
212
+ ```bash
213
+ PRIMARY_VER=$(cat "$INSTALL_DIR/VERSION" 2>/dev/null || echo "unknown")
214
+ LOCAL_VER=$(cat "$LOCAL_GSTACK/VERSION" 2>/dev/null || echo "unknown")
215
+ echo "PRIMARY=$PRIMARY_VER LOCAL=$LOCAL_VER"
216
+ ```
217
+
218
+ **If versions differ:** follow the Step 4.5 sync bash block above to update the local copy from the primary. Tell user: "Global v{PRIMARY_VER} is up to date. Updated local vendored copy from v{LOCAL_VER} → v{PRIMARY_VER}. Commit `.agents/skills/gstack/` when you're ready."
219
+
220
+ **If versions match:** tell the user "You're on the latest version (v{PRIMARY_VER}). Global and local vendored copy are both up to date."
@@ -0,0 +1,5 @@
1
+ # Copy to .env and fill in values
2
+ # bun auto-loads .env — no dotenv needed
3
+
4
+ # Required for LLM-as-judge evals (bun run test:eval)
5
+ ANTHROPIC_API_KEY=sk-ant-your-key-here
@@ -0,0 +1,17 @@
1
+ name: Skill Docs Freshness
2
+ on: [push, pull_request]
3
+ jobs:
4
+ check-freshness:
5
+ runs-on: ubuntu-latest
6
+ steps:
7
+ - uses: actions/checkout@v4
8
+ - uses: oven-sh/setup-bun@v2
9
+ - run: bun install
10
+ - name: Check Claude host freshness
11
+ run: bun run gen:skill-docs
12
+ - run: |
13
+ git diff --exit-code || (echo "Generated SKILL.md files are stale. Run: bun run gen:skill-docs" && exit 1)
14
+ - name: Check Codex host freshness
15
+ run: bun run gen:skill-docs --host codex
16
+ - run: |
17
+ git diff --exit-code -- .agents/ || (echo "Generated Codex SKILL.md files are stale. Run: bun run gen:skill-docs --host codex" && exit 1)
@@ -0,0 +1,49 @@
1
+ # gstack — AI Engineering Workflow
2
+
3
+ gstack is a collection of SKILL.md files that give AI agents structured roles for
4
+ software development. Each skill is a specialist: CEO reviewer, eng manager,
5
+ designer, QA lead, release engineer, debugger, and more.
6
+
7
+ ## Available skills
8
+
9
+ Skills live in `.agents/skills/`. Invoke them by name (e.g., `/office-hours`).
10
+
11
+ | Skill | What it does |
12
+ |-------|-------------|
13
+ | `/office-hours` | Start here. Reframes your product idea before you write code. |
14
+ | `/plan-ceo-review` | CEO-level review: find the 10-star product in the request. |
15
+ | `/plan-eng-review` | Lock architecture, data flow, edge cases, and tests. |
16
+ | `/plan-design-review` | Rate each design dimension 0-10, explain what a 10 looks like. |
17
+ | `/design-consultation` | Build a complete design system from scratch. |
18
+ | `/review` | Pre-landing PR review. Finds bugs that pass CI but break in prod. |
19
+ | `/debug` | Systematic root-cause debugging. No fixes without investigation. |
20
+ | `/design-review` | Design audit + fix loop with atomic commits. |
21
+ | `/qa` | Open a real browser, find bugs, fix them, re-verify. |
22
+ | `/qa-only` | Same as /qa but report only — no code changes. |
23
+ | `/ship` | Run tests, review, push, open PR. One command. |
24
+ | `/document-release` | Update all docs to match what you just shipped. |
25
+ | `/retro` | Weekly retro with per-person breakdowns and shipping streaks. |
26
+ | `/browse` | Headless browser — real Chromium, real clicks, ~100ms/command. |
27
+ | `/setup-browser-cookies` | Import cookies from your real browser for authenticated testing. |
28
+ | `/careful` | Warn before destructive commands (rm -rf, DROP TABLE, force-push). |
29
+ | `/freeze` | Lock edits to one directory. Hard block, not just a warning. |
30
+ | `/guard` | Activate both careful + freeze at once. |
31
+ | `/unfreeze` | Remove directory edit restrictions. |
32
+ | `/gstack-upgrade` | Update gstack to the latest version. |
33
+
34
+ ## Build commands
35
+
36
+ ```bash
37
+ bun install # install dependencies
38
+ bun test # run tests (free, <5s)
39
+ bun run build # generate docs + compile binaries
40
+ bun run gen:skill-docs # regenerate SKILL.md files from templates
41
+ bun run skill:check # health dashboard for all skills
42
+ ```
43
+
44
+ ## Key conventions
45
+
46
+ - SKILL.md files are **generated** from `.tmpl` templates. Edit the template, not the output.
47
+ - Run `bun run gen:skill-docs --host codex` to regenerate Codex-specific output.
48
+ - The browse binary provides headless browser access. Use `$B <command>` in skills.
49
+ - Safety skills (careful, freeze, guard) use inline advisory prose — always confirm before destructive operations.