Err.Source

This approach allows you to have a custom error-numbering strategy without fear of conflicting with native errors (or errors generated by other workbooks or applications.)

link - stackoverflow.com/questions/69370099/what-numbers-should-be-used-with-vbobjecterror/70283901#70283901 
Public Sub Test_Handler()
   On Error GoTo ErrorHandler
          
   Debug.Print 1 / 0 ' 11, Division-by-zero
   Kill "C:\Doesn't-Exist.txt" ' 53, File not found
   Err.Raise 11, "Custom" ' 11, User cancelled
   Err.Raise 53, "Custom" ' 53, User paused
   Exit Sub

ErrorHandler:
   Call GlobalHandler
   Resume Next
End Sub

Public Sub GlobalHandler()
Dim sDesc As String
          
   Select Case Err.Source
      Case "Custom"
         Select Case Err.Number
            Case 11: sDesc = "User Cancelled the process"
            Case 53: sDesc = "User has paused"
         End Select

      Case Else
         sDesc = Err.Description
   End Select
          
   Call MsgBox(sDesc)
End Sub

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