See the errors proposal here: https://golang.org/design/29934-error-values
Implementation in tip (available in 1.13 beta) https://tip.golang.org/pkg/errors/ Implementation in x/xerrors (backwards compatible): https://godoc.org/golang.org/x/xerrors xerrors - GoDoc On Mon, Jul 8, 2019, 9:54 AM Robert Engels <reng...@ix.netcom.com> wrote: > > I think you are on to something. As I've said, the boilerplate is ugly, > but manageable. It is the process of using and reporting errors that is the > problem. > > If the error interface were expanded, to included methods like > > int Type() > int SubType() > []Stack StackTrace() > error Cause() > Log(w Writer,string format,...) > > with stdlib defining constants for errors, and user developed constants > > N, the chances of constant collision is minimal. > > Alternatively, define like this > > string Type() > string SubType() > > with the Type being package.SomeErrorName > and sub-type being package.SomeErrorName.SubErrorName > > to allow easier capture and retry. > > To go even further, add a > > bool Permanent() > > to signify if the same call is made with the same parameters, it is also > fail - unless some action is taken (network reconfig, etc.) This is a more > difficult implementation, but could be just a 'hint'. > > It's is some amount of work to define the constants, and change existing > code, but it is just busy work. The Go error handling is worse than C in > that at least in C, the api doc clearly spells out which error codes can be > returned, and why. With the Go error interface, and the 'minimal api doc', > what is returned when is anybody's guess. > > > > -----Original Message----- > From: Chris Passas > Sent: Jul 8, 2019 8:32 AM > To: golang-nuts > Subject: [go-nuts] Go 2018 Survey "Error handling 5%" > > We are all aware error handling was tied for 4th most common challenging > when working with Go in the 2018 survey. > > There is not description of what about error handling. I'm sure I missed > the conversation but how did we get to the point of deciding it was the if > err!=nil that was the "challenging part"? > > Personally the only thing I wish was different was we could have error > times/categories in addion. Basically just a way to allow us to not need > the following. > > if strings.Contains(err.Err(),"timeout") > > Most of the time all you care is there was an error and don't parse the > message to decide what to do next. There are cases where you might decide > how to handle it based on the message. > > There are messages like "Connection failed to -> 192.168.1.1", this is > useful but also makes the error something you can't check for without > substring parsing. > > What if we could do something like > > if err.Type()=="Bad Connection" > > but then you could still return or log the 'err' as normal and get that > extra info. > > -- > You received this message because you are subscribed to the Google Groups > "golang-nuts" group. > To unsubscribe from this group and stop receiving emails from it, send an > email to golang-nuts+unsubscr...@googlegroups.com. > To view this discussion on the web visit > https://groups.google.com/d/msgid/golang-nuts/fa12d854-c317-4477-98b1-32ca883d2093%40googlegroups.com > <https://groups.google.com/d/msgid/golang-nuts/fa12d854-c317-4477-98b1-32ca883d2093%40googlegroups.com?utm_medium=email&utm_source=footer> > . > For more options, visit https://groups.google.com/d/optout. > > > > > -- > You received this message because you are subscribed to the Google Groups > "golang-nuts" group. > To unsubscribe from this group and stop receiving emails from it, send an > email to golang-nuts+unsubscr...@googlegroups.com. > To view this discussion on the web visit > https://groups.google.com/d/msgid/golang-nuts/1215816141.2411.1562594037454%40wamui-charming.atl.sa.earthlink.net > <https://groups.google.com/d/msgid/golang-nuts/1215816141.2411.1562594037454%40wamui-charming.atl.sa.earthlink.net?utm_medium=email&utm_source=footer> > . > For more options, visit https://groups.google.com/d/optout. > -- You received this message because you are subscribed to the Google Groups "golang-nuts" group. To unsubscribe from this group and stop receiving emails from it, send an email to golang-nuts+unsubscr...@googlegroups.com. To view this discussion on the web visit https://groups.google.com/d/msgid/golang-nuts/CAM4ZPhDoCFDxHqcJHJhFzs2DMnfG_JXF8RJ7%2BwdOpDO7a84AUA%40mail.gmail.com. For more options, visit https://groups.google.com/d/optout.