It is important to catch and handle errors on your programs. Yes we are all perfect and our systems do not generate errors, but our users are not perfect and since they do not know what they are doing, we should provide them with some tools to tell us what they did wrong.
This is an VB6 error handler routine
Public Sub HandleError(ErrNumber As Double, Description As String, CurrentModule As String, CurrentControl As String, CurrentRoutine As String)
On Error GoTo OOPS
'Writes error messages to a log file and displays a message
Dim ErrorMsg As String
Dim FileNum As Integer
Dim fileName As String
'Parse the error message
ErrorMsg = "Error : " & Trim(Str(ErrNumber)) & " " & Description & " at " & CurrentModule
If Len(Trim(CurrentControl)) > 0 Then ErrorMsg = ErrorMsg & "." & CurrentControl
If Len(Trim(CurrentRoutine)) > 0 Then ErrorMsg = ErrorMsg & "." & CurrentRoutine
'Display a message box
MsgBox ErrorMsg
'Save the error to a file so you can track errors
FileNum = FreeFile
fileName = App.Path & "\" & App.EXEName & ".err"
Open fileName For Append As #FileNum
Print #FileNum, ErrorMsg
Close #FileNum
ExitHere:
Exit Sub
OOPS:
MsgBox "Error : " & Err.Number & " " & Error$ & " at basGlobal.HandleError"
Resume ExitHere
End Sub
Assuming you want to add an error handler to one of your command buttons on a form:
Private Sub cmdAdd_Click()
On Error GoTo OOPS
Dim Type As String
Dim SQL As String
... your code here
ExitHere:
Exit Sub
OOPS:
HandleError Err, Error$, Me.Name, "cmdAdd", "Click"
Resume ExitHere
End Sub
You can get fancy and create an error handler class that can keep a collection of your errors, etc.
But most important keep it simple otherwise you will have to debug your error handler too.
My next posting will have an error handler class in .Net
No comments:
Post a Comment