rust-refactor-helper

Safe Rust refactoring with LSP analysis. Triggers on: /refactor, rename symbol, move function, extract, 重构, 重命名, 提取函数, 安全重构

INSTALLATION
npx skills add https://github.com/actionbook/rust-skills --skill rust-refactor-helper
Run in your project or agent environment. Adjust flags if your CLI version differs.

SKILL.md

Rust Refactor Helper

Perform safe refactoring with comprehensive impact analysis.

Usage

/rust-refactor-helper <action> <target> [--dry-run]

Actions:

  • rename <old> <new> - Rename symbol
  • extract-fn <selection> - Extract to function
  • inline <fn> - Inline function
  • move <symbol> <dest> - Move to module

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(&#x26;path)?;

let mut contents = String::new();

file.read_to_string(&#x26;mut contents)?;

let config: Config = toml::from_str(&#x26;contents)?;

validate_config(&#x26;config)?;

​```

### Analysis

**Inputs:** path: &#x26;Path

**Outputs:** config: Config

**Side Effects:** File I/O, may return error

### Extracted Function

​```rust

fn load_and_validate_config(path: &#x26;Path) -> Result<Config> {

    let file = File::open(path)?;

    let mut contents = String::new();

    file.read_to_string(&#x26;mut contents)?;

    let config: Config = toml::from_str(&#x26;contents)?;

    validate_config(&#x26;config)?;

    Ok(config)

}

​```

### Replacement

​```rust

let config = load_and_validate_config(&#x26;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

BrowserAct

Let your agent run on any real-world website

Bypass CAPTCHA & anti-bot for free. Start local, scale to cloud.

Explore BrowserAct Skills →

Stop writing automation&scrapers

Install the CLI. Run your first Skill in 30 seconds. Scale when you're ready.

Start free
free · no credit card