-
Notifications
You must be signed in to change notification settings - Fork 0
/
writer_output.go
68 lines (55 loc) · 1.01 KB
/
writer_output.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
package output
import (
"io"
"sync"
)
type writerOutput struct {
writer io.Writer
// Mutable.
mu sync.Mutex
stop chan struct{}
}
func NewWriterOutput(writer io.Writer) RtcmOutput {
return &writerOutput{
writer: writer,
}
}
func (o *writerOutput) Stream(input <-chan []byte) error {
// We need to lock if there are multiple Stream
// calls simultaneously.
o.mu.Lock()
defer o.mu.Unlock()
// First release the current continuous streaming if there is one
if o.stop != nil {
o.stop <- struct{}{}
o.stop = nil
}
o.stop = make(chan struct{})
go func(s <-chan struct{}) {
for {
select {
case <-s:
return
case data := <-input:
o.writer.Write(data)
}
}
}(o.stop)
return nil
}
func (o *writerOutput) Close() error {
o.mu.Lock()
defer o.mu.Unlock()
if o.stop != nil {
o.stop <- struct{}{}
o.stop = nil
}
if o.writer != nil {
oldWriter := o.writer
o.writer = nil
if writerCloser, ok := oldWriter.(io.WriteCloser); ok {
return writerCloser.Close()
}
}
return nil
}