summaryrefslogtreecommitdiffstats
path: root/vendor/github.com/francoispqt/gojay/encode_stream_pool.go
blob: 3bb8b1af0659dd93acec7819d0abb63d08bd00ae (plain) (blame)
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
package gojay

import (
	"io"
	"sync"
)

// NewEncoder returns a new StreamEncoder.
// It takes an io.Writer implementation to output data.
// It initiates the done channel returned by Done().
func (s stream) NewEncoder(w io.Writer) *StreamEncoder {
	enc := BorrowEncoder(w)
	return &StreamEncoder{Encoder: enc, nConsumer: 1, done: make(chan struct{}, 1), mux: &sync.RWMutex{}}
}

// BorrowEncoder borrows a StreamEncoder from the pool.
// It takes an io.Writer implementation to output data.
// It initiates the done channel returned by Done().
//
// If no StreamEncoder is available in the pool, it returns a fresh one
func (s stream) BorrowEncoder(w io.Writer) *StreamEncoder {
	streamEnc := streamEncPool.Get().(*StreamEncoder)
	streamEnc.w = w
	streamEnc.Encoder.err = nil
	streamEnc.done = make(chan struct{}, 1)
	streamEnc.Encoder.buf = streamEnc.buf[:0]
	streamEnc.nConsumer = 1
	streamEnc.isPooled = 0
	return streamEnc
}

func (s stream) borrowEncoder(w io.Writer) *StreamEncoder {
	streamEnc := streamEncPool.Get().(*StreamEncoder)
	streamEnc.isPooled = 0
	streamEnc.w = w
	streamEnc.Encoder.err = nil
	return streamEnc
}