|
|
@ -16,8 +16,22 @@ type BufferToBytesWriter struct {
|
|
|
|
func (w *BufferToBytesWriter) WriteMultiBuffer(mb MultiBuffer) error {
|
|
|
|
func (w *BufferToBytesWriter) WriteMultiBuffer(mb MultiBuffer) error {
|
|
|
|
defer mb.Release()
|
|
|
|
defer mb.Release()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
size := mb.Len()
|
|
|
|
|
|
|
|
if size == 0 {
|
|
|
|
|
|
|
|
return nil
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
bs := mb.ToNetBuffers()
|
|
|
|
bs := mb.ToNetBuffers()
|
|
|
|
return common.Error2(bs.WriteTo(w.Writer))
|
|
|
|
|
|
|
|
|
|
|
|
for size > 0 {
|
|
|
|
|
|
|
|
n, err := bs.WriteTo(w.Writer)
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
|
|
return err
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
size -= int32(n)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// ReadFrom implements io.ReaderFrom.
|
|
|
|
// ReadFrom implements io.ReaderFrom.
|
|
|
@ -105,23 +119,28 @@ func (w *BufferedWriter) WriteMultiBuffer(b MultiBuffer) error {
|
|
|
|
|
|
|
|
|
|
|
|
// Flush flushes buffered content into underlying writer.
|
|
|
|
// Flush flushes buffered content into underlying writer.
|
|
|
|
func (w *BufferedWriter) Flush() error {
|
|
|
|
func (w *BufferedWriter) Flush() error {
|
|
|
|
if !w.buffer.IsEmpty() {
|
|
|
|
if w.buffer.IsEmpty() {
|
|
|
|
b := w.buffer
|
|
|
|
return nil
|
|
|
|
w.buffer = nil
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if writer, ok := w.writer.(io.Writer); ok {
|
|
|
|
b := w.buffer
|
|
|
|
_, err := writer.Write(b.Bytes())
|
|
|
|
w.buffer = nil
|
|
|
|
b.Release()
|
|
|
|
|
|
|
|
|
|
|
|
if writer, ok := w.writer.(io.Writer); ok {
|
|
|
|
|
|
|
|
defer b.Release()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for !b.IsEmpty() {
|
|
|
|
|
|
|
|
n, err := writer.Write(b.Bytes())
|
|
|
|
if err != nil {
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else if err := w.writer.WriteMultiBuffer(NewMultiBufferValue(b)); err != nil {
|
|
|
|
b.Advance(int32(n))
|
|
|
|
return err
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
w.buffer = nil
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
|
|
|
|
|
|
|
|
return w.writer.WriteMultiBuffer(NewMultiBufferValue(b))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// SetBuffered sets whether the internal buffer is used. If set to false, Flush() will be called to clear the buffer.
|
|
|
|
// SetBuffered sets whether the internal buffer is used. If set to false, Flush() will be called to clear the buffer.
|
|
|
|