|
@@ -8,19 +8,19 @@ import (
|
|
|
|
|
|
|
|
// BytesToBufferReader is a Reader that adjusts its reading speed automatically.
|
|
// BytesToBufferReader is a Reader that adjusts its reading speed automatically.
|
|
|
type BytesToBufferReader struct {
|
|
type BytesToBufferReader struct {
|
|
|
- reader io.Reader
|
|
|
|
|
|
|
+ io.Reader
|
|
|
buffer []byte
|
|
buffer []byte
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
func NewBytesToBufferReader(reader io.Reader) Reader {
|
|
func NewBytesToBufferReader(reader io.Reader) Reader {
|
|
|
return &BytesToBufferReader{
|
|
return &BytesToBufferReader{
|
|
|
- reader: reader,
|
|
|
|
|
|
|
+ Reader: reader,
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
func (r *BytesToBufferReader) readSmall() (MultiBuffer, error) {
|
|
func (r *BytesToBufferReader) readSmall() (MultiBuffer, error) {
|
|
|
b := New()
|
|
b := New()
|
|
|
- if err := b.Reset(ReadFrom(r.reader)); err != nil {
|
|
|
|
|
|
|
+ if err := b.Reset(ReadFrom(r.Reader)); err != nil {
|
|
|
b.Release()
|
|
b.Release()
|
|
|
return nil, err
|
|
return nil, err
|
|
|
}
|
|
}
|
|
@@ -30,13 +30,13 @@ func (r *BytesToBufferReader) readSmall() (MultiBuffer, error) {
|
|
|
return NewMultiBufferValue(b), nil
|
|
return NewMultiBufferValue(b), nil
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
-// Read implements Reader.Read().
|
|
|
|
|
-func (r *BytesToBufferReader) Read() (MultiBuffer, error) {
|
|
|
|
|
|
|
+// ReadMultiBuffer implements Reader.
|
|
|
|
|
+func (r *BytesToBufferReader) ReadMultiBuffer() (MultiBuffer, error) {
|
|
|
if r.buffer == nil {
|
|
if r.buffer == nil {
|
|
|
return r.readSmall()
|
|
return r.readSmall()
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- nBytes, err := r.reader.Read(r.buffer)
|
|
|
|
|
|
|
+ nBytes, err := r.Reader.Read(r.buffer)
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
return nil, err
|
|
return nil, err
|
|
|
}
|
|
}
|
|
@@ -46,20 +46,33 @@ func (r *BytesToBufferReader) Read() (MultiBuffer, error) {
|
|
|
return mb, nil
|
|
return mb, nil
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
-type readerAdpater struct {
|
|
|
|
|
- MultiBufferReader
|
|
|
|
|
|
|
+type BufferedReader struct {
|
|
|
|
|
+ stream Reader
|
|
|
|
|
+ legacyReader io.Reader
|
|
|
|
|
+ leftOver MultiBuffer
|
|
|
|
|
+ buffered bool
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
-func (r *readerAdpater) Read() (MultiBuffer, error) {
|
|
|
|
|
- return r.ReadMultiBuffer()
|
|
|
|
|
|
|
+func NewBufferedReader(reader Reader) *BufferedReader {
|
|
|
|
|
+ r := &BufferedReader{
|
|
|
|
|
+ stream: reader,
|
|
|
|
|
+ buffered: true,
|
|
|
|
|
+ }
|
|
|
|
|
+ if lr, ok := reader.(io.Reader); ok {
|
|
|
|
|
+ r.legacyReader = lr
|
|
|
|
|
+ }
|
|
|
|
|
+ return r
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+func (r *BufferedReader) SetBuffered(f bool) {
|
|
|
|
|
+ r.buffered = f
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
-type bufferToBytesReader struct {
|
|
|
|
|
- stream Reader
|
|
|
|
|
- leftOver MultiBuffer
|
|
|
|
|
|
|
+func (r *BufferedReader) IsBuffered() bool {
|
|
|
|
|
+ return r.buffered
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
-func (r *bufferToBytesReader) Read(b []byte) (int, error) {
|
|
|
|
|
|
|
+func (r *BufferedReader) Read(b []byte) (int, error) {
|
|
|
if r.leftOver != nil {
|
|
if r.leftOver != nil {
|
|
|
nBytes, _ := r.leftOver.Read(b)
|
|
nBytes, _ := r.leftOver.Read(b)
|
|
|
if r.leftOver.IsEmpty() {
|
|
if r.leftOver.IsEmpty() {
|
|
@@ -69,7 +82,11 @@ func (r *bufferToBytesReader) Read(b []byte) (int, error) {
|
|
|
return nBytes, nil
|
|
return nBytes, nil
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- mb, err := r.stream.Read()
|
|
|
|
|
|
|
+ if !r.buffered && r.legacyReader != nil {
|
|
|
|
|
+ return r.legacyReader.Read(b)
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ mb, err := r.stream.ReadMultiBuffer()
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
return 0, err
|
|
return 0, err
|
|
|
}
|
|
}
|
|
@@ -81,39 +98,39 @@ func (r *bufferToBytesReader) Read(b []byte) (int, error) {
|
|
|
return nBytes, nil
|
|
return nBytes, nil
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
-func (r *bufferToBytesReader) ReadMultiBuffer() (MultiBuffer, error) {
|
|
|
|
|
|
|
+func (r *BufferedReader) ReadMultiBuffer() (MultiBuffer, error) {
|
|
|
if r.leftOver != nil {
|
|
if r.leftOver != nil {
|
|
|
mb := r.leftOver
|
|
mb := r.leftOver
|
|
|
r.leftOver = nil
|
|
r.leftOver = nil
|
|
|
return mb, nil
|
|
return mb, nil
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- return r.stream.Read()
|
|
|
|
|
|
|
+ return r.stream.ReadMultiBuffer()
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
-func (r *bufferToBytesReader) writeToInternal(writer io.Writer) (int64, error) {
|
|
|
|
|
|
|
+func (r *BufferedReader) writeToInternal(writer io.Writer) (int64, error) {
|
|
|
mbWriter := NewWriter(writer)
|
|
mbWriter := NewWriter(writer)
|
|
|
totalBytes := int64(0)
|
|
totalBytes := int64(0)
|
|
|
if r.leftOver != nil {
|
|
if r.leftOver != nil {
|
|
|
totalBytes += int64(r.leftOver.Len())
|
|
totalBytes += int64(r.leftOver.Len())
|
|
|
- if err := mbWriter.Write(r.leftOver); err != nil {
|
|
|
|
|
|
|
+ if err := mbWriter.WriteMultiBuffer(r.leftOver); err != nil {
|
|
|
return 0, err
|
|
return 0, err
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
for {
|
|
for {
|
|
|
- mb, err := r.stream.Read()
|
|
|
|
|
|
|
+ mb, err := r.stream.ReadMultiBuffer()
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
return totalBytes, err
|
|
return totalBytes, err
|
|
|
}
|
|
}
|
|
|
totalBytes += int64(mb.Len())
|
|
totalBytes += int64(mb.Len())
|
|
|
- if err := mbWriter.Write(mb); err != nil {
|
|
|
|
|
|
|
+ if err := mbWriter.WriteMultiBuffer(mb); err != nil {
|
|
|
return totalBytes, err
|
|
return totalBytes, err
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
-func (r *bufferToBytesReader) WriteTo(writer io.Writer) (int64, error) {
|
|
|
|
|
|
|
+func (r *BufferedReader) WriteTo(writer io.Writer) (int64, error) {
|
|
|
nBytes, err := r.writeToInternal(writer)
|
|
nBytes, err := r.writeToInternal(writer)
|
|
|
if errors.Cause(err) == io.EOF {
|
|
if errors.Cause(err) == io.EOF {
|
|
|
return nBytes, nil
|
|
return nBytes, nil
|