strategic-compact
Scannednpx machina-cli add skill affaan-m/everything-claude-code/strategic-compact --openclawStrategic Compact Skill
Suggests manual /compact at strategic points in your workflow rather than relying on arbitrary auto-compaction.
When to Activate
- Running long sessions that approach context limits (200K+ tokens)
- Working on multi-phase tasks (research → plan → implement → test)
- Switching between unrelated tasks within the same session
- After completing a major milestone and starting new work
- When responses slow down or become less coherent (context pressure)
Why Strategic Compaction?
Auto-compaction triggers at arbitrary points:
- Often mid-task, losing important context
- No awareness of logical task boundaries
- Can interrupt complex multi-step operations
Strategic compaction at logical boundaries:
- After exploration, before execution — Compact research context, keep implementation plan
- After completing a milestone — Fresh start for next phase
- Before major context shifts — Clear exploration context before different task
How It Works
The suggest-compact.js script runs on PreToolUse (Edit/Write) and:
- Tracks tool calls — Counts tool invocations in session
- Threshold detection — Suggests at configurable threshold (default: 50 calls)
- Periodic reminders — Reminds every 25 calls after threshold
Hook Setup
Add to your ~/.claude/settings.json:
{
"hooks": {
"PreToolUse": [
{
"matcher": "Edit",
"hooks": [{ "type": "command", "command": "node ~/.claude/skills/strategic-compact/suggest-compact.js" }]
},
{
"matcher": "Write",
"hooks": [{ "type": "command", "command": "node ~/.claude/skills/strategic-compact/suggest-compact.js" }]
}
]
}
}
Configuration
Environment variables:
COMPACT_THRESHOLD— Tool calls before first suggestion (default: 50)
Compaction Decision Guide
Use this table to decide when to compact:
| Phase Transition | Compact? | Why |
|---|---|---|
| Research → Planning | Yes | Research context is bulky; plan is the distilled output |
| Planning → Implementation | Yes | Plan is in TodoWrite or a file; free up context for code |
| Implementation → Testing | Maybe | Keep if tests reference recent code; compact if switching focus |
| Debugging → Next feature | Yes | Debug traces pollute context for unrelated work |
| Mid-implementation | No | Losing variable names, file paths, and partial state is costly |
| After a failed approach | Yes | Clear the dead-end reasoning before trying a new approach |
What Survives Compaction
Understanding what persists helps you compact with confidence:
| Persists | Lost |
|---|---|
| CLAUDE.md instructions | Intermediate reasoning and analysis |
| TodoWrite task list | File contents you previously read |
Memory files (~/.claude/memory/) | Multi-step conversation context |
| Git state (commits, branches) | Tool call history and counts |
| Files on disk | Nuanced user preferences stated verbally |
Best Practices
- Compact after planning — Once plan is finalized in TodoWrite, compact to start fresh
- Compact after debugging — Clear error-resolution context before continuing
- Don't compact mid-implementation — Preserve context for related changes
- Read the suggestion — The hook tells you when, you decide if
- Write before compacting — Save important context to files or memory before compacting
- Use
/compactwith a summary — Add a custom message:/compact Focus on implementing auth middleware next
Related
- The Longform Guide — Token optimization section
- Memory persistence hooks — For state that survives compaction
continuous-learningskill — Extracts patterns before session ends
Source
git clone https://github.com/affaan-m/everything-claude-code/blob/main/.agents/skills/strategic-compact/SKILL.mdView on GitHub Overview
Strategic Compact suggests invoking /compact at logical points in your workflow to preserve essential context through task phases. This helps maintain critical exploration and planning context as you move from research to execution, instead of relying on arbitrary auto-compaction.
How This Skill Works
A small script (suggest-compact.js) runs on PreToolUse (Edit/Write) to monitor tool calls. When a configurable threshold (default 50) is reached, it suggests a /compact, with periodic reminders every 25 calls after the threshold. The hook-based setup in ~/.claude/settings.json wires it into your workflow so compaction happens at strategic phase boundaries rather than randomly.
When to Use It
- Running long sessions that approach context limits (200K+ tokens)
- Working on multi-phase tasks (research → plan → implement → test)
- Switching between unrelated tasks within the same session
- After completing a major milestone and starting new work
- When responses slow down or become less coherent (context pressure)
Quick Start
- Step 1: Add the strategic-compact PreToolUse hook for Edit/Write to run suggest-compact.js (example: node ~/.claude/skills/strategic-compact/suggest-compact.js).
- Step 2: Ensure COMPACT_THRESHOLD is set (default 50) and adjust for your session length.
- Step 3: When phase boundaries are reached or the hook prompts, run /compact with a brief summary and continue into the next phase.
Best Practices
- Compact after planning — start fresh once the plan is finalized in TodoWrite.
- Compact after debugging — remove obsolete reasoning before continuing.
- Don't compact mid-implementation — maintain context for related changes.
- Read the suggestion — the hook indicates when; you decide if/when to compact.
- Write before compacting — save important context to files or memory before compacting.
Example Use Cases
- A researcher moves from exploratory notes to a concrete plan, using /compact after exploration.
- At the end of a milestone, compact to clear old context and begin implementation.
- Switching to a new unrelated task within the same session triggers a compact to avoid cross-talk.
- A long code refactor session nears 200K+ tokens; compact to preserve core context.
- A failed approach is encountered; compact to purge dead-end reasoning before retrying.