I know that Go will not have generics in the future and there are some recommendations to replace them by other constructs. But with my example below I got stuck.
func P(any interface{}, err error) (interface{}) {
if err != nil {
panic("error: "+ err.Error())
}
return any
}
As you might guess, I'm trying to just fail on any error and want to put P()
just around any function that is returning two results and the second is an error. This is working fine, but any
is losing it's type information and is only an empty interface in the result.
As I'm also calling lib functions I don't see a way to address this with Interfaces or Reflection.
Any ideas? Am I totally on the wrong track or close to the goal?
What you want to do would require generics but as you already mentioned, Go does not support generic types. Therefore, you can't create a general function which would not lose the type.
You have to create such a function for each type you want to support. Note that the standard library already contains some of these going under the name
MustXXX()
, which you can use out of the box, for example:template.Must(t *Template, err error) *Template
Or "similar" functions which suppress the
error
but if one still occurs, panics, for example:regexp.MustCompile(str string) *Regexp
(suppresseserror
but panics ifstr
is not a valid regexp)If you plan on just panicking on errors (bad idea) or logging them, then just define a function to do so and use it. E.g.
The user twotwotwo has already linked to the Errors are values article that shows more examples on how to make error handling less repetitive. But I would recommend just write the whole
if err != nil
thing, because in my experience every third error, if not second, requires some additional handling.One solution would be to
go generate
yourP()
function, one for each concrete type you need to work with.See examples in:
go generate
"".That would make calling those lib functions easier, since the concrete P () implementations generated would use the right type instead of interface{}.