diff options
author | Diego Biurrun <diego@biurrun.de> | 2013-07-31 23:56:26 +0200 |
---|---|---|
committer | Diego Biurrun <diego@biurrun.de> | 2013-08-01 12:43:54 +0200 |
commit | f900f35ac8db4ac30df6fda1c27502c2ef9e6ba5 (patch) | |
tree | eab151d6ad25dda61b3e1859646d44b184c5324b | |
parent | e4529df944616917ae8462f5102253ff7f983093 (diff) | |
download | ffmpeg-f900f35ac8db4ac30df6fda1c27502c2ef9e6ba5.tar.gz |
flvdec: Eliminate completely silly goto
-rw-r--r-- | libavformat/flvdec.c | 18 |
1 files changed, 7 insertions, 11 deletions
diff --git a/libavformat/flvdec.c b/libavformat/flvdec.c index c5e44ce310..11e7be147c 100644 --- a/libavformat/flvdec.c +++ b/libavformat/flvdec.c @@ -636,35 +636,32 @@ static void clear_index_entries(AVFormatContext *s, int64_t pos) static int flv_data_packet(AVFormatContext *s, AVPacket *pkt, int64_t dts, int64_t next) { - int ret = AVERROR_INVALIDDATA, i; AVIOContext *pb = s->pb; AVStream *st = NULL; AMFDataType type; char buf[20]; - int length; + int ret, i, length; type = avio_r8(pb); if (type == AMF_DATA_TYPE_MIXEDARRAY) avio_seek(pb, 4, SEEK_CUR); else if (type != AMF_DATA_TYPE_OBJECT) - goto out; + return AVERROR_INVALIDDATA; amf_get_string(pb, buf, sizeof(buf)); if (strcmp(buf, "type") || avio_r8(pb) != AMF_DATA_TYPE_STRING) - goto out; + return AVERROR_INVALIDDATA; amf_get_string(pb, buf, sizeof(buf)); // FIXME parse it as codec_id amf_get_string(pb, buf, sizeof(buf)); if (strcmp(buf, "text") || avio_r8(pb) != AMF_DATA_TYPE_STRING) - goto out; + return AVERROR_INVALIDDATA; length = avio_rb16(pb); ret = av_get_packet(s->pb, pkt, length); - if (ret < 0) { - ret = AVERROR(EIO); - goto out; - } + if (ret < 0) + return AVERROR(EIO); for (i = 0; i < s->nb_streams; i++) { st = s->streams[i]; @@ -675,7 +672,7 @@ static int flv_data_packet(AVFormatContext *s, AVPacket *pkt, if (i == s->nb_streams) { st = create_stream(s, AVMEDIA_TYPE_DATA); if (!st) - goto out; + return AVERROR_INVALIDDATA; st->codec->codec_id = AV_CODEC_ID_TEXT; } @@ -688,7 +685,6 @@ static int flv_data_packet(AVFormatContext *s, AVPacket *pkt, avio_seek(s->pb, next + 4, SEEK_SET); -out: return ret; } |