@adamjen/pi-agent-turn-limiter
Forces the pi orchestrator to delegate to a subagent after N turns — prevents getting stuck in endless work loops.
Package details
Install @adamjen/pi-agent-turn-limiter from npm and Pi will load the resources declared by the package manifest.
$ pi install npm:@adamjen/pi-agent-turn-limiter- Package
@adamjen/pi-agent-turn-limiter- Version
0.1.3- Published
- May 23, 2026
- Downloads
- not available
- Author
- adamjen
- License
- MIT
- Types
- extension
- Size
- 2 MB
- Dependencies
- 0 dependencies · 0 peers
Pi manifest JSON
{
"extensions": [
"extensions/agent-turn-limiter.ts"
],
"image": "https://raw.githubusercontent.com/adamjen/pi-agent-turn-limiter/master/screenshot.png"
}Security note
Pi packages can execute code and influence agent behavior. Review the source before installing third-party packages.
README
@adamjen/pi-agent-turn-limiter
Forces the pi orchestrator to delegate to a subagent after N turns — prevents getting stuck in endless work loops.
The Problem
You give pi a big task. The orchestrator starts working directly — reading files, grepping code, writing content itself instead of spawning specialist subagents. After 20+ turns of the orchestrator doing grunt work, you realize it never delegated anything. It got "in the weeds" and lost sight of its role as an orchestrator.
This is especially bad with local models that have weaker instruction following — they forget their system prompt rules about delegation and just start doing everything themselves.
The Solution
A tiny extension that counts turns. After 3 grace turns (for setup), then 7 working turns without the orchestrator spawning a subagent, it blocks ALL tool calls except subagent and TaskExecute. The orchestrator MUST delegate or it can't proceed.
Install
pi install npm:@adamjen/pi-agent-turn-limiter
Configure
Change the turn limit (default 7):
export AGENT_TURN_LIMIT=15
How It Works
- Session starts → grace period begins, status bar shows
🟢 0/3 grace - Grace turns (1-3) → free turns for setup, reading context, planning
- Countdown starts (turn 4+) → shows
🔄 1/7 (4 total),🔄 2/7 (5 total)... - Orchestrator spawns subagent → counter resets to 0, shows
🔄 0/7 ✓ delegated - Counter hits limit → status turns red:
🚫 7/7 — DELEGATE NOW - Next tool call blocked → returns error:
"ORCHESTRATOR LIMIT REACHED (7/7 turns without delegation, 10 total). STOP working directly. Create a task and delegate to a subagent."
Status Bar
Shows real-time turn count in the pi TUI footer:
🔄 3/7 # Normal — under limit
🔄 0/7 ✓ delegated # Reset after subagent spawn
🚫 7/7 — DELEGATE NOW # Limit reached, blocking tools
Pair With
@adamjen/pi-one-subagent-at-a-time— prevents parallel subagent spawns on single-GPU setups. One forces delegation, the other prevents melting.HazAT/pi-interactive-subagents— interactive subagent management for advanced control.
Browse all my pi packages: pi.dev/packages/@adamjen/pi-agent-turn-limiter?name=adamjen
Why This Exists
Built because my local Qwen3.6-27B orchestrator would spend 30+ turns reading files and writing content directly instead of spawning the researcher or coder subagents. After the 5th time I had to manually interrupt it, I wrote this extension. Now it delegates on the first try every time.
License
MIT
