1
1
mirror of https://github.com/wader/fq.git synced 2024-12-26 23:15:04 +03:00
fq/format/mpeg/annexb.go
Mattias Wadman 1b32b42f93 decode: Major decode API refactor
Generate more code
More generic and comfortable API
Improve and Update format decoder to new API
Add some more format tests
2021-11-15 21:12:07 +01:00

48 lines
1.0 KiB
Go

package mpeg
import (
"github.com/wader/fq/pkg/decode"
)
func annexBFindStartCode(d *decode.D) (int64, int64, error) {
offset, v, err := d.TryPeekFind(32, 8, -1, func(v uint64) bool {
return annexBDecodeStartCodeLen(v) > 0
})
return offset, annexBDecodeStartCodeLen(v), err
}
func annexBDecodeStartCodeLen(v uint64) int64 {
switch {
case v == 0x00_00_00_01:
return 4 * 8
case v&0xff_ff_ff_00 == 0x00_00_01_00:
return 3 * 8
default:
return 0
}
}
func annexBDecode(d *decode.D, _ interface{}, format []*decode.Format) interface{} {
currentOffset, currentPrefixLen, err := annexBFindStartCode(d)
// TODO: really restrict to 0?
if err != nil || currentOffset != 0 {
d.Invalid("could not find start code (first)")
}
for d.NotEnd() {
d.FieldRawLen("start_code", currentPrefixLen)
nextOffset, nextPrefixLen, err := annexBFindStartCode(d)
if err != nil {
nextOffset = d.Len() - d.Pos()
}
naluLen := nextOffset
d.FieldFormatLen("nalu", naluLen, format, nil)
currentPrefixLen = nextPrefixLen
}
return nil
}