A 7-File Governance Layer to Prevent LLM Session Drift

A developer on r/LocalLLaMA shared a solution to prevent LLM coding assistants like Claude from silently undoing architectural decisions across sessions. Instead of treating LLM sessions as conversations, they now treat them as stateless processes that need a protocol.
The Core Problem
Every LLM session starts with zero memory. You re-explain, it re-interprets, and it drifts confidently. The developer noted: "You won't even notice until you are deep inside the project maybe three files deep or four files or who knows even on the last part of project."
The 7-File Governance Layer
The fix isn't a better prompt but a governance layer that any model can read and immediately operate within. The system uses seven files, each owning a specific concern with no overlap:
active_context.md- Session controller, defines what's in scope right nowcontracts.md- Behavioral law, data schemas, enum values, required behavioragent_core.md- Execution discipline, how to operate, validate, reportagent_project.md- Project intent, why this system exists, expected outcomesdecisions.md- ADR log, non-obvious choices and why they were acceptedbuild_plan.md- Module roadmap, implementation order and deliverablesstate.md- Living journal, what's done, what changed, what remains
Key Design Decisions
The developer explained two critical separations:
Separating contracts.md from agent_core.md: "When a behavioral conflict appeared, the model had no way to know which layer to defer to. Was this a schema rule or an execution preference? When they're separate, the hierarchy is unambiguous, contracts always win."
Including decisions.md: "I almost skipped it ('I'll just remember'). Three weeks later I couldn't reconstruct why we'd chosen Postgres over SQLite for a specific module. The ADR log exists precisely because 'I'll remember' is not a protocol."
The Operational Loop
Every session follows this order, no exceptions:
- Read
active_context.md→ extract what's in scope - Re-ground against
contracts.md→ behavioral rules locked - Confirm operating constraints from
agent_core.md+agent_project.md - Check
decisions.md→ don't reverse accepted choices - Execute only what
active_context.mdauthorizes, perbuild_plan.md - Validate with tests — don't declare done without evidence
- Update
state.mdwith factual outcomes - If a new non-trivial decision was made, log it in
decisions.md
Workflow Impact
The active_context.md scope lock proved particularly valuable: "Before this, I would start a session to fix a bug and then end up refactoring an unrelated module because 'it was right there.' Felt productive.........and it Was."
📖 Read the full source: r/LocalLLaMA
👀 See Also

Developer Builds Tool for Realistic Relational Database Generation
A developer built a tool that generates fully loaded relational databases with realistic data, solving the problem of creating test databases with intact foreign key relationships and cross-table consistency.

Fixing OpenClaw's Blind Spots: Building a Sitemap to Fetch All Anthropic Blogs
OpenClaw's browser tool fails to discover all Anthropic blogs because they're hosted across multiple URLs. A user fixed this by feeding a generated sitemap, then packaged the solution as a shareable skill.

Claude Watch: Open Source Tool Visualizes AI-Generated Code Logic
Claude Watch is an open source tool that provides graphical semantic visualization for projects built with AI coding agents like Claude Code. It analyzes code in a nested way and includes AI-powered search to answer questions about project logic.

Claude Code Plan Mode Reduces Redo Rate from 40% to Near Zero
A developer tracked 30+ coding sessions with Claude Code and found that skipping Plan Mode resulted in redoing tasks from scratch 40% of the time. With Plan Mode, the redo rate dropped to basically zero, with one feature taking 17 minutes total versus 35+ minutes without planning.