File: data.go

package info (click to toggle)
golang-github-inconshreveable-muxado 0.0~git20140312.0.f693c7e-1
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 256 kB
  • ctags: 374
  • sloc: makefile: 2
file content (68 lines) | stat: -rw-r--r-- 1,380 bytes parent folder | download | duplicates (3)
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 frame

import (
	"io"
)

const (
	// data frames are actually longer, but they are variable length
	dataFrameSize = headerSize
)

type RStreamData struct {
	Header
	fixed [dataFrameSize]byte

	toRead io.LimitedReader // when reading, the underlying connection's io.Reader is handed up
}

func (f *RStreamData) Reader() io.Reader {
	return &f.toRead
}

func (f *RStreamData) readFrom(d deserializer) (err error) {
	// not using io.LimitReader to avoid a heap memory allocation in the hot path
	f.toRead.R = d
	f.toRead.N = int64(f.Length())
	return
}

// WStreamData is a StreamData frame that you can write
// It delivers opaque data on a stream to the application layer
type WStreamData struct {
	Header
	fixed   [dataFrameSize]byte
	toWrite []byte // when writing, you just pass a byte slice to write
}

func (f *WStreamData) writeTo(s serializer) (err error) {
	if _, err = s.Write(f.fixed[:]); err != nil {
		return err
	}

	if _, err = s.Write(f.toWrite); err != nil {
		return err
	}

	return
}

func (f *WStreamData) Set(streamId StreamId, data []byte, fin bool) (err error) {
	var flags flagsType
	if fin {
		flags.Set(flagFin)
	}

	if err = f.Header.SetAll(TypeStreamData, len(data), streamId, flags); err != nil {
		return
	}

	f.toWrite = data
	return
}

func NewWStreamData() (f *WStreamData) {
	f = new(WStreamData)
	f.Header = f.fixed[:headerSize]
	return
}