You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
|
|
using System;
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
using NLog;
|
|
|
|
|
|
|
|
|
|
namespace NzbDrone.Common.Instrumentation
|
|
|
|
|
{
|
|
|
|
|
public static class GlobalExceptionHandlers
|
|
|
|
|
{
|
|
|
|
|
private static readonly Logger Logger = NzbDroneLogger.GetLogger();
|
|
|
|
|
public static void Register()
|
|
|
|
|
{
|
|
|
|
|
AppDomain.CurrentDomain.UnhandledException += ((s, e) => AppDomainException(e.ExceptionObject as Exception));
|
|
|
|
|
TaskScheduler.UnobservedTaskException += ((s, e) => TaskException(e.Exception));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static void TaskException(Exception exception)
|
|
|
|
|
{
|
|
|
|
|
Console.WriteLine("Task Error: {0}", exception);
|
|
|
|
|
Logger.Error("Task Error: " + exception.Message, exception);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static void AppDomainException(Exception exception)
|
|
|
|
|
{
|
|
|
|
|
if (exception == null) return;
|
|
|
|
|
|
|
|
|
|
if (exception is NullReferenceException &&
|
|
|
|
|
exception.ToString().Contains("Microsoft.AspNet.SignalR.Transports.TransportHeartbeat.ProcessServerCommand"))
|
|
|
|
|
{
|
|
|
|
|
Logger.Warn("SignalR Heartbeat error.");
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Console.WriteLine("EPIC FAIL: {0}", exception);
|
|
|
|
|
Logger.FatalException("EPIC FAIL: " + exception.Message, exception);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|