diff options
author | Luca Barbato <lu_zero@gentoo.org> | 2013-09-19 01:49:41 +0200 |
---|---|---|
committer | Luca Barbato <lu_zero@gentoo.org> | 2013-09-19 09:13:04 +0200 |
commit | ae0f316a4778e473d407cffa8392595ba0735153 (patch) | |
tree | ba14cb20fca6466eb7e1b7d12538f96e6e1e338a /libavformat/rtmpproto.c | |
parent | 1914e6f010b3320025c7b692aaea51d9b9a992a8 (diff) | |
download | ffmpeg-ae0f316a4778e473d407cffa8392595ba0735153.tar.gz |
rtmp: Unbreak handle_notify
Commit 5626f994f273af80fb100d4743b963304de9e05c broke it.
Diffstat (limited to 'libavformat/rtmpproto.c')
-rw-r--r-- | libavformat/rtmpproto.c | 27 |
1 files changed, 14 insertions, 13 deletions
diff --git a/libavformat/rtmpproto.c b/libavformat/rtmpproto.c index 4cf0f0c75f..e404d60ca4 100644 --- a/libavformat/rtmpproto.c +++ b/libavformat/rtmpproto.c @@ -2070,7 +2070,7 @@ static int handle_notify(URLContext *s, RTMPPacket *pkt) { GetByteContext gbc; PutByteContext pbc; uint32_t ts; - int old_flv_size; + int old_flv_size, err; const uint8_t *datatowrite; unsigned datatowritelength; @@ -2098,22 +2098,23 @@ static int handle_notify(URLContext *s, RTMPPacket *pkt) { old_flv_size = rt->flv_size; rt->flv_size += datatowritelength + 15; } else { - int err; old_flv_size = 0; rt->flv_size = datatowritelength + 15; rt->flv_off = 0; - if ((err = av_reallocp(&rt->flv_data, rt->flv_size)) < 0) - return err; - bytestream2_init_writer(&pbc, rt->flv_data, rt->flv_size); - bytestream2_skip_p(&pbc, old_flv_size); - bytestream2_put_byte(&pbc, pkt->type); - bytestream2_put_be24(&pbc, datatowritelength); - bytestream2_put_be24(&pbc, ts); - bytestream2_put_byte(&pbc, ts >> 24); - bytestream2_put_be24(&pbc, 0); - bytestream2_put_buffer(&pbc, datatowrite, datatowritelength); - bytestream2_put_be32(&pbc, 0); } + + if ((err = av_reallocp(&rt->flv_data, rt->flv_size)) < 0) + return err; + bytestream2_init_writer(&pbc, rt->flv_data, rt->flv_size); + bytestream2_skip_p(&pbc, old_flv_size); + bytestream2_put_byte(&pbc, pkt->type); + bytestream2_put_be24(&pbc, datatowritelength); + bytestream2_put_be24(&pbc, ts); + bytestream2_put_byte(&pbc, ts >> 24); + bytestream2_put_be24(&pbc, 0); + bytestream2_put_buffer(&pbc, datatowrite, datatowritelength); + bytestream2_put_be32(&pbc, 0); + return 0; } |