multi_buffer.go 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. package buf
  2. import "net"
  3. type MultiBufferWriter interface {
  4. WriteMultiBuffer(MultiBuffer) error
  5. }
  6. type MultiBufferReader interface {
  7. ReadMultiBuffer() (MultiBuffer, error)
  8. }
  9. // MultiBuffer is a list of Buffers. The order of Buffer matters.
  10. type MultiBuffer []*Buffer
  11. // NewMultiBuffer creates a new MultiBuffer instance.
  12. func NewMultiBuffer() MultiBuffer {
  13. return MultiBuffer(make([]*Buffer, 0, 128))
  14. }
  15. // NewMultiBufferValue wraps a list of Buffers into MultiBuffer.
  16. func NewMultiBufferValue(b ...*Buffer) MultiBuffer {
  17. return MultiBuffer(b)
  18. }
  19. func (mb *MultiBuffer) Append(buf *Buffer) {
  20. *mb = append(*mb, buf)
  21. }
  22. func (mb *MultiBuffer) AppendMulti(buf MultiBuffer) {
  23. *mb = append(*mb, buf...)
  24. }
  25. func (mb MultiBuffer) Copy(b []byte) int {
  26. total := 0
  27. for _, bb := range mb {
  28. nBytes := copy(b[total:], bb.Bytes())
  29. total += nBytes
  30. if nBytes < bb.Len() {
  31. break
  32. }
  33. }
  34. return total
  35. }
  36. func (mb *MultiBuffer) Read(b []byte) (int, error) {
  37. endIndex := len(*mb)
  38. totalBytes := 0
  39. for i, bb := range *mb {
  40. nBytes, _ := bb.Read(b)
  41. totalBytes += nBytes
  42. b = b[nBytes:]
  43. if bb.IsEmpty() {
  44. bb.Release()
  45. } else {
  46. endIndex = i
  47. break
  48. }
  49. }
  50. *mb = (*mb)[endIndex:]
  51. return totalBytes, nil
  52. }
  53. func (mb *MultiBuffer) Write(b []byte) {
  54. n := len(*mb)
  55. if n > 0 && !(*mb)[n-1].IsFull() {
  56. nBytes, _ := (*mb)[n-1].Write(b)
  57. b = b[nBytes:]
  58. }
  59. for len(b) > 0 {
  60. bb := New()
  61. nBytes, _ := bb.Write(b)
  62. b = b[nBytes:]
  63. mb.Append(bb)
  64. }
  65. }
  66. // Len returns the total number of bytes in the MultiBuffer.
  67. func (mb MultiBuffer) Len() int {
  68. size := 0
  69. for _, b := range mb {
  70. size += b.Len()
  71. }
  72. return size
  73. }
  74. // IsEmpty return true if the MultiBuffer has no content.
  75. func (mb MultiBuffer) IsEmpty() bool {
  76. for _, b := range mb {
  77. if !b.IsEmpty() {
  78. return false
  79. }
  80. }
  81. return true
  82. }
  83. // Release releases all Buffers in the MultiBuffer.
  84. func (mb MultiBuffer) Release() {
  85. for i, b := range mb {
  86. b.Release()
  87. mb[i] = nil
  88. }
  89. }
  90. // ToNetBuffers converts this MultiBuffer to net.Buffers. The return net.Buffers points to the same content of the MultiBuffer.
  91. func (mb MultiBuffer) ToNetBuffers() net.Buffers {
  92. bs := make([][]byte, len(mb))
  93. for i, b := range mb {
  94. bs[i] = b.Bytes()
  95. }
  96. return bs
  97. }
  98. func (mb *MultiBuffer) SliceBySize(size int) MultiBuffer {
  99. slice := NewMultiBuffer()
  100. sliceSize := 0
  101. endIndex := len(*mb)
  102. for i, b := range *mb {
  103. if b.Len()+sliceSize > size {
  104. endIndex = i
  105. break
  106. }
  107. sliceSize += b.Len()
  108. slice.Append(b)
  109. }
  110. *mb = (*mb)[endIndex:]
  111. return slice
  112. }
  113. func (mb *MultiBuffer) SplitFirst() *Buffer {
  114. if len(*mb) == 0 {
  115. return nil
  116. }
  117. b := (*mb)[0]
  118. *mb = (*mb)[1:]
  119. return b
  120. }