refactor-helper
2
总安装量
2
周安装量
#70063
全站排名
安装命令
npx skills add https://github.com/shunsukehayashi/miyabi --skill refactor-helper
Agent 安装分布
openclaw
2
gemini-cli
2
github-copilot
2
codex
2
kimi-cli
2
cursor
2
Skill 文档
Refactor Helper
Version: 1.0.0 Purpose: Safe, systematic code refactoring
Triggers
| Trigger | Examples |
|---|---|
| Refactor | “refactor this”, “ãªãã¡ã¯ã¿ãªã³ã°ã㦔, “clean up code” |
| Improve | “improve this code”, “ã³ã¼ãæ¹å” |
| Modernize | “update to modern syntax”, “ã¢ãã³å” |
Refactoring Principles
1. Make Small Changes
â
GOOD: One refactoring per commit
â BAD: Multiple unrelated changes in one commit
2. Ensure Tests Pass
# Before refactoring
npm test
# After each change
npm test
3. Keep Behavior Unchanged
Refactoring = Improving structure WITHOUT changing behavior
Common Patterns
Extract Function
// Before
function processOrder(order: Order) {
// validate
if (!order.items.length) throw new Error('Empty');
if (order.total < 0) throw new Error('Invalid total');
// calculate
const subtotal = order.items.reduce((s, i) => s + i.price, 0);
const tax = subtotal * 0.1;
const total = subtotal + tax;
// save
db.save({ ...order, total });
}
// After
function validateOrder(order: Order): void {
if (!order.items.length) throw new Error('Empty');
if (order.total < 0) throw new Error('Invalid total');
}
function calculateTotal(items: Item[]): number {
const subtotal = items.reduce((s, i) => s + i.price, 0);
const tax = subtotal * 0.1;
return subtotal + tax;
}
function processOrder(order: Order) {
validateOrder(order);
const total = calculateTotal(order.items);
db.save({ ...order, total });
}
Replace Conditionals with Polymorphism
// Before
function getPrice(type: string, base: number): number {
switch (type) {
case 'premium': return base * 0.8;
case 'vip': return base * 0.7;
default: return base;
}
}
// After
interface PricingStrategy {
calculate(base: number): number;
}
class RegularPricing implements PricingStrategy {
calculate(base: number) { return base; }
}
class PremiumPricing implements PricingStrategy {
calculate(base: number) { return base * 0.8; }
}
Simplify Conditionals
// Before
if (user !== null && user !== undefined && user.isActive === true) {
if (user.role === 'admin' || user.role === 'moderator') {
// ...
}
}
// After
const isActiveUser = user?.isActive ?? false;
const hasPrivileges = ['admin', 'moderator'].includes(user?.role ?? '');
if (isActiveUser && hasPrivileges) {
// ...
}
Remove Dead Code
# Find unused exports
npx ts-prune
# Find unused dependencies
npx depcheck
Workflow
Step 1: Identify Smell
| Code Smell | Refactoring |
|---|---|
| Long function | Extract Function |
| Duplicate code | Extract and reuse |
| Complex conditionals | Simplify/Polymorphism |
| God class | Split responsibilities |
| Feature envy | Move method |
Step 2: Write Tests (if missing)
describe('processOrder', () => {
it('should calculate total correctly', () => {
const order = { items: [{ price: 100 }] };
expect(processOrder(order).total).toBe(110);
});
});
Step 3: Refactor
Small, incremental changes with tests after each.
Step 4: Verify
npm test
npm run lint
npm run typecheck
Checklist
- Tests exist and pass before refactoring
- Each change is small and focused
- Tests pass after each change
- No behavior changes
- Code is more readable
- Commit with clear message