[FFmpeg-cvslog] lavfi/select: correctly set prev_t and prev_pts
Stefano Sabatini
git at videolan.org
Thu Feb 7 21:31:00 CET 2013
ffmpeg | branch: master | Stefano Sabatini <stefasab at gmail.com> | Thu Feb 7 21:16:11 2013 +0100| [c0a4871c1687279c5fbe6d5d7f475a393c645b05] | committer: Stefano Sabatini
lavfi/select: correctly set prev_t and prev_pts
In particular, fix trac ticket #2248.
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=c0a4871c1687279c5fbe6d5d7f475a393c645b05
---
libavfilter/f_select.c | 4 +++-
1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/libavfilter/f_select.c b/libavfilter/f_select.c
index fabddef..0f21145 100644
--- a/libavfilter/f_select.c
+++ b/libavfilter/f_select.c
@@ -184,6 +184,7 @@ static int config_input(AVFilterLink *inlink)
select->var_values[VAR_PREV_PTS] = NAN;
select->var_values[VAR_PREV_SELECTED_PTS] = NAN;
select->var_values[VAR_PREV_SELECTED_T] = NAN;
+ select->var_values[VAR_PREV_T] = NAN;
select->var_values[VAR_START_PTS] = NAN;
select->var_values[VAR_START_T] = NAN;
@@ -273,7 +274,6 @@ static int select_frame(AVFilterContext *ctx, AVFilterBufferRef *ref)
select->var_values[VAR_PTS] = TS2D(ref->pts);
select->var_values[VAR_T ] = TS2D(ref->pts) * av_q2d(inlink->time_base);
select->var_values[VAR_POS] = ref->pos == -1 ? NAN : ref->pos;
- select->var_values[VAR_PREV_PTS] = TS2D(ref ->pts);
switch (inlink->type) {
case AVMEDIA_TYPE_AUDIO:
@@ -334,6 +334,8 @@ static int select_frame(AVFilterContext *ctx, AVFilterBufferRef *ref)
}
select->var_values[VAR_N] += 1.0;
+ select->var_values[VAR_PREV_PTS] = select->var_values[VAR_PTS];
+ select->var_values[VAR_PREV_T] = select->var_values[VAR_T];
return res;
}
More information about the ffmpeg-cvslog
mailing list