|
|
|
package errorx
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"sync"
|
|
|
|
)
|
|
|
|
|
|
|
|
type (
|
|
|
|
// A BatchError is an error that can hold multiple errors.
|
|
|
|
BatchError struct {
|
|
|
|
errs errorArray
|
|
|
|
lock sync.Mutex
|
|
|
|
}
|
|
|
|
|
|
|
|
errorArray []error
|
|
|
|
)
|
|
|
|
|
|
|
|
// Add adds errs to be, nil errors are ignored.
|
|
|
|
func (be *BatchError) Add(errs ...error) {
|
|
|
|
be.lock.Lock()
|
|
|
|
defer be.lock.Unlock()
|
|
|
|
|
|
|
|
for _, err := range errs {
|
|
|
|
if err != nil {
|
|
|
|
be.errs = append(be.errs, err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Err returns an error that represents all errors.
|
|
|
|
func (be *BatchError) Err() error {
|
|
|
|
be.lock.Lock()
|
|
|
|
defer be.lock.Unlock()
|
|
|
|
|
|
|
|
switch len(be.errs) {
|
|
|
|
case 0:
|
|
|
|
return nil
|
|
|
|
case 1:
|
|
|
|
return be.errs[0]
|
|
|
|
default:
|
|
|
|
return be.errs
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// NotNil checks if any error inside.
|
|
|
|
func (be *BatchError) NotNil() bool {
|
|
|
|
be.lock.Lock()
|
|
|
|
defer be.lock.Unlock()
|
|
|
|
|
|
|
|
return len(be.errs) > 0
|
|
|
|
}
|
|
|
|
|
|
|
|
// Error returns a string that represents inside errors.
|
|
|
|
func (ea errorArray) Error() string {
|
|
|
|
var buf bytes.Buffer
|
|
|
|
|
|
|
|
for i := range ea {
|
|
|
|
if i > 0 {
|
|
|
|
buf.WriteByte('\n')
|
|
|
|
}
|
|
|
|
buf.WriteString(ea[i].Error())
|
|
|
|
}
|
|
|
|
|
|
|
|
return buf.String()
|
|
|
|
}
|