io.go 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. package buf
  2. import (
  3. "io"
  4. "v2ray.com/core/common/errors"
  5. "v2ray.com/core/common/signal"
  6. )
  7. // Reader extends io.Reader with alloc.Buffer.
  8. type Reader interface {
  9. // Read reads content from underlying reader, and put it into an alloc.Buffer.
  10. Read() (*Buffer, error)
  11. }
  12. // Writer extends io.Writer with alloc.Buffer.
  13. type Writer interface {
  14. // Write writes an alloc.Buffer into underlying writer.
  15. Write(*Buffer) error
  16. }
  17. // ReadFrom creates a Supplier to read from a given io.Reader.
  18. func ReadFrom(reader io.Reader) Supplier {
  19. return func(b []byte) (int, error) {
  20. return reader.Read(b)
  21. }
  22. }
  23. // ReadFullFrom creates a Supplier to read full buffer from a given io.Reader.
  24. func ReadFullFrom(reader io.Reader, size int) Supplier {
  25. return func(b []byte) (int, error) {
  26. return io.ReadFull(reader, b[:size])
  27. }
  28. }
  29. // Pipe dumps all payload from reader to writer, until an error occurs.
  30. // ActivityTimer gets updated as soon as there is a payload.
  31. func Pipe(timer *signal.ActivityTimer, reader Reader, writer Writer) error {
  32. for {
  33. buffer, err := reader.Read()
  34. if err != nil {
  35. return err
  36. }
  37. timer.UpdateActivity()
  38. if buffer.IsEmpty() {
  39. buffer.Release()
  40. continue
  41. }
  42. err = writer.Write(buffer)
  43. if err != nil {
  44. buffer.Release()
  45. return err
  46. }
  47. }
  48. }
  49. // PipeUntilEOF behaves the same as Pipe(). The only difference is PipeUntilEOF returns nil on EOF.
  50. func PipeUntilEOF(timer *signal.ActivityTimer, reader Reader, writer Writer) error {
  51. err := Pipe(timer, reader, writer)
  52. if err != nil && errors.Cause(err) != io.EOF {
  53. return err
  54. }
  55. return nil
  56. }
  57. // NewReader creates a new Reader.
  58. // The Reader instance doesn't take the ownership of reader.
  59. func NewReader(reader io.Reader) Reader {
  60. return &BytesToBufferReader{
  61. reader: reader,
  62. }
  63. }
  64. // ToBytesReader converts a Reaaer to io.Reader.
  65. func ToBytesReader(stream Reader) io.Reader {
  66. return &BufferToBytesReader{
  67. stream: stream,
  68. }
  69. }
  70. // NewWriter creates a new Writer.
  71. func NewWriter(writer io.Writer) Writer {
  72. return &BufferToBytesWriter{
  73. writer: writer,
  74. }
  75. }
  76. // ToBytesWriter converts a Writer to io.Writer
  77. func ToBytesWriter(writer Writer) io.Writer {
  78. return &BytesToBufferWriter{
  79. writer: writer,
  80. }
  81. }