Log unhandled exceptions
This commit is contained in:
@@ -12,8 +12,8 @@ using System;
|
|||||||
using System.Diagnostics;
|
using System.Diagnostics;
|
||||||
using System.Globalization;
|
using System.Globalization;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Windows.Forms;
|
|
||||||
using System.Text;
|
using System.Text;
|
||||||
|
using System.Windows.Forms;
|
||||||
|
|
||||||
namespace OpenRA
|
namespace OpenRA
|
||||||
{
|
{
|
||||||
@@ -31,19 +31,26 @@ namespace OpenRA
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
AppDomain.CurrentDomain.UnhandledException += (_, e) => LogException((Exception)e.ExceptionObject);
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
Run(args);
|
Run(args);
|
||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
Log.AddChannel("exception", "exception.log");
|
LogException(e);
|
||||||
var rpt = BuildExceptionReport(e).ToString();
|
|
||||||
Log.Write("exception", "{0}", rpt);
|
|
||||||
Console.Error.WriteLine(rpt);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void LogException(Exception e)
|
||||||
|
{
|
||||||
|
Log.AddChannel("exception", "exception.log");
|
||||||
|
var rpt = BuildExceptionReport(e).ToString();
|
||||||
|
Log.Write("exception", "{0}", rpt);
|
||||||
|
Console.Error.WriteLine(rpt);
|
||||||
|
}
|
||||||
|
|
||||||
static StringBuilder BuildExceptionReport(Exception e)
|
static StringBuilder BuildExceptionReport(Exception e)
|
||||||
{
|
{
|
||||||
return BuildExceptionReport(e, new StringBuilder(), 0);
|
return BuildExceptionReport(e, new StringBuilder(), 0);
|
||||||
|
|||||||
Reference in New Issue
Block a user