Custom PostToolUse Hook for On-Demand CLAUDE.md Loading Outside Project Tree

CLAUDE.md Loading Behavior in Claude Code
The source details how Claude Code handles CLAUDE.md files under different conditions:
- Hierarchical loading: When starting a session in a subdirectory, both the local CLAUDE.md and parent directory CLAUDE.md files are loaded. Example: Session in
root/a/loads bothroot/a/CLAUDE.mdandroot/CLAUDE.md. - On-demand child directory loading: Child directories of the current session's root directory load their CLAUDE.md files when Claude accesses files in those directories. Example: Session in
root/loadsroot/CLAUDE.mdinitially, then loadsroot/a/CLAUDE.mdwhen Claude reads a file inroot/a/. - Additional directory access via flags: Using
--add-dirwithCLAUDE_CODE_ADDITIONAL_DIRECTORIES_CLAUDE_MD=1allows access to CLAUDE.md files in directories outside the project tree, but these load at session start rather than on-demand.
The Problem: External Directory CLAUDE.md Files Not Loading On-Demand
The author notes that when working in one project and instructing Claude to read files from directories outside the session's directory tree, any CLAUDE.md files in those external directories won't load automatically. This creates issues for progressive disclosure of context and requires manual intervention each time.
Solution: Custom PostToolUse Hook
The solution involves creating a PostToolUse hook that:
- Checks if Claude is operating outside the project tree on each tool call
- Walks up from that directory looking for CLAUDE.md files
- If found, exits with code 2 to feed instructions back to Claude telling it to read them
- Tracks which files have already been surfaced in a session-scoped temp file to avoid repeated instructions
A SessionStop hook cleans up the temp file used for tracking. The author provides a script called check_claude_md.py (source linked in original post) that implements this PostToolUse hook functionality.
Practical Implementation
The approach addresses the specific limitation where external directory CLAUDE.md files only load at session start when using the --add-dir flag with CLAUDE_CODE_ADDITIONAL_DIRECTORIES_CLAUDE_MD=1. By intercepting tool calls and checking for operations outside the project tree, the hook enables on-demand loading similar to how child directories work within the project tree.
This type of custom hook is useful for developers who frequently work across multiple projects or need to reference shared context files from external directories without manually instructing Claude to read CLAUDE.md files each time.
📖 Read the full source: r/ClaudeAI
👀 See Also

Fix Ollama Cloud Model maxTokens: Cap is 16K, Not Config Value
Ollama cloud caps output at 16,384 tokens regardless of maxTokens config. Set to 14,000 to avoid EOF errors. Restructure long outputs or route to direct provider.

Vague Prompts Are the Real Problem, Not the Model — 50-Run Test Shows Prompt Quality Trumps Model Choice
A Reddit user ran the same ten prompts through ChatGPT 4, Claude Sonnet, and Gemini 1.5 Pro five times each (150 outputs total) and found that all three models produced similarly usable or similarly generic results — the deciding factor was prompt specificity, not the model.

Enhancing OpenClaw with the Power of Local LLM: Introducing GLM-4.7-Flash
The integration of GLM-4.7-Flash with OpenClaw is revolutionizing AI automation by enabling seamless local deployment and sophisticated code execution.

Using the Dispatcher Pattern to Reduce Claude API Costs by 95%
A developer reduced Claude API costs from $800-$2,000/month to $215/month by implementing a dispatcher pattern that delegates heavy work to Claude Code CLI on a $200/month Max subscription, with API overhead costing only $5-15/month.