Code Inspection: Type is never used (non-private accessibility)
Last modified: 21 July 2022tip
Unused types might indicate dead code, which can occur for example, after changing the consumer code. ReSharper detects such unused types and suggests that you either remove or comment them to reduce code size and simplify its maintenance.
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 type 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 type in one of the following ways:
The recommended way is to decorate the implicitly used type with a code annotation attribute. There are two attributes for this purpose: [UsedImplicitly] and [PublicAPI], which are functionally similar, but let you and your teammates understand how the type is actually used.
You can also suppress usage-checking inspections with any custom attribute. To do so, mark the definition of that attribute with the [MeansImplicitUse] attribute.
And finally, you can suppress a specific usage-checking inspection as any other code inspection with a suppression comment or a suppression attribute.