A 7-File Governance Layer to Prevent LLM Session Drift

✍️ OpenClawRadar📅 Published: April 13, 2026🔗 Source
A 7-File Governance Layer to Prevent LLM Session Drift
Ad

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 now
  • contracts.md - Behavioral law, data schemas, enum values, required behavior
  • agent_core.md - Execution discipline, how to operate, validate, report
  • agent_project.md - Project intent, why this system exists, expected outcomes
  • decisions.md - ADR log, non-obvious choices and why they were accepted
  • build_plan.md - Module roadmap, implementation order and deliverables
  • state.md - Living journal, what's done, what changed, what remains
Ad

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:

  1. Read active_context.md → extract what's in scope
  2. Re-ground against contracts.md → behavioral rules locked
  3. Confirm operating constraints from agent_core.md + agent_project.md
  4. Check decisions.md → don't reverse accepted choices
  5. Execute only what active_context.md authorizes, per build_plan.md
  6. Validate with tests — don't declare done without evidence
  7. Update state.md with factual outcomes
  8. 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

Ad

👀 See Also

Building a Programming Language with Claude Code: The Cutlet Experiment
Tools

Building a Programming Language with Claude Code: The Cutlet Experiment

Ankur Sethi built a complete programming language called Cutlet using Claude Code over four weeks, with the AI generating every line of code while he focused on guardrails and testing. The language features dynamic typing, vectorized operations, and a REPL, running on macOS and Linux.

OpenClawRadar
Pair Programmer Plugin Adds Live Screen, Voice, and Audio Context to Claude Code
Tools

Pair Programmer Plugin Adds Live Screen, Voice, and Audio Context to Claude Code

A developer has built a plugin called Pair Programmer that gives Claude Code real-time desktop perception by capturing screen, microphone, and system audio streams. The architecture uses specialized agents running in parallel for different input types, with indexing currently handled by cloud models but designed to be model-agnostic.

OpenClawRadar
Open Source Rust MCP Server Gives Claude Full Email Management Capabilities
Tools

Open Source Rust MCP Server Gives Claude Full Email Management Capabilities

A developer built a Rust-based MCP server that provides Claude with 25 tools for comprehensive email management including IMAP search, SMTP sending, Microsoft Graph API support, and multi-account handling with OAuth2 authentication.

OpenClawRadar
Local semantic search for AI conversations with fastembed and LanceDB
Tools

Local semantic search for AI conversations with fastembed and LanceDB

A developer indexed 368K AI conversation messages locally using fastembed for CPU-based embeddings and LanceDB as a serverless vector store, achieving 12ms p50 search latency without API keys.

OpenClawRadar