When the Extract Method refactoring is invoked , IntelliJ IDEA analyses the selected block of code and detects variables that are the input for the selected code fragment and the variables that are output for it.
If there is exactly one output variable, it is used as a return value for the extracted method. In case there are multiple output variables, the Extract Method refactoring may not be applied, and the error message appears.
There are several workarounds to allow Extract Method work in this case. For example, you may introduce a special data-class that contains all output values.
To extract a method
- In the editor, select a block of code to be transformed into a method or a function.
- On the main menu or on the context menu of the selection, choose Refactor | Extract | Method or press Ctrl+Alt+M.
- In the Extract Method dialog box that opens, specify the name of the new method.
- To create a static method, select the Declare Static check box.
area, do the following:
- Specify the variables to be passed as method parameters, by selecting/clearing the corresponding check boxes; if a parameter is disabled, a local variable of the corresponding type, with the initial value ... will be created in the extracted method, so that you will have to enter the initializer with an appropriate value manually.
- Rename the desired parameters, by double-clicking the corresponding parameter lines and entering new names.
- In the Visibility area define the method's visibility scope.
- Check the result in the Signature Preview pane and click OK to create the method. The selected code fragment will be replaced with a method call. Additionally, IntelliJ IDEA will propose to replace any similar code fragments found within the current class.