plugins/agentic-behavior/skills/exit/SKILL.md
Gracefully exit the Claude Code session by sending SIGINT to the Claude process. Works for local CLI sessions and Claude Code Web (remote sessions). Use when you need to exit the session cleanly, or when the user requests exit/termination.
npx skillsauth add nsheaps/ai-mktpl exitInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
This skill enables Claude to gracefully exit its own session by sending a SIGINT signal to its process.
/restart skill for restarting (exit + launcher picks up again)This plugin includes a PreToolUse hook that validates git state before exit. The hook intercepts Bash tool calls that invoke exit.sh or kill -INT and checks the working directory.
Checks performed:
If any check fails, the hook blocks the tool call (exit 2) and provides a message explaining what needs to be resolved.
Note: The manual method (kill -INT $PPID) is also intercepted by the hook. However, if you bypass the Bash tool entirely (e.g., running a signal from outside Claude), the hook cannot intercept it.
Claude runs as a process that spawns shell subprocesses for Bash commands. The parent PID ($PPID) of any spawned shell is the Claude process itself.
Sending SIGINT (signal 2) to the Claude process triggers a graceful shutdown, similar to pressing Ctrl+C.
The easiest way is to execute the provided script:
${CLAUDE_PLUGIN_ROOT}/bin/exit.sh
Or via the installed plugin cache path (varies by installation):
~/.claude/plugins/cache/ai-mktpl/agentic-behavior/*/bin/exit.sh
If the script is unavailable, Claude can exit itself manually:
echo "Shell PID: $$"
echo "Claude PID (parent): $PPID"
ps -o pid,ppid,comm -p $$ -p $PPID
ps -o comm= -p $PPID
This should output claude or similar.
kill -INT $PPID
A typical Claude Code process tree looks like:
iTerm/Terminal
└── shell (user's interactive shell)
└── claude (PID: XXXXX) ← Target this
└── /bin/zsh (spawned for Bash commands)
└── (your command)
After exit:
claudeScript says parent is not Claude: You may be running in a nested shell or different environment. Check pstree -p $$ to see the full process tree.
Signal ignored: Some environments may mask signals. Try kill -TERM $PPID as an alternative.
In Claude Code Web environments, stop hooks may validate state before shutdown:
Example stop hook location: ~/.claude/stop-hook-git-check.sh
| Environment Variable | Purpose |
| ------------------------ | ------------------------------------ |
| CLAUDE_CODE_REMOTE | Set to "true" in Claude Code Web |
| CLAUDE_PROJECT_DIR | Repository root (available in hooks) |
| CLAUDE_CODE_SESSION_ID | Current session UUID |
For Claude Code Web sessions, you can also exit by:
tools
Reference material for Claude Code internals — the on-disk layout under ~/.claude and project-scope .claude, the plugin cache, session-env propagation, and the full hook lifecycle. Auto-recall when working on Claude-Code-related tasks: writing or debugging hooks, authoring plugins, inspecting session state, troubleshooting why an env var is or isn't visible to a Bash tool call, or when paths under ~/.claude or ~/.claude/plugins/ come up.
development
Manage GitHub App installation tokens in Claude Code sessions. Use when tokens expire, auth errors occur in long-running sessions, or when setting up GitHub App credentials for agent teams. <example>my github token expired</example> <example>refresh the github app token</example> <example>check token status</example> <example>set up github app authentication for this session</example>
tools
Auto-detect project formatting tools and configure edit-utils settings
tools
Use this skill when the user asks about 1Password, secrets management, retrieving credentials, using op CLI, service accounts, secret references, vault operations, or any task involving the 1Password CLI (op). Also use when needing to inject secrets into environment variables, read passwords or API keys from 1Password, or manage 1Password items from the command line.