mirror of
https://git.do.srb2.org/STJr/UltimateZoneBuilder.git
synced 2025-01-07 09:21:07 +00:00
9c85635ff0
The exception dialog now correctly states that it's UDB and not GZDB
236 lines
8 KiB
C#
Executable file
236 lines
8 KiB
C#
Executable file
#region ================== Namespaces
|
||
|
||
using System;
|
||
using System.IO;
|
||
using System.Management;
|
||
using System.Windows.Forms;
|
||
using System.Threading;
|
||
|
||
#endregion
|
||
|
||
namespace CodeImp.DoomBuilder.Windows
|
||
{
|
||
public partial class ExceptionDialog : Form
|
||
{
|
||
private const string CRASH_DUMP_FILE = "UDBCrash.txt";
|
||
|
||
private readonly bool isterminating;
|
||
private readonly string logpath;
|
||
|
||
public ExceptionDialog(UnhandledExceptionEventArgs e)
|
||
{
|
||
InitializeComponent();
|
||
|
||
logpath = Path.Combine(General.SettingsPath, CRASH_DUMP_FILE);
|
||
Exception ex = (Exception)e.ExceptionObject;
|
||
errorDescription.Text = "Error in " + ex.Source + ":";
|
||
string sysinfo = GetSystemInfo();
|
||
using(StreamWriter sw = File.CreateText(logpath))
|
||
{
|
||
sw.Write(sysinfo + GetExceptionDescription(ex));
|
||
}
|
||
|
||
errorMessage.Text = ex.Message + Environment.NewLine + ex.StackTrace;
|
||
isterminating = e.IsTerminating; // Recoverable?
|
||
}
|
||
|
||
public ExceptionDialog(ThreadExceptionEventArgs e)
|
||
{
|
||
InitializeComponent();
|
||
|
||
logpath = Path.Combine(General.SettingsPath, CRASH_DUMP_FILE);
|
||
errorDescription.Text = "Error in " + e.Exception.Source + ":";
|
||
string sysinfo = GetSystemInfo();
|
||
using(StreamWriter sw = File.CreateText(logpath))
|
||
{
|
||
sw.Write(sysinfo + GetExceptionDescription(e.Exception));
|
||
}
|
||
|
||
errorMessage.Text = sysinfo + "********EXCEPTION DETAILS********" + Environment.NewLine
|
||
+ e.Exception.Message + Environment.NewLine + e.Exception.StackTrace;
|
||
}
|
||
|
||
public void Setup()
|
||
{
|
||
string[] titles =
|
||
{
|
||
"0x000000 at 0xFFFFFF. That's probably bad",
|
||
"Here we go again...",
|
||
"Uh oh, you're screwed",
|
||
"All is lost!",
|
||
"Achievement unlocked: CRASH TIME!",
|
||
"OH NOES! TEH ERROR!",
|
||
"0001000001111011000000000011001101011120110111",
|
||
"Nuclear launch detected!",
|
||
"Don't send this to Microsoft",
|
||
"You. Shall. Not. Pass!!!",
|
||
"Yep, we have bugs",
|
||
"It's dangerous to go alone. Take this!",
|
||
"The operation completed successfully",
|
||
"Security Alert – Moving cursor is not as safe as you thought",
|
||
"Random error appears from north",
|
||
"ERROR: NO_ERROR",
|
||
"Epic fail",
|
||
"At least it's not BSoD...",
|
||
"User Error. Please Replace User",
|
||
"Brought to you by MaxED!",
|
||
"Ultimate Doom Builder proudly presents:",
|
||
"You aren't expected to understand this",
|
||
"Back to the drawing board...",
|
||
"I'm sorry... :(",
|
||
"This is a horrible day for you, and of course, the world",
|
||
"Abort, Retry, Fail?",
|
||
"You are making progress. I'm afraid that's something I can't allow to happen",
|
||
"You are making progress. That's not OK",
|
||
"No errors found, restarting computer",
|
||
"Does Not Compute!",
|
||
"I’m sorry, Dave, I’m afraid I can’t do that",
|
||
"What's that? Chicken?",
|
||
"It can only be attributable to human error",
|
||
"It's now safe to turn off your computer",
|
||
"I've got a bad feeling about this",
|
||
"YOU CAN’T DO THAT!",
|
||
"Man the Lifeboats! Women and children first!",
|
||
"IMPOSSIBURU!!!",
|
||
"Now deleting all files. Goodbye",
|
||
"General Failure",
|
||
"Invalid Error",
|
||
"Beam me up Scotty, there’s no life out here",
|
||
"Well, you ran into something and the game is over",
|
||
"I'm good at writing bad code",
|
||
"$FUNNY_ERROR_CAPTION",
|
||
"In Soviet Russia, exception throws YOU!",
|
||
"...and then GZDB was the demons!",
|
||
"B U S T E D",
|
||
"Freeze mode enabled",
|
||
"You feel strange...",
|
||
"That doesn't seem to work",
|
||
"This function is only available in the retail version of Ultimate Doom Builder",
|
||
"You picked up the Random Exception.",
|
||
"Pinky says that you're the new hope. Bear that in mind.",
|
||
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA",
|
||
"Deal with it",
|
||
"Error 47",
|
||
"YOU DIED",
|
||
"The God Of Exceptions Demands MORE Exceptions!",
|
||
"Good. It's boring here anyway.",
|
||
"Shameful display!",
|
||
"It's CRASHENING!",
|
||
"W-W-W-WIPEOUT!",
|
||
"EVERYTHING IS LOST!",
|
||
"Your empty is full!",
|
||
"Let's see how far this infinite loop goes...",
|
||
"Windows 10 is here! RUN!",
|
||
"You really screwed up this time!",
|
||
"[WFDS]",
|
||
"[No]",
|
||
"An error has occurred while creating an error",
|
||
"Catastrophic failure",
|
||
"This time, it’s the human’s fault",
|
||
"No error occurred",
|
||
"Hey! It looks like you're having an error!",
|
||
"What, what, what, what, what, what, what, what, what, what?",
|
||
"WARNING: PROGRAMMING BUG IN GZDB!",
|
||
"Something happened",
|
||
"The Device is Error",
|
||
"Worship me, and I may yet be merciful... then again, maybe not.",
|
||
"EXTERMINATE",
|
||
"What you spend years building may be destroyed overnight; build it anyway"
|
||
};
|
||
|
||
this.Text = titles[new Random().Next(0, titles.Length - 1)];
|
||
bContinue.Enabled = !isterminating;
|
||
}
|
||
|
||
private static string GetSystemInfo()
|
||
{
|
||
string result = "***********SYSTEM INFO***********" + Environment.NewLine;
|
||
|
||
// Get OS name
|
||
ManagementObjectSearcher searcher = new ManagementObjectSearcher("SELECT Caption FROM Win32_OperatingSystem");
|
||
foreach(ManagementBaseObject mo in searcher.Get())
|
||
{
|
||
result += "OS: " + mo["Caption"] + Environment.NewLine;
|
||
break;
|
||
}
|
||
|
||
// Get GPU name
|
||
searcher = new ManagementObjectSearcher("SELECT * FROM Win32_VideoController");
|
||
foreach(ManagementBaseObject mo in searcher.Get())
|
||
{
|
||
PropertyData bpp = mo.Properties["CurrentBitsPerPixel"];
|
||
PropertyData description = mo.Properties["Description"];
|
||
if(bpp != null && description != null && bpp.Value != null)
|
||
{
|
||
result += "GPU: " + description.Value + Environment.NewLine;
|
||
break;
|
||
}
|
||
}
|
||
|
||
// Get GZDB version
|
||
result += "UDB: R" + General.ThisAssembly.GetName().Version.Revision + Environment.NewLine;
|
||
result += "Platform: " + (Environment.Is64BitProcess ? "x64" : "x86") + Environment.NewLine + Environment.NewLine;
|
||
|
||
return result;
|
||
}
|
||
|
||
private static string GetExceptionDescription(Exception ex)
|
||
{
|
||
// Add to error logger
|
||
General.WriteLogLine("***********************************************************");
|
||
General.ErrorLogger.Add(ErrorType.Error, ex.Source + ": " + ex.Message);
|
||
General.WriteLogLine("***********************************************************");
|
||
|
||
string message = "********EXCEPTION DETAILS********"
|
||
+ Environment.NewLine + ex.Source + ": " + ex.Message + Environment.NewLine + ex.StackTrace;
|
||
|
||
if(File.Exists(General.LogFile))
|
||
{
|
||
try
|
||
{
|
||
string[] lines = File.ReadAllLines(General.LogFile);
|
||
message += Environment.NewLine + Environment.NewLine + "***********ACTIONS LOG***********";
|
||
for(int i = lines.Length - 1; i > -1; i--)
|
||
message += Environment.NewLine + lines[i];
|
||
} catch(Exception) { }
|
||
}
|
||
|
||
return message;
|
||
}
|
||
|
||
private void reportlink_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)
|
||
{
|
||
if(!File.Exists(logpath)) return;
|
||
try { System.Diagnostics.Process.Start("explorer.exe", @"/select, " + logpath); }
|
||
catch { MessageBox.Show("Unable to show the error report location..."); }
|
||
reportlink.LinkVisited = true;
|
||
}
|
||
|
||
private void newissue_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)
|
||
{
|
||
try { System.Diagnostics.Process.Start("https://github.com/jewalky/UltimateDoomBuilder/issues"); }
|
||
catch { MessageBox.Show("Unable to open URL..."); }
|
||
newissue.LinkVisited = true;
|
||
}
|
||
|
||
private void bContinue_Click(object sender, EventArgs e)
|
||
{
|
||
this.DialogResult = DialogResult.OK;
|
||
this.Close();
|
||
}
|
||
|
||
private void bQuit_Click(object sender, EventArgs e)
|
||
{
|
||
if(General.Map != null) General.Map.SaveMapBackup();
|
||
this.DialogResult = DialogResult.Cancel;
|
||
this.Close();
|
||
}
|
||
|
||
private void bToClipboard_Click(object sender, EventArgs e)
|
||
{
|
||
errorMessage.SelectAll();
|
||
errorMessage.Copy();
|
||
errorMessage.DeselectAll();
|
||
}
|
||
}
|
||
}
|