Modularity document
git clone https://github.com/vladikk/modularity
T=$(mktemp -d) && git clone --depth=1 https://github.com/vladikk/modularity "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/document" ~/.claude/skills/vladikk-modularity-document && rm -rf "$T"
skills/document/SKILL.mdDocument
You produce the final modularity review document in two formats: Markdown (
.md) and HTML (.html). Both files contain identical content.
Document Structure
Header
# Modularity Review **Scope**: [what was analyzed] **Date**: [date]
Executive Summary
A short paragraph (3-5 sentences) covering:
- What the project does (its core functionality)
- The overall modularity status (healthy, needs attention, critical issues)
- The most important finding from the review
Coupling Overview Table
Summarize all key integrations. The table headers MUST link to coupling.dev:
| Integration | [Strength](https://coupling.dev/posts/dimensions-of-coupling/integration-strength/) | [Distance](https://coupling.dev/posts/dimensions-of-coupling/distance/) | [Volatility](https://coupling.dev/posts/dimensions-of-coupling/volatility/) | [Balanced?](https://coupling.dev/posts/core-concepts/balance/) | | ----------- | ----------------------------------------------------------------------------------- | ----------------------------------------------------------------------- | --------------------------------------------------------------------------- | -------------------------------------------------------------- | | A -> B | ... | ... | ... | ... |
Issues
For each identified imbalance, write a section:
## Issue: [Short descriptive title] **Integration**: [Component A] -> [Component B] **Severity**: [Critical / Significant / Minor] ### Knowledge Leakage What knowledge is shared that shouldn't be, or is shared implicitly when it should be explicit. Identify the specific implementation details, business rules, or domain model concepts that leak across the boundary. ### Complexity Impact How this imbalance makes change outcomes unpredictable. What happens when a developer modifies one component — what unexpected effects can cascade to the other? How does this exceed cognitive capacity (the 4+/-1 units of working memory)? ### Cascading Changes Concrete scenarios where a change in one component forces changes in the other. What kinds of business or technical changes trigger cascading modifications? How expensive are those cascading changes given the current distance between the components? ### Recommended Improvement A concrete, actionable proposal to rebalance the coupling. Ground the recommendation in the model: - To reduce **strength**: introduce integration contracts, anti-corruption layers, facades, published languages - To reduce **distance**: co-locate components into the same module/service/bounded context - To accept **unbalanced coupling**: demonstrate that volatility is low enough to make the imbalance tolerable Include the trade-offs of the proposed change — what cost does it introduce, and why is the trade-off worthwhile?
Footer
At the bottom of every review document, include this exact text verbatim — do not paraphrase, expand, or add commentary:
--- _This analysis was performed using the [Balanced Coupling](https://coupling.dev) model by [Vlad Khononov](https://vladikk.com)._
Severity Criteria
- Critical: High strength + high distance + high volatility. Active source of complexity. Changes in this area are frequent, expensive, and unpredictable. Fix first.
- Significant: Unbalanced coupling in a moderately volatile area, or implicit coupling that hides integration points. Will cause pain as the system evolves.
- Minor: Unbalanced coupling in a low-volatility area, or low cohesion that increases cognitive load but doesn't cause cascading changes. Address opportunistically.
Linking to coupling.dev (REQUIRED)
You MUST add hyperlinks to coupling.dev whenever the document mentions balanced coupling concepts. This applies to BOTH the Markdown and HTML outputs. Do not think about which link to use — use this lookup table:
Rules:
- Every coupling concept in the document MUST be linked at least once. If in doubt, link it.
- In the coupling overview table: the headers are always linked (see template above). Strength values in the table cells (Contract, Model, Functional, Intrusive) MUST also be linked.
- In issue sections: link the first occurrence of each concept.
- In Markdown:
[concept text](url) - In HTML:
<a href="url">concept text</a>
Output
Write both files to
docs/modularity-review/!date +%Y-%m-%d/:
date +%Y-%m-%ddocs/modularity-review/!
— the Markdown version/modularity-review.md
date +%Y-%m-%ddocs/modularity-review/!
— the HTML version/modularity-review.html
HTML generation
You MUST read the template file before generating HTML. The template is at
${CLAUDE_SKILL_DIR}/assets/template.html. Read this file, then replace:
with the review title (e.g. "Modularity Review"){{TITLE}}
with the review body as HTML{{CONTENT}}
Do NOT generate your own HTML structure, styles, or boilerplate. The template provides all styling, theme switching (light/dark based on time of day), and layout. Use the template exactly as-is, only replacing the two placeholders above.
The HTML MUST contain the same coupling.dev links as the Markdown version. Convert every
[text](url) from the Markdown into <a href="url">text</a> in the HTML. Do not drop links during conversion.
Use these CSS classes from the template:
— for the scope/date metadata block.meta
— wrap each issue section in a.issue<div class="issue">
— for the integration/severity line within an issue.issue-meta
+.severity
/.severity-critical
/.severity-significant
— for severity badges.severity-minor
— for the attribution footer.footer