diff --git a/doc/filters.texi b/doc/filters.texi index daa1b380ac1d41346bd3b957459f5525b2a86426..a7f8a53f360e1e3dd1dc7cb192a688785fdc71c4 100644 --- a/doc/filters.texi +++ b/doc/filters.texi @@ -7154,6 +7154,10 @@ The filter accept the following option: @table @option @item inputs Set number of input streams. Default is 2. + +@item shortest +If set to 1, force the output to terminate when the shortest input +terminates. Default value is 0. @end table @section hue @@ -11598,6 +11602,10 @@ The filter accept the following option: @table @option @item inputs Set number of input streams. Default is 2. + +@item shortest +If set to 1, force the output to terminate when the shortest input +terminates. Default value is 0. @end table @section w3fdif diff --git a/libavfilter/vf_stack.c b/libavfilter/vf_stack.c index c4bbd6166d0c7a3ca6b75f8d768982579a161cc3..2fe371275d14180b973bc6e6521a92b9930e7303 100644 --- a/libavfilter/vf_stack.c +++ b/libavfilter/vf_stack.c @@ -33,6 +33,7 @@ typedef struct StackContext { const AVClass *class; const AVPixFmtDescriptor *desc; int nb_inputs; + int shortest; int is_vertical; int nb_planes; @@ -199,7 +200,7 @@ static int config_output(AVFilterLink *outlink) in[i].time_base = inlink->time_base; in[i].sync = 1; in[i].before = EXT_STOP; - in[i].after = EXT_INFINITY; + in[i].after = s->shortest ? EXT_STOP : EXT_INFINITY; } return ff_framesync_configure(&s->fs); @@ -222,6 +223,7 @@ static av_cold void uninit(AVFilterContext *ctx) #define FLAGS AV_OPT_FLAG_VIDEO_PARAM | AV_OPT_FLAG_FILTERING_PARAM static const AVOption stack_options[] = { { "inputs", "set number of inputs", OFFSET(nb_inputs), AV_OPT_TYPE_INT, {.i64=2}, 2, INT_MAX, .flags = FLAGS }, + { "shortest", "force termination when the shortest input terminates", OFFSET(shortest), AV_OPT_TYPE_BOOL, {.i64=0}, 0, 1, .flags = FLAGS }, { NULL }, };