use type switch instead of if/else

This reduces the syntax noise of the code by
removing excessive type assertions.

Signed-off-by: Iskander Sharipov <quasilyte@gmail.com>
This commit is contained in:
Iskander (Alex) Sharipov 2019-01-29 22:51:02 +03:00 committed by GitHub
parent b67dcf995b
commit 5b83c895a7
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

7
app.go
View File

@ -495,11 +495,12 @@ func (a Author) String() string {
// it's an ActionFunc or a func with the legacy signature for Action, the func // it's an ActionFunc or a func with the legacy signature for Action, the func
// is run! // is run!
func HandleAction(action interface{}, context *Context) (err error) { func HandleAction(action interface{}, context *Context) (err error) {
if a, ok := action.(ActionFunc); ok { switch a := action.(type) {
case ActionFunc:
return a(context) return a(context)
} else if a, ok := action.(func(*Context) error); ok { case func(*Context) error:
return a(context) return a(context)
} else if a, ok := action.(func(*Context)); ok { // deprecated function signature case func(*Context): // deprecated function signature
a(context) a(context)
return nil return nil
} }