mirror of
https://github.com/aler9/gortsplib
synced 2025-10-05 15:16:51 +08:00
deprecate rtpav1.Decoder.Decode, rtph264.Decoder.Decode, rtph265.Decoder.Decode
This commit is contained in:
@@ -101,7 +101,7 @@ func main() {
|
|||||||
saveCount := 0
|
saveCount := 0
|
||||||
c.OnPacketRTP(medi, forma, func(pkt *rtp.Packet) {
|
c.OnPacketRTP(medi, forma, func(pkt *rtp.Packet) {
|
||||||
// extract access units from RTP packets
|
// extract access units from RTP packets
|
||||||
au, _, err := rtpDec.Decode(pkt)
|
au, _, err := rtpDec.DecodeUntilMarker(pkt)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if err != rtph264.ErrNonStartingPacketAndNoPrevious && err != rtph264.ErrMorePacketsNeeded {
|
if err != rtph264.ErrNonStartingPacketAndNoPrevious && err != rtph264.ErrMorePacketsNeeded {
|
||||||
log.Printf("ERR: %v", err)
|
log.Printf("ERR: %v", err)
|
||||||
|
@@ -65,7 +65,6 @@ func main() {
|
|||||||
// called when a RTP packet arrives
|
// called when a RTP packet arrives
|
||||||
c.OnPacketRTP(medi, forma, func(pkt *rtp.Packet) {
|
c.OnPacketRTP(medi, forma, func(pkt *rtp.Packet) {
|
||||||
// extract access unit from RTP packets
|
// extract access unit from RTP packets
|
||||||
// DecodeUntilMarker is necessary for the DTS extractor to work
|
|
||||||
au, pts, err := rtpDec.DecodeUntilMarker(pkt)
|
au, pts, err := rtpDec.DecodeUntilMarker(pkt)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if err != rtph264.ErrNonStartingPacketAndNoPrevious && err != rtph264.ErrMorePacketsNeeded {
|
if err != rtph264.ErrNonStartingPacketAndNoPrevious && err != rtph264.ErrMorePacketsNeeded {
|
||||||
|
@@ -77,7 +77,7 @@ func main() {
|
|||||||
// called when a RTP packet arrives
|
// called when a RTP packet arrives
|
||||||
c.OnPacketRTP(medi, forma, func(pkt *rtp.Packet) {
|
c.OnPacketRTP(medi, forma, func(pkt *rtp.Packet) {
|
||||||
// extract access units from RTP packets
|
// extract access units from RTP packets
|
||||||
au, pts, err := rtpDec.Decode(pkt)
|
au, pts, err := rtpDec.DecodeUntilMarker(pkt)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if err != rtph264.ErrNonStartingPacketAndNoPrevious && err != rtph264.ErrMorePacketsNeeded {
|
if err != rtph264.ErrNonStartingPacketAndNoPrevious && err != rtph264.ErrMorePacketsNeeded {
|
||||||
log.Printf("ERR: %v", err)
|
log.Printf("ERR: %v", err)
|
||||||
|
@@ -59,7 +59,7 @@ func main() {
|
|||||||
// called when a RTP packet arrives
|
// called when a RTP packet arrives
|
||||||
c.OnPacketRTP(medi, forma, func(pkt *rtp.Packet) {
|
c.OnPacketRTP(medi, forma, func(pkt *rtp.Packet) {
|
||||||
// extract access units from RTP packets
|
// extract access units from RTP packets
|
||||||
au, pts, err := rtpDec.Decode(pkt)
|
au, pts, err := rtpDec.DecodeUntilMarker(pkt)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if err != rtph265.ErrNonStartingPacketAndNoPrevious && err != rtph265.ErrMorePacketsNeeded {
|
if err != rtph265.ErrNonStartingPacketAndNoPrevious && err != rtph265.ErrMorePacketsNeeded {
|
||||||
log.Printf("ERR: %v", err)
|
log.Printf("ERR: %v", err)
|
||||||
|
@@ -29,7 +29,7 @@ func TestAV1DecEncoder(t *testing.T) {
|
|||||||
dec, err := format.CreateDecoder2()
|
dec, err := format.CreateDecoder2()
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
byts, _, err := dec.Decode(pkts[0])
|
byts, _, err := dec.DecodeUntilMarker(pkts[0])
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.Equal(t, [][]byte{{0x01, 0x02, 0x03, 0x04}}, byts)
|
require.Equal(t, [][]byte{{0x01, 0x02, 0x03, 0x04}}, byts)
|
||||||
}
|
}
|
||||||
|
@@ -57,7 +57,7 @@ func TestH264DecEncoder(t *testing.T) {
|
|||||||
dec, err := format.CreateDecoder2()
|
dec, err := format.CreateDecoder2()
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
byts, _, err := dec.Decode(pkts[0])
|
byts, _, err := dec.DecodeUntilMarker(pkts[0])
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.Equal(t, [][]byte{{0x01, 0x02, 0x03, 0x04}}, byts)
|
require.Equal(t, [][]byte{{0x01, 0x02, 0x03, 0x04}}, byts)
|
||||||
}
|
}
|
||||||
|
@@ -60,7 +60,7 @@ func TestH265DecEncoder(t *testing.T) {
|
|||||||
dec, err := format.CreateDecoder2()
|
dec, err := format.CreateDecoder2()
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
byts, _, err := dec.Decode(pkts[0])
|
byts, _, err := dec.DecodeUntilMarker(pkts[0])
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.Equal(t, [][]byte{{0x01, 0x02, 0x03, 0x04}}, byts)
|
require.Equal(t, [][]byte{{0x01, 0x02, 0x03, 0x04}}, byts)
|
||||||
}
|
}
|
||||||
|
@@ -52,7 +52,13 @@ func (d *Decoder) Init() error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Decode decodes OBUs from a RTP packet.
|
// Decode decodes OBUs from a RTP packet.
|
||||||
|
//
|
||||||
|
// Deprecated: this method returns incomplete temporal units.
|
||||||
func (d *Decoder) Decode(pkt *rtp.Packet) ([][]byte, time.Duration, error) {
|
func (d *Decoder) Decode(pkt *rtp.Packet) ([][]byte, time.Duration, error) {
|
||||||
|
return d.decodeOBUs(pkt)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (d *Decoder) decodeOBUs(pkt *rtp.Packet) ([][]byte, time.Duration, error) {
|
||||||
var av1header codecs.AV1Packet
|
var av1header codecs.AV1Packet
|
||||||
_, err := av1header.Unmarshal(pkt.Payload)
|
_, err := av1header.Unmarshal(pkt.Payload)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@@ -126,11 +132,9 @@ func (d *Decoder) Decode(pkt *rtp.Packet) ([][]byte, time.Duration, error) {
|
|||||||
return obus, d.timeDecoder.Decode(pkt.Timestamp), nil
|
return obus, d.timeDecoder.Decode(pkt.Timestamp), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// DecodeUntilMarker decodes OBUs from a RTP packet and puts them in a buffer.
|
// DecodeUntilMarker decodes a temporal unit from a RTP packet.
|
||||||
// When a packet has the marker flag (meaning that all OBUs with the same PTS have
|
|
||||||
// been received), the buffer is returned.
|
|
||||||
func (d *Decoder) DecodeUntilMarker(pkt *rtp.Packet) ([][]byte, time.Duration, error) {
|
func (d *Decoder) DecodeUntilMarker(pkt *rtp.Packet) ([][]byte, time.Duration, error) {
|
||||||
obus, pts, err := d.Decode(pkt)
|
obus, pts, err := d.decodeOBUs(pkt)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, 0, err
|
return nil, 0, err
|
||||||
}
|
}
|
||||||
|
@@ -18,7 +18,7 @@ func TestDecode(t *testing.T) {
|
|||||||
var obus [][]byte
|
var obus [][]byte
|
||||||
|
|
||||||
for _, pkt := range ca.pkts {
|
for _, pkt := range ca.pkts {
|
||||||
addOBUs, _, err := d.Decode(pkt)
|
addOBUs, _, err := d.DecodeUntilMarker(pkt)
|
||||||
if err == ErrMorePacketsNeeded {
|
if err == ErrMorePacketsNeeded {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
@@ -59,7 +59,7 @@ func FuzzDecoder(f *testing.F) {
|
|||||||
d := &Decoder{}
|
d := &Decoder{}
|
||||||
d.Init() //nolint:errcheck
|
d.Init() //nolint:errcheck
|
||||||
|
|
||||||
d.Decode(&rtp.Packet{ //nolint:errcheck
|
d.DecodeUntilMarker(&rtp.Packet{ //nolint:errcheck
|
||||||
Header: rtp.Header{
|
Header: rtp.Header{
|
||||||
Version: 2,
|
Version: 2,
|
||||||
Marker: am,
|
Marker: am,
|
||||||
@@ -71,7 +71,7 @@ func FuzzDecoder(f *testing.F) {
|
|||||||
Payload: a,
|
Payload: a,
|
||||||
})
|
})
|
||||||
|
|
||||||
d.Decode(&rtp.Packet{ //nolint:errcheck
|
d.DecodeUntilMarker(&rtp.Packet{ //nolint:errcheck
|
||||||
Header: rtp.Header{
|
Header: rtp.Header{
|
||||||
Version: 2,
|
Version: 2,
|
||||||
Marker: bm,
|
Marker: bm,
|
||||||
|
@@ -60,7 +60,13 @@ func (d *Decoder) Init() error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Decode decodes NALUs from a RTP packet.
|
// Decode decodes NALUs from a RTP packet.
|
||||||
|
//
|
||||||
|
// Deprecated: this method returns incomplete access units.
|
||||||
func (d *Decoder) Decode(pkt *rtp.Packet) ([][]byte, time.Duration, error) {
|
func (d *Decoder) Decode(pkt *rtp.Packet) ([][]byte, time.Duration, error) {
|
||||||
|
return d.decodeNALUs(pkt)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (d *Decoder) decodeNALUs(pkt *rtp.Packet) ([][]byte, time.Duration, error) {
|
||||||
if len(pkt.Payload) < 1 {
|
if len(pkt.Payload) < 1 {
|
||||||
d.fragments = d.fragments[:0] // discard pending fragments
|
d.fragments = d.fragments[:0] // discard pending fragments
|
||||||
return nil, 0, fmt.Errorf("payload is too short")
|
return nil, 0, fmt.Errorf("payload is too short")
|
||||||
@@ -170,11 +176,9 @@ func (d *Decoder) Decode(pkt *rtp.Packet) ([][]byte, time.Duration, error) {
|
|||||||
return nalus, d.timeDecoder.Decode(pkt.Timestamp), nil
|
return nalus, d.timeDecoder.Decode(pkt.Timestamp), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// DecodeUntilMarker decodes NALUs from a RTP packet and puts them in a buffer.
|
// DecodeUntilMarker decodes an access unit from a RTP packet.
|
||||||
// When a packet has the marker flag (meaning that all the NALUs with the same PTS have
|
|
||||||
// been received), the buffer is returned.
|
|
||||||
func (d *Decoder) DecodeUntilMarker(pkt *rtp.Packet) ([][]byte, time.Duration, error) {
|
func (d *Decoder) DecodeUntilMarker(pkt *rtp.Packet) ([][]byte, time.Duration, error) {
|
||||||
nalus, pts, err := d.Decode(pkt)
|
nalus, pts, err := d.decodeNALUs(pkt)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, 0, err
|
return nil, 0, err
|
||||||
}
|
}
|
||||||
|
@@ -21,7 +21,7 @@ func TestDecode(t *testing.T) {
|
|||||||
for _, pkt := range ca.pkts {
|
for _, pkt := range ca.pkts {
|
||||||
clone := pkt.Clone()
|
clone := pkt.Clone()
|
||||||
|
|
||||||
addNALUs, _, err := d.Decode(pkt)
|
addNALUs, _, err := d.DecodeUntilMarker(pkt)
|
||||||
|
|
||||||
// test input integrity
|
// test input integrity
|
||||||
require.Equal(t, clone, pkt)
|
require.Equal(t, clone, pkt)
|
||||||
@@ -44,10 +44,10 @@ func TestDecodeCorruptedFragment(t *testing.T) {
|
|||||||
err := d.Init()
|
err := d.Init()
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
_, _, err = d.Decode(&rtp.Packet{
|
_, _, err = d.DecodeUntilMarker(&rtp.Packet{
|
||||||
Header: rtp.Header{
|
Header: rtp.Header{
|
||||||
Version: 2,
|
Version: 2,
|
||||||
Marker: false,
|
Marker: true,
|
||||||
PayloadType: 96,
|
PayloadType: 96,
|
||||||
SequenceNumber: 17645,
|
SequenceNumber: 17645,
|
||||||
Timestamp: 2289527317,
|
Timestamp: 2289527317,
|
||||||
@@ -63,10 +63,10 @@ func TestDecodeCorruptedFragment(t *testing.T) {
|
|||||||
})
|
})
|
||||||
require.Equal(t, ErrMorePacketsNeeded, err)
|
require.Equal(t, ErrMorePacketsNeeded, err)
|
||||||
|
|
||||||
nalus, _, err := d.Decode(&rtp.Packet{
|
nalus, _, err := d.DecodeUntilMarker(&rtp.Packet{
|
||||||
Header: rtp.Header{
|
Header: rtp.Header{
|
||||||
Version: 2,
|
Version: 2,
|
||||||
Marker: false,
|
Marker: true,
|
||||||
PayloadType: 96,
|
PayloadType: 96,
|
||||||
SequenceNumber: 17646,
|
SequenceNumber: 17646,
|
||||||
Timestamp: 2289527317,
|
Timestamp: 2289527317,
|
||||||
@@ -100,7 +100,7 @@ func TestDecodeSTAPAWithPadding(t *testing.T) {
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
nalus, _, err := d.Decode(&pkt)
|
nalus, _, err := d.DecodeUntilMarker(&pkt)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.Equal(t, [][]byte{
|
require.Equal(t, [][]byte{
|
||||||
{0xaa, 0xbb},
|
{0xaa, 0xbb},
|
||||||
@@ -113,7 +113,7 @@ func TestDecodeAnnexB(t *testing.T) {
|
|||||||
err := d.Init()
|
err := d.Init()
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
nalus, _, err := d.Decode(&rtp.Packet{
|
nalus, _, err := d.DecodeUntilMarker(&rtp.Packet{
|
||||||
Header: rtp.Header{
|
Header: rtp.Header{
|
||||||
Version: 2,
|
Version: 2,
|
||||||
Marker: true,
|
Marker: true,
|
||||||
@@ -132,7 +132,7 @@ func TestDecodeAnnexB(t *testing.T) {
|
|||||||
}, nalus)
|
}, nalus)
|
||||||
|
|
||||||
for i := 0; i < 2; i++ {
|
for i := 0; i < 2; i++ {
|
||||||
nalus, _, err := d.Decode(&rtp.Packet{
|
nalus, _, err := d.DecodeUntilMarker(&rtp.Packet{
|
||||||
Header: rtp.Header{
|
Header: rtp.Header{
|
||||||
Version: 2,
|
Version: 2,
|
||||||
Marker: true,
|
Marker: true,
|
||||||
@@ -217,7 +217,7 @@ func FuzzDecoder(f *testing.F) {
|
|||||||
d := &Decoder{}
|
d := &Decoder{}
|
||||||
d.Init() //nolint:errcheck
|
d.Init() //nolint:errcheck
|
||||||
|
|
||||||
d.Decode(&rtp.Packet{ //nolint:errcheck
|
d.DecodeUntilMarker(&rtp.Packet{ //nolint:errcheck
|
||||||
Header: rtp.Header{
|
Header: rtp.Header{
|
||||||
Version: 2,
|
Version: 2,
|
||||||
Marker: false,
|
Marker: false,
|
||||||
@@ -229,7 +229,7 @@ func FuzzDecoder(f *testing.F) {
|
|||||||
Payload: a,
|
Payload: a,
|
||||||
})
|
})
|
||||||
|
|
||||||
d.Decode(&rtp.Packet{ //nolint:errcheck
|
d.DecodeUntilMarker(&rtp.Packet{ //nolint:errcheck
|
||||||
Header: rtp.Header{
|
Header: rtp.Header{
|
||||||
Version: 2,
|
Version: 2,
|
||||||
Marker: false,
|
Marker: false,
|
||||||
|
@@ -58,7 +58,13 @@ func (d *Decoder) Init() error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Decode decodes NALUs from a RTP packet.
|
// Decode decodes NALUs from a RTP packet.
|
||||||
|
//
|
||||||
|
// Deprecated: this method returns incomplete access units.
|
||||||
func (d *Decoder) Decode(pkt *rtp.Packet) ([][]byte, time.Duration, error) {
|
func (d *Decoder) Decode(pkt *rtp.Packet) ([][]byte, time.Duration, error) {
|
||||||
|
return d.decodeNALUs(pkt)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (d *Decoder) decodeNALUs(pkt *rtp.Packet) ([][]byte, time.Duration, error) {
|
||||||
if len(pkt.Payload) < 2 {
|
if len(pkt.Payload) < 2 {
|
||||||
d.fragments = d.fragments[:0] // discard pending fragments
|
d.fragments = d.fragments[:0] // discard pending fragments
|
||||||
return nil, 0, fmt.Errorf("payload is too short")
|
return nil, 0, fmt.Errorf("payload is too short")
|
||||||
@@ -161,11 +167,9 @@ func (d *Decoder) Decode(pkt *rtp.Packet) ([][]byte, time.Duration, error) {
|
|||||||
return nalus, d.timeDecoder.Decode(pkt.Timestamp), nil
|
return nalus, d.timeDecoder.Decode(pkt.Timestamp), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// DecodeUntilMarker decodes NALUs from a RTP packet and puts them in a buffer.
|
// DecodeUntilMarker decodes an access unit from a RTP packet.
|
||||||
// When a packet has the marker flag (meaning that all the NALUs with the same PTS have
|
|
||||||
// been received), the buffer is returned.
|
|
||||||
func (d *Decoder) DecodeUntilMarker(pkt *rtp.Packet) ([][]byte, time.Duration, error) {
|
func (d *Decoder) DecodeUntilMarker(pkt *rtp.Packet) ([][]byte, time.Duration, error) {
|
||||||
nalus, pts, err := d.Decode(pkt)
|
nalus, pts, err := d.decodeNALUs(pkt)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, 0, err
|
return nil, 0, err
|
||||||
}
|
}
|
||||||
|
@@ -20,7 +20,7 @@ func TestDecode(t *testing.T) {
|
|||||||
for _, pkt := range ca.pkts {
|
for _, pkt := range ca.pkts {
|
||||||
clone := pkt.Clone()
|
clone := pkt.Clone()
|
||||||
|
|
||||||
addNALUs, _, err := d.Decode(pkt)
|
addNALUs, _, err := d.DecodeUntilMarker(pkt)
|
||||||
|
|
||||||
// test input integrity
|
// test input integrity
|
||||||
require.Equal(t, clone, pkt)
|
require.Equal(t, clone, pkt)
|
||||||
@@ -65,7 +65,7 @@ func FuzzDecoder(f *testing.F) {
|
|||||||
d := &Decoder{}
|
d := &Decoder{}
|
||||||
d.Init() //nolint:errcheck
|
d.Init() //nolint:errcheck
|
||||||
|
|
||||||
d.Decode(&rtp.Packet{ //nolint:errcheck
|
d.DecodeUntilMarker(&rtp.Packet{ //nolint:errcheck
|
||||||
Header: rtp.Header{
|
Header: rtp.Header{
|
||||||
Version: 2,
|
Version: 2,
|
||||||
Marker: false,
|
Marker: false,
|
||||||
@@ -77,7 +77,7 @@ func FuzzDecoder(f *testing.F) {
|
|||||||
Payload: a,
|
Payload: a,
|
||||||
})
|
})
|
||||||
|
|
||||||
d.Decode(&rtp.Packet{ //nolint:errcheck
|
d.DecodeUntilMarker(&rtp.Packet{ //nolint:errcheck
|
||||||
Header: rtp.Header{
|
Header: rtp.Header{
|
||||||
Version: 2,
|
Version: 2,
|
||||||
Marker: false,
|
Marker: false,
|
||||||
|
Reference in New Issue
Block a user