-
Notifications
You must be signed in to change notification settings - Fork 1
/
list.go
104 lines (90 loc) · 2.05 KB
/
list.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
package errors
import (
"fmt"
)
/*
An error which is a list of errors.
It's intended to be used locally in a function to aggregate errors from different calls.
Here is a typical use case:
type aggregator struct {
val1 io.Closer
val2 io.Closer
vals []io.Closer
}
func (self *aggregator) Close() error {
errs := errors.List().
Add(self.val1.Close()).
Add(self.val2.Close())
for _, v := range self.vals {
errs.Add(v.Close())
}
return errs.Err()
}
*/
type ErrorList struct {
errs []error
}
// Add an error to the list.
// This function ignores nil errors
// and inlines other error lists so that you don't have error lists of error lists.
func (self *ErrorList) Add(err error) *ErrorList {
if err == nil {
return self
}
if v, ok := err.(*ErrorList); ok {
return self.AddAll(v.errs)
}
if self.errs == nil {
self.errs = []error{err}
} else {
self.errs = append(self.errs, err)
}
return self
}
// Add all errors from the array to the error list.
// Nil errors and other error lists are added as in Add.
func (self *ErrorList) AddAll(errs []error) *ErrorList {
if errs == nil {
return self
}
for _, e := range errs {
self.Add(e)
}
return self
}
// Simplify the error list.
// This function gives nil for empty error list
// and a single error for the error list of length one.
func (self *ErrorList) Err() error {
if self.errs == nil {
return nil
} else {
if len(self.errs) == 1 {
return self.errs[0]
}
return self
}
}
// Implementation of an error interface for error list.
func (self *ErrorList) Error() string {
err := self.Err()
if err == nil {
return fmt.Sprintf("%v", nil)
}
if v, ok := err.(*ErrorList); ok {
return fmt.Sprintf("%v", v.errs)
}
return fmt.Sprintf("%v", err)
}
func (self *ErrorList) copy() *ErrorList {
return AsList(self.errs...)
}
// Create an empty error list.
func List() *ErrorList {
return &ErrorList{}
}
// Create an error list from errors.
// Nil errors and other error lists are added as in Add.
func AsList(errs ...error) *ErrorList {
return List().AddAll(errs)
}