refactoring
npx skills add https://github.com/lexler/skill-factory --skill refactoring
Agent 安装分布
Skill 文档
Refactoring Production Code
STARTER_CHARACTER = ð£
When starting, announce: “ð£ Using REFACTORING skill”.
Work autonomously as much as possible. Start with the simplest thing or file and proceed to the more complex ones.
Stages
- Prep
- Main Refactoring
- Final Evaluation
- Summary
Test Code Policy
Do not change test code during refactoring, except:
- Renames that follow production code renames (imports, function calls)
- Import path updates if something moved
Never change test assertions, test data, or test logic.
1. Prep
- Determine scope: use specified files, or identify related files (imports, shared functionality), or ask user
- Add files in scope to todo list
- Find or create ./test.sh, verify all tests pass
- Remove comments from files in scope (commit per file)
2. Main Refactoring
Code Style
Prefer self-explanatory, readable code over comments.
- Use functional helper methods for clarity
- Remove dead code
- Extract paragraphs into methods
- Use better variable names
- Remove unused imports
- Remove unhelpful local variables
- Look for opportunities to simplify
- Use domain language – name things for what they ARE, not how they’re implemented
- Keep consistent abstraction levels within methods
Process
For each refactor:
- Ensure all tests pass
- Choose and perform the simplest possible refactoring (one at a time)
- Ensure all tests pass after the change
- Commit each successful refactor with the message format: “- r ” (the message must include the “- r” prefix) Prefer small granular commits. If applying the same refactoring pattern to multiple locations, change one location at a time and commit each separately.
- Provide a status update after each refactor
3. Final Evaluation
When you see no more obvious refactoring opportunities, say “ð Entering final evaluation.”
Shift focus: you’ve been implementing. Now become a critic. Your job is to find problems, not produce code.
Re-read Code Style guidelines. Look at each file in scope. Consider blind spots – what improvements haven’t we even considered that would make the code better, easier, more maintainable?
For each file, find ONE thing that could be better. If you find something:
- Fix it using the same refactoring process (test, change, test, commit)
- Look again; fixing one thing often reveals the next
Repeat until you find nothing more to improve.
4. Summary
Provide a high-level summary of the refactoring:
- List each file that was touched
- Describe the key improvements made in each file
Language-Specific
For Java: See references/java.md