snappy.go 934 B

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. package conn
  2. import (
  3. "github.com/cnlh/nps/lib/pool"
  4. "github.com/cnlh/nps/lib/rate"
  5. "github.com/cnlh/nps/vender/github.com/golang/snappy"
  6. "net"
  7. )
  8. type SnappyConn struct {
  9. w *snappy.Writer
  10. r *snappy.Reader
  11. rate *rate.Rate
  12. }
  13. func NewSnappyConn(conn net.Conn, crypt bool, rate *rate.Rate) *SnappyConn {
  14. c := new(SnappyConn)
  15. c.w = snappy.NewBufferedWriter(conn)
  16. c.r = snappy.NewReader(conn)
  17. c.rate = rate
  18. return c
  19. }
  20. //snappy压缩写
  21. func (s *SnappyConn) Write(b []byte) (n int, err error) {
  22. if n, err = s.w.Write(b); err != nil {
  23. return
  24. }
  25. if err = s.w.Flush(); err != nil {
  26. return
  27. }
  28. if s.rate != nil {
  29. s.rate.Get(int64(n))
  30. }
  31. return
  32. }
  33. //snappy压缩读
  34. func (s *SnappyConn) Read(b []byte) (n int, err error) {
  35. buf := pool.BufPool.Get().([]byte)
  36. defer pool.BufPool.Put(buf)
  37. if n, err = s.r.Read(buf); err != nil {
  38. return
  39. }
  40. copy(b, buf[:n])
  41. if s.rate != nil {
  42. s.rate.Get(int64(n))
  43. }
  44. return
  45. }