loading…
Search for a command to run...
loading…
An interrupt-aware MCP sidecar for long-running coding agents that detects changes in user guidance, constraints, or plans, enabling agents to pause, replan, an
An interrupt-aware MCP sidecar for long-running coding agents that detects changes in user guidance, constraints, or plans, enabling agents to pause, replan, and acknowledge updates before continuing.
PulseAgent is an interrupt-aware MCP sidecar for long-running coding agents. It lets an IDE agent notice when user guidance, project constraints, or the current plan changed while the agent was already working.
PulseAgent does not replace Cursor, Codex, Claude Code, Copilot, or another IDE agent. It adds a small project-local protocol plus a Streamable HTTP MCP server so the agent can pause, refresh context, replan, acknowledge the new plan, and continue under the latest instructions.
Long coding tasks often drift because the user changes their mind, adds a constraint, or updates the plan while the agent is still executing an older mental model. PulseAgent gives that workflow a shared source of truth:
.pulse/;Install from GitHub:
pip install git+https://github.com/zhangyh0426/PulseAgent.git
For local development:
pip install -e ".[dev]"
Start PulseAgent in the project you want an agent to work on:
cd my-project
pulse start
The first run creates:
.pulse/
├─ task.md
├─ guidance.md
├─ constraints.md
├─ plan.md
├─ state.json
└─ events.jsonl
The MCP endpoint is:
http://127.0.0.1:8765/mcp
Connect with the MCP Inspector:
npx -y @modelcontextprotocol/inspector
Then connect to http://127.0.0.1:8765/mcp.
Add PulseAgent as an HTTP MCP server in your IDE agent. For Claude Code:
claude mcp add --transport http pulse-agent http://127.0.0.1:8765/mcp
Add this rule to the agent instructions:
Before continuing long-running work, read pulse://context/latest and call
pulse_should_interrupt. If needs_replan is true, update .pulse/plan.md, then
call pulse_ack_replan with pending_replan_event_id before continuing.
During a long task, edit .pulse/guidance.md or .pulse/constraints.md when the
agent needs new direction or tighter boundaries.
PulseAgent watches four project-local files:
.pulse/task.md describes the current task..pulse/guidance.md contains user-authored direction that may change the task..pulse/constraints.md contains restrictions that may narrow agent behavior..pulse/plan.md contains the agent's current working plan.Changes to guidance.md and constraints.md are plan-invalidating. Updating
plan.md alone does not clear the interrupt. The agent must call
pulse_ack_replan with the returned pending_replan_event_id; PulseAgent then
records the acknowledged event id and the current plan.md SHA-256 hash.
pulse://context/latestpulse_should_interrupt(last_seen_event_id: str | None = None)pulse_ack_replan(event_id: str)pulse_replanpulse_should_interrupt returns the latest event state, including:
{
"needs_replan": true,
"latest_event_id": "evt_...",
"has_new_events": true,
"changed_files": [".pulse/guidance.md"],
"pending_replan_event_id": "evt_...",
"pending_replan_files": [".pulse/guidance.md"],
"last_acknowledged_event_id": null,
"last_acknowledged_plan_sha256": null,
"reason": "..."
}
pulse_ack_replan accepts the current pending replan event:
{
"event_id": "evt_..."
}
and returns:
{
"accepted": true,
"acknowledged_event_id": "evt_...",
"plan_sha256": "...",
"reason": "..."
}
Start PulseAgent:
pulse start
Change guidance while the agent is working:
printf "# Guidance\n\nPrefer a smaller patch and keep public APIs stable.\n" > .pulse/guidance.md
The agent calls pulse_should_interrupt and sees needs_replan: true.
The agent then:
pulse://context/latest;.pulse/plan.md;pulse_ack_replan with pending_replan_event_id;.pulse/guidance.md may change task direction..pulse/constraints.md may restrict behavior but must not expand permissions.Install the package in editable mode:
pip install -e ".[dev]"
Run tests and lint:
python -m pytest
python -m ruff check .
Run the CLI directly:
python -m pulse_agent --help
python -m pulse_agent --version
PulseAgent is currently an alpha project. The core protocol is intentionally
small: a project-local .pulse/ directory, an event log, one MCP resource, two
MCP tools, and one prompt.
See docs/agent-wrapper.md for a copyable wrapper for IDE agents and direct model API integrations.
MIT
Добавь это в claude_desktop_config.json и перезапусти Claude Desktop.
{
"mcpServers": {
"pulseagent": {
"command": "npx",
"args": []
}
}
}PRs, issues, code search, CI status
Database, auth and storage
Reference / test server with prompts, resources, and tools.
Secure file operations with configurable access controls.