JetBrains Rider 2023.3 Help

Extract Method refactoring

This refactoring allows you to create a new method or a local function based on the selected code fragment. JetBrains Rider analyzes the selected statements and detects variables that can be converted into method parameters or represent its return value.

Consider the following example. The method PrintReversed() actually does two things: it reverses the string and prints it. We can select the reversing logic, which is all statements except Console.WriteLine(reversed);, and use this refactoring to move that logic to a new PrintReversed() method.

static void PrintReversed(string input) { var chars = input.ToCharArray(); Array.Reverse(chars); var reversed = new string(chars); Console.WriteLine(reversed); }
static void PrintReversed(string input) { var reversed = ReverseStr(input); Console.WriteLine(reversed); } private static string ReverseStr(string input) { var chars = input.ToCharArray(); Array.Reverse(chars); var reversed = new string(chars); return reversed; }

Extract a method from selected statements

  1. In the editor, select one or more statements that you want to convert into a local function.

  2. Do one of the following:

    • Press Ctrl+Alt+M.

    • Press Alt+Enter and choose Extract Method.

    • Press Ctrl+Alt+Shift+T and then choose Extract Method.

    • Choose Refactor | Extract Method from the main menu.

  3. In the popup that opens, select Extract Local Function.

  4. A dialog appears where you can configure the extracted local function:

    JetBrains Rider. Extract Method refactoring
  5. Type a name for the new local function in the Name field.

  6. Select one of expressions that JetBrains Rider detected as possible return values in the Return list. There may be other expressions detected as possible return values. They are listed as out parameters.

  7. Include or exclude parameters using the corresponding checkboxes in the Parameters area. If you exclude a parameter from the list, the local variable with the same name and type will be created if necessary.

  8. To change the order of the parameters, select a parameter in the list and use the Move Up and Move Up buttons.

  9. Select the Make static and/or Make virtual to add the corresponding modifiers to the method.

  10. If necessary, change the visibility of the method in the Visibility list.

  11. Check the signature and body of the resulting local function in the Preview field.

  12. To apply the refactoring, click Next.

  13. If no conflicts are found, JetBrains Rider performs the refactoring immediately. Otherwise, it prompts you to resolve conflicts.

Extract local function from selected statements

  1. In the editor, select one or more statements that you want to convert into a local function.

  2. Do one of the following:

    • Press Ctrl+Alt+M.

    • Press Alt+Enter and choose Extract Method.

    • Press Ctrl+Alt+Shift+T and then choose Extract Method.

    • Choose Refactor | Extract Method from the main menu.

  3. In the popup that opens, select Extract Local Function.

  4. In the dialog that opens, specify where to place the local function inside the current method, and click Next.

    JetBrains Rider: Extract local function refactoring
  5. A dialog appears where you can configure the extracted local function:

    JetBrains Rider. Extract Method refactoring
  6. Type a name for the new local function in the Name field.

  7. Select one of expressions that JetBrains Rider detected as possible return values in the Return list. There may be other expressions detected as possible return values. They are listed as out parameters.

  8. Include or exclude parameters using the corresponding checkboxes in the Parameters area. If you exclude a parameter from the list, the local variable with the same name and type will be created if necessary.

  9. To change the order of the parameters, select a parameter in the list and use the Move Up and Move Up buttons.

  10. Check the signature and body of the resulting local function in the Preview field.

  11. To apply the refactoring, click Next.

  12. If no conflicts are found, JetBrains Rider performs the refactoring immediately. Otherwise, it prompts you to resolve conflicts.

Last modified: 18 March 2024