Skip to content

Commit

Permalink
chore(clouderror): clarify GoDoc for error wrapping
Browse files Browse the repository at this point in the history
Co-authored-by: John Blåberg Kristoffersson <[email protected]>
  • Loading branch information
odsod and blaberg committed Oct 21, 2024
1 parent b7449a7 commit 0e92ae0
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 11 deletions.
17 changes: 10 additions & 7 deletions clouderror/wrap.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,25 +13,28 @@ import (
"google.golang.org/grpc/status"
)

// Wrap an error with a gRPC status.
// Wrap masks the gRPC status of the provided error by replacing it with the provided status.
func Wrap(err error, s *status.Status) error {
return &wrappedStatusError{status: s, err: err, caller: NewCaller(runtime.Caller(1))}
}

// WrapCaller wraps an error with a gRPC status and a caller.
// WrapCaller masks the gRPC status of the provided error by replacing it with the provided status.
// The call site of the error is captured from the provided caller.
func WrapCaller(err error, s *status.Status, caller Caller) error {
return &wrappedStatusError{status: s, err: err, caller: caller}
}

// WrapTransient wraps transient errors (possibly status.Status) with
// appropriate codes.Code. The returned error will always be a status.Status
// with description set to msg.
// WrapTransient masks the gRPC status of the provided error by replacing the status message.
// If the original error has transient (retryable) gRPC status code, the status code is forwarded.
// Otherwise, the status code is masked with INTERNAL.
func WrapTransient(err error, msg string) error {
return WrapTransientCaller(err, msg, NewCaller(runtime.Caller(1)))
}

// WrapTransientCaller wraps transient errors with an appropriate codes.Code and caller.
// The returned error will always be a status.Status with description set to msg.
// WrapTransient masks the gRPC status of the provided error by replacing the status message.
// If the original error has transient (retryable) gRPC status code, the status code is forwarded.
// Otherwise, the status code is masked with INTERNAL.
// The call site of the error is captured from the provided caller.
func WrapTransientCaller(err error, msg string, caller Caller) error {
if s, ok := status.FromError(err); ok {
switch s.Code() {
Expand Down
8 changes: 4 additions & 4 deletions wrap.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,14 +7,14 @@ import (
"google.golang.org/grpc/status"
)

// Wrap an error with a gRPC status.
// Wrap masks the gRPC status of the provided error by replacing it with the provided status.
func Wrap(err error, s *status.Status) error {
return clouderror.WrapCaller(err, s, clouderror.NewCaller(runtime.Caller(1)))
}

// WrapTransient wraps transient errors (possibly status.Status) with
// appropriate codes.Code. The returned error will always be a status.Status
// with description set to msg.
// WrapTransient masks the gRPC status of the provided error by replacing the status message.
// If the original error has transient (retryable) gRPC status code, the status code will be forwarded.
// Otherwise, the status code will be masked with INTERNAL.
func WrapTransient(err error, msg string) error {
return clouderror.WrapTransientCaller(err, msg, clouderror.NewCaller(runtime.Caller(1)))
}

0 comments on commit 0e92ae0

Please sign in to comment.