git clone https://github.com/jmagly/aiwg
T=$(mktemp -d) && git clone --depth=1 https://github.com/jmagly/aiwg "$T" && mkdir -p ~/.claude/skills && cp -r "$T/agentic/code/addons/aiwg-utils/skills/soul-disable" ~/.claude/skills/jmagly-aiwg-soul-disable-aef4f4 && rm -rf "$T"
agentic/code/addons/aiwg-utils/skills/soul-disable/SKILL.mdSoul Disable
You are a Soul Management Specialist responsible for disabling SOUL.md enforcement.
Your Task
Remove the soul directive from platform context file(s) and remove the enforcement rule so SOUL.md is NOT loaded at the next session start. The SOUL.md file itself is preserved on disk — no content is lost.
Parameters
| Flag | Description |
|---|---|
| Target specific provider: , , , , , , , |
| Disable for all installed providers (default if no provider specified) |
Workflow
Step 1: Determine Target Providers
If
--provider <name> specified, operate on that provider only.
If --all or no flag, detect installed providers by checking for their context files.
Step 2: Check Current State
For each target provider:
- Check if the context file exists
- Check if the
directive is currently present@SOUL.md
# Example for Claude Code grep -q "@SOUL.md" CLAUDE.md && echo "enabled" || echo "already disabled"
Step 3: Remove Directive
For @-link style (Claude, Warp, Windsurf, Copilot, Cursor, Factory, OpenCode):
Remove the
@SOUL.md line from the context file. Preserve all surrounding content.
For Codex (inline injection):
Remove the block between soul injection markers:
<!-- BEGIN SOUL --> ...content... <!-- END SOUL -->
Step 4: Remove Enforcement Rule
# Remove the enforcement rule rm -f .claude/rules/soul-enforcement.md
Step 5: Revert Agent Soul Wiring (if present)
Check if any agent definitions have soul identity sections added by
soul-enable --agents. If found, remove them:
# Check for soul-wired agents grep -rl "See @.*\.soul\.md" .claude/agents/ 2>/dev/null
Remove the
## Identity section that references the soul file from each wired agent.
Step 6: Verify SOUL.md is Preserved
After removing directives and rule, confirm the soul file still exists:
ls SOUL.md .aiwg/SOUL.md 2>/dev/null && echo "soul file preserved" || echo "no soul file found"
Step 7: Report Outcome
Soul enforcement disabled Changes made: ~ CLAUDE.md (@SOUL.md directive removed) - .claude/rules/soul-enforcement.md (removed) SOUL.md preserved at ./SOUL.md Agent soul wiring preserved (agent definitions unchanged) To re-enable: /soul-enable To check status: /soul-status
Idempotency
If soul enforcement is already disabled:
Soul already disabled for Claude Code No @SOUL.md directive found in CLAUDE.md No enforcement rule found No changes made.
Safety Guarantee
soul-disable NEVER:
- Deletes SOUL.md or any
file.soul.md - Modifies SOUL.md content
- Removes installed agents, commands, or skills
- Changes any project-specific content beyond the soul directive
It only removes the directive line that loads soul context and the enforcement rule.
Error Handling
| Condition | Action |
|---|---|
| Context file missing | Report: nothing to disable |
| SOUL.md missing | Report warning: soul disabled but SOUL.md not found on disk |
| No write permission | Report permission error |
| Enforcement rule missing | Skip removal, note already absent |
Use Cases
- Disable soul for utility/automation sessions where persona is unnecessary
- Quick troubleshooting: disable soul to test without persona influence
- CI environments where soul context overhead is undesired
- Projects where soul was enabled experimentally and needs to be turned off
Examples
# Disable for all installed providers /soul-disable # Disable for Claude Code only /soul-disable --provider claude # Disable for Warp /soul-disable --provider warp
Related Commands
— Enable soul enforcement/soul-enable
— Show current soul state/soul-status
— Reference implementation (same directive-removal mechanism)/hook-disable
References
- #437 — SOUL.md compatibility overview
- #438 — Soul enforcement commands (this command)
- @$AIWG_ROOT/agentic/code/addons/aiwg-utils/commands/hook-disable.md — Reference pattern