views:

914

answers:

5

How do I find dead code in a Visual Studio 2008 C# project? Like unused classes, unused variables or unused resources?

+6  A: 

You can try FxCop, which is integrated in Visual Studio 2008 by the name of Code Analysis. You just have to right click the project file and 'Run Code Analysis'.

FxCop is an application that analyzes managed code assemblies (code that targets the .NET Framework common language runtime) and reports information about the assemblies, such as possible design, localization, performance, and security improvements.

The active rules can be configured in the Code Analysis section of the project properties. For example some rules relevant to the case in hand are present in Usage Rules and Performance Rules:

  • CA1801: Review unused parameters.
  • CA1811: Avoid uncalled private code.

And for greater flexibility you also write your own custom rules (Tutorial on writing your own Code Analysis rule).

João Angelo
+1  A: 

Install JetBrains ReSharper which will highlight the unused code for you.

David M
It will highlight it in a file, but it won't find dead code across an entire solution. This is one of the features I thought solution-wide analysis would offer.
Jamie Ide
@Jamie Ide - but it allows you to navigate from warning to warning, even across files, if you enable solution-wide analysis, I think?
David M
A: 

While I wouldn't recommend this for a large code base you can do a certain amount manually.

If you right click over a method or class and then select "Find Usages" you'll get an output of all places where it's referenced. Obviously this will be empty if it's not used.

For ongoing clean up I'd install ReSharper

ChrisF
I did a certain amount manually. That was when I came up with the question.
Holli
@Holli - fair enough.
ChrisF
A: 

Shift + F12 in VS is useful for a quick check :)

leppie
+1  A: 

A very useful tool for this is the NDepend dependency analysis tool. You can load your Visual Studio project into this, and it will analyse the dependencies of all your assemblies, types and methods. It gives you a wealth of information on the dependenices, including (but in no way limited to!) methods/types that are not used by anything at all.

You can view the dependencies either graphically, or in a list, and can write your own custom dependency queries such as this - a simple CQL query show potentially unused methods :

SELECT 
  METHODS         // Get me a list of methods
WHERE 
  MethodCa == 0   // Where their afferent coupling is zero, (afferent coupling being the number of other methods that call it)

A highly recommended tool.

Rob Levine