Using Enum

If you want to raise your own specific errors and have code to handle these errors you could put everything into a dedicated class.
Define all your errors using an Enum.

Public enCustomErrors 
    lFirstError = -10000000 + 1024
    lSecondError
    lThirdError
End Enum

Use the vbObjectError built-in constant to ensure the custom error codes do not overlap with reserved/existing error codes.
The Err.Raise method can also take custom Description and Source parameters so it worth having a description associated with each error.

Private Const sDescription_FirstError As String = "This is the first type of error." 
Private Const sDescription_SecondError As String = "This is the second type of error."

Create a dedicated private method to raise each error:

Private Sub OnFirstError(ByVal source As String) 
    Err.Raise enCustomErrors.lFirstError, source, sDescription_FirstError
End Sub

Private Sub OnSecondError(ByVal source As String)
    Err.Raise enCustomErrors.lSecondError, source, sDescription_SecondError
End Sub

To raise the error, just call the correspnding subroutine.

Public Sub DoSomething() 
   If (True) Then
      Call OnFirstError("DoSomething")
   End If
End Sub

© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopPrevNext