| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248 | package bufimport (	"io"	"net"	"v2ray.com/core/common"	"v2ray.com/core/common/errors"	"v2ray.com/core/common/serial")// ReadAllToMultiBuffer reads all content from the reader into a MultiBuffer, until EOF.func ReadAllToMultiBuffer(reader io.Reader) (MultiBuffer, error) {	mb := NewMultiBufferCap(128)	if _, err := mb.ReadFrom(reader); err != nil {		mb.Release()		return nil, err	}	return mb, nil}// ReadAllToBytes reads all content from the reader into a byte array, until EOF.func ReadAllToBytes(reader io.Reader) ([]byte, error) {	mb, err := ReadAllToMultiBuffer(reader)	if err != nil {		return nil, err	}	if mb.Len() == 0 {		return nil, nil	}	b := make([]byte, mb.Len())	common.Must2(mb.Read(b))	mb.Release()	return b, nil}// MultiBuffer is a list of Buffers. The order of Buffer matters.type MultiBuffer []*Buffer// NewMultiBufferCap creates a new MultiBuffer instance.func NewMultiBufferCap(capacity int32) MultiBuffer {	return MultiBuffer(make([]*Buffer, 0, capacity))}// NewMultiBufferValue wraps a list of Buffers into MultiBuffer.func NewMultiBufferValue(b ...*Buffer) MultiBuffer {	return MultiBuffer(b)}// Append appends buffer to the end of this MultiBufferfunc (mb *MultiBuffer) Append(buf *Buffer) {	if buf != nil {		*mb = append(*mb, buf)	}}// AppendMulti appends a MultiBuffer to the end of this one.func (mb *MultiBuffer) AppendMulti(buf MultiBuffer) {	*mb = append(*mb, buf...)}// Copy copied the beginning part of the MultiBuffer into the given byte array.func (mb MultiBuffer) Copy(b []byte) int {	total := 0	for _, bb := range mb {		nBytes := copy(b[total:], bb.Bytes())		total += nBytes		if int32(nBytes) < bb.Len() {			break		}	}	return total}// ReadFrom implements io.ReaderFrom.func (mb *MultiBuffer) ReadFrom(reader io.Reader) (int64, error) {	totalBytes := int64(0)	for {		b := New()		err := b.Reset(ReadFullFrom(reader, Size))		if b.IsEmpty() {			b.Release()		} else {			mb.Append(b)		}		totalBytes += int64(b.Len())		if err != nil {			if errors.Cause(err) == io.EOF || errors.Cause(err) == io.ErrUnexpectedEOF {				return totalBytes, nil			}			return totalBytes, err		}	}}// Read implements io.Reader.func (mb *MultiBuffer) Read(b []byte) (int, error) {	if mb.IsEmpty() {		return 0, io.EOF	}	endIndex := len(*mb)	totalBytes := 0	for i, bb := range *mb {		nBytes, _ := bb.Read(b)		totalBytes += nBytes		b = b[nBytes:]		if bb.IsEmpty() {			bb.Release()			(*mb)[i] = nil		} else {			endIndex = i			break		}	}	*mb = (*mb)[endIndex:]	return totalBytes, nil}// WriteTo implements io.WriterTo.func (mb *MultiBuffer) WriteTo(writer io.Writer) (int64, error) {	defer mb.Release()	totalBytes := int64(0)	for _, b := range *mb {		nBytes, err := writer.Write(b.Bytes())		totalBytes += int64(nBytes)		if err != nil {			return totalBytes, err		}	}	return totalBytes, nil}// Write implements io.Writer.func (mb *MultiBuffer) Write(b []byte) (int, error) {	totalBytes := len(b)	n := len(*mb)	if n > 0 && !(*mb)[n-1].IsFull() {		nBytes, _ := (*mb)[n-1].Write(b)		b = b[nBytes:]	}	for len(b) > 0 {		bb := New()		nBytes, _ := bb.Write(b)		b = b[nBytes:]		mb.Append(bb)	}	return totalBytes, nil}// WriteMultiBuffer implements Writer.func (mb *MultiBuffer) WriteMultiBuffer(b MultiBuffer) error {	*mb = append(*mb, b...)	for i := range b {		b[i] = nil	}	return nil}// Len returns the total number of bytes in the MultiBuffer.func (mb *MultiBuffer) Len() int32 {	if mb == nil {		return 0	}	size := int32(0)	for _, b := range *mb {		size += b.Len()	}	return size}// IsEmpty return true if the MultiBuffer has no content.func (mb MultiBuffer) IsEmpty() bool {	for _, b := range mb {		if !b.IsEmpty() {			return false		}	}	return true}// Release releases all Buffers in the MultiBuffer.func (mb *MultiBuffer) Release() {	for i, b := range *mb {		b.Release()		(*mb)[i] = nil	}	*mb = nil}func (mb MultiBuffer) String() string {	v := make([]interface{}, len(mb))	for i, b := range mb {		v[i] = b	}	return serial.Concat(v...)}// ToNetBuffers converts this MultiBuffer to net.Buffers. The return net.Buffers points to the same content of the MultiBuffer.func (mb MultiBuffer) ToNetBuffers() net.Buffers {	bs := make([][]byte, len(mb))	for i, b := range mb {		bs[i] = b.Bytes()	}	return bs}// SliceBySize splits the beginning of this MultiBuffer into another one, for at most size bytes.func (mb *MultiBuffer) SliceBySize(size int32) MultiBuffer {	slice := NewMultiBufferCap(10)	sliceSize := int32(0)	endIndex := len(*mb)	for i, b := range *mb {		if b.Len()+sliceSize > size {			endIndex = i			break		}		sliceSize += b.Len()		slice.Append(b)		(*mb)[i] = nil	}	*mb = (*mb)[endIndex:]	if endIndex == 0 && len(*mb) > 0 {		b := NewSize(size)		common.Must(b.Reset(ReadFullFrom((*mb)[0], size)))		return NewMultiBufferValue(b)	}	return slice}// SplitFirst splits out the first Buffer in this MultiBuffer.func (mb *MultiBuffer) SplitFirst() *Buffer {	if len(*mb) == 0 {		return nil	}	b := (*mb)[0]	(*mb)[0] = nil	*mb = (*mb)[1:]	return b}
 |