Releases: ing-bank/ginerr
v3.0.0
Change the internal method of saving errors entirely to make use of errors.As
and errors.Is
, removing the need for 3 separate methods as suggested in #7 by @bkmeneguello and implemented in #8.
V3 migration guide
V3 completely revamps the ErrorRegistry
and now utilises the errors
package to match errors.
The following changes have been made:
RegisterErrorHandler
now requires a concrete instance of the error as its first argumentRegisterErrorHandlerOn
now requires a concrete instance of the error as its second argumentRegisterStringErrorHandler
has been removed, use staticerrors.New
inRegisterErrorHandler
to get this to workRegisterStringErrorHandlerOn
has been removed, use staticerrors.New
inRegisterErrorHandlerOn
to get this to workRegisterCustomErrorTypeHandler
has been removed, wrap unexported errors from libraries to create handlers for theseRegisterCustomErrorTypeHandlerOn
has been removed, wrap unexported errors from libraries to create handlers for theseErrorRegistry
changes:DefaultCode
has been removed, useRegisterDefaultHandler
insteadDefaultResponse
has been removed, useRegisterDefaultHandler
insteadSetDefaultResponse
has been removed, useRegisterDefaultHandler
instead
v0.0.2
Add deprecation notices in v1
v2.1.0
Use reflect
to deduce the errortype dynamically
This is to fix when a custom error type (type SomeError error) would default to *error.errorString, while the value could hold a different implementation.
This will now be deduced correctly.
v2.0.1
Add RegisterDefaultHandler
as a method on the ErrorRegistry and deprecate SetDefaultResponse
along with its properties in favour of a default handler.
v2.0.0
Prerelease of interface improvements and addition of context
v0.0.1
- Removed unused generic from
NewErrorResponse
- Move creation of errorString handler to
NewErrorRegistry
call
v0.0.0
Initial release