mirror of https://github.com/v2ray/v2ray-core
write all content
parent
8d689fb92d
commit
28ccd4ddd5
|
@ -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,25 +119,30 @@ 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() {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
b := w.buffer
|
b := w.buffer
|
||||||
w.buffer = nil
|
w.buffer = nil
|
||||||
|
|
||||||
if writer, ok := w.writer.(io.Writer); ok {
|
if writer, ok := w.writer.(io.Writer); ok {
|
||||||
_, err := writer.Write(b.Bytes())
|
defer b.Release()
|
||||||
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.
|
||||||
func (w *BufferedWriter) SetBuffered(f bool) error {
|
func (w *BufferedWriter) SetBuffered(f bool) error {
|
||||||
w.buffered = f
|
w.buffered = f
|
||||||
|
|
Loading…
Reference in New Issue