Deconstruct variable declaration (IDE0042)
Property | Value |
---|---|
Rule ID | IDE0042 |
Title | Deconstruct variable declaration |
Category | Style |
Subcategory | Language rules (expression-level preferences) |
Applicable languages | C# |
Options | csharp_style_deconstructed_variable_declaration |
Overview
This style rule concerns the use of deconstruction in variable declarations, when possible.
Options
Options specify the behavior that you want the rule to enforce. For information about configuring options, see Option format.
csharp_style_deconstructed_variable_declaration
Property | Value | Description |
---|---|---|
Option name | csharp_style_deconstructed_variable_declaration | |
Option values | true |
Prefer deconstructed variable declaration |
false |
Do not prefer deconstruction in variable declarations | |
Default option value | true |
// csharp_style_deconstructed_variable_declaration = true
var (name, age) = GetPersonTuple();
Console.WriteLine($"{name} {age}");
(int x, int y) = GetPointTuple();
Console.WriteLine($"{x} {y}");
// csharp_style_deconstructed_variable_declaration = false
var person = GetPersonTuple();
Console.WriteLine($"{person.name} {person.age}");
(int x, int y) point = GetPointTuple();
Console.WriteLine($"{point.x} {point.y}");
Suppress a warning
If you want to suppress only a single violation, add preprocessor directives to your source file to disable and then re-enable the rule.
#pragma warning disable IDE0042
// The code that's violating the rule is on this line.
#pragma warning restore IDE0042
To disable the rule for a file, folder, or project, set its severity to none
in the configuration file.
[*.{cs,vb}]
dotnet_diagnostic.IDE0042.severity = none
To disable all of the code-style rules, set the severity for the category Style
to none
in the configuration file.
[*.{cs,vb}]
dotnet_analyzer_diagnostic.category-Style.severity = none
For more information, see How to suppress code analysis warnings.