Sunday, October 10, 2010

There's only one ThreadExceptionHandler

There can only ever be one Application.ThreadException handler. Yes, you read that correctly.
To give some context, the core of our error reporting code in SmartAssembly adds event handlers to AppDomain.CurrentDomain.UnhandledException (for general exceptions) and Application.ThreadException (for winforms exceptions) to display our error reporting dialog, or send the unhandled exception details back to the application developers as a bug report.
I was recently debugging an issue where any exceptions thrown after a call to Microsoft.Data.ConnectionUI.DataConnectionDialog.Show would not be picked up by our error reporting code. In other words, this:
throw new Exception();
DataConnectionDialog.Show(new DataConnectionDialog());
would display our error reporting dialog, and this:
DataConnectionDialog.Show(new DataConnectionDialog());
throw new Exception();
would display the standard .NET winforms error dialog. At some point during the call to Show, our exception handler was disappearing.
After quite a bit of digging, I noticed something odd about the definition of ThreadException:
public static event ThreadExceptionEventHandler ThreadException {
   add {
       IntSecurity.AffectThreadBehavior.Demand();
Read more: Simon Cooper