Skip to content

Commit

Permalink
Added a more general crash reporting code to catch more errors. Updat…
Browse files Browse the repository at this point in the history
…ed Flycast code
  • Loading branch information
RossenX committed Sep 12, 2021
1 parent 202ff7d commit df012d7
Show file tree
Hide file tree
Showing 12 changed files with 367 additions and 40 deletions.
Binary file modified .vs/NullDC BEAR/v16/.suo
Binary file not shown.
58 changes: 43 additions & 15 deletions NullDC CvS2 BEAR/ApplicationEvents.vb
Original file line number Diff line number Diff line change
@@ -1,22 +1,50 @@
Imports System.IO

Namespace My
' The following events are available for MyApplication:
' Startup: Raised when the application starts, before the startup form is created.
' Shutdown: Raised after all application forms are closed. This event is not raised if the application terminates abnormally.
' UnhandledException: Raised if the application encounters an unhandled exception.
' StartupNextInstance: Raised when launching a single-instance application and the application is already active.
' NetworkAvailabilityChanged: Raised when the network connection is connected or disconnected.
Namespace My
Partial Friend Class MyApplication

Private Sub MyApplication_UnhandledException(ByVal _
sender As Object, ByVal e As _
ApplicationServices.UnhandledExceptionEventArgs) _
Handles Me.UnhandledException
e.ExitApplication =
MessageBox.Show("Yo Something went wrong send this to RossenX" & vbCrLf & e.Exception.Message & vbNewLine & vbNewLine & e.Exception.StackTrace, "Crashy McCrashface")
Private Delegate Sub SafeApplicationThreadException(ByVal sender As Object, ByVal e As Threading.ThreadExceptionEventArgs)

Private Sub ShowDebugOutput(ByVal ex As Exception)

Dim st As StackTrace = New StackTrace(ex, True)
FrmCrash.ShowDialog2("Yo something went wrong! Send this to RossenX: " & vbNewLine & vbNewLine & ex.ToString)
'MsgBox("Yo something went wrong! Send this to RossenX: " & vbNewLine & ex.Message & vbNewLine & ">" & FileName & "(" & st.GetFrame(0).GetFileLineNumber & ")" & vbNewLine & Stacktrace & vbNewLine & ex.ToString,, "Crashy McCrashface ")

Environment.Exit(0)

End Sub

Private Sub MyApplication_Startup(ByVal sender As Object, ByVal e As Microsoft.VisualBasic.ApplicationServices.StartupEventArgs) Handles Me.Startup

AddHandler AppDomain.CurrentDomain.UnhandledException, AddressOf AppDomain_UnhandledException
AddHandler System.Windows.Forms.Application.ThreadException, AddressOf app_ThreadException

End Sub

Private Sub app_ThreadException(ByVal sender As Object, ByVal e As Threading.ThreadExceptionEventArgs)

'This is not thread safe, so make it thread safe.
If MainForm.InvokeRequired Then
' Invoke back to the main thread
MainForm.Invoke(New SafeApplicationThreadException(AddressOf app_ThreadException), New Object() {sender, e})
Else
ShowDebugOutput(e.Exception)
End If

End Sub

Private Sub AppDomain_UnhandledException(ByVal sender As Object, ByVal e As UnhandledExceptionEventArgs)

ShowDebugOutput(DirectCast(e.ExceptionObject, Exception))

End Sub

Private Sub MyApplication_UnhandledException(sender As Object, e As Microsoft.VisualBasic.ApplicationServices.UnhandledExceptionEventArgs) Handles Me.UnhandledException

ShowDebugOutput(e.Exception)

End Sub
End Class


End Namespace

103 changes: 103 additions & 0 deletions NullDC CvS2 BEAR/FrmCrash.Designer.vb

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

120 changes: 120 additions & 0 deletions NullDC CvS2 BEAR/FrmCrash.resx
Original file line number Diff line number Diff line change
@@ -0,0 +1,120 @@
<?xml version="1.0" encoding="utf-8"?>
<root>
<!--
Microsoft ResX Schema
Version 2.0
The primary goals of this format is to allow a simple XML format
that is mostly human readable. The generation and parsing of the
various data types are done through the TypeConverter classes
associated with the data types.
Example:
... ado.net/XML headers & schema ...
<resheader name="resmimetype">text/microsoft-resx</resheader>
<resheader name="version">2.0</resheader>
<resheader name="reader">System.Resources.ResXResourceReader, System.Windows.Forms, ...</resheader>
<resheader name="writer">System.Resources.ResXResourceWriter, System.Windows.Forms, ...</resheader>
<data name="Name1"><value>this is my long string</value><comment>this is a comment</comment></data>
<data name="Color1" type="System.Drawing.Color, System.Drawing">Blue</data>
<data name="Bitmap1" mimetype="application/x-microsoft.net.object.binary.base64">
<value>[base64 mime encoded serialized .NET Framework object]</value>
</data>
<data name="Icon1" type="System.Drawing.Icon, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64">
<value>[base64 mime encoded string representing a byte array form of the .NET Framework object]</value>
<comment>This is a comment</comment>
</data>
There are any number of "resheader" rows that contain simple
name/value pairs.
Each data row contains a name, and value. The row also contains a
type or mimetype. Type corresponds to a .NET class that support
text/value conversion through the TypeConverter architecture.
Classes that don't support this are serialized and stored with the
mimetype set.
The mimetype is used for serialized objects, and tells the
ResXResourceReader how to depersist the object. This is currently not
extensible. For a given mimetype the value must be set accordingly:
Note - application/x-microsoft.net.object.binary.base64 is the format
that the ResXResourceWriter will generate, however the reader can
read any of the formats listed below.
mimetype: application/x-microsoft.net.object.binary.base64
value : The object must be serialized with
: System.Runtime.Serialization.Formatters.Binary.BinaryFormatter
: and then encoded with base64 encoding.
mimetype: application/x-microsoft.net.object.soap.base64
value : The object must be serialized with
: System.Runtime.Serialization.Formatters.Soap.SoapFormatter
: and then encoded with base64 encoding.
mimetype: application/x-microsoft.net.object.bytearray.base64
value : The object must be serialized into a byte array
: using a System.ComponentModel.TypeConverter
: and then encoded with base64 encoding.
-->
<xsd:schema id="root" xmlns="" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
<xsd:import namespace="http://www.w3.org/XML/1998/namespace" />
<xsd:element name="root" msdata:IsDataSet="true">
<xsd:complexType>
<xsd:choice maxOccurs="unbounded">
<xsd:element name="metadata">
<xsd:complexType>
<xsd:sequence>
<xsd:element name="value" type="xsd:string" minOccurs="0" />
</xsd:sequence>
<xsd:attribute name="name" use="required" type="xsd:string" />
<xsd:attribute name="type" type="xsd:string" />
<xsd:attribute name="mimetype" type="xsd:string" />
<xsd:attribute ref="xml:space" />
</xsd:complexType>
</xsd:element>
<xsd:element name="assembly">
<xsd:complexType>
<xsd:attribute name="alias" type="xsd:string" />
<xsd:attribute name="name" type="xsd:string" />
</xsd:complexType>
</xsd:element>
<xsd:element name="data">
<xsd:complexType>
<xsd:sequence>
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
<xsd:element name="comment" type="xsd:string" minOccurs="0" msdata:Ordinal="2" />
</xsd:sequence>
<xsd:attribute name="name" type="xsd:string" use="required" msdata:Ordinal="1" />
<xsd:attribute name="type" type="xsd:string" msdata:Ordinal="3" />
<xsd:attribute name="mimetype" type="xsd:string" msdata:Ordinal="4" />
<xsd:attribute ref="xml:space" />
</xsd:complexType>
</xsd:element>
<xsd:element name="resheader">
<xsd:complexType>
<xsd:sequence>
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
</xsd:sequence>
<xsd:attribute name="name" type="xsd:string" use="required" />
</xsd:complexType>
</xsd:element>
</xsd:choice>
</xsd:complexType>
</xsd:element>
</xsd:schema>
<resheader name="resmimetype">
<value>text/microsoft-resx</value>
</resheader>
<resheader name="version">
<value>2.0</value>
</resheader>
<resheader name="reader">
<value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
</resheader>
<resheader name="writer">
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
</resheader>
</root>
22 changes: 22 additions & 0 deletions NullDC CvS2 BEAR/FrmCrash.vb
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
Public Class FrmCrash
Private Sub FrmCrash_Load(sender As Object, e As EventArgs) Handles MyBase.Load
Me.Icon = My.Resources.NewNullDCBearIcon
End Sub

Public Sub ShowDialog2(ByVal Message)
Label1.Text = Message
Me.CenterToScreen()
Me.ShowDialog()

End Sub

Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click
Me.Close()
End Sub

Private Sub Button2_Click(sender As Object, e As EventArgs) Handles Button2.Click
Process.Start("https://www.google.com/search?q=happy+puppies&hl=en&tbm=isch")
Me.Close()
End Sub

End Class
22 changes: 11 additions & 11 deletions NullDC CvS2 BEAR/NetworkHandling.vb
Original file line number Diff line number Diff line change
Expand Up @@ -35,15 +35,9 @@ Public Class NetworkHandling
Dim toSend As String = MainformRef.ConfigFile.Version & ":" & message
Dim data() As Byte = Encoding.ASCII.GetBytes(toSend)

Try
BEAR_UDPSender = New UdpClient(SendtoIP, port)
BEAR_UDPSender.EnableBroadcast = True
BEAR_UDPSender.SendAsync(data, data.Length)

Catch ex As Exception
Console.WriteLine("Failed to send")

End Try
BEAR_UDPSender = New UdpClient(SendtoIP, port)
BEAR_UDPSender.EnableBroadcast = True
BEAR_UDPSender.SendAsync(data, data.Length)

End Sub

Expand All @@ -60,6 +54,7 @@ Public Class NetworkHandling
Dim data() As Byte = BEAR_UDPReceiver.Receive(endPoint)
Dim message As String = Encoding.ASCII.GetString(data)
MessageReceived(message, endPoint.Address.ToString, endPoint.Port.ToString)

End While

End Sub)
Expand All @@ -71,6 +66,7 @@ Public Class NetworkHandling

Delegate Sub MessageReceived_delegate(ByRef message As String, ByRef senderip As String, ByRef port As String)
Private Sub MessageReceived(ByRef message As String, ByRef senderip As String, ByRef port As String)

If message.Length > 500 Then
Console.WriteLine("<-Recieved-> long ass message from " & senderip & ":" & port)
Else
Expand Down Expand Up @@ -234,14 +230,18 @@ Public Class NetworkHandling

If MainformRef.IsNullDCRunning Or MainformRef.MednafenLauncher.MednafenInstance IsNot Nothing Or MainformRef.FlycastLauncher.FlycastProc IsNot Nothing Then ' We were told to join a game but we're already in a game
Exit Sub

End If


Console.WriteLine("<-Host Started->" & message)
Dim INVOKATION As JoinHost_delegate = AddressOf MainformRef.JoinHost

If message.Split(New String() {",eeprom,"}, StringSplitOptions.None).Count > 1 Then
Rx.EEPROM = message.Split(New String() {",eeprom,"}, StringSplitOptions.None)(1)
If message.Split(New String() {",eeprom,"}, StringSplitOptions.None)(1) IsNot Nothing Then
Rx.EEPROM = message.Split(New String() {",eeprom,"}, StringSplitOptions.None)(1)
Else
Rx.EEPROM = ""
End If
Else
Rx.EEPROM = ""
End If
Expand Down
Loading

0 comments on commit df012d7

Please sign in to comment.