Skip to main content

Map features in any codebase from git history alone. No Jira required.

Project description

Faultlines — Codebase intelligence for teams and AI agents

Faultlines turns raw git history into a living map of every feature and user flow in your repo — with bug hotspots, test coverage, and the precise context your AI coding agent actually needs.

No Jira. No annotations. No manual tagging. Just git log and your code.

PyPI Python License: MIT MCP Downloads

Website · Quick start · For AI agents · How it works · Releases


The problem

Every engineer rediscovers the same thing on a new codebase:

"Which files actually implement checkout?" "What breaks if I change this?" "Who owns the billing flow?" "Where are the bugs hiding?"

Your issue tracker doesn't know — it's full of aspirational tickets. Static analysis sees imports, not intent. And your AI agent just greps 15 files and burns your context window guessing.

The answers were in your git history the whole time. Faultlines reads them.

What Faultlines does

$ faultlines ./my-app

  ✓ 472 commits analysed · 1,284 files mapped

  FEATURE                  HEALTH  COVERAGE  HOTSPOTS  FLOWS
  ─────────────────────────────────────────────────────────
  Billing & Subscriptions    62      48%        3        7
  Authentication             88      91%        0        4
  Document E-Sign            41 ⚠     22%        5        9
  Team & Permissions         79      66%        1        5
  …

  → Highest blast radius:  src/payments/charge.ts (touches 4 features)
  → Riskiest flow:         e-sign/finalize  (low coverage · 5 recent bug-fixes)

A two-layer feature map:

  • Developer features — code-grounded, the units your engineers actually work in.
  • Product features — the customer-facing capabilities those roll up into.

…each broken into flows (real user journeys), scored, attributed down to the function and line range, and served to humans and AI agents.

Features

  • Feature & flow detection — from git history + code structure, on any stack (Next.js, Rails, Django, FastAPI, Express, Spring, Laravel, Phoenix, and more).
  • Bug hotspots & health scores — find what's rotting before it pages you.
  • Behavioral test coverage — coverage per user flow, inferred from history even when there's no lcov.
  • Change-impact / blast radius — "if I touch these files, here's what breaks and who to add as reviewer."
  • Symbol-level attribution — functions, classes and line ranges per flow, not just file lists.
  • Ownership & bus-factor — who maintains each feature, and where the knowledge is dangerously concentrated.
  • MCP server for AI agents — 13 typed tools your coding agent calls instead of grepping.
  • Runtime overlays — map Sentry errors and PostHog usage onto features (which features actually fail and get used).
  • Local-first & private — runs on your machine; your source code never has to leave it.

Quick start

pip install faultlines

# Scan a repo. Bare `faultlines <repo>` runs the scan pipeline —
# flows and symbol-level attribution are included by default.
faultlines /path/to/your/repo

Faultlines is deterministic-first: the feature/flow structure comes from your code and git history with no LLM required. Set an ANTHROPIC_API_KEY and a Haiku pass automatically adds human-readable names and flow detection — no flag needed. Pick the model with --model haiku|sonnet|opus (default: haiku):

export ANTHROPIC_API_KEY=sk-ant-...
faultlines /path/to/your/repo --model sonnet

scan-v2 is the explicit name of the same pipeline (faultlines scan-v2 <repo>); the bare form is just shorthand for it.

That writes a versioned feature-map JSON to ~/.faultline/. Explore it, diff it across runs, ship it to CI, or hand it to your AI agent (below).

Built for AI coding agents

This is the wedge. Install the companion MCP server and your agent stops guessing:

# one-off, no install (recommended)
uvx faultlines-mcp

# or install it
pip install faultlines-mcp
// ~/.cursor/mcp.json  (or: claude mcp add faultlines -- faultlines-mcp)
{
  "mcpServers": {
    "faultlines": { "command": "faultlines-mcp" }
  }
}

Now Cursor / Claude Code / Cline / Windsurf can call 13 tools:

Tools
Discover list_features · find_feature · get_repo_summary
Files & symbols get_feature_files · get_flow_files · find_symbols_in_flow · find_symbols_for_feature
Risk & impact get_hotspots · get_feature_owners · analyze_change_impact · get_regression_risk
Runtime get_feature_errors (Sentry) · get_feature_pageviews (PostHog)

Typical result: ~90% fewer tokens per query than a naive grep-and-read loop — your agent reads the right functions, with line ranges, on the first try.

The metrics — and why they matter

Metric What it tells you Why you care
Health score Composite of churn, bug-fixes, coverage & ownership One number to triage what to refactor next
Bug-fix ratio Share of commits that fix bugs High = fragile, defect-prone code
Churn How often a feature changes Hotspot detection; instability signal
Impact score Structural blast radius − coverage What a change here actually endangers
Coverage Behavioral test coverage per flow Find untested user journeys, not just untested lines
Ownership / bus factor Who holds the knowledge Spot single-points-of-failure before they leave

How it works

 git history ─┐
              ├─▶  deterministic extractors  ─┐
 code/config ─┘    (routes · MVC · schema ·   │
                    package · stack patterns)  ├─▶  feature & flow map
                                               │     + metrics + symbols
        Haiku pass · naming + flows (key set) ─┘            │
                                                            ▼
                              feature-map JSON  ──▶  CLI · CI · dashboard · MCP

Deterministic-first. The structure comes from your routing conventions, configs, schemas and git co-change patterns — no LLM required. When ANTHROPIC_API_KEY is set, an Anthropic (Haiku by default, --model sonnet|opus) pass adds human-readable names and flow detection automatically. The output is a single versioned JSON — the stable contract every consumer reads.

Integrations

  • GitHub — PR comments with risk, coverage gaps and runtime signal on the exact features a diff touches.
  • Sentry — production errors mapped to features.
  • PostHog — real usage & traffic per feature.
  • Slack — weekly digest of top risks, coverage gaps and hotspots.

Why not just…

  • …grep / read the files? Burns context and misses cross-boundary, runtime and historical coupling that static analysis can't see.
  • …SonarQube / linters? Great for line-level issues; blind to features, flows and blast radius.
  • …your issue tracker? Describes intent, not reality. Faultlines is grounded in what the code and history actually say.

Faultlines is the only layer that joins structure + git history + runtime into one map — and serves it to your AI agent.

Roadmap

  • Two-layer feature/flow map on any stack
  • Behavioral test coverage & health scoring
  • Symbol-level attribution
  • MCP server (13 tools) — Local · Hosted · VPC
  • Sentry + PostHog runtime overlays
  • Incremental, sub-second re-scans on every commit
  • Native plugins for more agents & IDEs

Contributing

Issues, ideas and PRs are welcome. Faultlines is built to map any codebase — if it mis-reads your stack, that's a bug we want to hear about.

License

MIT — see LICENSE.

Star this repo if Faultlines helps you (or your agent) understand a codebase faster.

Made for engineers and the AI agents that work alongside them · faultlines.dev

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

dynvo-1.38.0.tar.gz (1.4 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

dynvo-1.38.0-py3-none-any.whl (879.9 kB view details)

Uploaded Python 3

File details

Details for the file dynvo-1.38.0.tar.gz.

File metadata

  • Download URL: dynvo-1.38.0.tar.gz
  • Upload date:
  • Size: 1.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for dynvo-1.38.0.tar.gz
Algorithm Hash digest
SHA256 b902d0caf85ae70c35e019123af6ff8db2eb8f1c2a2f370e0c7eb048b4f91fb9
MD5 1687526f6132da552008e293fe8b0444
BLAKE2b-256 d11cf8c8529b55d47bdfbe33ea72ec5c5484bc3444a5666faa6027f4cbeb27e6

See more details on using hashes here.

Provenance

The following attestation bundles were made for dynvo-1.38.0.tar.gz:

Publisher: release.yml on PashaSchool/dynvo

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file dynvo-1.38.0-py3-none-any.whl.

File metadata

  • Download URL: dynvo-1.38.0-py3-none-any.whl
  • Upload date:
  • Size: 879.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for dynvo-1.38.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8faa366d5fbcb9168764bc1ab26e1f7d4bd0a3a43fbcf7a81769e83f349a1dde
MD5 917f95d05be88fb398ad0e30dd768e50
BLAKE2b-256 d25ec0a38718d9395b9b1552bca25f3be9c7a0f39e7da0a4ff769625268e3f85

See more details on using hashes here.

Provenance

The following attestation bundles were made for dynvo-1.38.0-py3-none-any.whl:

Publisher: release.yml on PashaSchool/dynvo

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page