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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
|
package queue
import (
"errors"
"time"
"io"
)
var errTimeout = errors.New("read timeout expired")
type Q chan []byte
type reader struct {
b []byte
q Q
d time.Duration
}
type writer struct {
q Q
}
func New() Q {
return make(Q)
}
func (q Q) Reader() io.Reader {
return &reader{q: q}
}
func (q Q) TimeoutReader(d time.Duration) io.Reader {
return &reader{q: q, d: d}
}
func (r *reader) Read(p []byte) (int, error) {
if len(r.b) == 0 {
if r.d == 0 {
r.b = <-r.q
} else {
t := time.NewTimer(r.d)
select {
case r.b = <-r.q:
t.Stop()
case <-t.C:
return 0, errTimeout
}
}
if r.b == nil {
return 0, io.EOF
}
}
n := copy(p, r.b)
r.b = r.b[n:]
return n, nil
}
func (r *reader) ReadByte() (byte, error) {
var b [1]byte
_, err := r.Read(b[:])
return b[0], err
}
func (r *reader) WriteTo(w io.Writer) (int64, error) {
if writer, ok := w.(*writer); ok {
if len(r.b) > 0 {
writer.q <- r.b
}
return 0, Copy(r.q, writer.q)
}
if len(r.b) > 0 {
if _, err := w.Write(r.b); err != nil {
return 0, err
}
}
for b := range r.q {
if _, err := w.Write(b); err != nil {
return 0, err
}
}
return 0, nil
}
func (q Q) Writer() io.Writer {
return &writer{q: q}
}
func (q Q) Dry() {
for _ = range q {
}
}
func (w *writer) Write(p []byte) (int, error) {
buf := make([]byte, len(p))
copy(buf, p)
w.q <- buf
return len(p), nil
}
func IoCopy(r io.Reader, w io.Writer) error {
if _, err := io.Copy(w, r); err != nil {
if err != io.EOF {
return err
}
}
return nil
}
func Copy(rq, wq Q) error {
for b := range rq {
wq <- b
}
return nil
}
|