Deferring WriteHeader. Part 1

This commit is contained in:
Manu Mtz-Almeida 2014-08-18 05:24:48 +02:00
parent 78c7101ff6
commit dcafad3ced
4 changed files with 34 additions and 16 deletions

10
gin.go
View File

@ -45,10 +45,15 @@ type (
func (engine *Engine) handle404(w http.ResponseWriter, req *http.Request) {
c := engine.createContext(w, req, nil, engine.finalNoRoute)
c.Writer.setStatus(404)
// set 404 by default, useful for logging
c.Writer.WriteHeader(404)
c.Next()
if !c.Writer.Written() {
c.Data(404, MIMEPlain, []byte("404 page not found"))
if c.Writer.Status() == 404 {
c.Data(-1, MIMEPlain, []byte("404 page not found"))
} else {
c.Writer.WriteHeaderNow()
}
}
engine.cache.Put(c)
}
@ -166,6 +171,7 @@ func (group *RouterGroup) Handle(method, p string, handlers []HandlerFunc) {
group.engine.router.Handle(method, p, func(w http.ResponseWriter, req *http.Request, params httprouter.Params) {
c := group.engine.createContext(w, req, params, handlers)
c.Next()
c.Writer.WriteHeaderNow()
group.engine.cache.Put(c)
})
}

View File

@ -47,7 +47,6 @@ func Logger() HandlerFunc {
if len(requester) == 0 {
requester = c.Request.Header.Get("X-Forwarded-For")
}
// if the requester is still empty, use the hard-coded address from the socket
if len(requester) == 0 {
requester = c.Request.RemoteAddr

View File

@ -35,10 +35,8 @@ var (
)
func writeHeader(w http.ResponseWriter, code int, contentType string) {
if code >= 0 {
w.Header().Set("Content-Type", contentType)
w.WriteHeader(code)
}
}
func (_ jsonRender) Render(w http.ResponseWriter, code int, data ...interface{}) error {

View File

@ -1,6 +1,7 @@
package gin
import (
"log"
"net/http"
)
@ -9,9 +10,7 @@ type (
http.ResponseWriter
Status() int
Written() bool
// private
setStatus(int)
WriteHeaderNow()
}
responseWriter struct {
@ -27,14 +26,30 @@ func (w *responseWriter) reset(writer http.ResponseWriter) {
w.written = false
}
func (w *responseWriter) setStatus(code int) {
func (w *responseWriter) WriteHeader(code int) {
if code != 0 {
w.status = code
if w.written {
log.Println("[GIN] WARNING. Headers were already written!")
}
}
}
func (w *responseWriter) WriteHeader(code int) {
w.status = code
func (w *responseWriter) WriteHeaderNow() {
if !w.written {
w.written = true
w.ResponseWriter.WriteHeader(code)
w.ResponseWriter.WriteHeader(w.status)
}
}
func (w *responseWriter) Write(data []byte) (n int, err error) {
if !w.written {
if w.status != 0 {
w.ResponseWriter.WriteHeader(w.status)
}
w.written = true
}
return w.ResponseWriter.Write(data)
}
func (w *responseWriter) Status() int {