Agent Skills: πŸ”§ Tech Debt Reducer

Systematic technical debt reduction and code optimization agent. Use when refactoring code, reducing complexity, eliminating code smells, improving performance, cleaning up unused code, or modernizing legacy patterns. Handles dependency updates, architecture improvements, and codebase health metrics.

UncategorizedID: g97iulio1609/vscode-agent-skills/tech-debt-reducer

Install this agent skill to your local

pnpm dlx add-skill https://github.com/giulio-leone/vscode-agent-skills/tree/HEAD/skills/tech-debt-reducer

Skill Files

Browse the full folder contents for tech-debt-reducer.

Download Skill

Loading file tree…

skills/tech-debt-reducer/SKILL.md

Skill Metadata

Name
tech-debt-reducer
Description
Systematic technical debt reduction and code optimization agent. Use when refactoring code, reducing complexity, eliminating code smells, improving performance, cleaning up unused code, or modernizing legacy patterns. Handles dependency updates, architecture improvements, and codebase health metrics.

πŸ”§ Tech Debt Reducer

Systematic approach to identifying, prioritizing, and eliminating technical debt while improving code quality and performance.

Quick Reference

| Task | Command/Action | |------|----------------| | Analyze complexity | Run scripts/analyze-complexity.ts | | Find unused code | Run scripts/find-unused.ts | | Detect code smells | Run scripts/detect-smells.ts | | Generate debt report | Run scripts/debt-report.ts | | Prioritize debt items | Follow "Prioritization Matrix" section |

Core Methodology

Phase 1: Assessment (ALWAYS FIRST)

Before any refactoring, assess the current state:

## πŸ“Š Tech Debt Assessment

### Codebase Metrics
- **Total Files**: [count]
- **Lines of Code**: [count]
- **Average Complexity**: [score]
- **Test Coverage**: [percentage]
- **Dependency Age**: [stats]

### Identified Issues
| Category | Count | Severity | Effort |
|----------|-------|----------|--------|
| Code Smells | X | High/Med/Low | S/M/L |
| Unused Code | X | Low | S |
| Complex Functions | X | Med | M |
| Outdated Deps | X | High | M |
| Missing Types | X | Med | S |

Phase 2: Categorization

Classify debt into categories:

| Category | Description | Examples | |----------|-------------|----------| | Architecture | Structural issues | Circular deps, wrong abstractions | | Code Quality | Maintainability issues | Long functions, duplicate code | | Performance | Speed/memory issues | N+1 queries, memory leaks | | Security | Vulnerability issues | Outdated deps, exposed secrets | | Testing | Coverage gaps | Missing tests, flaky tests | | Documentation | Knowledge gaps | Missing docs, outdated comments |

Phase 3: Prioritization Matrix

Use the Impact vs Effort matrix:

High Impact β”‚  Quick Wins    β”‚  Strategic
            β”‚  (Do First)    β”‚  (Plan Carefully)
────────────┼────────────────┼─────────────────
Low Impact  β”‚  Fill-ins      β”‚  Avoid
            β”‚  (If Time)     β”‚  (Not Worth It)
            └────────────────┴─────────────────
              Low Effort       High Effort

Priority Formula: Score = (Impact Γ— Risk) / Effort

Phase 4: Refactoring Patterns

See references/REFACTORING_PATTERNS.md for detailed patterns.

Safe Refactoring Workflow

1. βœ… Ensure tests exist (or write them first)
2. πŸ“Έ Create snapshot/checkpoint (git commit)
3. πŸ”§ Apply ONE refactoring at a time
4. πŸ§ͺ Run tests after each change
5. πŸ“ Commit with descriptive message
6. πŸ”„ Repeat

Code Smell Detection

Common Smells and Fixes

| Smell | Detection | Fix | |-------|-----------|-----| | Long Function | >50 lines | Extract methods | | Large Class | >300 lines | Split into smaller classes | | Long Parameter List | >4 params | Use parameter object | | Duplicate Code | Similar blocks | Extract common function | | Dead Code | Unreachable code | Remove safely | | Magic Numbers | Hardcoded values | Extract constants | | God Object | Does too much | Single responsibility | | Feature Envy | Uses other class data | Move method |

TypeScript-Specific Smells

| Smell | Example | Fix | |-------|---------|-----| | any abuse | data: any | Proper types | | Missing null checks | obj.prop | Optional chaining ?. | | Type assertions | as Type | Type guards | | Implicit any | No param types | Explicit types | | No return types | Functions without | Add return types |

Performance Optimization

Quick Wins

// ❌ Bad: Multiple re-renders
const items = data.filter(x => x.active).map(x => x.name);

// βœ… Good: Single pass with reduce
const items = data.reduce((acc, x) => {
  if (x.active) acc.push(x.name);
  return acc;
}, []);

// ❌ Bad: Creating functions in render
<Button onClick={() => handleClick(id)} />

// βœ… Good: useCallback or handler
const handleButtonClick = useCallback(() => handleClick(id), [id]);

// ❌ Bad: Missing memoization
const expensiveValue = computeExpensive(data);

// βœ… Good: useMemo for expensive computations
const expensiveValue = useMemo(() => computeExpensive(data), [data]);

Database Query Optimization

// ❌ Bad: N+1 Query
const users = await prisma.user.findMany();
for (const user of users) {
  const posts = await prisma.post.findMany({ where: { userId: user.id } });
}

// βœ… Good: Include related data
const users = await prisma.user.findMany({
  include: { posts: true }
});

// βœ… Better: Select only needed fields
const users = await prisma.user.findMany({
  select: { id: true, name: true, posts: { select: { title: true } } }
});

Dependency Management

Update Strategy

  1. Check outdated: npm outdated
  2. Review changelogs for breaking changes
  3. Update in order: patch β†’ minor β†’ major
  4. Test after each major update

Cleanup Unused Dependencies

# Find unused dependencies
npx depcheck

# Analyze bundle size
npx webpack-bundle-analyzer

# Check for duplicates
npm dedupe

Output Template

After completing debt reduction work:

## πŸ”§ Tech Debt Report

### πŸ“Š Before/After Metrics
| Metric | Before | After | Change |
|--------|--------|-------|--------|
| Complexity | X | Y | -Z% |
| Lines of Code | X | Y | -Z% |
| Test Coverage | X% | Y% | +Z% |
| Bundle Size | X KB | Y KB | -Z% |

### βœ… Changes Made
1. [Description of change 1]
2. [Description of change 2]

### πŸ§ͺ Tests
- [ ] All existing tests pass
- [ ] New tests added for refactored code
- [ ] No regressions detected

### πŸ“ Follow-up Items
- [ ] Item that needs future attention

Safety Guidelines

  • ❌ NEVER refactor without tests
  • ❌ NEVER make multiple unrelated changes in one commit
  • ❌ NEVER refactor and add features simultaneously
  • βœ… ALWAYS commit working state before refactoring
  • βœ… ALWAYS run tests after each change
  • βœ… ALWAYS preserve external behavior

Escalation Criteria

Stop and reassess if:

  • Tests start failing unexpectedly
  • Refactoring scope grows beyond initial estimate
  • Performance degrades after optimization
  • Breaking changes affect public API