uk/03-skills/refactor/SKILL.md
Систематичний рефакторинг коду на основі методології Мартіна Фаулера. Використовуйте, коли користувачі просять рефакторити код, покращити структуру коду, зменшити технічний борг, очистити застарілий код, усунути запахи коду (code smells) або покращити супровідність коду. Ця навичка проводить через поетапний підхід з дослідженням, плануванням та безпечною інкрементальною реалізацією.
npx skillsauth add luongnv89/claude-howto code-refactorInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Систематичний підхід до рефакторингу коду на основі книги Мартіна Фаулера Refactoring: Improving the Design of Existing Code (2-ге видання). Ця навичка наголошує на безпечних, інкрементальних змінах, підкріплених тестами.
«Рефакторинг — це процес зміни програмної системи таким чином, що не змінює зовнішню поведінку коду, але покращує його внутрішню структуру.» — Мартін Фаулер
Фаза 1: Дослідження та аналіз
↓
Фаза 2: Оцінка покриття тестами
↓
Фаза 3: Виявлення запахів коду
↓
Фаза 4: Створення плану рефакторингу
↓
Фаза 5: Інкрементальна реалізація
↓
Фаза 6: Перегляд та ітерація
Перед початком уточніть:
Представити знахідки користувачу:
«Рефакторинг без тестів — як їзда без пасків безпеки.» — Мартін Фаулер
Тести — ключовий засіб безпечного рефакторингу. Без них ви ризикуєте внести помилки.
Перевірити наявні тести
# Пошук файлів тестів
find . -name "*test*" -o -name "*spec*" | head -20
Запустити існуючі тести
# JavaScript/TypeScript
npm test
# Python
pytest -v
# Java
mvn test
Перевірити покриття (якщо доступно)
# JavaScript
npm run test:coverage
# Python
pytest --cov=.
Якщо тести існують та проходять:
Якщо тести відсутні або неповні: Представити варіанти:
Якщо тести не проходять:
Для кожної функції, що рефакториться, забезпечити тести для:
Використовуйте цикл «red-green-refactor»:
Симптоми глибших проблем у коді. Це не помилки, а індикатори того, що код можна покращити.
Див. references/code-smells.md для повного каталогу.
| Запах | Ознаки | Вплив | |-------|--------|-------| | Довгий метод | Методи > 30-50 рядків | Важко зрозуміти, тестувати, супроводжувати | | Дубльований код | Та сама логіка в кількох місцях | Виправлення помилок потрібне в кількох місцях | | Великий клас | Клас з занадто багатьма відповідальностями | Порушує принцип єдиної відповідальності | | Заздрість до функцій | Метод використовує дані іншого класу більше | Погана інкапсуляція | | Одержимість примітивами | Надмірне використання примітивів замість обʼєктів | Відсутні доменні концепції | | Довгий список параметрів | Методи з 4+ параметрами | Складно викликати правильно | | Групи даних | Ті самі елементи даних зʼявляються разом | Відсутня абстракція | | Оператори Switch | Складні ланцюжки switch/if-else | Важко розширювати | | Спекулятивна загальність | Код «на всякий випадок» | Зайва складність | | Мертвий код | Невикористаний код | Плутанина, тягар супровідності |
Автоматичний аналіз (якщо скрипти доступні)
python scripts/detect-smells.py <file>
Ручний перегляд
Пріоритезація Зосередитися на запахах, які:
Представити користувачу:
Для кожного запаху обрати відповідний рефакторинг з каталогу.
Див. references/refactoring-catalog.md для повного списку.
| Запах коду | Рекомендований рефакторинг | |------------|---------------------------| | Long Method | Extract Method, Replace Temp with Query | | Duplicated Code | Extract Method, Pull Up Method, Form Template Method | | Large Class | Extract Class, Extract Subclass | | Feature Envy | Move Method, Move Field | | Primitive Obsession | Replace Primitive with Object, Replace Type Code with Class | | Long Parameter List | Introduce Parameter Object, Preserve Whole Object | | Data Clumps | Extract Class, Introduce Parameter Object | | Switch Statements | Replace Conditional with Polymorphism | | Speculative Generality | Collapse Hierarchy, Inline Class, Remove Dead Code | | Dead Code | Remove Dead Code |
Використовуйте шаблон templates/refactoring-plan.md.
Для кожного рефакторингу:
КРИТИЧНО: Впроваджуйте рефакторинг поступово, фазами.
Фаза A: Швидкі перемоги (Низький ризик, висока цінність)
Фаза B: Структурні покращення (Середній ризик)
Фаза C: Архітектурні зміни (Вищий ризик)
Перед реалізацією:
«Зміна → Тест → Зелений? → Коміт → Наступний крок»
Для кожного кроку рефакторингу:
Попередня перевірка
Зробити ОДНУ малу зміну
Верифікація
Якщо тести проходять (зелені)
Якщо тести не проходять (червоні)
Кожен коміт має бути:
Приклади повідомлень комітів:
refactor: Extract calculateTotal() from processOrder()
refactor: Rename 'x' to 'customerCount' for clarity
refactor: Remove unused validateOldFormat() method
Після кожної підфази звітувати користувачу:
Запустити аналіз складності до і після:
python scripts/analyze-complexity.py <file>
Представити покращення:
Представити фінальні результати:
Обговорити з користувачем:
Завжди паузу та консультацію з користувачем, коли:
До:
function processOrder(order) {
// 150 рядків коду з:
// - Дубльованою логікою валідації
// - Інлайн-обчисленнями
// - Змішаними відповідальностями
}
Кроки рефакторингу:
Після:
function processOrder(order) {
validateOrder(order);
const total = calculateOrderTotal(order);
notifyCustomer(order, total);
return { order, total };
}
scripts/analyze-complexity.py — аналіз метрик складності кодуscripts/detect-smells.py — автоматичне виявлення запахівdevelopment
提供全面的代码审查能力,覆盖安全、性能和代码质量分析。适用于用户请求代码审查、代码质量评估、Pull Request 审查,或提到安全分析和性能优化时。
development
Review code toàn diện với phân tích bảo mật, hiệu suất, và chất lượng. Sử dụng khi người dùng yêu cầu review code, phân tích chất lượng code, đánh giá pull requests, hoặc đề cập đến review code, phân tích bảo mật, hoặc tối ưu hóa hiệu suất.
development
Комплексне код-рев'ю з аналізом безпеки, продуктивності та якості. Використовуйте, коли користувачі просять переглянути код, проаналізувати якість коду, оцінити pull request, або згадують код-рев'ю, аналіз безпеки чи оптимізацію продуктивності.
development
<!-- i18n-source: 03-skills/code-review-specialist/SKILL.md --> <!-- i18n-source-sha: e978c49 --> <!-- i18n-date: 2026-04-27 --> --- name: code-review-specialist description: セキュリティ、パフォーマンス、品質分析を含む包括的なコードレビュー。コードレビュー、コード品質分析、プルリクエスト評価の依頼があった場合、またはコードレビュー、セキュリティ分析、パフォーマンス最適化について言及がある場合に使用する。 --- # コードレビュー・スキル このスキルは、以下に焦点を当てた包括的なコードレビュー機能を提供する。 1. **セキュリティ分析** - 認証・認可の問題 - データ漏洩リスク - インジェクション脆弱性 - 暗号の弱点 - 機密データのロギング 2. **パフォーマンス・レビュー** - アルゴリズム効率(Big O 分析) - メモリ最適化 -