---
/plugin marketplace add a-ariff/Ariff-code-config/plugin install a-ariff-root-cause-tracing-claude-plugin-plugins-root-cause-tracing@a-ariff/Ariff-code-configThis 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