type ResponseController … // NewResponseController creates a [ResponseController] for a request. // // The ResponseWriter should be the original value passed to the [Handler.ServeHTTP] method, // or have an Unwrap method returning the original ResponseWriter. // // If the ResponseWriter implements any of the following methods, the ResponseController // will call them as appropriate: // // Flush() // FlushError() error // alternative Flush returning an error // Hijack() (net.Conn, *bufio.ReadWriter, error) // SetReadDeadline(deadline time.Time) error // SetWriteDeadline(deadline time.Time) error // EnableFullDuplex() error // // If the ResponseWriter does not support a method, ResponseController returns // an error matching [ErrNotSupported]. func NewResponseController(rw ResponseWriter) *ResponseController { … } type rwUnwrapper … // Flush flushes buffered data to the client. func (c *ResponseController) Flush() error { … } // Hijack lets the caller take over the connection. // See the Hijacker interface for details. func (c *ResponseController) Hijack() (net.Conn, *bufio.ReadWriter, error) { … } // SetReadDeadline sets the deadline for reading the entire request, including the body. // Reads from the request body after the deadline has been exceeded will return an error. // A zero value means no deadline. // // Setting the read deadline after it has been exceeded will not extend it. func (c *ResponseController) SetReadDeadline(deadline time.Time) error { … } // SetWriteDeadline sets the deadline for writing the response. // Writes to the response body after the deadline has been exceeded will not block, // but may succeed if the data has been buffered. // A zero value means no deadline. // // Setting the write deadline after it has been exceeded will not extend it. func (c *ResponseController) SetWriteDeadline(deadline time.Time) error { … } // EnableFullDuplex indicates that the request handler will interleave reads from [Request.Body] // with writes to the [ResponseWriter]. // // For HTTP/1 requests, the Go HTTP server by default consumes any unread portion of // the request body before beginning to write the response, preventing handlers from // concurrently reading from the request and writing the response. // Calling EnableFullDuplex disables this behavior and permits handlers to continue to read // from the request while concurrently writing the response. // // For HTTP/2 requests, the Go HTTP server always permits concurrent reads and responses. func (c *ResponseController) EnableFullDuplex() error { … } // errNotSupported returns an error that Is ErrNotSupported, // but is not == to it. func errNotSupported() error { … }