multi_buffer.go 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  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) Read(b []byte) (int, error) {
  26. endIndex := len(*mb)
  27. totalBytes := 0
  28. for i, bb := range *mb {
  29. nBytes, _ := bb.Read(b)
  30. totalBytes += nBytes
  31. b = b[nBytes:]
  32. if bb.IsEmpty() {
  33. bb.Release()
  34. } else {
  35. endIndex = i
  36. break
  37. }
  38. }
  39. *mb = (*mb)[endIndex:]
  40. return totalBytes, nil
  41. }
  42. // Len returns the total number of bytes in the MultiBuffer.
  43. func (mb MultiBuffer) Len() int {
  44. size := 0
  45. for _, b := range mb {
  46. size += b.Len()
  47. }
  48. return size
  49. }
  50. // IsEmpty return true if the MultiBuffer has no content.
  51. func (mb MultiBuffer) IsEmpty() bool {
  52. for _, b := range mb {
  53. if !b.IsEmpty() {
  54. return false
  55. }
  56. }
  57. return true
  58. }
  59. // Release releases all Buffers in the MultiBuffer.
  60. func (mb MultiBuffer) Release() {
  61. for i, b := range mb {
  62. b.Release()
  63. mb[i] = nil
  64. }
  65. }
  66. // ToNetBuffers converts this MultiBuffer to net.Buffers. The return net.Buffers points to the same content of the MultiBuffer.
  67. func (mb MultiBuffer) ToNetBuffers() net.Buffers {
  68. bs := make([][]byte, len(mb))
  69. for i, b := range mb {
  70. bs[i] = b.Bytes()
  71. }
  72. return bs
  73. }
  74. func (mb *MultiBuffer) SliceBySize(size int) MultiBuffer {
  75. slice := NewMultiBuffer()
  76. sliceSize := 0
  77. endIndex := len(*mb)
  78. for i, b := range *mb {
  79. if b.Len()+sliceSize > size {
  80. endIndex = i
  81. break
  82. }
  83. sliceSize += b.Len()
  84. slice.Append(b)
  85. }
  86. *mb = (*mb)[endIndex:]
  87. return slice
  88. }