ReSharper 2024.3 Help

Code inspection: Non-accessed positional property (non-private accessibility)

C# 9 record syntax defines a bunch of members implicitly, including Equals()/GetHashCode()/ToString() implementations, properties corresponding to primary constructor parameters, and the Deconstruct() method.

Taking into account all these implicit definitions, ReSharper reports positional properties of records that are never accessed.

record Person( string Name, int Age, // non-accessed positional property object Tag ); class SomeClass { public void PrintName() { var (name, _, tag) = GetPerson(); Console.WriteLine(name); } public Person GetPerson() => new("Alex", 32, null); }
record Person( string Name, object Tag ); class SomeClass { public void PrintName() { var (name, tag) = GetPerson(); Console.WriteLine(name); } public Person GetPerson() => new("Alex", null); }

To make removal of redundant positional members safe, the Remove unused property quick-fix ( Alt+Enter) invokes the Safe Delete refactoring to support all record usage patterns. In the example above, ReSharper recognizes indirect usages in all C# deconstruction forms and is able to remove the corresponding _ from such deconstructions.

For the solution-wide inspection to work, you need to enable at least one of the following:

  • Simplified global usage checking: select Show unused non-private type members when solution-wide analysis is off on the Code Inspection | Settings page of ReSharper options Alt+R, O.

  • Solution-wide analysis: select Enable solution-wide analysis on the Code Inspection | Settings page of ReSharper options Alt+R, O.

Note that even if the reported positional member has no direct usages in your solution, there could be cases where it is used indirectly — for example, via reflection — or it could just be designed as public API. In all those cases, you would want to suppress the usage-checking inspection for the positional member in one of the following ways:

Last modified: 25 September 2024