Learn-skills.dev rust-refactor-helper
Safe Rust refactoring with LSP analysis. Triggers on: /refactor, rename symbol, move function, extract, 重构, 重命名, 提取函数, 安全重构
install
source · Clone the upstream repo
git clone https://github.com/NeverSight/learn-skills.dev
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/NeverSight/learn-skills.dev "$T" && mkdir -p ~/.claude/skills && cp -r "$T/data/skills-md/actionbook/rust-skills/rust-refactor-helper" ~/.claude/skills/neversight-learn-skills-dev-rust-refactor-helper && rm -rf "$T"
manifest:
data/skills-md/actionbook/rust-skills/rust-refactor-helper/SKILL.mdsource content
Rust Refactor Helper
Perform safe refactoring with comprehensive impact analysis.
Usage
/rust-refactor-helper <action> <target> [--dry-run]
Actions:
- Rename symbolrename <old> <new>
- Extract to functionextract-fn <selection>
- Inline functioninline <fn>
- Move to modulemove <symbol> <dest>
Examples:
/rust-refactor-helper rename parse_config load_config/rust-refactor-helper extract-fn src/main.rs:20-35/rust-refactor-helper move UserService src/services/
LSP Operations Used
Pre-Refactor Analysis
# Find all references before renaming LSP( operation: "findReferences", filePath: "src/lib.rs", line: 25, character: 8 ) # Get symbol info LSP( operation: "hover", filePath: "src/lib.rs", line: 25, character: 8 ) # Check call hierarchy for move operations LSP( operation: "incomingCalls", filePath: "src/lib.rs", line: 25, character: 8 )
Refactoring Workflows
1. Rename Symbol
User: "Rename parse_config to load_config" │ ▼ [1] Find symbol definition LSP(goToDefinition) │ ▼ [2] Find ALL references LSP(findReferences) │ ▼ [3] Categorize by file │ ▼ [4] Check for conflicts - Is 'load_config' already used? - Are there macro-generated uses? │ ▼ [5] Show impact analysis (--dry-run) │ ▼ [6] Apply changes with Edit tool
Output:
## Rename: parse_config → load_config ### Impact Analysis **Definition:** src/config.rs:25 **References found:** 8 | File | Line | Context | Change | |------|------|---------|--------| | src/config.rs | 25 | `pub fn parse_config(` | Definition | | src/config.rs | 45 | `parse_config(path)?` | Call | | src/main.rs | 12 | `config::parse_config` | Import | | src/main.rs | 30 | `let cfg = parse_config(` | Call | | src/lib.rs | 8 | `pub use config::parse_config` | Re-export | | tests/config_test.rs | 15 | `parse_config("test.toml")` | Test | | tests/config_test.rs | 25 | `parse_config("")` | Test | | docs/api.md | 42 | `parse_config` | Documentation | ### Potential Issues ⚠️ **Documentation reference:** docs/api.md:42 may need manual update ⚠️ **Re-export:** src/lib.rs:8 - public API change ### Proceed? - [x] --dry-run (preview only) - [ ] Apply changes
2. Extract Function
User: "Extract lines 20-35 in main.rs to a function" │ ▼ [1] Read the selected code block │ ▼ [2] Analyze variables - Which are inputs? (used but not defined in block) - Which are outputs? (defined and used after block) - Which are local? (defined and used only in block) │ ▼ [3] Determine function signature │ ▼ [4] Check for early returns, loops, etc. │ ▼ [5] Generate extracted function │ ▼ [6] Replace original code with call
Output:
## Extract Function: src/main.rs:20-35 ### Selected Code ```rust let file = File::open(&path)?; let mut contents = String::new(); file.read_to_string(&mut contents)?; let config: Config = toml::from_str(&contents)?; validate_config(&config)?; ``` ### Analysis **Inputs:** path: &Path **Outputs:** config: Config **Side Effects:** File I/O, may return error ### Extracted Function ```rust fn load_and_validate_config(path: &Path) -> Result<Config> { let file = File::open(path)?; let mut contents = String::new(); file.read_to_string(&mut contents)?; let config: Config = toml::from_str(&contents)?; validate_config(&config)?; Ok(config) } ``` ### Replacement ```rust let config = load_and_validate_config(&path)?; ```
3. Move Symbol
User: "Move UserService to src/services/" │ ▼ [1] Find symbol and all its dependencies │ ▼ [2] Find all references (callers) LSP(findReferences) │ ▼ [3] Analyze import changes needed │ ▼ [4] Check for circular dependencies │ ▼ [5] Generate move plan
Output:
## Move: UserService → src/services/user.rs ### Current Location src/handlers/auth.rs:50-120 ### Dependencies (will be moved together) - struct UserService (50-80) - impl UserService (82-120) - const DEFAULT_TIMEOUT (48) ### Import Changes Required | File | Current | New | |------|---------|-----| | src/main.rs | `use handlers::auth::UserService` | `use services::user::UserService` | | src/handlers/api.rs | `use super::auth::UserService` | `use crate::services::user::UserService` | | tests/auth_test.rs | `use crate::handlers::auth::UserService` | `use crate::services::user::UserService` | ### New File Structure ``` src/ ├── services/ │ ├── mod.rs (NEW - add `pub mod user;`) │ └── user.rs (NEW - UserService moved here) ├── handlers/ │ └── auth.rs (UserService removed) ``` ### Circular Dependency Check ✅ No circular dependencies detected
Safety Checks
| Check | Purpose |
|---|---|
| Reference completeness | Ensure all uses are found |
| Name conflicts | Detect existing symbols with same name |
| Visibility changes | Warn if pub/private scope changes |
| Macro-generated code | Warn about code in macros |
| Documentation | Flag doc comments mentioning symbol |
| Test coverage | Show affected tests |
Dry Run Mode
Always use
--dry-run first to preview changes:
/rust-refactor-helper rename old_name new_name --dry-run
This shows all changes without applying them.
Related Skills
| When | See |
|---|---|
| Navigate to symbol | rust-code-navigator |
| Understand call flow | rust-call-graph |
| Project structure | rust-symbol-analyzer |
| Trait implementations | rust-trait-explorer |