[FFmpeg-cvslog] lavf/gif: simplify streams type checking.
Clément Bœsch
git at videolan.org
Thu Apr 18 13:45:07 CEST 2013
ffmpeg | branch: master | Clément Bœsch <ubitux at gmail.com> | Thu Apr 18 12:19:33 2013 +0200| [28f9858c91ffe43609abf5cb6ee91dafae3517fe] | committer: Clément Bœsch
lavf/gif: simplify streams type checking.
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=28f9858c91ffe43609abf5cb6ee91dafae3517fe
---
libavformat/gif.c | 38 +++++++++++++-------------------------
1 file changed, 13 insertions(+), 25 deletions(-)
diff --git a/libavformat/gif.c b/libavformat/gif.c
index b4a61f5..7a68d31 100644
--- a/libavformat/gif.c
+++ b/libavformat/gif.c
@@ -104,32 +104,23 @@ static int gif_write_header(AVFormatContext *s)
{
GIFContext *gif = s->priv_data;
AVIOContext *pb = s->pb;
- AVCodecContext *enc, *video_enc;
- int i, width, height /*, rate*/;
+ AVCodecContext *video_enc;
+ int width, height;
uint32_t palette[AVPALETTE_COUNT];
-/* XXX: do we reject audio streams or just ignore them ?
- * if (s->nb_streams > 1)
- * return -1;
- */
+ if (s->nb_streams != 1 || !s->streams[0]->codec ||
+ s->streams[0]->codec->codec_type != AVMEDIA_TYPE_VIDEO) {
+ av_log(s, AV_LOG_ERROR,
+ "GIF supports only a single video stream.\n");
+ return AVERROR(EINVAL);
+ }
+
gif->time = 0;
gif->file_time = 0;
- video_enc = NULL;
- for (i = 0; i < s->nb_streams; i++) {
- enc = s->streams[i]->codec;
- if (enc->codec_type != AVMEDIA_TYPE_AUDIO)
- video_enc = enc;
- }
-
- if (!video_enc) {
- av_free(gif);
- return -1;
- } else {
- width = video_enc->width;
- height = video_enc->height;
-// rate = video_enc->time_base.den;
- }
+ video_enc = s->streams[0]->codec;
+ width = video_enc->width;
+ height = video_enc->height;
if (avpriv_set_systematic_pal2(palette, video_enc->pix_fmt) < 0) {
av_assert0(video_enc->pix_fmt == AV_PIX_FMT_PAL8);
@@ -174,10 +165,7 @@ static int gif_write_video(AVFormatContext *s, AVCodecContext *enc,
static int gif_write_packet(AVFormatContext *s, AVPacket *pkt)
{
AVCodecContext *codec = s->streams[pkt->stream_index]->codec;
- if (codec->codec_type == AVMEDIA_TYPE_AUDIO)
- return 0; /* just ignore audio */
- else
- return gif_write_video(s, codec, pkt->data, pkt->size);
+ return gif_write_video(s, codec, pkt->data, pkt->size);
}
static int gif_write_trailer(AVFormatContext *s)
More information about the ffmpeg-cvslog
mailing list