Protocol-driven agent loops for shipping real code with less babysitting.
Project description
Autoloop
Protocol-driven agent loops for shipping real code with less babysitting.
Autoloop is a stateful orchestration runtime for repository work. It runs plan, implement, and test producer/verifier pairs with durable state, resumable runs, phase scoping, provider-neutral sessions, and git-backed checkpoints.
Requirements
- Python 3.10+
- One supported provider CLI:
codexforprovider.name: codex(default)claudeforprovider.name: claude, with localclaude auth statusalready working
gitis optional when running with--no-git
Install
Install from PyPI:
python3 -m pip install autoloop
autoloop --help
Install from this repository:
python3 -m pip install -e .
autoloop --help
python3 -m autoloop --help
Or use the bundled installer:
./install_autoloop.sh
The installer sets up Autoloop itself and the packaged skill, but it does not install provider CLIs for you. Install codex or claude separately based on the provider you plan to run.
Reruns are intentionally conservative: use ./install_autoloop.sh --dry-run to preview changes, --overwrite to replace an existing launcher or skill file, --recreate-venv to replace an existing virtualenv, and --skill-target both|codex|agents|none to control where the packaged skill is installed.
Quickstart
Put config in either:
~/.config/autoloop/autoloop.yaml(or$XDG_CONFIG_HOME/autoloop/autoloop.yaml) for global defaults/path/to/workspace/autoloop.yamlfor workspace-local overrides
Minimal Codex config:
provider:
name: codex
Minimal Claude config:
provider:
name: claude
First run:
autoloop --workspace /path/to/workspace --intent "Describe the task you want shipped"
Expected success artifacts under the workspace:
.autoloop/tasks/<task-id>/request.md.autoloop/tasks/<task-id>/runs/<run-id>/raw_phase_log.md.autoloop/tasks/<task-id>/runs/<run-id>/events.jsonl
Useful follow-up commands:
autoloop --workspace /path/to/workspace --list-tasks
autoloop --workspace /path/to/workspace --task-id <task-id> --resume
Troubleshooting:
| Symptom | Fix |
|---|---|
codex is missing for the default setup |
Install Codex with npm i -g @openai/codex, or switch to provider.name: claude and verify claude auth status. |
autoloop command is not found after running the installer |
Add the installer bin directory to PATH, or run python3 -m autoloop --help from the repo checkout. |
| Autoloop is not picking up your config | Put exactly one autoloop.yaml or autoloop.config file in the global config directory or workspace root. |
git is unavailable |
Install git, or run Autoloop with --no-git if you do not need checkpoints. |
Configuration
Autoloop reads configuration from these directories, in this order:
$XDG_CONFIG_HOME/autoloop/or~/.config/autoloop/- the selected workspace root passed to
--workspace
Within each directory it looks for:
autoloop.yamlautoloop.config- legacy read-only fallback:
superloop.yaml - legacy read-only fallback:
superloop.config
If more than one config file exists in the same directory, Autoloop fails fast instead of guessing.
Use the nested provider shape for new configs:
provider:
name: codex
codex:
model: gpt-5.4
model_effort: null
claude:
model: null
effort: null
permission_strategy: inherit
runtime:
pairs: plan,implement,test
max_iterations: 15
phase_mode: single
intent_mode: preserve
full_auto_answers: false
no_git: false
Notes:
- Legacy flat Codex keys
provider.modelandprovider.model_effortare still read for backward compatibility. --modeland--model-effortare Codex-only CLI overrides.- Claude defaults intentionally inherit the operator's existing Claude Code environment. Default Claude runs do not add strict mode,
--bare, tool restriction flags, orstream-json. runtime.full_auto_answersnow uses the active provider instead of being Codex-only.
Runtime State
Fresh runs write state under .autoloop/.
For the first Autoloop release, resume and task listing can still read legacy .superloop/ workspaces when no .autoloop/ state exists for the requested task or run.
Session files now store provider-neutral provider and session_id fields. Legacy Codex session files that only contain thread_id remain load-compatible.
Claude Validation
Maintainer live-validation steps for inherited-environment Claude repos and resume config-drift checks are recorded in docs/claude_rollout_checklist.md.
Skill
The packaged Autoloop skill lives at src/autoloop/skill/SKILL.md.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file autoloop-0.1.2.tar.gz.
File metadata
- Download URL: autoloop-0.1.2.tar.gz
- Upload date:
- Size: 84.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8183254cd90cdc7283174165c49d443cb5588574f46a146665915bdc191dbda2
|
|
| MD5 |
9159eaafb6a5deb92f04e9d66e951827
|
|
| BLAKE2b-256 |
1e554429c828bf3e4c3c5c00c057fabb030b1c091602beb5e7482fa823fccac2
|
File details
Details for the file autoloop-0.1.2-py3-none-any.whl.
File metadata
- Download URL: autoloop-0.1.2-py3-none-any.whl
- Upload date:
- Size: 63.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
843c01d7ccffd472f78738168f040fccbe6aa6d9dc92ab5a0bddcb18075e308c
|
|
| MD5 |
d0e95ac771a25632b483e22fde9d01a3
|
|
| BLAKE2b-256 |
b60340c6b565688b4f8956e40ebe823abbd2705d07feb5166e9cd3894a121a24
|