OK, say I have an application like this:
using System;
using AliensExist; // some DLL which can\'t be found...
What I want is that if the
Old question, but I feel this info needs added:
You can't try/catch a using statement, but you can try/catch the resolving of an assembly.
You have even more control if you manually load assemblies as suggested by Mike Atlas.
Also, you can manually verify an assembly before attempting to resolve by selecting from GetEntryAssembly.GetReferencedAssemblies() and comparing against something like AssemblyName.GetAssemblyName().
Of course, you can use a simple File.Exists(AssemblyPath)
in some cases, but the methods above would help verify additional assembly issues, such as version numbering or signing.
AssemblyResolve
is nice by offering an event based approach. Good if you've got high cyclomatic complexity and/or want to ride along with JIT, but less informative than an upfront verification.
Be mindful of the fail-fast principal, and the extent to which assembly resolve errors may limit functionality.
You can't really do that in a try/catch, but what you can do is handle the AssemblyResolve
event on the AppDomain.
See http://msdn.microsoft.com/en-us/library/system.appdomain.assemblyresolve.aspx for further details.
However, you will at least need to get your code compiling. If you are trying to "reference" an assembly which may or may not exist, you will need to dynamically load it and work from there.