1
0

snappy.go 890 B

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. package conn
  2. import (
  3. "errors"
  4. "io"
  5. "github.com/golang/snappy"
  6. )
  7. type SnappyConn struct {
  8. w *snappy.Writer
  9. r *snappy.Reader
  10. c io.Closer
  11. }
  12. func NewSnappyConn(conn io.ReadWriteCloser) *SnappyConn {
  13. c := new(SnappyConn)
  14. c.w = snappy.NewBufferedWriter(conn)
  15. c.r = snappy.NewReader(conn)
  16. c.c = conn.(io.Closer)
  17. return c
  18. }
  19. //snappy压缩写
  20. func (s *SnappyConn) Write(b []byte) (n int, err error) {
  21. if n, err = s.w.Write(b); err != nil {
  22. return
  23. }
  24. if err = s.w.Flush(); err != nil {
  25. return
  26. }
  27. return
  28. }
  29. //snappy压缩读
  30. func (s *SnappyConn) Read(b []byte) (n int, err error) {
  31. return s.r.Read(b)
  32. }
  33. func (s *SnappyConn) Close() error {
  34. err := s.w.Close()
  35. err2 := s.c.Close()
  36. if err != nil && err2 == nil {
  37. return err
  38. }
  39. if err == nil && err2 != nil {
  40. return err2
  41. }
  42. if err != nil && err2 != nil {
  43. return errors.New(err.Error() + err2.Error())
  44. }
  45. return nil
  46. }