1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253 |
- package conn
- import (
- "errors"
- "io"
- "github.com/golang/snappy"
- )
- type SnappyConn struct {
- w *snappy.Writer
- r *snappy.Reader
- c io.Closer
- }
- func NewSnappyConn(conn io.ReadWriteCloser) *SnappyConn {
- c := new(SnappyConn)
- c.w = snappy.NewBufferedWriter(conn)
- c.r = snappy.NewReader(conn)
- c.c = conn.(io.Closer)
- return c
- }
- //snappy压缩写
- func (s *SnappyConn) Write(b []byte) (n int, err error) {
- if n, err = s.w.Write(b); err != nil {
- return
- }
- if err = s.w.Flush(); err != nil {
- return
- }
- return
- }
- //snappy压缩读
- func (s *SnappyConn) Read(b []byte) (n int, err error) {
- return s.r.Read(b)
- }
- func (s *SnappyConn) Close() error {
- err := s.w.Close()
- err2 := s.c.Close()
- if err != nil && err2 == nil {
- return err
- }
- if err == nil && err2 != nil {
- return err2
- }
- if err != nil && err2 != nil {
- return errors.New(err.Error() + err2.Error())
- }
- return nil
- }
|