Skip to content

Commit

Permalink
Browse files Browse the repository at this point in the history
  • Loading branch information
astaxie committed May 25, 2015
1 parent 2c9363d commit 26130a5
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 20 deletions.
18 changes: 9 additions & 9 deletions error.go
Original file line number Diff line number Diff line change
Expand Up @@ -439,24 +439,26 @@ func exception(errcode string, ctx *context.Context) {
if err != nil {
code = 503
}
ctx.ResponseWriter.WriteHeader(code)
if h, ok := ErrorMaps[errcode]; ok {
executeError(h, ctx)
executeError(h, ctx, code)
return
} else if h, ok := ErrorMaps["503"]; ok {
executeError(h, ctx)
executeError(h, ctx, code)
return
} else {
ctx.ResponseWriter.WriteHeader(code)
ctx.WriteString(errcode)
}
}

func executeError(err *errorInfo, ctx *context.Context) {
func executeError(err *errorInfo, ctx *context.Context, code int) {
if err.errorType == errorTypeHandler {
ctx.ResponseWriter.WriteHeader(code)
err.handler(ctx.ResponseWriter, ctx.Request)
return
}
if err.errorType == errorTypeController {
ctx.Output.SetStatus(code)
//Invoke the request handler
vc := reflect.New(err.controllerType)
execController, ok := vc.Interface().(ControllerInterface)
Expand All @@ -476,11 +478,9 @@ func executeError(err *errorInfo, ctx *context.Context) {
method.Call(in)

//render template
if ctx.Output.Status == 0 {
if AutoRender {
if err := execController.Render(); err != nil {
panic(err)
}
if AutoRender {
if err := execController.Render(); err != nil {
panic(err)
}
}

Expand Down
14 changes: 3 additions & 11 deletions router.go
Original file line number Diff line number Diff line change
Expand Up @@ -862,8 +862,8 @@ func (p *ControllerRegistor) recoverPanic(context *beecontext.Context) {
panic(err)
} else {
if ErrorsShow {
if handler, ok := ErrorMaps[fmt.Sprint(err)]; ok {
executeError(handler, context)
if _, ok := ErrorMaps[fmt.Sprint(err)]; ok {
exception(fmt.Sprint(err), context)
return
}
}
Expand All @@ -886,15 +886,7 @@ func (p *ControllerRegistor) recoverPanic(context *beecontext.Context) {
} else {
// in production model show all infomation
if ErrorsShow {
if handler, ok := ErrorMaps[fmt.Sprint(err)]; ok {
executeError(handler, context)
return
} else if handler, ok := ErrorMaps["503"]; ok {
executeError(handler, context)
return
} else {
context.WriteString(fmt.Sprint(err))
}
exception(fmt.Sprint(err), context)
} else {
Critical("the request url is ", context.Input.Url())
Critical("Handler crashed with error", err)
Expand Down

0 comments on commit 26130a5

Please sign in to comment.