multi_buffer.go 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  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. (*mb)[i] = nil
  85. } else {
  86. endIndex = i
  87. break
  88. }
  89. }
  90. *mb = (*mb)[endIndex:]
  91. return totalBytes, nil
  92. }
  93. // Write implements io.Writer.
  94. func (mb *MultiBuffer) Write(b []byte) {
  95. n := len(*mb)
  96. if n > 0 && !(*mb)[n-1].IsFull() {
  97. nBytes, _ := (*mb)[n-1].Write(b)
  98. b = b[nBytes:]
  99. }
  100. for len(b) > 0 {
  101. bb := New()
  102. nBytes, _ := bb.Write(b)
  103. b = b[nBytes:]
  104. mb.Append(bb)
  105. }
  106. }
  107. // Len returns the total number of bytes in the MultiBuffer.
  108. func (mb MultiBuffer) Len() int {
  109. size := 0
  110. for _, b := range mb {
  111. size += b.Len()
  112. }
  113. return size
  114. }
  115. // IsEmpty return true if the MultiBuffer has no content.
  116. func (mb MultiBuffer) IsEmpty() bool {
  117. for _, b := range mb {
  118. if !b.IsEmpty() {
  119. return false
  120. }
  121. }
  122. return true
  123. }
  124. // Release releases all Buffers in the MultiBuffer.
  125. func (mb *MultiBuffer) Release() {
  126. for i, b := range *mb {
  127. b.Release()
  128. (*mb)[i] = nil
  129. }
  130. *mb = (*mb)[:0]
  131. }
  132. // ToNetBuffers converts this MultiBuffer to net.Buffers. The return net.Buffers points to the same content of the MultiBuffer.
  133. func (mb MultiBuffer) ToNetBuffers() net.Buffers {
  134. bs := make([][]byte, len(mb))
  135. for i, b := range mb {
  136. bs[i] = b.Bytes()
  137. }
  138. return bs
  139. }
  140. func (mb *MultiBuffer) SliceBySize(size int) MultiBuffer {
  141. slice := NewMultiBuffer()
  142. sliceSize := 0
  143. endIndex := len(*mb)
  144. for i, b := range *mb {
  145. if b.Len()+sliceSize > size {
  146. endIndex = i
  147. break
  148. }
  149. sliceSize += b.Len()
  150. slice.Append(b)
  151. (*mb)[i] = nil
  152. }
  153. *mb = (*mb)[endIndex:]
  154. return slice
  155. }
  156. func (mb *MultiBuffer) SplitFirst() *Buffer {
  157. if len(*mb) == 0 {
  158. return nil
  159. }
  160. b := (*mb)[0]
  161. (*mb)[0] = nil
  162. *mb = (*mb)[1:]
  163. return b
  164. }