reader.go 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. package bufio
  2. import (
  3. "io"
  4. "sync"
  5. "v2ray.com/core/common"
  6. "v2ray.com/core/common/buf"
  7. )
  8. // BufferedReader is a reader with internal cache.
  9. type BufferedReader struct {
  10. sync.Mutex
  11. reader io.Reader
  12. buffer *buf.Buffer
  13. cached bool
  14. }
  15. // NewReader creates a new BufferedReader based on an io.Reader.
  16. func NewReader(rawReader io.Reader) *BufferedReader {
  17. return &BufferedReader{
  18. reader: rawReader,
  19. buffer: buf.New(),
  20. cached: true,
  21. }
  22. }
  23. // Release implements Releasable.Release().
  24. func (v *BufferedReader) Release() {
  25. v.Lock()
  26. defer v.Unlock()
  27. v.buffer.Release()
  28. v.buffer = nil
  29. if releasable, ok := v.reader.(common.Releasable); ok {
  30. releasable.Release()
  31. }
  32. v.reader = nil
  33. }
  34. // Cached returns true if the internal cache is effective.
  35. func (v *BufferedReader) Cached() bool {
  36. return v.cached
  37. }
  38. // SetCached is to enable or disable internal cache. If cache is disabled,
  39. // Read() and Write() calls will be delegated to the underlying io.Reader directly.
  40. func (v *BufferedReader) SetCached(cached bool) {
  41. v.cached = cached
  42. }
  43. // Read implements io.Reader.Read().
  44. func (v *BufferedReader) Read(b []byte) (int, error) {
  45. v.Lock()
  46. defer v.Unlock()
  47. if v.reader == nil {
  48. return 0, io.EOF
  49. }
  50. if !v.cached {
  51. if !v.buffer.IsEmpty() {
  52. return v.buffer.Read(b)
  53. }
  54. return v.reader.Read(b)
  55. }
  56. if v.buffer.IsEmpty() {
  57. err := v.buffer.AppendSupplier(buf.ReadFrom(v.reader))
  58. if err != nil {
  59. return 0, err
  60. }
  61. }
  62. if v.buffer.IsEmpty() {
  63. return 0, nil
  64. }
  65. return v.buffer.Read(b)
  66. }