Merge remote-tracking branch 'upstream/master' into validate

This commit is contained in:
Jimmy Pettersson 2014-09-17 11:45:55 +02:00
commit c4237c363c
15 changed files with 90 additions and 1 deletions

View File

@ -1,3 +1,7 @@
// Copyright 2014 Manu Martinez-Almeida. All rights reserved.
// Use of this source code is governed by a MIT style
// license that can be found in the LICENSE file.
package gin package gin
import ( import (

View File

@ -1,3 +1,7 @@
// Copyright 2014 Manu Martinez-Almeida. All rights reserved.
// Use of this source code is governed by a MIT style
// license that can be found in the LICENSE file.
package gin package gin
import ( import (

View File

@ -1,3 +1,7 @@
// Copyright 2014 Manu Martinez-Almeida. All rights reserved.
// Use of this source code is governed by a MIT style
// license that can be found in the LICENSE file.
package binding package binding
import ( import (

View File

@ -1,3 +1,7 @@
// Copyright 2014 Manu Martinez-Almeida. All rights reserved.
// Use of this source code is governed by a MIT style
// license that can be found in the LICENSE file.
package gin package gin
import ( import (

View File

@ -1,3 +1,7 @@
// Copyright 2014 Manu Martinez-Almeida. All rights reserved.
// Use of this source code is governed by a MIT style
// license that can be found in the LICENSE file.
package gin package gin
import ( import (

View File

@ -1,3 +1,7 @@
// Copyright 2014 Manu Martinez-Almeida. All rights reserved.
// Use of this source code is governed by a MIT style
// license that can be found in the LICENSE file.
package gin package gin
import ( import (

4
gin.go
View File

@ -1,3 +1,7 @@
// Copyright 2014 Manu Martinez-Almeida. All rights reserved.
// Use of this source code is governed by a MIT style
// license that can be found in the LICENSE file.
package gin package gin
import ( import (

View File

@ -1,3 +1,7 @@
// Copyright 2014 Manu Martinez-Almeida. All rights reserved.
// Use of this source code is governed by a MIT style
// license that can be found in the LICENSE file.
package gin package gin
import ( import (

View File

@ -1,3 +1,7 @@
// Copyright 2014 Manu Martinez-Almeida. All rights reserved.
// Use of this source code is governed by a MIT style
// license that can be found in the LICENSE file.
package gin package gin
import ( import (

View File

@ -1,3 +1,7 @@
// Copyright 2014 Manu Martinez-Almeida. All rights reserved.
// Use of this source code is governed by a MIT style
// license that can be found in the LICENSE file.
package gin package gin
import ( import (

View File

@ -1,3 +1,7 @@
// Copyright 2014 Manu Martinez-Almeida. All rights reserved.
// Use of this source code is governed by a MIT style
// license that can be found in the LICENSE file.
package gin package gin
import ( import (

View File

@ -1,3 +1,7 @@
// Copyright 2014 Manu Martinez-Almeida. All rights reserved.
// Use of this source code is governed by a MIT style
// license that can be found in the LICENSE file.
package gin package gin
import ( import (

View File

@ -1,3 +1,7 @@
// Copyright 2014 Manu Martinez-Almeida. All rights reserved.
// Use of this source code is governed by a MIT style
// license that can be found in the LICENSE file.
package render package render
import ( import (

View File

@ -1,13 +1,24 @@
// Copyright 2014 Manu Martinez-Almeida. All rights reserved.
// Use of this source code is governed by a MIT style
// license that can be found in the LICENSE file.
package gin package gin
import ( import (
"bufio"
"errors"
"log" "log"
"net"
"net/http" "net/http"
) )
type ( type (
ResponseWriter interface { ResponseWriter interface {
http.ResponseWriter http.ResponseWriter
http.Hijacker
http.Flusher
http.CloseNotifier
Status() int Status() int
Written() bool Written() bool
WriteHeaderNow() WriteHeaderNow()
@ -27,7 +38,7 @@ func (w *responseWriter) reset(writer http.ResponseWriter) {
} }
func (w *responseWriter) WriteHeader(code int) { func (w *responseWriter) WriteHeader(code int) {
if code != 0 { if code > 0 {
w.status = code w.status = code
if w.written { if w.written {
log.Println("[GIN] WARNING. Headers were already written!") log.Println("[GIN] WARNING. Headers were already written!")
@ -54,3 +65,25 @@ func (w *responseWriter) Status() int {
func (w *responseWriter) Written() bool { func (w *responseWriter) Written() bool {
return w.written return w.written
} }
// Implements the http.Hijacker interface
func (w *responseWriter) Hijack() (net.Conn, *bufio.ReadWriter, error) {
hijacker, ok := w.ResponseWriter.(http.Hijacker)
if !ok {
return nil, nil, errors.New("the ResponseWriter doesn't support the Hijacker interface")
}
return hijacker.Hijack()
}
// Implements the http.CloseNotify interface
func (w *responseWriter) CloseNotify() <-chan bool {
return w.ResponseWriter.(http.CloseNotifier).CloseNotify()
}
// Implements the http.Flush interface
func (w *responseWriter) Flush() {
flusher, ok := w.ResponseWriter.(http.Flusher)
if ok {
flusher.Flush()
}
}

View File

@ -1,3 +1,7 @@
// Copyright 2014 Manu Martinez-Almeida. All rights reserved.
// Use of this source code is governed by a MIT style
// license that can be found in the LICENSE file.
package gin package gin
import ( import (