Documentation ¶
Overview ¶
Package decoder provides several decoders for differently encoded trice streams.
Example (Rub4) ¶
TestTableMode = true lut := make(id.TriceIDLookUp) m := new(sync.RWMutex) msg.OnErr(lut.FromJSON([]byte(til))) lut.AddFmtCount() buf := make([]byte, defaultSize) dec := NewFlexDecoder(lut, m, nil, littleEndian) // p is a new decoder instance table := testTable{ {[]byte{1, 124, 227, 255, 0, 0, 4, 0}, `MSG: triceFifoMaxDepth = 4, select = 0`}, {[]byte{2, 239, 245, 135, 224, 255, 31, 0, 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, 0}, ` !"#$%&'()*+,-./0123456789:;<=>`}, } for _, x := range table { in := ioutil.NopCloser(bytes.NewBuffer(x.in)) dec.setInput(in) var err error var n int var act string for nil == err { n, err = dec.Read(buf) if io.EOF == err && 0 == n { break } a := fmt.Sprint(string(buf[:n])) if emitter.SyncPacketPattern != a { act += a // ignore sync packets } } fmt.Println(act + "},") testTableVirgin = true }
Output: { []byte{ 1,124,227,255, 0, 0, 4, 0,MSG: triceFifoMaxDepth = 4, select = 0\n}, { []byte{ 2,239,245,135,224,255, 31, 0, 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, 0, !"#$%&'()*+,-./0123456789:;<=>\n},
Index ¶
Examples ¶
Constants ¶
This section is empty.
Variables ¶
var ( // Verbose gives mor information on output if set. The value is injected from main packages. Verbose bool // ShowID is used as format string for displaying the first trice ID at the start of each line if not "". ShowID string // LastTriceID is last decoded ID. It is used for switch -showID. LastTriceID id.TriceID // Encoding describes the way the byte stream is coded. Encoding string // TestTableMode is a special option for easy decoder test table generation. TestTableMode bool // UnsignedHex if true, forces hex and in values printed as unsigned values. UnsignedHex bool )
Functions ¶
func Translate ¶
func Translate(sw *emitter.TriceLineComposer, lut id.TriceIDLookUp, m *sync.RWMutex, rc io.ReadCloser) error
Translate performs the trice log task. Bytes are read with rc. Then according decoder.Encoding they are translated into strings. Each read returns the amount of bytes for one trice. rc is called on every Translate returns true on io.EOF or false on hard read error or sigterm.
Types ¶
type Decoder ¶
Decoder is providing a byte reader returning decoded trice's. setInput allows switching the input stream to a different source.
func NewEscDecoder ¶ added in v0.18.4
NewEscDecoder provides an EscDecoder instance. l is the trice id list in slice of struct format. in is the usable reader for the input bytes.
func NewFlexDecoder ¶ added in v0.21.0
NewFlexDecoder provides an decoder instance. l is the trice id list in slice of struct format. in is the usable reader for the input bytes. littleEndian is false on normal network order.
type Esc ¶
type Esc struct {
// contains filtered or unexported fields
}
Esc is the Decoding instance for esc encoded trices.
func (*Esc) Read ¶ added in v0.18.4
Read is the provided read method for esc decoding of next string as byte slice. It uses inner reader p.in and internal id look-up table to fill b with a string. b is a slice of bytes with a len for the max expected string size. n is the count of read bytes inside b. Read returns one trice string or nothing.
type Flex ¶ added in v0.21.0
type Flex struct {
// contains filtered or unexported fields
}
Flex is the Decoding instance for bare encoded trices.
func (*Flex) Read ¶ added in v0.21.0
Read is the provided read method for flex decoding of next string as byte slice. It uses inner reader p.in and internal id look-up table to fill b with a string. b is a slice of bytes with a len for the max expected string size. n is the count of read bytes inside b. Read returns one trice string (optionally starting wth a channel specifier). A line can contain several trice strings.