---
Inherits all available tools
Additional assets for this skill
This skill inherits all available tools. When active, it can use any tool Claude has access to.
TRACE BACKWARD TO THE BUG'S ORIGIN
Don't patch symptoms - fix the disease
SYMPTOM
↓ Where does this value come from?
IMMEDIATE CAUSE
↓ What set that to wrong value?
DEEPER CAUSE
↓ Why did that happen?
ROOT CAUSE ← Fix HERE
Q: What exactly went wrong?
→ Document the exact symptom
→ Note file, line, error message
Q: Where does this value/state come from?
→ Find the direct source
→ Check: is THIS the bug or just a carrier?
Q: What set THAT to the wrong value?
→ Follow the data flow backward
→ Each step: is this the origin or just passing it along?
SIGNS YOU'VE FOUND ROOT:
- Logic error in requirements interpretation
- Initial state incorrectly set
- Wrong assumption in algorithm
- Missing validation at entry point
- Broken invariant at creation
You've found root cause when:
You're still at symptoms if:
| Bug Pattern | Root Usually At |
|---|---|
| Wrong value displayed | Data calculation, not display code |
| Null pointer | Where object should've been created |
| Off-by-one | Loop bounds definition, not body |
| Race condition | Shared state design, not specific access |
| Invalid state | State transition logic, not current handler |
❌ Symptom Patching
// Bad: Fix where error happens
if (value === undefined) value = defaultValue
// Good: Find why value is undefined
❌ Guard Stacking
// Bad: Add guards everywhere
if (x) if (y) if (z) doThing()
// Good: Ensure x, y, z correct at source
❌ Quick Fix Pressure
"Just make it work" → Technical debt
Better: "5 more minutes tracing saves 5 hours debugging later"
After identifying root cause:
Use with:
assumption-checker → Was root cause an assumption?dependency-validator → Was root cause a broken dependency?pre-action-verifier → Verify root cause fix before applying