Git worktrees
Each agent runs in its own git worktree—a separate directory on a separate branch—so parallel agents never step on each other. You configure setup, scripts, and long-running services through a amadev.json file at your repo root.
Layout and workflow
Worktrees live under $AMADEV_HOME/worktrees/, grouped by a hash of the source checkout path. Each worktree gets a random slug; the branch name is chosen when you first launch an agent.
~/.amadev/worktrees/
└── 1vnnm9k3/ # hash of source checkout path
├── tidy-fox/ # worktree slug (branch set on first agent)
└── bold-owl/
- Create a worktree, Amadev runs your setup hooks.
- Launch an agent, a branch is created or assigned.
- Review the diff against the base branch.
- Merge or archive. Archive runs teardown and removes the directory.
amadev.json
Drop a amadev.json in your repo root. Amadev reads it from the committed version of the base branch you picked, so uncommitted changes in other branches don't apply.
{
"worktree": {
"setup": "npm ci",
"teardown": "rm -rf .cache"
},
"scripts": {
"test": {
"command": "npm test"
},
"web": {
"command": "npm run dev",
"type": "service",
"port": 3000
}
}
}
Setup and teardown
setup runs once after the worktree is created. A fresh worktree has no installed dependencies and no ignored files (like .env), so use setup to install and copy what you need. teardown runs during archive, before the directory is removed.
{
"worktree": {
"setup": "npm ci\ncp \"$AMADEV_SOURCE_CHECKOUT_PATH/.env\" .env\nnpm run db:migrate",
"teardown": "npm run db:migrate:rollback || true"
}
}
Both fields accept a multiline shell script or an array of commands; commands run sequentially either way. Commands run with the worktree as cwd. Use $AMADEV_SOURCE_CHECKOUT_PATH to reach files in the original checkout (untracked config, local caches, etc).
Scripts and services
scripts are named commands you can run inside a worktree on demand. Mark one as a service and Amadev supervises it as a long-running process, assigns it a port, and routes HTTP traffic to it through the daemon's reverse proxy.
Plain scripts
{
"scripts": {
"test": { "command": "npm test" },
"lint": { "command": "npm run lint" }
}
}
Services
{
"scripts": {
"web": {
"type": "service",
"command": "npm run dev -- --port $AMADEV_PORT",
"port": 3000
},
"api": {
"type": "service",
"command": "npm run api -- --port $AMADEV_PORT"
}
}
}
Omit port to let Amadev auto-assign one. Bind your process to $AMADEV_PORT rather than hard-coding; each worktree gets a distinct port so multiple copies of the same service can coexist.
Reverse proxy
Every service is reachable through the daemon at a deterministic hostname:
http://<script>.<branch>.<project>.localhost:<daemon-port>
On the default branch, the branch label is dropped: http://<script>.<project>.localhost:<daemon-port>
*.localhost resolves to 127.0.0.1 on modern systems, so these URLs work out of the box. The proxy supports WebSocket upgrades.
Service-to-service
Services launched from the same workspace see each other's ports and proxy URLs. Given web and api above, each process gets:
$AMADEV_PORT=3000(this service's port)$AMADEV_URL=http://web.my-app.localhost:6767(this service's proxy URL)$AMADEV_SERVICE_API_PORT=51732$AMADEV_SERVICE_API_URL=http://api.my-app.localhost:6767
Script names are upper-cased and non-alphanumerics become _. Point your frontend at $AMADEV_SERVICE_API_URL instead of hard-coding a port.
Terminals
Open terminals automatically when a worktree is created. Useful for tailing logs or leaving a REPL ready to go.
{
"worktree": {
"terminals": [
{ "name": "logs", "command": "tail -f dev.log" },
{ "name": "shell", "command": "bash" }
]
}
}
Environment variables
Setup, teardown, scripts, and services all see:
$AMADEV_SOURCE_CHECKOUT_PATH: the original repo root$AMADEV_WORKTREE_PATH: the worktree directory$AMADEV_BRANCH_NAME: the worktree's branch$AMADEV_PORT: the assigned port (for services)$AMADEV_URL: the proxy URL (for services)$AMADEV_SERVICE_<NAME>_PORT/_URL: peer service ports and URLs
CLI
amadev run --worktree feature-auth --base main "implement auth"
amadev worktree ls
amadev worktree archive feature-auth
