output.go 1.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. package kcp
  2. import (
  3. "io"
  4. "sync"
  5. "github.com/v2fly/v2ray-core/v5/common/buf"
  6. "github.com/v2fly/v2ray-core/v5/common/retry"
  7. )
  8. type SegmentWriter interface {
  9. Write(seg Segment) error
  10. Release()
  11. }
  12. type SimpleSegmentWriter struct {
  13. sync.Mutex
  14. buffer *buf.Buffer
  15. writer io.Writer
  16. }
  17. func NewSegmentWriter(writer io.Writer) SegmentWriter {
  18. return &SimpleSegmentWriter{
  19. writer: writer,
  20. buffer: buf.New(),
  21. }
  22. }
  23. func (w *SimpleSegmentWriter) Write(seg Segment) error {
  24. w.Lock()
  25. defer w.Unlock()
  26. w.buffer.Clear()
  27. rawBytes := w.buffer.Extend(seg.ByteSize())
  28. seg.Serialize(rawBytes)
  29. _, err := w.writer.Write(w.buffer.Bytes())
  30. return err
  31. }
  32. func (w *SimpleSegmentWriter) Release() {
  33. w.buffer.Release()
  34. }
  35. type RetryableWriter struct {
  36. writer SegmentWriter
  37. }
  38. func NewRetryableWriter(writer SegmentWriter) SegmentWriter {
  39. return &RetryableWriter{
  40. writer: writer,
  41. }
  42. }
  43. func (w *RetryableWriter) Write(seg Segment) error {
  44. return retry.Timed(5, 100).On(func() error {
  45. return w.writer.Write(seg)
  46. })
  47. }
  48. func (w *RetryableWriter) Release() {
  49. w.writer.Release()
  50. }