2018-08-01 20:16:49 +00:00
|
|
|
|
// Copyright 2018 The Go Authors. All rights reserved.
|
|
|
|
|
// Use of this source code is governed by a BSD-style
|
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
|
|
// Package errors implements functions to manipulate errors.
|
|
|
|
|
package errors
|
|
|
|
|
|
|
|
|
|
import (
|
2020-01-17 21:40:51 +00:00
|
|
|
|
"errors"
|
2018-08-01 20:16:49 +00:00
|
|
|
|
"fmt"
|
2019-09-06 23:57:46 +00:00
|
|
|
|
|
|
|
|
|
"google.golang.org/protobuf/internal/detrand"
|
2018-08-01 20:16:49 +00:00
|
|
|
|
)
|
|
|
|
|
|
2020-01-17 21:40:51 +00:00
|
|
|
|
// Error is a sentinel matching all errors produced by this package.
|
|
|
|
|
var Error = errors.New("protobuf error")
|
|
|
|
|
|
2018-08-01 20:16:49 +00:00
|
|
|
|
// New formats a string according to the format specifier and arguments and
|
|
|
|
|
// returns an error that has a "proto" prefix.
|
|
|
|
|
func New(f string, x ...interface{}) error {
|
2020-01-17 21:40:51 +00:00
|
|
|
|
return &prefixError{s: format(f, x...)}
|
2018-08-01 20:16:49 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
type prefixError struct{ s string }
|
|
|
|
|
|
2019-09-06 23:57:46 +00:00
|
|
|
|
var prefix = func() string {
|
2019-09-07 19:06:05 +00:00
|
|
|
|
// Deliberately introduce instability into the error message string to
|
|
|
|
|
// discourage users from performing error string comparisons.
|
2019-09-06 23:57:46 +00:00
|
|
|
|
if detrand.Bool() {
|
2019-09-07 19:06:05 +00:00
|
|
|
|
return "proto: " // use non-breaking spaces (U+00a0)
|
|
|
|
|
} else {
|
|
|
|
|
return "proto: " // use regular spaces (U+0020)
|
2019-09-06 23:57:46 +00:00
|
|
|
|
}
|
|
|
|
|
}()
|
|
|
|
|
|
|
|
|
|
func (e *prefixError) Error() string {
|
|
|
|
|
return prefix + e.s
|
|
|
|
|
}
|
2019-06-19 16:28:29 +00:00
|
|
|
|
|
2020-01-17 21:40:51 +00:00
|
|
|
|
func (e *prefixError) Unwrap() error {
|
|
|
|
|
return Error
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Wrap returns an error that has a "proto" prefix, the formatted string described
|
|
|
|
|
// by the format specifier and arguments, and a suffix of err. The error wraps err.
|
|
|
|
|
func Wrap(err error, f string, x ...interface{}) error {
|
|
|
|
|
return &wrapError{
|
|
|
|
|
s: format(f, x...),
|
|
|
|
|
err: err,
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
type wrapError struct {
|
|
|
|
|
s string
|
|
|
|
|
err error
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (e *wrapError) Error() string {
|
|
|
|
|
return format("%v%v: %v", prefix, e.s, e.err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (e *wrapError) Unwrap() error {
|
|
|
|
|
return e.err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (e *wrapError) Is(target error) bool {
|
|
|
|
|
return target == Error
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func format(f string, x ...interface{}) string {
|
|
|
|
|
// avoid "proto: " prefix when chaining
|
|
|
|
|
for i := 0; i < len(x); i++ {
|
|
|
|
|
switch e := x[i].(type) {
|
|
|
|
|
case *prefixError:
|
|
|
|
|
x[i] = e.s
|
|
|
|
|
case *wrapError:
|
|
|
|
|
x[i] = format("%v: %v", e.s, e.err)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return fmt.Sprintf(f, x...)
|
|
|
|
|
}
|
|
|
|
|
|
2019-06-19 16:28:29 +00:00
|
|
|
|
func InvalidUTF8(name string) error {
|
|
|
|
|
return New("field %v contains invalid UTF-8", name)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func RequiredNotSet(name string) error {
|
|
|
|
|
return New("required field %v not set", name)
|
|
|
|
|
}
|