-
Notifications
You must be signed in to change notification settings - Fork 3
/
gzip.go
75 lines (59 loc) · 1.39 KB
/
gzip.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
package compress
import (
"io"
"io/ioutil"
"sync"
"github.com/klauspost/compress/gzip"
)
/*
gin-compress Copyright (C) 2022 Aurora McGinnis
This Source Code Form is subject to the terms of the Mozilla Public
License, v. 2.0. If a copy of the MPL was not distributed with this
file, You can obtain one at https://mozilla.org/MPL/2.0/.
*/
type algorithmGzip struct {
compressorPool *sync.Pool
cfg algorithmConfig
}
func (a *algorithmGzip) makeCompressor() interface{} {
gz, err := gzip.NewWriterLevel(ioutil.Discard, a.cfg.compressLevel)
if err != nil {
panic(err)
}
return gz
}
/* Implement algorithm */
func (a *algorithmGzip) getConfig() *algorithmConfig {
return &a.cfg
}
func (a *algorithmGzip) getWriter(w io.Writer) io.WriteCloser {
gw := a.compressorPool.Get().(*gzip.Writer)
gw.Reset(w)
return &wrappedWriter{
p: a.compressorPool,
w: gw,
}
}
func (a *algorithmGzip) getReader(r io.Reader) io.ReadCloser {
// gzip reader implements Reset, but isn't usable with a sync pool
// because it'll panic when you try to construct one with a nil
// reader
gr, err := gzip.NewReader(r)
if err != nil {
panic(err)
}
return gr
}
func newAlgorithmGzip() *algorithmGzip {
a := algorithmGzip{
cfg: algorithmConfig{
priority: 300,
enable: true,
compressLevel: GzFlateDefault,
},
}
a.compressorPool = &sync.Pool{
New: a.makeCompressor,
}
return &a
}