mirror of
https://github.com/obra/superpowers.git
synced 2026-07-01 06:59:06 +08:00
Compare commits
4 Commits
codex/read
...
e795530c23
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
e795530c23 | ||
|
|
28fd7a8192 | ||
|
|
831f6f977c | ||
|
|
5745f0ea99 |
146
README.md
146
README.md
@@ -2,6 +2,10 @@
|
|||||||
|
|
||||||
Superpowers is a complete software development methodology for your coding agents, built on top of a set of composable skills and some initial instructions that make sure your agent uses them.
|
Superpowers is a complete software development methodology for your coding agents, built on top of a set of composable skills and some initial instructions that make sure your agent uses them.
|
||||||
|
|
||||||
|
## Quickstart
|
||||||
|
|
||||||
|
Give your agent Superpowers: [Claude Code](#claude-code), [Codex CLI](#codex-cli), [Codex App](#codex-app), [Factory Droid](#factory-droid), [Gemini CLI](#gemini-cli), [OpenCode](#opencode), [Cursor](#cursor), [GitHub Copilot CLI](#github-copilot-cli).
|
||||||
|
|
||||||
## How it works
|
## How it works
|
||||||
|
|
||||||
It starts from the moment you fire up your coding agent. As soon as it sees that you're building something, it *doesn't* just jump into trying to write code. Instead, it steps back and asks you what you're really trying to do.
|
It starts from the moment you fire up your coding agent. As soon as it sees that you're building something, it *doesn't* just jump into trying to write code. Instead, it steps back and asks you what you're really trying to do.
|
||||||
@@ -26,112 +30,126 @@ Thanks!
|
|||||||
|
|
||||||
## Installation
|
## Installation
|
||||||
|
|
||||||
**Note:** Installation differs by platform.
|
Installation differs by harness. If you use more than one, install Superpowers separately for each one.
|
||||||
|
|
||||||
### Claude Code Official Marketplace
|
### Claude Code
|
||||||
|
|
||||||
Superpowers is available via the [official Claude plugin marketplace](https://claude.com/plugins/superpowers)
|
Superpowers is available via the [official Claude plugin marketplace](https://claude.com/plugins/superpowers)
|
||||||
|
|
||||||
Install the plugin from Anthropic's official marketplace:
|
#### Official Marketplace
|
||||||
|
|
||||||
```bash
|
- Install the plugin from Anthropic's official marketplace:
|
||||||
/plugin install superpowers@claude-plugins-official
|
|
||||||
```
|
|
||||||
|
|
||||||
### Claude Code (Superpowers Marketplace)
|
```bash
|
||||||
|
/plugin install superpowers@claude-plugins-official
|
||||||
|
```
|
||||||
|
|
||||||
|
#### Superpowers Marketplace
|
||||||
|
|
||||||
The Superpowers marketplace provides Superpowers and some other related plugins for Claude Code.
|
The Superpowers marketplace provides Superpowers and some other related plugins for Claude Code.
|
||||||
|
|
||||||
In Claude Code, register the marketplace first:
|
- Register the marketplace:
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
/plugin marketplace add obra/superpowers-marketplace
|
/plugin marketplace add obra/superpowers-marketplace
|
||||||
```
|
```
|
||||||
|
|
||||||
Then install the plugin from this marketplace:
|
- Install the plugin from this marketplace:
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
/plugin install superpowers@superpowers-marketplace
|
/plugin install superpowers@superpowers-marketplace
|
||||||
```
|
```
|
||||||
|
|
||||||
### OpenAI Codex CLI
|
### Codex CLI
|
||||||
|
|
||||||
- Open plugin search interface
|
Superpowers is available via the [official Codex plugin marketplace](https://github.com/openai/plugins).
|
||||||
|
|
||||||
```bash
|
- Open the plugin search interface:
|
||||||
/plugins
|
|
||||||
```
|
|
||||||
|
|
||||||
Search for Superpowers
|
```bash
|
||||||
|
/plugins
|
||||||
|
```
|
||||||
|
|
||||||
```bash
|
- Search for Superpowers:
|
||||||
superpowers
|
|
||||||
```
|
|
||||||
|
|
||||||
Select `Install Plugin`
|
```bash
|
||||||
|
superpowers
|
||||||
|
```
|
||||||
|
|
||||||
### OpenAI Codex App
|
- Select `Install Plugin`.
|
||||||
|
|
||||||
|
### Codex App
|
||||||
|
|
||||||
|
Superpowers is available via the [official Codex plugin marketplace](https://github.com/openai/plugins).
|
||||||
|
|
||||||
- In the Codex app, click on Plugins in the sidebar.
|
- In the Codex app, click on Plugins in the sidebar.
|
||||||
- You should see `Superpowers` in the Coding section.
|
- You should see `Superpowers` in the Coding section.
|
||||||
- Click the `+` next to Superpowers and follow the prompts.
|
- Click the `+` next to Superpowers and follow the prompts.
|
||||||
|
|
||||||
|
### Factory Droid
|
||||||
|
|
||||||
### Cursor (via Plugin Marketplace)
|
- Register the marketplace:
|
||||||
|
|
||||||
In Cursor Agent chat, install from marketplace:
|
```bash
|
||||||
|
droid plugin marketplace add https://github.com/obra/superpowers
|
||||||
|
```
|
||||||
|
|
||||||
```text
|
- Install the plugin:
|
||||||
/add-plugin superpowers
|
|
||||||
```
|
|
||||||
|
|
||||||
or search for "superpowers" in the plugin marketplace.
|
```bash
|
||||||
|
droid plugin install superpowers@superpowers
|
||||||
|
```
|
||||||
|
|
||||||
|
### Gemini CLI
|
||||||
|
|
||||||
|
- Install the extension:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
gemini extensions install https://github.com/obra/superpowers
|
||||||
|
```
|
||||||
|
|
||||||
|
- Update later:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
gemini extensions update superpowers
|
||||||
|
```
|
||||||
|
|
||||||
### OpenCode
|
### OpenCode
|
||||||
|
|
||||||
OpenCode uses its own plugin install; install Superpowers separately even if you
|
OpenCode uses its own plugin install; install Superpowers separately even if you
|
||||||
already use it in another harness.
|
already use it in another harness.
|
||||||
|
|
||||||
Tell OpenCode:
|
- Tell OpenCode:
|
||||||
|
|
||||||
```
|
```
|
||||||
Fetch and follow instructions from https://raw.githubusercontent.com/obra/superpowers/refs/heads/main/.opencode/INSTALL.md
|
Fetch and follow instructions from https://raw.githubusercontent.com/obra/superpowers/refs/heads/main/.opencode/INSTALL.md
|
||||||
```
|
```
|
||||||
|
|
||||||
**Detailed docs:** [docs/README.opencode.md](docs/README.opencode.md)
|
- Detailed docs: [docs/README.opencode.md](docs/README.opencode.md)
|
||||||
|
|
||||||
|
### Cursor
|
||||||
|
|
||||||
|
- In Cursor Agent chat, install from marketplace:
|
||||||
|
|
||||||
|
```text
|
||||||
|
/add-plugin superpowers
|
||||||
|
```
|
||||||
|
|
||||||
|
- Or search for "superpowers" in the plugin marketplace.
|
||||||
|
|
||||||
### GitHub Copilot CLI
|
### GitHub Copilot CLI
|
||||||
|
|
||||||
```bash
|
- Register the marketplace:
|
||||||
copilot plugin marketplace add obra/superpowers-marketplace
|
|
||||||
copilot plugin install superpowers@superpowers-marketplace
|
|
||||||
```
|
|
||||||
|
|
||||||
### Gemini CLI
|
```bash
|
||||||
|
copilot plugin marketplace add obra/superpowers-marketplace
|
||||||
|
```
|
||||||
|
|
||||||
```bash
|
- Install the plugin:
|
||||||
gemini extensions install https://github.com/obra/superpowers
|
|
||||||
```
|
|
||||||
|
|
||||||
To update:
|
```bash
|
||||||
|
copilot plugin install superpowers@superpowers-marketplace
|
||||||
```bash
|
```
|
||||||
gemini extensions update superpowers
|
|
||||||
```
|
|
||||||
|
|
||||||
### Factory Droid
|
|
||||||
|
|
||||||
In Droid, register the marketplace:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
droid plugin marketplace add https://github.com/obra/superpowers
|
|
||||||
```
|
|
||||||
|
|
||||||
Then install:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
droid plugin install superpowers@superpowers
|
|
||||||
```
|
|
||||||
|
|
||||||
## The Basic Workflow
|
## The Basic Workflow
|
||||||
|
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
"hooks": {
|
"hooks": {
|
||||||
"sessionStart": [
|
"sessionStart": [
|
||||||
{
|
{
|
||||||
"command": "./hooks/session-start"
|
"command": "./hooks/run-hook.cmd session-start"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -6,7 +6,7 @@ Skills use Claude Code tool names. When you encounter these in a skill, use your
|
|||||||
|-----------------|------------------|
|
|-----------------|------------------|
|
||||||
| `Task` tool (dispatch subagent) | `spawn_agent` (see [Named agent dispatch](#named-agent-dispatch)) |
|
| `Task` tool (dispatch subagent) | `spawn_agent` (see [Named agent dispatch](#named-agent-dispatch)) |
|
||||||
| Multiple `Task` calls (parallel) | Multiple `spawn_agent` calls |
|
| Multiple `Task` calls (parallel) | Multiple `spawn_agent` calls |
|
||||||
| Task returns result | `wait` |
|
| Task returns result | `wait_agent` |
|
||||||
| Task completes automatically | `close_agent` to free slot |
|
| Task completes automatically | `close_agent` to free slot |
|
||||||
| `TodoWrite` (task tracking) | `update_plan` |
|
| `TodoWrite` (task tracking) | `update_plan` |
|
||||||
| `Skill` tool (invoke a skill) | Skills load natively — just follow the instructions |
|
| `Skill` tool (invoke a skill) | Skills load natively — just follow the instructions |
|
||||||
@@ -22,7 +22,12 @@ Add to your Codex config (`~/.codex/config.toml`):
|
|||||||
multi_agent = true
|
multi_agent = true
|
||||||
```
|
```
|
||||||
|
|
||||||
This enables `spawn_agent`, `wait`, and `close_agent` for skills like `dispatching-parallel-agents` and `subagent-driven-development`.
|
This enables `spawn_agent`, `wait_agent`, and `close_agent` for skills like `dispatching-parallel-agents` and `subagent-driven-development`.
|
||||||
|
|
||||||
|
Legacy note: Codex builds before `rust-v0.115.0` exposed spawned-agent
|
||||||
|
waiting as `wait`. Current Codex uses `wait_agent` for spawned agents. The
|
||||||
|
`wait` name now belongs to code-mode `exec/wait`, which resumes a yielded exec
|
||||||
|
cell by `cell_id`; it is not the spawned-agent result tool.
|
||||||
|
|
||||||
## Named agent dispatch
|
## Named agent dispatch
|
||||||
|
|
||||||
|
|||||||
@@ -135,8 +135,7 @@ EOF
|
|||||||
|
|
||||||
# Note: We use a longer timeout since this is integration testing
|
# Note: We use a longer timeout since this is integration testing
|
||||||
# Use --allowed-tools to enable tool usage in headless mode
|
# Use --allowed-tools to enable tool usage in headless mode
|
||||||
# IMPORTANT: Run from superpowers directory so local dev skills are available
|
PROMPT="Execute the implementation plan at docs/superpowers/plans/implementation-plan.md using the subagent-driven-development skill.
|
||||||
PROMPT="Change to directory $TEST_PROJECT and then execute the implementation plan at docs/superpowers/plans/implementation-plan.md using the subagent-driven-development skill.
|
|
||||||
|
|
||||||
IMPORTANT: Follow the skill exactly. I will be verifying that you:
|
IMPORTANT: Follow the skill exactly. I will be verifying that you:
|
||||||
1. Read the plan once at the beginning
|
1. Read the plan once at the beginning
|
||||||
@@ -147,9 +146,14 @@ IMPORTANT: Follow the skill exactly. I will be verifying that you:
|
|||||||
|
|
||||||
Begin now. Execute the plan."
|
Begin now. Execute the plan."
|
||||||
|
|
||||||
echo "Running Claude (output will be shown below and saved to $OUTPUT_FILE)..."
|
PLUGIN_DIR=$(cd "$SCRIPT_DIR/../.." && pwd)
|
||||||
|
|
||||||
|
# Run claude from inside the test project so its session JSONL lands in a
|
||||||
|
# project-specific directory under ~/.claude/projects/, isolated from any
|
||||||
|
# other concurrent claude sessions.
|
||||||
|
echo "Running Claude (plugin-dir: $PLUGIN_DIR, cwd: $TEST_PROJECT)..."
|
||||||
echo "================================================================================"
|
echo "================================================================================"
|
||||||
cd "$SCRIPT_DIR/../.." && timeout 1800 claude -p "$PROMPT" --allowed-tools=all --add-dir "$TEST_PROJECT" --permission-mode bypassPermissions 2>&1 | tee "$OUTPUT_FILE" || {
|
cd "$TEST_PROJECT" && timeout 1800 claude -p "$PROMPT" --plugin-dir "$PLUGIN_DIR" --allowed-tools=all --permission-mode bypassPermissions 2>&1 | tee "$OUTPUT_FILE" || {
|
||||||
echo ""
|
echo ""
|
||||||
echo "================================================================================"
|
echo "================================================================================"
|
||||||
echo "EXECUTION FAILED (exit code: $?)"
|
echo "EXECUTION FAILED (exit code: $?)"
|
||||||
@@ -161,13 +165,17 @@ echo ""
|
|||||||
echo "Execution complete. Analyzing results..."
|
echo "Execution complete. Analyzing results..."
|
||||||
echo ""
|
echo ""
|
||||||
|
|
||||||
# Find the session transcript
|
# Find the session transcript. Because we ran claude from $TEST_PROJECT (a
|
||||||
# Session files are in ~/.claude/projects/-<working-dir>/<session-id>.jsonl
|
# unique tmp dir), its sessions live in their own ~/.claude/projects/ folder
|
||||||
WORKING_DIR_ESCAPED=$(echo "$SCRIPT_DIR/../.." | sed 's/\//-/g' | sed 's/^-//')
|
# and we can pick the most-recent one without racing other concurrent sessions.
|
||||||
SESSION_DIR="$HOME/.claude/projects/$WORKING_DIR_ESCAPED"
|
# Resolve the real path because macOS mktemp returns /var/... but claude
|
||||||
|
# normalizes it to /private/var/... when naming the project dir.
|
||||||
# Find the most recent session file (created during this test run)
|
TEST_PROJECT_REAL=$(cd "$TEST_PROJECT" && pwd -P)
|
||||||
SESSION_FILE=$(find "$SESSION_DIR" -name "*.jsonl" -type f -mmin -60 2>/dev/null | sort -r | head -1)
|
# Claude normalizes the cwd to a directory name by replacing every non-alphanumeric
|
||||||
|
# character with `-` (so `_`, `.`, `/` all become `-`).
|
||||||
|
SESSION_DIR="$HOME/.claude/projects/$(echo "$TEST_PROJECT_REAL" | sed 's|[^a-zA-Z0-9]|-|g')"
|
||||||
|
# `|| true` prevents pipefail killing the script if ls gets SIGPIPE'd by head.
|
||||||
|
SESSION_FILE=$(ls -t "$SESSION_DIR"/*.jsonl 2>/dev/null | head -1 || true)
|
||||||
|
|
||||||
if [ -z "$SESSION_FILE" ]; then
|
if [ -z "$SESSION_FILE" ]; then
|
||||||
echo "ERROR: Could not find session transcript file"
|
echo "ERROR: Could not find session transcript file"
|
||||||
@@ -194,9 +202,9 @@ else
|
|||||||
fi
|
fi
|
||||||
echo ""
|
echo ""
|
||||||
|
|
||||||
# Test 2: Subagents were used (Task tool)
|
# Test 2: Subagents were used (Agent / Task tool — name varies by harness version)
|
||||||
echo "Test 2: Subagents dispatched..."
|
echo "Test 2: Subagents dispatched..."
|
||||||
task_count=$(grep -c '"name":"Task"' "$SESSION_FILE" || echo "0")
|
task_count=$(grep -cE '"name":"(Agent|Task)"' "$SESSION_FILE" || echo "0")
|
||||||
if [ "$task_count" -ge 2 ]; then
|
if [ "$task_count" -ge 2 ]; then
|
||||||
echo " [PASS] $task_count subagents dispatched"
|
echo " [PASS] $task_count subagents dispatched"
|
||||||
else
|
else
|
||||||
|
|||||||
Reference in New Issue
Block a user