pull/314/merge
Darien Raymond 2016-12-12 02:14:48 +01:00
parent a11d2ce9d6
commit f159d504f2
No known key found for this signature in database
GPG Key ID: 7251FFA14BB18169
3 changed files with 18 additions and 0 deletions

View File

@ -6,10 +6,12 @@ import (
"io" "io"
) )
// OriginalReader invokes bufio.NewReader() from Golang standard library.
func OriginalReader(reader io.Reader) *bufio.Reader { func OriginalReader(reader io.Reader) *bufio.Reader {
return bufio.NewReader(reader) return bufio.NewReader(reader)
} }
// OriginalReaderSize invokes bufio.NewReaderSize() from Golang standard library.
func OriginalReaderSize(reader io.Reader, size int) *bufio.Reader { func OriginalReaderSize(reader io.Reader, size int) *bufio.Reader {
return bufio.NewReaderSize(reader, size) return bufio.NewReaderSize(reader, size)
} }

View File

@ -4,9 +4,11 @@ import (
"io" "io"
"sync" "sync"
"v2ray.com/core/common"
"v2ray.com/core/common/buf" "v2ray.com/core/common/buf"
) )
// BufferedReader is a reader with internal cache.
type BufferedReader struct { type BufferedReader struct {
sync.Mutex sync.Mutex
reader io.Reader reader io.Reader
@ -14,6 +16,7 @@ type BufferedReader struct {
cached bool cached bool
} }
// NewReader creates a new BufferedReader based on an io.Reader.
func NewReader(rawReader io.Reader) *BufferedReader { func NewReader(rawReader io.Reader) *BufferedReader {
return &BufferedReader{ return &BufferedReader{
reader: rawReader, reader: rawReader,
@ -22,23 +25,31 @@ func NewReader(rawReader io.Reader) *BufferedReader {
} }
} }
// Release implements Releasable.Release().
func (v *BufferedReader) Release() { func (v *BufferedReader) Release() {
v.Lock() v.Lock()
defer v.Unlock() defer v.Unlock()
v.buffer.Release() v.buffer.Release()
v.buffer = nil v.buffer = nil
if releasable, ok := v.reader.(common.Releasable); ok {
releasable.Release()
}
v.reader = nil v.reader = nil
} }
// Cached returns true if the internal cache is effective.
func (v *BufferedReader) Cached() bool { func (v *BufferedReader) Cached() bool {
return v.cached return v.cached
} }
// SetCached is to enable or disable internal cache. If cache is disabled,
// Read() and Write() calls will be delegated to the underlying io.Reader directly.
func (v *BufferedReader) SetCached(cached bool) { func (v *BufferedReader) SetCached(cached bool) {
v.cached = cached v.cached = cached
} }
// Read implements io.Reader.Read().
func (v *BufferedReader) Read(b []byte) (int, error) { func (v *BufferedReader) Read(b []byte) (int, error) {
v.Lock() v.Lock()
defer v.Unlock() defer v.Unlock()

View File

@ -4,6 +4,7 @@ import (
"io" "io"
"sync" "sync"
"v2ray.com/core/common"
"v2ray.com/core/common/buf" "v2ray.com/core/common/buf"
"v2ray.com/core/common/errors" "v2ray.com/core/common/errors"
) )
@ -117,5 +118,9 @@ func (v *BufferedWriter) Release() {
v.buffer.Release() v.buffer.Release()
v.buffer = nil v.buffer = nil
if releasable, ok := v.writer.(common.Releasable); ok {
releasable.Release()
}
v.writer = nil v.writer = nil
} }