diff options
| author | Petar Maymounkov <petarm@gmail.com> | 2010-02-19 08:21:21 -0800 | 
|---|---|---|
| committer | Petar Maymounkov <petarm@gmail.com> | 2010-02-19 08:21:21 -0800 | 
| commit | f70c002907f03ed850ffa7d586acf5b0190c722f (patch) | |
| tree | 83505c38b4799f940338233bc7efd99a70b4a428 | |
| parent | e3c162e3c704af8c056020a6d789643d736c0d89 (diff) | |
| download | golang-f70c002907f03ed850ffa7d586acf5b0190c722f.tar.gz | |
http: add Pending method to ServerConn, ClientConn
R=rsc
CC=golang-dev
http://codereview.appspot.com/216052
Committer: Russ Cox <rsc@golang.org>
| -rw-r--r-- | src/pkg/http/persist.go | 20 | 
1 files changed, 19 insertions, 1 deletions
| diff --git a/src/pkg/http/persist.go b/src/pkg/http/persist.go index a4da3da65..8bfc09755 100644 --- a/src/pkg/http/persist.go +++ b/src/pkg/http/persist.go @@ -45,6 +45,8 @@ func NewServerConn(c net.Conn, r *bufio.Reader) *ServerConn {  // called before Read has signaled the end of the keep-alive logic. The user  // should not call Close while Read or Write is in progress.  func (sc *ServerConn) Close() (c net.Conn, r *bufio.Reader) { +	sc.lk.Lock() +	defer sc.lk.Unlock()  	c = sc.c  	r = sc.r  	sc.c = nil @@ -111,6 +113,14 @@ func (sc *ServerConn) Read() (req *Request, err os.Error) {  	return  } +// Pending returns the number of unanswered requests +// that have been received on the connection. +func (sc *ServerConn) Pending() int { +	sc.lk.Lock() +	defer sc.lk.Unlock() +	return sc.nread - sc.nwritten +} +  // Write writes a repsonse. To close the connection gracefully, set the  // Response.Close field to true. Write should be considered operational until  // it returns an error, regardless of any errors returned on the Read side. @@ -176,11 +186,11 @@ func NewClientConn(c net.Conn, r *bufio.Reader) *ClientConn {  // called before the user or Read have signaled the end of the keep-alive  // logic. The user should not call Close while Read or Write is in progress.  func (cc *ClientConn) Close() (c net.Conn, r *bufio.Reader) { +	cc.lk.Lock()  	c = cc.c  	r = cc.r  	cc.c = nil  	cc.r = nil -	cc.lk.Lock()  	cc.reqm.Init()  	cc.lk.Unlock()  	return @@ -228,6 +238,14 @@ func (cc *ClientConn) Write(req *Request) os.Error {  	return nil  } +// Pending returns the number of unanswered requests +// that have been sent on the connection. +func (cc *ClientConn) Pending() int { +	cc.lk.Lock() +	defer cc.lk.Unlock() +	return cc.nwritten - cc.nread +} +  // Read reads the next response from the wire. A valid response might be  // returned together with an ErrPersistEOF, which means that the remote  // requested that this be the last request serviced. Read can be called | 
