Profiles
This page of ReSharper options allows you to manage and configure custom cleanup profiles, as well as to assign a cleanup profile for the silent code cleanup. The two default profiles (Full Cleanup, Reformat & Apply Syntax Style and Reformat Code) are also shown here. You cannot modify them, but you can clone them to make new custom profiles.
Toolbar controls
Use the following controls to configure the selected cleanup profile:
Set as default | Click this button to use the selected profile for silent cleanup. The profile used for silent cleanup is marked with the icon. |
Duplicate | Click this button to create a copy of the selected profile. If you have default settings, you will need to duplicate one of the default cleanup profiles to create a custom cleanup profile. As soon as a new profile is created, it opens in the editing mode, where you can configure the list of cleanup tasks. |
Configure | Click this button to enable the editing mode for the selected custom profile. Note that default profiles (Full Cleanup, Reformat & Apply Syntax Style and Reformat Code) cannot be edited. |
Rename | Click this button to rename the selected custom profile. Note that default profiles (Full Cleanup, Reformat & Apply Syntax Style and Reformat Code) cannot be renamed. |
Remove | Click this button to remove the selected custom profile. Note that default profiles (Full Cleanup, Reformat & Apply Syntax Style and Reformat Code) cannot be removed. |
Done | Click this button to exit the editing mode and go back to the preview of the selected profile. Note that your modifications will not be applied unless you click Save. |
Code cleanup tasks for selected profile
These tasks become configurable when you switch the editing mode ( Configure) for the selected custom cleanup profile. Initially, there are no custom profiles and tasks of the default profiles cannot be edited. You can click Duplicate to create an editable copy of one of the default profiles and then edit its tasks.
C#
Apply file layout | Reorders type members in files according to the rules configurable on the Alt+R, O). For more information, see Rearrange Members with File and Type Layout Patterns. | page of ReSharper options(
Update file header | Inserts or updates the file header comment that you can configure on the File Header Style. | page of ReSharper options. For more information, see
Syntax Styles | |
Apply 'var' style | Applies the rules for 'var' usage during the cleanup. The rules are configurable on the page of ReSharper options(Alt+R, O). |
Use explicit or implicit modifier definition for types | Applies the rule for type modifiers - whether on not to use the internal modifier explicitly. The rule is configurable on the page of ReSharper options(Alt+R, O). For more information, see Code Syntax Style: Modifiers. |
Use explicit or implicit modifier definition for type members | Applies the rule for type member modifiers - whether on not to use the private modifier explicitly. The rule is configurable on the page of ReSharper options(Alt+R, O). For more information, see Code Syntax Style: Modifiers. |
Sort modifiers | Applies the preferred order of type/member modifiers. The rule is configurable on the Alt+R, O). For more information, see Code Syntax Style: Modifiers. | page of ReSharper options(
Apply arguments style (named | positional) | Applies the preferences for named/positional arguments for specific types of parameters. The preferences are configurable on the Alt+R, O). For more information, see Code Syntax Style: Named/Positional Arguments. | page of ReSharper options(
Remove redundant parentheses | Removes redundant optional parentheses in cases specified on the Alt+R, O). For more information, see Code Syntax Style: Optional Parentheses. | page of ReSharper options(
Add parentheses to explicitly specify operation precedence | Adds optional parentheses to clarify precedence of operations in cases specified on the Alt+R, O). For more information, see Code Syntax Style: Optional Parentheses. | page of ReSharper options(
Add/remove braces around single statements | Adds or removes optional braces around single nested statements as specified on the Alt+R, O). For more information, see Code Syntax Style: Braces for Single Nested Statements. | page of ReSharper options(
Arrange attributes | Applies the rules for multiple attributes as specified on the Alt+R, O). For more information, see Code Syntax Style: Multiple Attributes. | page of ReSharper options(
Apply code body style | Applies preferences for bodies of type members (expression body | statement body) as specified on the Alt+R, O). For more information, see Code Syntax Style: Bodies of Type Members. | page of ReSharper options(
Arrange trailing commas | Applies preferences for trailing commas in declarations with multiple items and similar constructs (object, array, and collection initializers, as well as enums and switch expressions) as specified on the Alt+R, O). For more information, see Code Syntax Style: Trailing Commas. | page of ReSharper options(
Apply object creation style ('new()' vs 'new T()') | Applies preferences for using the target-typed new operator in C# 9.0 and later as specified on the page of ReSharper options(Alt+R, O). For more information, see Code Syntax Style: Object Creation ('new()' vs 'new T()'). |
Apply default value style ('default' vs 'default(T)') | Applies preferences for using optional type specification in default value expressions as specified on the Alt+R, O). For more information, see Code Syntax Style: Default Value Expressions ('default' vs 'default(T)'). | page of ReSharper options(
Remove code redundancies | On the Alt+R, O), in the Redundancies in Code categories for most languages, ReSharper lists over 50 redundancies that have associated code inspections. Some of them require special attention, and you cannot process them in the batch mode. That leaves Code Cleanup with about 30 redundancies that it is able to remove automatically whenever you select Remove code redundancies in your cleanup profile.
|
Use auto-property, if possible | Replaces simple properties and corresponding backing fields with auto-properties. For more information, see Use Auto-Properties. |
Make field read-only, if possible | Adds the 'readonly' keyword to fields that are assigned in the declaration or in a constructor and only have read usages. For more information, see Make Fields Readonly. |
Make auto-property get-only, if possible | Removes the redundant set accessor on auto-properties that are initialized from the constructor/initializer and have no write usages. Note that this task only works for C# 6.0. By default, ReSharper automatically detects C# version based on the associated compiler. However, you can specify the target C# version explicitly — right-click the project in the Solution Explorer, choose Edit project item properties from the context menu and use the C# Language Level selector. |
Arrange qualifiers | Applies the rules for qualifying type members. The rules are configurable on the Alt+R, O). For more information, see Code Syntax Style: Optional Member Qualifiers. | page of ReSharper options(
Fix built-in type references | Applies the rule for built-in type names (C# keyword or CLR type name). The rule is configurable on the Alt+R, O). For more information, see Code Syntax Style: Built-In Type References. | page of ReSharper options(
Usings | Includes the following configurable options:
|
Shorten qualified references | Replaces fully qualified names with short names when possible by importing namespaces, implementing settings configured on the Alt+R, O). | page of ReSharper options(
Reformat code | Reformats your code according to the preferences that you can configure on the Alt+R, O). For more information, see Manage and Apply Code Formatting Rules. | page of ReSharper options(
Reformat embedded XML doc comments | Reformats XML doc comments according to options configurable on the Alt+R, O). Note that ReSharper does not reformat plain comments like: | page of ReSharper options(
XAML
Collapse empty tags | Removes the closing tag if the tag body is empty. |
Remove redundant attributes | Removes attributes, such as Freeze , modifiers , name , span , UpdateSourceTrigger , Mode if they are redundant in the context |
Remove redundant resource | Removes resource references that are not used |
Remove redundant property setters | Removes unused setters for the following properties: property , attached , style . |
Remove redundant namespace alias | Remove all redundant namespace aliases in the scope of cleanup. Redundant aliases are also detected with the code inspection and can be removed with a quick-fix. |
Remove redundant definitions | Removes definitions if they are redundant in the context |
Remove forbidden attributes | Removes attributes, such as name , span if they are forbidden in the context |
XML
Reformat code | Reformats your code according to the preferences that you can configure on the Alt+R, O). For more information, see Manage and Apply Code Formatting Rules. | page of ReSharper options(
C++
C++ code styles and code redundancies |
|
Apply Clang-tidy fix-its | In this node, you can choose all or specific fixes that will be applied according to the Clang-Tidy checks. The selected fixes will be applied even if the corresponding inspections are turned off on the Alt+R, O). Be careful when enabling too many checks at once — code cleanup runs Clang-Tidy only once for a given file, so if multiple fixes touch the same block of code, the changes might conflict with each other. page of ReSharper options( |
Reformat code | Reformats your code according to the preferences that you can configure on the Alt+R, O). For more information, see Manage and Apply Code Formatting Rules. | page of ReSharper options(
Update file header | Inserts or updates the file header comment that you can configure on the File Header Style. | page of ReSharper options. For more information, see
VB.NET
Remove code redundancies | Removes redundant code the same way as for C# Language |
Optimize 'import' directives | Removes unused namespace import directives implementing rules configured on the | page of ReSharper options.
Shorten qualified references | Replaces fully qualified names with short names when possible by importing namespaces, implementing settings configured on the Alt+R, O). | page of ReSharper options(
Reformat code | Reformats your code according to the preferences that you can configure on the Alt+R, O). For more information, see Manage and Apply Code Formatting Rules. | page of ReSharper options(
Reformat embedded XML doc comments | Reformats XML doc comments according to options configurable on the Alt+R, O). Note that ReSharper does not reformat plain comments like: | page of ReSharper options(
CSS
Alphabetize properties | Rearranges CSS properties in the alphabetical order. |
Reformat code | Reformats your code according to the preferences that you can configure on the Alt+R, O). For more information, see Manage and Apply Code Formatting Rules. | page of ReSharper options(
JavaScript-like languages
Apply statement termination | Adds the optional semicolon ; at the end of statements in JavaScript, TypeScript, and JSON. |
JavaScript
Normalize quotes around string literal | Applies the preferred quote style: single quote (') or double quote ("). The preference can be configured on the Alt+R, O). For more information, see Quotes style. | page of ReSharper options(
Correct 'var' to 'let'/'const' where possible |
|
Move let/const to most possible inner scopes | Moves variables defined outside of a function/compound statement, and so on closer to their usages if there are no other usages in outer scopes. |
Convert string concatenations to template strings | In JavaScript code, if the target JavaScript language level is ECMAScript 6 (you can choose it on the Alt+R, O)), as well as in TypeScript 1.4 or later, this option will convert string concatenations to template strings. For example:
var str1 = "Hello,";
var str2 = "Test: " + str1 + " World1";
will be converted to
const str1 = "Hello, ";
const str2 = `Test: ${str1} World1`;
| page of ReSharper options(
Reformat code | Reformats your code according to the preferences that you can configure on the Alt+R, O). For more information, see Manage and Apply Code Formatting Rules. | page of ReSharper options(
Reformat embedded XML doc comments | Reformats XML doc comments according to options configurable on the Alt+R, O). Note that ReSharper does not reformat plain comments like: | page of ReSharper options(
TypeScript
Remove redundant qualifiers | Use this option to remove redundant type name qualifiers. |
Optimize 'import' statements | Use this option to remove redundant 'import' statements or fully-qualified names according to the settings configurable on the Alt+R, O). | page of ReSharper options(
Optimize reference comments | Use this option to remove redundant reference comments. |
Synchronize 'public' presence with code style | This option lets you add or remove explicit 'public' modifier according to settings configurable on the Alt+R, O). | page of ReSharper options(
Add explicit 'any' type annotation if needed | This option lets you add explicit 'any' annotation to types according to settings configurable on the Alt+R, O). | page of ReSharper options(
Synchronize type annotation presence with code style | This option lets you enforce explicit/implicit typing according to settings configurable on the Alt+R, O). | page of ReSharper options(
Fix relative path style in 'require' if needed | Applies the Relative file reference style in 'require' code style preference for relative paths in the require keyword. For example, import X = require("file1") or import X = require("./file1") . You can configure this preference on the page of ReSharper options(Alt+R, O). |
Use 'as' instead of type assertions | Replaces var bar = <string> foo; with var bar = foo as string; which is a recommended way to avoid ambiguity with JSX syntax. |
HTML
Reformat code | Reformats your code according to the preferences that you can configure on the Alt+R, O). For more information, see Manage and Apply Code Formatting Rules. | page of ReSharper options(
Normalize quotes around attribute value | Applies the preferred quote style: single quote (') or double quote ("), configurable on the | page of ReSharper options.
ASP.NET
Optimize @Register directives | Removes unused @Register directives. |