Boundary Analysis — act101 Agent Skill
Use when looking for extraction candidates, planning a module split, analyzing module boundaries, or before decomposing a large component. Also use when asked "where should I split this?" or "find natural module boundaries". Depth 2 — investigate. Produces extraction candidates with cut costs, layer violations, interface width assessment, orphan types, and a recommended decomposition sequence.
Boundary Analysis
Depth: Level 2 (Investigate).
See ../analysis-protocol/references/protocol.md for: artifact directory structure,
the investigation loop, depth levels, summary format, token budget rules, and project
map structure. Read that document before proceeding.
Phase 1: Parallel Tool Dispatch
Dispatch all available tools in a single parallel batch.
Each subagent runs one tool, saves raw JSON to raw/<tool-name>.json, returns a
structured summary.
Must-have tools:
| Tool | Purpose | MCP call |
|---|---|---|
analyze_clusters |
Current module groupings | analyze_clusters |
analyze_seams |
Natural boundaries | analyze_seams |
If both must-have tools are unavailable, report that and stop.
Extended tools (use if available, skip and note in manifest if not):
| Tool | Purpose | MCP call |
|---|---|---|
analyze_layers |
Layer detection + violations (S1+S2) | analyze_layers |
analyze_extraction |
Extraction candidates (M2) | analyze_extraction |
analyze_interfaces |
Cross-module contracts (M4) | analyze_interfaces |
analyze_cohesion |
Are current modules coherent? (H2) | analyze_cohesion |
analyze_interface_bloat |
Are APIs too wide? (H3) | analyze_interface_bloat |
analyze_orphan_types |
Misplaced type definitions (H4) | analyze_orphan_types |
Phase 2: Investigation
For each significant finding, form a hypothesis before dispatching a subagent:
Extraction candidate hypothesis example:
Hypothesis N:
<candidate>can be extracted as a clean module. Evidence:analyze_seamsidentified a seam at this boundary;analyze_extractionscored it high. Confirming query:analyze_surfaceon the candidate files to measure cut cost (edges to sever vs. edges retained internally). Confirms if: Internal edges >> external edges (low cut cost relative to cohesion). Refutes if: External edges ≥ internal edges (high entanglement — extraction would be expensive).
Layer violation hypothesis example:
Hypothesis N: The violation from
<source>to<target>is structural (not accidental), indicating architectural erosion. Evidence:analyze_layersflagged an inversion from layer X to layer Y. Confirming query:graphon<source>to trace the full import path. Confirms if: Multiple files in layer X import from layer Y (pattern, not one-off). Refutes if: Single file, single import — likely a quick fix rather than erosion.
Low-cohesion split hypothesis example:
Hypothesis N:
<file>contains two distinct concept clusters that should be separate modules. Evidence:analyze_cohesionscored this module low; it is large. Confirming query:skeletonon the file to find concept clusters. Confirms if: Skeleton reveals two distinct groups of functions with no shared state. Refutes if: Functions share common state/types — low cohesion score is misleading.
Interface bloat hypothesis example:
Hypothesis N:
<module>'s public API is wider than necessary — some exports are never used externally. Evidence:analyze_interface_bloatflagged this module as over-exposed. Confirming query:referenceson each exported symbol. Confirms if: Several exports have 0 external callers. Refutes if: All exports have at least one external caller.
Save investigation notes to investigation/hypothesis-N.md.
Report Structure
# Boundary Analysis: <project name>
## Boundary Map
Current module structure with cluster sizes and labels.
Which clusters are cohesive vs. artificially grouped.
## Layer Architecture
Detected or user-specified layers. Direction consistency score.
(Present only if analyze_layers ran successfully.)
## Extraction Candidates
Ranked by extraction score. Per-candidate:
- Files included
- Internal vs. external edges
- API surface width
- Cut cost (edges to sever)
- Recommended extraction steps (specific act MCP operations)
## Layer Violations
(Present only if analyze_layers ran successfully.)
Per-violation: source layer, target layer, specific files involved, imported symbols,
fix recommendation. Distinguish: inversions (higher layer imports from lower) vs.
skips (layer bypasses an intermediate layer).
## Interface Width Assessment
(Present only if analyze_interface_bloat ran successfully.)
Modules with disproportionately wide public APIs.
Per-module: which exports are used externally, which are never called externally,
recommended visibility reduction.
## Orphan Types
(Present only if analyze_orphan_types ran successfully.)
Type definitions living in the wrong module.
Per-orphan: where defined, where used, recommended move destination.
## Cohesion Assessment
(Present only if analyze_cohesion ran successfully.)
Low-cohesion modules with natural split points identified from skeleton investigation.
Per-module: cohesion score, identified split boundary, recommended next step.
## Recommended Decomposition Steps
Prioritized, ordered steps to improve module boundaries.
Each step links to a specific act MCP tool call or skill.
Order: cheapest/highest-value extractions first, invasive restructuring last.
Project Map Updates
Updates "Module Map", "Layer Architecture", and "Key Boundaries" sections. Appends to the Analysis History table.