Skip to content

Commit

Permalink
Remove TeeWriter (#28)
Browse files Browse the repository at this point in the history
* feat(context): remove TeeWriter

* feat(context): remove TeeWriter

* feat(context): remove rwUnwrapper interface
  • Loading branch information
tigerwill90 authored Feb 14, 2024
1 parent 4858ca2 commit 6b8d3ab
Show file tree
Hide file tree
Showing 8 changed files with 2 additions and 777 deletions.
61 changes: 1 addition & 60 deletions context.go
Original file line number Diff line number Diff line change
Expand Up @@ -45,9 +45,6 @@ type Context interface {
Writer() ResponseWriter
// SetWriter sets the ResponseWriter.
SetWriter(w ResponseWriter)
// TeeWriter append an additional writer (sink) to which the response body will be written.
// This API is EXPERIMENTAL and is likely to change in future release.
TeeWriter(w io.Writer)
// Path returns the registered path for the handler.
Path() string
// Params returns a Params slice containing the matched
Expand Down Expand Up @@ -94,7 +91,6 @@ type context struct {
req *http.Request
params *Params
skipNds *skippedNodes
mw *[]io.Writer

// tree at allocation (read-only, no reset)
tree *Tree
Expand All @@ -120,7 +116,6 @@ func (c *context) Reset(fox *Router, w http.ResponseWriter, r *http.Request) {
c.path = ""
c.cachedQuery = nil
*c.params = (*c.params)[:0]
*c.mw = (*c.mw)[:0]
}

func (c *context) resetNil() {
Expand All @@ -130,7 +125,6 @@ func (c *context) resetNil() {
c.path = ""
c.cachedQuery = nil
*c.params = (*c.params)[:0]
*c.mw = (*c.mw)[:0]
}

// Request returns the *http.Request.
Expand All @@ -153,55 +147,6 @@ func (c *context) SetWriter(w ResponseWriter) {
c.w = w
}

// TeeWriter append an additional writer (sink) to which the response body will be written.
// Internally, TeeWriter make reasonable effort to reflect which interface the underlying ResponseWriter implement.
func (c *context) TeeWriter(w io.Writer) {
if w != nil {
if len(*c.mw) == 0 {
*c.mw = append(*c.mw, c.w)
}
*c.mw = append(*c.mw, w)
switch c.w.(type) {
case h1Writer:
c.w = h1MultiWriter{c.mw}
return
case h2Writer:
c.w = h2MultiWriter{c.mw}
return
}

if c.req.ProtoMajor == 2 {
switch c.w.(type) {
case interface {
http.Flusher
http.Pusher
}:
c.w = h2MultiWriter{c.mw}
case http.Flusher:
c.w = flushMultiWriter{c.mw}
case http.Pusher:
c.w = pushMultiWriter{c.mw}
default:
c.w = multiWriter{c.mw}
}
return
}

switch c.w.(type) {
case interface {
http.Flusher
http.Hijacker
io.ReaderFrom
}:
c.w = h1MultiWriter{c.mw}
case http.Flusher:
c.w = flushMultiWriter{c.mw}
default:
c.w = multiWriter{c.mw}
}
}
}

// Ctx returns the context associated with the current request.
func (c *context) Ctx() netcontext.Context {
return c.req.Context()
Expand Down Expand Up @@ -298,8 +243,7 @@ func (c *context) Fox() *Router {
}

// Clone returns a copy of the Context that is safe to use after the HandlerFunc returns.
// Any attempt to write on the ResponseWriter will panic with the error ErrDiscardedResponseWriter. Note that
// TeeWriter are discarded.
// Any attempt to write on the ResponseWriter will panic with the error ErrDiscardedResponseWriter.
func (c *context) Clone() Context {
cp := context{
rec: c.rec,
Expand All @@ -314,8 +258,6 @@ func (c *context) Clone() Context {
copy(params, *c.params)
cp.params = &params
cp.cachedQuery = nil
mw := make([]io.Writer, 0, 2)
cp.mw = &mw
return &cp
}

Expand All @@ -339,7 +281,6 @@ func (c *context) CloneWith(w ResponseWriter, r *http.Request) ContextCloser {
// now constraint into len(c.params) & cap(c.params)
*cp.params = (*cp.params)[:len(*c.params):cap(*c.params)]
copy(*cp.params, *c.params)
*cp.mw = (*cp.mw)[:0]
return cp
}

Expand Down
Loading

0 comments on commit 6b8d3ab

Please sign in to comment.