ReSharper 2020.2 Help

Replace Constructor with Factory Method refactoring

ReSharper | Refactor | Convert | Constructor to Factory Method…
ReSharper_Constructor2FactoryMethodAction

This refactoring helps implement the factory method pattern for an existing class. If you opt to create the factory method in the same class, the refactoring makes the selected constructor private and encapsulates it into a static method that returns a new instance of the class. You can also choose to create the factory method in any other class. In this case, the constructor stays public, you can change its access modifier later, if necessary.

If there are any usages of the constructor, they are replaced with factory method calls.

In the example below, we use the refactoring to add the factory method in the same class:

class Foo { public Foo() { // instance initialization } }
class Foo { public static Foo CreateFoo() { return new Foo(); } private Foo() { // instance initialization } }

Replace a constructor with a factory method

  1. In the editor, place the caret at a constructor or choose a constructor in the File Structure window.

  2. Do one of the following:

    • Press Control+Shift+R and then choose Replace Constructor with Factory Method

    • Right-click and choose Refactor | Replace Constructor with Factory Method in the context menu.

    • Choose ReSharper | Refactor | Convert | Constructor to Factory Method… in the main menu.

    The Replace Constructor with Factory Method dialog will open.

  3. Specify a name for the factory method or accept the suggested name.

  4. By default, the refactoring creates factory method in the same class. If you want to create the factory method in another class, specify the fully qualified name of the class.

  5. To apply the refactoring, click Next.

  6. If no conflicts are found, ReSharper performs the refactoring immediately. Otherwise, it prompts you to resolve conflicts.

ReSharper. Replace Constructor with Factory Method refactoring

This feature is supported in the following languages and technologies:

Language: C#Language: VB.NETLanguage: C++Language: HTMLLanguage: ASP.NETLanguage: RazorLanguage: JavaScriptLanguage: TypeScriptLanguage: CSSLanguage: XMLLanguage: XAMLLanguage: ResxLanguage: Build ScriptsLanguage: ProtobufLanguage: JSON
Feature is available in C#Feature is available in Visual Basic .NETFeature is not available in C++Feature is not available in HTMLFeature is not available in ASP.NETFeature is not available in RazorFeature is not available in JavaScriptFeature is not available in TypeScriptFeature is not available in CSSFeature is not available in XMLFeature is not available in XAMLFeature is not available in Resource filesFeature is not available in build script filesFeature is not available in ProtobufFeature is not available in JSON

The instructions and examples given here address the use of the feature in C#. For details specific to other languages, see corresponding topics in the ReSharper by Language section.

Last modified: 03 September 2020