Your AI agent writes the code.
sentrux shows you the architecture and scores the quality — live.
Install · Quick Start · MCP Integration · Rules Engine · Releases
Watch Claude Code build a FastAPI project from scratch — while sentrux shows the architecture decaying in real-time.
See the final grade report of this demo project
![]() Health: D cohesion F, dead code F (25%) comments D (2%) |
![]() Architecture: B levelization A, distance A blast radius B (23 files) |
![]() Test Coverage: D 38% coverage 42 untested files |
You start a project with Claude Code or Cursor. Day one is magic. The agent writes clean code, understands your intent, ships features fast.
Then something shifts.
The agent starts hallucinating functions that don't exist. It puts new code in the wrong place. It introduces bugs in files it touched yesterday. You ask for a simple feature and it breaks three other things. You're spending more time fixing the agent's output than writing it yourself.
Everyone assumes the AI got worse. It didn't. Your codebase did.
Here's what actually happened: when you used an IDE, you saw the file tree. You opened files. You built a mental model of the architecture — which module does what, how they connect, where things belong. You were the governor. Every edit passed through your understanding of the whole.
Then AI agents moved us to the terminal. The agent modifies dozens of files per session. You see a stream of Modified src/foo.rs — but you've lost the spatial awareness. You don't see where that file sits in the dependency graph. You don't see that it just created a cycle. You don't see that three modules now depend on a file that was supposed to be internal. Many developers let AI agents build entire applications without ever opening the file browser.
You've lost control. And you don't even know it yet.
Every AI session silently degrades your architecture. Same function names, different purposes, scattered across files. Unrelated code dumped in the same folder. Dependencies tangling into spaghetti. When the agent searches your project, it finds twenty conflicting matches — and picks the wrong one. Every session makes the mess worse. Every mess makes the next session harder.
This is the dirty secret of AI-assisted development: the better the AI generates code, the faster your codebase becomes ungovernable.
The traditional answer — "plan your architecture first, then let AI implement" — sounds right but misses the point. Tools like GitHub's Spec Kit try this approach: generate detailed specs and plans before writing code. But in practice, it reinvents waterfall — producing seas of markdown documents while having zero visibility into the code that actually gets produced. No feedback loop. No way to detect when the implementation drifts from the spec. No structural analysis of any kind. The spec goes in, the agent writes code, and nobody checks what came out.
That's not how anyone actually works with AI agents anyway. You prototype fast. You iterate through conversation. You follow inspiration. You let the creative flow drive the code. That creative flow is exactly what makes AI agents powerful. And it's exactly what destroys codebases.
You don't need a better plan. You need a better sensor.
sentrux is the missing feedback loop.
Every system that works at scale has one: a sensor that observes reality, a spec that defines "good," and an actuator that corrects drift. Compilers close a feedback loop on syntax. Test suites close a loop on behavior. Linters close a loop on style.
But architecture — does this change fit the system? will this abstraction cause problems as the codebase grows? — had no sensor and no actuator. Only humans could judge that. And humans can't keep up with machine-speed code generation.
sentrux closes the loop at the architecture level.
It watches your codebase in real-time — not the diffs, not the terminal output — the actual structure. Every file. Every dependency. Every architectural relationship. Visualized as a live interactive treemap that updates as the agent writes code.
14 health dimensions. Graded A through F. Computed in milliseconds.
When architecture degrades, you see it immediately — not two weeks later when everything is broken and nobody remembers which session caused it.
sentrux gives you the sensor. Your rules give you the spec. The agent is the actuator. The loop closes.
| Visualize Live treemap with dependency edges, files glow when the agent modifies them |
Measure 14 health dimensions graded A-F: coupling, cycles, cohesion, dead code... |
Govern Quality gate catches regression. Rules engine enforces constraints. |
brew install sentrux/tap/sentrux# or: macOS / Linux
curl -fsSL https://raw.githubusercontent.com/sentrux/sentrux/main/install.sh | shPure Rust. Single binary. No runtime dependencies. 23 languages via tree-sitter.
From source / upgrade
# Build from source
git clone https://github.com/sentrux/sentrux.git
cd sentrux && cargo build --release
# Upgrade
brew update && brew upgrade sentrux
# or re-run the curl install — it always pulls the latest releasesentrux # open the GUI — live treemap of your project
sentrux check . # check rules (CI-friendly, exits 0 or 1)
sentrux gate --save . # save baseline before agent session
sentrux gate . # compare after — catches degradationsentrux runs as an MCP server — your AI agent can query structural health mid-session.
{
"sentrux": {
"command": "sentrux",
"args": ["--mcp"]
}
}Works with Claude Code, Cursor, Windsurf, and any MCP-compatible agent.
See the agent workflow
Agent: scan("/Users/me/myproject")
→ { structure_grade: "B", architecture_grade: "B", files: 139 }
Agent: session_start()
→ { status: "Baseline saved", grade: "B" }
... agent writes 500 lines of code ...
Agent: session_end()
→ { pass: false, grade_before: "B", grade_after: "C",
summary: "Architecture degraded during this session" }
15 tools: scan · health · architecture · coupling · cycles · hottest · evolution · dsm · test_gaps · check_rules · session_start · session_end · rescan · blast_radius · level
Define architectural constraints. Enforce them in CI. Let the agent know the boundaries.
Example .sentrux/rules.toml
[constraints]
max_cycles = 0
max_coupling = "B"
max_cc = 25
no_god_files = true
[[layers]]
name = "core"
paths = ["src/core/*"]
order = 0
[[layers]]
name = "app"
paths = ["src/app/*"]
order = 2
[[boundaries]]
from = "src/app/*"
to = "src/core/internal/*"
reason = "App must not depend on core internals"sentrux check .
# ✓ All rules pass — Structure: B Architecture: BRust · Python · JavaScript · TypeScript · Go · C · C++ · Java · Ruby · C# · PHP · Bash · HTML · CSS · SCSS · Swift · Lua · Scala · Elixir · Haskell · Zig · R · OCaml
The human role is changing — from writing code to governing code.
Every engineering practice that mattered before AI — documentation, testing, codified architecture, fast feedback loops — now matters exponentially more. Skip the tests and the feedback loop can't close. Skip the architectural constraints and drift compounds at machine speed. And here's the trap: you can't use agents to clean up the mess if the agents don't know what clean looks like.
sentrux is built on three beliefs:
1. Human-in-the-loop is non-negotiable. AI agents are powerful but limited. They cannot hold the big picture and the small details at the same time. A human must be able to see, at any moment, what the agent is doing to the whole — not just which file it touched, but what that file means to the architecture. sentrux makes that possible.
2. Verification is more valuable than generation. Generating a correct solution is harder than verifying one (the intuition behind P vs NP). You don't need to out-code the machine. You need to out-evaluate it — specify what "correct" looks like, recognize when the output misses, judge whether the direction is right. sentrux turns architectural judgment into machine-readable grades and constraints.
3. Good systems make good outcomes inevitable. A well-designed system constrains behavior so that the right thing is the easy thing. A quality gate that blocks degradation before it ships. A rules engine that encodes your architectural decisions. A visual map that makes structural rot impossible to ignore. The practices haven't changed. The penalty for ignoring them has become unbearable.
Once you have a feedback loop that works, you don't go back to doing it by hand. Not because you can't. Because it no longer makes sense.
AI agents write code at machine speed. Without structural governance, codebases decay at machine speed too.
sentrux is the governor.



