multi_buffer.go 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. package buf
  2. import (
  3. "io"
  4. "net"
  5. "v2ray.com/core/common"
  6. "v2ray.com/core/common/errors"
  7. )
  8. // MultiBufferWriter is a writer that writes MultiBuffer.
  9. type MultiBufferWriter interface {
  10. WriteMultiBuffer(MultiBuffer) error
  11. }
  12. // MultiBufferReader is a reader that reader payload as MultiBuffer.
  13. type MultiBufferReader interface {
  14. ReadMultiBuffer() (MultiBuffer, error)
  15. }
  16. func ReadAllToMultiBuffer(reader io.Reader) (MultiBuffer, error) {
  17. mb := NewMultiBuffer()
  18. for {
  19. b := New()
  20. err := b.AppendSupplier(ReadFrom(reader))
  21. if !b.IsEmpty() {
  22. mb.Append(b)
  23. }
  24. if err != nil {
  25. if errors.Cause(err) == io.EOF {
  26. return mb, nil
  27. }
  28. mb.Release()
  29. return nil, err
  30. }
  31. }
  32. }
  33. // ReadAllToBytes reads all content from the reader into a byte array, until EOF.
  34. func ReadAllToBytes(reader io.Reader) ([]byte, error) {
  35. mb, err := ReadAllToMultiBuffer(reader)
  36. if err != nil {
  37. return nil, err
  38. }
  39. b := make([]byte, mb.Len())
  40. common.Must2(mb.Read(b))
  41. mb.Release()
  42. return b, nil
  43. }
  44. // MultiBuffer is a list of Buffers. The order of Buffer matters.
  45. type MultiBuffer []*Buffer
  46. // NewMultiBuffer creates a new MultiBuffer instance.
  47. func NewMultiBuffer() MultiBuffer {
  48. return MultiBuffer(make([]*Buffer, 0, 128))
  49. }
  50. // NewMultiBufferValue wraps a list of Buffers into MultiBuffer.
  51. func NewMultiBufferValue(b ...*Buffer) MultiBuffer {
  52. return MultiBuffer(b)
  53. }
  54. // Append appends buffer to the end of this MultiBuffer
  55. func (mb *MultiBuffer) Append(buf *Buffer) {
  56. *mb = append(*mb, buf)
  57. }
  58. // AppendMulti appends a MultiBuffer to the end of this one.
  59. func (mb *MultiBuffer) AppendMulti(buf MultiBuffer) {
  60. *mb = append(*mb, buf...)
  61. }
  62. // Copy copied the begining part of the MultiBuffer into the given byte array.
  63. func (mb MultiBuffer) Copy(b []byte) int {
  64. total := 0
  65. for _, bb := range mb {
  66. nBytes := copy(b[total:], bb.Bytes())
  67. total += nBytes
  68. if nBytes < bb.Len() {
  69. break
  70. }
  71. }
  72. return total
  73. }
  74. // Read implements io.Reader.
  75. func (mb *MultiBuffer) Read(b []byte) (int, error) {
  76. endIndex := len(*mb)
  77. totalBytes := 0
  78. for i, bb := range *mb {
  79. nBytes, _ := bb.Read(b)
  80. totalBytes += nBytes
  81. b = b[nBytes:]
  82. if bb.IsEmpty() {
  83. bb.Release()
  84. } else {
  85. endIndex = i
  86. break
  87. }
  88. }
  89. *mb = (*mb)[endIndex:]
  90. return totalBytes, nil
  91. }
  92. // Write implements io.Writer.
  93. func (mb *MultiBuffer) Write(b []byte) {
  94. n := len(*mb)
  95. if n > 0 && !(*mb)[n-1].IsFull() {
  96. nBytes, _ := (*mb)[n-1].Write(b)
  97. b = b[nBytes:]
  98. }
  99. for len(b) > 0 {
  100. bb := New()
  101. nBytes, _ := bb.Write(b)
  102. b = b[nBytes:]
  103. mb.Append(bb)
  104. }
  105. }
  106. // Len returns the total number of bytes in the MultiBuffer.
  107. func (mb MultiBuffer) Len() int {
  108. size := 0
  109. for _, b := range mb {
  110. size += b.Len()
  111. }
  112. return size
  113. }
  114. // IsEmpty return true if the MultiBuffer has no content.
  115. func (mb MultiBuffer) IsEmpty() bool {
  116. for _, b := range mb {
  117. if !b.IsEmpty() {
  118. return false
  119. }
  120. }
  121. return true
  122. }
  123. // Release releases all Buffers in the MultiBuffer.
  124. func (mb *MultiBuffer) Release() {
  125. for i, b := range *mb {
  126. b.Release()
  127. (*mb)[i] = nil
  128. }
  129. *mb = (*mb)[:0]
  130. }
  131. // ToNetBuffers converts this MultiBuffer to net.Buffers. The return net.Buffers points to the same content of the MultiBuffer.
  132. func (mb MultiBuffer) ToNetBuffers() net.Buffers {
  133. bs := make([][]byte, len(mb))
  134. for i, b := range mb {
  135. bs[i] = b.Bytes()
  136. }
  137. return bs
  138. }
  139. func (mb *MultiBuffer) SliceBySize(size int) MultiBuffer {
  140. slice := NewMultiBuffer()
  141. sliceSize := 0
  142. endIndex := len(*mb)
  143. for i, b := range *mb {
  144. if b.Len()+sliceSize > size {
  145. endIndex = i
  146. break
  147. }
  148. sliceSize += b.Len()
  149. slice.Append(b)
  150. (*mb)[i] = nil
  151. }
  152. *mb = (*mb)[endIndex:]
  153. return slice
  154. }
  155. func (mb *MultiBuffer) SplitFirst() *Buffer {
  156. if len(*mb) == 0 {
  157. return nil
  158. }
  159. b := (*mb)[0]
  160. (*mb)[0] = nil
  161. *mb = (*mb)[1:]
  162. return b
  163. }