Move ResponseWriter.Flush to Flusher interface

This commit is contained in:
Adnan Maolood 2021-02-17 11:44:11 -05:00
parent fb9b50871c
commit a3c1804395
3 changed files with 21 additions and 6 deletions

View File

@ -39,6 +39,12 @@ func main() {
// stream writes an infinite stream to w.
func stream(w gemini.ResponseWriter, r *gemini.Request) {
flusher, ok := w.(gemini.Flusher)
if !ok {
w.Status(gemini.StatusTemporaryFailure)
return
}
ch := make(chan string)
ctx, cancel := context.WithCancel(context.Background())
@ -63,7 +69,7 @@ func stream(w gemini.ResponseWriter, r *gemini.Request) {
break
}
fmt.Fprintln(w, s)
if err := w.Flush(); err != nil {
if err := flusher.Flush(); err != nil {
cancel()
return
}

View File

@ -156,11 +156,16 @@ type ResponseWriter interface {
// Write writes the response header if it has not already been written.
// It writes a successful status code if one is not set.
Write([]byte) (int, error)
}
// Flush writes any buffered data to the underlying io.Writer.
//
// Flush writes the response header if it has not already been written.
// It writes a failure status code if one is not set.
// The Flusher interface is implemented by ResponseWriters that allow a
// Gemini handler to flush buffered data to the client.
//
// The default Gemini ResponseWriter implementation supports Flusher,
// but ResponseWriter wrappers may not. Handlers should always test
// for this ability at runtime.
type Flusher interface {
// Flush sends any buffered data to the client.
Flush() error
}
@ -174,6 +179,10 @@ type responseWriter struct {
// NewResponseWriter returns a ResponseWriter that uses the provided io.Writer.
func NewResponseWriter(w io.Writer) ResponseWriter {
return newResponseWriter(w)
}
func newResponseWriter(w io.Writer) *responseWriter {
return &responseWriter{
b: bufio.NewWriter(w),
}

View File

@ -376,7 +376,7 @@ func (srv *Server) respond(conn net.Conn) {
conn.SetWriteDeadline(time.Now().Add(d))
}
w := NewResponseWriter(conn)
w := newResponseWriter(conn)
req, err := ReadRequest(conn)
if err != nil {