Loop through input capses instead of just picking the first, and handle encoding errors

Original commit message from CVS:
Loop through input capses instead of just picking the first, and handle encoding errors
This commit is contained in:
Ronald S. Bultje 2003-06-07 21:06:05 +00:00
parent 49b22bcee6
commit 40deef896e

View file

@ -284,11 +284,6 @@ gst_ffmpegenc_connect (GstPad *pad,
ffmpegenc->context->qmax = 15; ffmpegenc->context->qmax = 15;
ffmpegenc->context->max_qdiff = 3; ffmpegenc->context->max_qdiff = 3;
/* fill in the context (width/height/pixfmt or
* rate/channels/samplefmt) */
gst_ffmpeg_caps_to_codectype (oclass->in_plugin->type,
caps, ffmpegenc->context);
/* no edges */ /* no edges */
ffmpegenc->context->flags |= CODEC_FLAG_EMU_EDGE; ffmpegenc->context->flags |= CODEC_FLAG_EMU_EDGE;
@ -298,11 +293,23 @@ gst_ffmpegenc_connect (GstPad *pad,
ffmpegenc->context->frame_rate = 25 * DEFAULT_FRAME_RATE_BASE; ffmpegenc->context->frame_rate = 25 * DEFAULT_FRAME_RATE_BASE;
ffmpegenc->context->frame_rate_base = DEFAULT_FRAME_RATE_BASE; ffmpegenc->context->frame_rate_base = DEFAULT_FRAME_RATE_BASE;
/* open codec */ for (ret_caps = caps; ret_caps != NULL; ret_caps = ret_caps->next) {
if (avcodec_open (ffmpegenc->context, oclass->in_plugin) < 0) { /* fetch pix_fmt and so on */
GST_DEBUG (GST_CAT_PLUGIN_INFO, gst_ffmpeg_caps_to_codectype (oclass->in_plugin->type,
"ffenc_%s: Failed to open FFMPEG codec", caps, ffmpegenc->context);
oclass->in_plugin->name);
/* open codec */
if (avcodec_open (ffmpegenc->context, oclass->in_plugin) < 0) {
GST_DEBUG (GST_CAT_PLUGIN_INFO,
"ffenc_%s: Failed to open FFMPEG codec",
oclass->in_plugin->name);
continue;
}
break;
}
if (ret_caps == NULL) {
return GST_PAD_LINK_REFUSED; return GST_PAD_LINK_REFUSED;
} }
@ -375,6 +382,13 @@ gst_ffmpegenc_chain (GstPad *pad,
break; break;
} }
if (ret_size < 0) {
g_warning("ffenc_%s: failed to encode buffer",
oclass->in_plugin->name);
gst_buffer_unref (inbuf);
return;
}
/* bla */ /* bla */
GST_BUFFER_SIZE (outbuf) = ret_size; GST_BUFFER_SIZE (outbuf) = ret_size;
GST_BUFFER_TIMESTAMP (outbuf) = GST_BUFFER_TIMESTAMP (inbuf); GST_BUFFER_TIMESTAMP (outbuf) = GST_BUFFER_TIMESTAMP (inbuf);