multi_buffer.go 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. package buf
  2. import (
  3. "io"
  4. "net"
  5. )
  6. type MultiBufferWriter interface {
  7. WriteMultiBuffer(MultiBuffer) (int, error)
  8. }
  9. type MultiBuffer []*Buffer
  10. func NewMultiBuffer() MultiBuffer {
  11. return MultiBuffer(make([]*Buffer, 0, 8))
  12. }
  13. func NewMultiBufferValue(b ...*Buffer) MultiBuffer {
  14. return MultiBuffer(b)
  15. }
  16. func (b *MultiBuffer) Append(buf *Buffer) {
  17. *b = append(*b, buf)
  18. }
  19. func (b *MultiBuffer) AppendMulti(mb MultiBuffer) {
  20. *b = append(*b, mb...)
  21. }
  22. func (mb *MultiBuffer) Read(b []byte) (int, error) {
  23. if len(*mb) == 0 {
  24. return 0, io.EOF
  25. }
  26. endIndex := len(*mb)
  27. totalBytes := 0
  28. for i, bb := range *mb {
  29. nBytes, err := bb.Read(b)
  30. totalBytes += nBytes
  31. if err != nil {
  32. return totalBytes, err
  33. }
  34. b = b[nBytes:]
  35. if bb.IsEmpty() {
  36. bb.Release()
  37. } else {
  38. endIndex = i
  39. break
  40. }
  41. }
  42. *mb = (*mb)[endIndex:]
  43. return totalBytes, nil
  44. }
  45. func (mb MultiBuffer) WriteTo(writer io.Writer) (int, error) {
  46. if mw, ok := writer.(MultiBufferWriter); ok {
  47. return mw.WriteMultiBuffer(mb)
  48. }
  49. bs := make([][]byte, len(mb))
  50. for i, b := range mb {
  51. bs[i] = b.Bytes()
  52. }
  53. nbs := net.Buffers(bs)
  54. nBytes, err := nbs.WriteTo(writer)
  55. return int(nBytes), err
  56. }
  57. func (mb MultiBuffer) Len() int {
  58. size := 0
  59. for _, b := range mb {
  60. size += b.Len()
  61. }
  62. return size
  63. }
  64. func (mb MultiBuffer) IsEmpty() bool {
  65. for _, b := range mb {
  66. if !b.IsEmpty() {
  67. return false
  68. }
  69. }
  70. return true
  71. }
  72. func (mb MultiBuffer) Release() {
  73. for _, b := range mb {
  74. b.Release()
  75. }
  76. }