kopia lustrzana https://github.com/njcrawford/EmbroideryReader
First try at reporting unhandled exceptions
rodzic
9c1ec936a6
commit
d32bab0edb
embroideryReader
|
@ -25,6 +25,8 @@ You can contact me at http://www.njcrawford.com/contact
|
|||
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Diagnostics;
|
||||
using System.Reflection;
|
||||
using System.Windows.Forms;
|
||||
|
||||
namespace embroideryReader
|
||||
|
@ -37,9 +39,71 @@ namespace embroideryReader
|
|||
[STAThread]
|
||||
static void Main()
|
||||
{
|
||||
// Handle unhandled exceptions
|
||||
AppDomain.CurrentDomain.UnhandledException +=
|
||||
new UnhandledExceptionEventHandler(CurrentDomain_UnhandledException);
|
||||
Application.ThreadException +=
|
||||
new System.Threading.ThreadExceptionEventHandler(Application_ThreadException);
|
||||
|
||||
// Normal program.cs stuff
|
||||
Application.EnableVisualStyles();
|
||||
Application.SetCompatibleTextRenderingDefault(false);
|
||||
Application.Run(new frmMain());
|
||||
}
|
||||
|
||||
// Functions to deal with unhandled exceptions
|
||||
// Based on code from http://stevenbenner.com/2010/01/reporting-of-unhandled-exceptions-in-your-distributable-net-application/
|
||||
static void CurrentDomain_UnhandledException(object sender, UnhandledExceptionEventArgs e)
|
||||
{
|
||||
reportError((Exception)e.ExceptionObject);
|
||||
}
|
||||
|
||||
public static void Application_ThreadException(object sender, System.Threading.ThreadExceptionEventArgs e)
|
||||
{
|
||||
reportError(e.Exception);
|
||||
}
|
||||
|
||||
public static void reportError(Exception ex)
|
||||
{
|
||||
try
|
||||
{
|
||||
if (MessageBox.Show(
|
||||
"Embroidery Reader has encountered a error.\n\n" +
|
||||
"Click Yes to report this error via the contact form on my website.\n" +
|
||||
"Click No if you'd rather not report the error.\n" +
|
||||
"Please consider submitting the report to help find and fix this issue.\n\n" +
|
||||
"Error:\n" +
|
||||
ex.Message + "\n" +
|
||||
ex.StackTrace,
|
||||
"Report Application Error?",
|
||||
MessageBoxButtons.YesNo,
|
||||
MessageBoxIcon.Stop) == DialogResult.Yes)
|
||||
{
|
||||
// Base url
|
||||
string url = "http://www.njcrawford.com/contact/error-reports/?1subject=Automated%20Error%20Report&1message=";
|
||||
|
||||
// Add error message to it
|
||||
Assembly caller = Assembly.GetEntryAssembly();
|
||||
string errorText = "Description: (If possible, please describe what happened right before the error)\n\n" +
|
||||
"Time: " + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + "\n" +
|
||||
"Program: " + caller.FullName + "\n" +
|
||||
"OS: " + Environment.OSVersion.ToString() + "\n" +
|
||||
"OS Culture: " + System.Globalization.CultureInfo.CurrentCulture.Name + "\n" +
|
||||
"Framework: " + Environment.Version + "\n\n" +
|
||||
"Error:\n" +
|
||||
ex.GetType().ToString() + " (" + ex.Message + ")\n" +
|
||||
ex.StackTrace;
|
||||
// URL encode message
|
||||
url += System.Uri.EscapeDataString(errorText);
|
||||
|
||||
// Open URL in browser
|
||||
System.Diagnostics.Process.Start(url);
|
||||
}
|
||||
}
|
||||
finally
|
||||
{
|
||||
Application.Exit();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Ładowanie…
Reference in New Issue