reader.go 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. package buf
  2. import (
  3. "io"
  4. "v2ray.com/core/common/errors"
  5. )
  6. // BytesToBufferReader is a Reader that adjusts its reading speed automatically.
  7. type BytesToBufferReader struct {
  8. io.Reader
  9. buffer []byte
  10. }
  11. func NewBytesToBufferReader(reader io.Reader) Reader {
  12. return &BytesToBufferReader{
  13. Reader: reader,
  14. }
  15. }
  16. func (r *BytesToBufferReader) readSmall() (MultiBuffer, error) {
  17. b := New()
  18. if err := b.Reset(ReadFrom(r.Reader)); err != nil {
  19. b.Release()
  20. return nil, err
  21. }
  22. if b.IsFull() {
  23. r.buffer = make([]byte, 32*1024)
  24. }
  25. return NewMultiBufferValue(b), nil
  26. }
  27. // ReadMultiBuffer implements Reader.
  28. func (r *BytesToBufferReader) ReadMultiBuffer() (MultiBuffer, error) {
  29. if r.buffer == nil {
  30. return r.readSmall()
  31. }
  32. nBytes, err := r.Reader.Read(r.buffer)
  33. if err != nil {
  34. return nil, err
  35. }
  36. mb := NewMultiBufferCap(nBytes/Size + 1)
  37. mb.Write(r.buffer[:nBytes])
  38. return mb, nil
  39. }
  40. type BufferedReader struct {
  41. stream Reader
  42. legacyReader io.Reader
  43. leftOver MultiBuffer
  44. buffered bool
  45. }
  46. func NewBufferedReader(reader Reader) *BufferedReader {
  47. r := &BufferedReader{
  48. stream: reader,
  49. buffered: true,
  50. }
  51. if lr, ok := reader.(io.Reader); ok {
  52. r.legacyReader = lr
  53. }
  54. return r
  55. }
  56. func (r *BufferedReader) SetBuffered(f bool) {
  57. r.buffered = f
  58. }
  59. func (r *BufferedReader) IsBuffered() bool {
  60. return r.buffered
  61. }
  62. func (r *BufferedReader) Read(b []byte) (int, error) {
  63. if r.leftOver != nil {
  64. nBytes, _ := r.leftOver.Read(b)
  65. if r.leftOver.IsEmpty() {
  66. r.leftOver.Release()
  67. r.leftOver = nil
  68. }
  69. return nBytes, nil
  70. }
  71. if !r.buffered && r.legacyReader != nil {
  72. return r.legacyReader.Read(b)
  73. }
  74. mb, err := r.stream.ReadMultiBuffer()
  75. if err != nil {
  76. return 0, err
  77. }
  78. nBytes, _ := mb.Read(b)
  79. if !mb.IsEmpty() {
  80. r.leftOver = mb
  81. }
  82. return nBytes, nil
  83. }
  84. func (r *BufferedReader) ReadMultiBuffer() (MultiBuffer, error) {
  85. if r.leftOver != nil {
  86. mb := r.leftOver
  87. r.leftOver = nil
  88. return mb, nil
  89. }
  90. return r.stream.ReadMultiBuffer()
  91. }
  92. func (r *BufferedReader) writeToInternal(writer io.Writer) (int64, error) {
  93. mbWriter := NewWriter(writer)
  94. totalBytes := int64(0)
  95. if r.leftOver != nil {
  96. totalBytes += int64(r.leftOver.Len())
  97. if err := mbWriter.WriteMultiBuffer(r.leftOver); err != nil {
  98. return 0, err
  99. }
  100. }
  101. for {
  102. mb, err := r.stream.ReadMultiBuffer()
  103. if err != nil {
  104. return totalBytes, err
  105. }
  106. totalBytes += int64(mb.Len())
  107. if err := mbWriter.WriteMultiBuffer(mb); err != nil {
  108. return totalBytes, err
  109. }
  110. }
  111. }
  112. func (r *BufferedReader) WriteTo(writer io.Writer) (int64, error) {
  113. nBytes, err := r.writeToInternal(writer)
  114. if errors.Cause(err) == io.EOF {
  115. return nBytes, nil
  116. }
  117. return nBytes, err
  118. }