Equal Comparison Method

Error objects support comparison, and the Equal method is used to fully determine whether two errors are the same. This is mainly achieved through the following method:

  1. // Equal reports whether current error `err` equals to error `target`.
  2. // Please note that, in default comparison for `Error`,
  3. // the errors are considered the same if both the `code` and `text` of them are the same.
  4. func Equal(err, target error) bool

Interface Definition

If a custom error data structure needs to support comparison, the custom error structure needs to implement the following interface:

  1. // IEqual is the interface for Equal feature.
  2. type IEqual interface {
  3. Error() string
  4. Equal(target error) bool
  5. }

Error objects created by the GoFrame framework’s error component already implement this interface, and the component’s default comparison logic checks the error code and error message.

Error Handling - Comparison - 图1info

Note that if both errors do not carry error codes and their error messages are the same, the component considers the two errors to be the same.

Usage Example

  1. func ExampleEqual() {
  2. err1 := errors.New("permission denied")
  3. err2 := gerror.New("permission denied")
  4. err3 := gerror.NewCode(gcode.CodeNotAuthorized, "permission denied")
  5. fmt.Println(gerror.Equal(err1, err2))
  6. fmt.Println(gerror.Equal(err2, err3))
  7. // Output:
  8. // true
  9. // false
  10. }

Is Inclusion Judgment

Error objects support inclusion judgment. The Is method is used to determine whether the given error is in a specified error chain (if the error carries a stack, it will be judged recursively). This is mainly achieved through the following method:

  1. // Is reports whether current error `err` has error `target` in its chaining errors.
  2. // It is just for implements for stdlib errors.Unwrap from Go version 1.17.
  3. func Is(err, target error) bool

Usage Example

  1. func ExampleIs() {
  2. err1 := errors.New("permission denied")
  3. err2 := gerror.Wrap(err1, "operation failed")
  4. fmt.Println(gerror.Is(err1, err1))
  5. fmt.Println(gerror.Is(err2, err2))
  6. fmt.Println(gerror.Is(err2, err1))
  7. fmt.Println(gerror.Is(err1, err2))
  8. // Output:
  9. // false
  10. // true
  11. // true
  12. // false
  13. }