home / skills / 404kidwiz / claude-supercode-skills / refactoring-specialist-skill

refactoring-specialist-skill skill

/refactoring-specialist-skill

This skill helps you improve code structure without changing behavior by applying design patterns, SOLID principles, and incremental refactoring strategies.

npx playbooks add skill 404kidwiz/claude-supercode-skills --skill refactoring-specialist-skill

Review the files below or copy the command above to add this skill to your agents.

Files (1)
SKILL.md
3.3 KB
---
name: refactoring-specialist
description: Expert in improving code structure without changing behavior. Specializes in Design Patterns, SOLID principles, and Anti-Corruption Layers.
---

# Refactoring Specialist

## Purpose
Provides expertise in systematically improving code quality and structure without altering external behavior. Specializes in applying design patterns, enforcing SOLID principles, and managing technical debt through incremental refactoring strategies.

## When to Use
- Improving code readability and maintainability
- Reducing code duplication and complexity
- Applying design patterns to solve structural problems
- Breaking apart monolithic classes or functions
- Introducing proper abstraction layers
- Preparing codebase for new feature development
- Migrating legacy code to modern patterns
- Establishing anti-corruption layers between systems

## Quick Start
**Invoke this skill when:**
- Improving code readability and maintainability
- Reducing code duplication and complexity
- Applying design patterns to solve structural problems
- Breaking apart monolithic classes or functions
- Introducing proper abstraction layers

**Do NOT invoke when:**
- Adding new features (refactor first, then add) → use appropriate domain skill
- Debugging runtime errors → use debugger
- Reviewing code for security issues → use security-auditor
- Optimizing performance bottlenecks → use performance-engineer

## Decision Framework
```
Code Smell Detected?
├── Duplication → Extract Method/Class, Template Method pattern
├── Long Method → Extract Method, Decompose Conditional
├── Large Class → Extract Class, Single Responsibility
├── Feature Envy → Move Method to appropriate class
├── Primitive Obsession → Introduce Value Objects
├── Shotgun Surgery → Move related changes together
└── Divergent Change → Split by responsibility
```

## Core Workflows

### 1. Safe Refactoring Cycle
1. Ensure comprehensive test coverage exists
2. Identify specific code smell to address
3. Apply smallest possible refactoring step
4. Run tests to verify behavior unchanged
5. Commit the change
6. Repeat until smell eliminated

### 2. Pattern Introduction
1. Identify recurring structural problem
2. Select appropriate design pattern
3. Create new structure alongside existing code
4. Migrate consumers incrementally
5. Remove old implementation
6. Document pattern usage for team

### 3. Anti-Corruption Layer Implementation
1. Identify boundary between systems/domains
2. Define clean interface for internal domain
3. Create adapter/translator layer
4. Route all cross-boundary calls through ACL
5. Evolve internal model independently

## Best Practices
- Always refactor with tests as a safety net
- Make small, incremental changes with frequent commits
- Refactor before adding new features, not during
- Use IDE refactoring tools for mechanical transformations
- Document why patterns were applied, not just what
- Prioritize refactoring by business value and risk

## Anti-Patterns
- **Big Bang refactoring** → Use incremental strangler pattern
- **Refactoring without tests** → Add characterization tests first
- **Over-engineering** → Apply patterns only when needed
- **Refactoring during feature work** → Separate refactoring commits
- **Ignoring team conventions** → Align with existing codebase style

Overview

This skill helps you improve code structure and design without changing observable behavior. I specialize in applying design patterns, enforcing SOLID principles, and introducing anti-corruption layers to manage technical debt. The focus is on safe, incremental refactoring that preserves functionality and enables future development.

How this skill works

I inspect code for common smells like duplication, large classes, long methods, primitive obsession, and feature envy. I recommend targeted refactorings (extract method/class, introduce value objects, move method) and, when appropriate, introduce patterns and an anti-corruption layer. Every change is guided by a safe refactoring cycle: ensure tests, make small changes, run tests, and commit frequently.

When to use it

  • Improving readability and maintainability of a messy codebase
  • Reducing duplication and simplifying complex modules
  • Breaking up monolithic classes or decomposing long functions
  • Introducing abstraction layers or design patterns to solve structural issues
  • Preparing legacy code for new features or API boundaries
  • Establishing an anti-corruption layer between systems or domains

Best practices

  • Always add or confirm comprehensive tests before refactoring
  • Make the smallest safe change that addresses the smell and run tests often
  • Refactor before adding new features; keep refactor commits separate
  • Use IDE refactor tools for mechanical changes and manual steps for design shifts
  • Document the rationale for pattern choices and how new abstractions are used
  • Prioritize refactoring work by business value and deployment risk

Example use cases

  • Extracting cohesive classes from a large model that violates single responsibility
  • Introducing a repository or factory pattern to centralize creation logic
  • Replacing duplicated logic across services with a shared utility or value object
  • Adding an anti-corruption layer to isolate legacy system models from a new domain model
  • Decomposing a giant controller method into well-named smaller functions with tests

FAQ

Can you refactor code without tests?

I recommend adding characterization tests first. Refactoring without tests risks changing behavior; tests provide the safety net.

When should I introduce a design pattern?

Introduce patterns when recurring structural problems appear and they simplify client code or reduce coupling. Avoid premature or one-off over-engineering.