Convert Abstract Class to Interface refactoring
ReSharper | Refactor | Convert | Abstract Class to Interface…
To assign a shortcut, go to Tools | Options | Environment | Keyboard and find the ReSharper_Abstract2Interface
command.
This refactoring allows you to convert an abstract class to an interface. This can be useful when you want a class to inherit from more than one abstract classes — then you can easily convert one of them to an interface.
tip
The reverse functionality is available with the Convert Interface to Abstract Class refactoring refactoring.
Consider the example below. After applying the refactoring, a class is converted into an interface:
Before refactoring
public abstract class CachedItem{ public abstract int Id { get; set; } public abstract void Register(); public abstract void UnRegister();}
After refactoring
public interface CachedItem{ int Id { get; set; } void Register(); void UnRegister();}
Select an abstract class in one of the following ways:
In the editor, place the caret at the name of an abstract class.
Select an abstract class in the Solution Explorer.
Select an abstract class in the File Structure window window.
Select an abstract class in the Class View.
Select an abstract class in the Object Browser.
Select an abstract class in the type dependency diagram.
Do one of the following:
Press CtrlShift0R and then choose Convert Abstract Class to Interface.
Right-click and choose Refactor | Convert Abstract Class to Interface from the context menu.
Choose ReSharper | Refactor | Convert | Abstract Class to Interface… from the main menu.
If the abstract class contains non-abstract members, ReSharper shows you a dialog notifying that the bodies and/or accessors of such members will be removed. To avoid this, you need to move the logic of non-abstract members to child classes or elsewhere manually, and then invoke the refactoring again.
If no conflicts are identified, the abstract class is converted into an interface with the same name, and modifiers of abstract members are changed accordingly. Otherwise, resolve conflicts.
By default, the naming style for interfaces requires interface names to start with I
. Therefore, if you did not change the settings, the interface name will be highlighted as inconsistently named. Just press AltEnter and use the corresponding quick-fix to rename the interface.
This feature is supported in the following languages and technologies:
The instructions and examples given here address the use of the feature in C#. For more information about other languages, refer to corresponding topics in the Languages and frameworks section.