PowerToys/Wox/Helper/ErrorReporting/ErrorReporting.cs

99 lines
3.2 KiB
C#
Raw Normal View History

using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Text;
using System.Windows;
using System.Windows.Forms;
using System.Windows.Threading;
using System.Xml;
using Microsoft.Win32;
2014-12-29 23:02:50 +08:00
using Wox.Core.Exception;
2014-09-19 16:57:48 +08:00
using Wox.Infrastructure.Logger;
namespace Wox.Helper.ErrorReporting
{
public static class ErrorReporting
{
public static void UnhandledExceptionHandle(object sender, System.UnhandledExceptionEventArgs e)
{
2014-12-29 23:02:50 +08:00
if (Debugger.IsAttached) return;
2014-12-29 23:02:50 +08:00
string error = ExceptionFormatter.FormatExcpetion(e.ExceptionObject);
2014-07-18 20:00:55 +08:00
//e.IsTerminating is always true in most times, so try to avoid use this property
//http://stackoverflow.com/questions/10982443/what-causes-the-unhandledexceptioneventargs-isterminating-flag-to-be-true-or-fal
Log.Error(error);
TryShowErrorMessageBox(error, e.ExceptionObject);
}
2014-07-18 20:00:55 +08:00
public static void DispatcherUnhandledException(object sender, DispatcherUnhandledExceptionEventArgs e)
{
if (Debugger.IsAttached) return;
e.Handled = true;
2014-12-29 23:02:50 +08:00
string error = ExceptionFormatter.FormatExcpetion(e.Exception);
Log.Error(error);
TryShowErrorMessageBox(error, e.Exception);
}
2014-12-29 23:02:50 +08:00
public static void ThreadException(object sender, System.Threading.ThreadExceptionEventArgs e)
{
if (Debugger.IsAttached) return;
2014-12-29 23:02:50 +08:00
string error = ExceptionFormatter.FormatExcpetion(e.Exception);
Log.Fatal(error);
2014-07-18 20:00:55 +08:00
TryShowErrorMessageBox(error, e.Exception);
}
2014-07-18 20:00:55 +08:00
public static bool TryShowErrorMessageBox(string error, object exceptionObject)
{
var title = "Wox - Unhandled Exception";
try
{
ShowWPFDialog(error, title, exceptionObject);
return true;
}
catch { }
2014-07-18 20:00:55 +08:00
error = "Wox has occured an error that can't be handled. " + Environment.NewLine + Environment.NewLine + error;
try
{
ShowWPFMessageBox(error, title);
return true;
}
catch { }
try
{
ShowWindowsFormsMessageBox(error, title);
return true;
}
catch { }
return true;
}
private static void ShowWPFDialog(string error, string title, object exceptionObject)
{
var dialog = new WPFErrorReportingDialog(error, title, exceptionObject);
dialog.ShowDialog();
}
2014-12-29 23:02:50 +08:00
private static void ShowWPFMessageBox(string error, string title)
{
System.Windows.MessageBox.Show(error, title, MessageBoxButton.OK, MessageBoxImage.Error,
MessageBoxResult.OK, System.Windows.MessageBoxOptions.None);
}
2014-12-29 23:02:50 +08:00
private static void ShowWindowsFormsMessageBox(string error, string title)
{
System.Windows.Forms.MessageBox.Show(error, title, MessageBoxButtons.OK,
MessageBoxIcon.Error, MessageBoxDefaultButton.Button1);
}
}
}