reader.go 1.4 KB

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