ffmpeg: deprecate passing numbers to -vsync

There is never a reason to do this, using symbolic names is always
preferred.
This commit is contained in:
Anton Khirnov 2021-12-04 15:03:07 +01:00
parent e3833e8a24
commit 6ce9546428
2 changed files with 14 additions and 9 deletions

View File

@ -1620,23 +1620,25 @@ It is useful for when flow speed of output packets is important, such as live st
Read input at native frame rate. This is equivalent to setting @code{-readrate 1}. Read input at native frame rate. This is equivalent to setting @code{-readrate 1}.
@item -vsync @var{parameter} @item -vsync @var{parameter}
Video sync method. Video sync method.
For compatibility reasons old values can be specified as numbers.
Newly added values will have to be specified as strings always. For compatibility reasons some of the values can be specified as numbers (shown
in parentheses in the following table). This is deprecated and will stop working
in the future.
@table @option @table @option
@item 0, passthrough @item passthrough (0)
Each frame is passed with its timestamp from the demuxer to the muxer. Each frame is passed with its timestamp from the demuxer to the muxer.
@item 1, cfr @item cfr (1)
Frames will be duplicated and dropped to achieve exactly the requested Frames will be duplicated and dropped to achieve exactly the requested
constant frame rate. constant frame rate.
@item 2, vfr @item vfr (2)
Frames are passed through with their timestamp or dropped so as to Frames are passed through with their timestamp or dropped so as to
prevent 2 frames from having the same timestamp. prevent 2 frames from having the same timestamp.
@item drop @item drop
As passthrough but destroys all timestamps, making the muxer generate As passthrough but destroys all timestamps, making the muxer generate
fresh timestamps based on frame-rate. fresh timestamps based on frame-rate.
@item -1, auto @item auto (-1)
Chooses between 1 and 2 depending on muxer capabilities. This is the Chooses between cfr and vfr depending on muxer capabilities. This is the
default method. default method.
@end table @end table

View File

@ -1731,7 +1731,7 @@ static OutputStream *new_video_stream(OptionsContext *o, AVFormatContext *oc, in
if ((frame_rate || max_frame_rate) && if ((frame_rate || max_frame_rate) &&
video_sync_method == VSYNC_PASSTHROUGH) video_sync_method == VSYNC_PASSTHROUGH)
av_log(NULL, AV_LOG_ERROR, "Using -vsync 0 and -r/-fpsmax can produce invalid output files\n"); av_log(NULL, AV_LOG_ERROR, "Using -vsync passthrough and -r/-fpsmax can produce invalid output files\n");
MATCH_PER_STREAM_OPT(frame_aspect_ratios, str, frame_aspect_ratio, oc, st); MATCH_PER_STREAM_OPT(frame_aspect_ratios, str, frame_aspect_ratio, oc, st);
if (frame_aspect_ratio) { if (frame_aspect_ratio) {
@ -3191,8 +3191,11 @@ static int opt_vsync(void *optctx, const char *opt, const char *arg)
else if (!av_strcasecmp(arg, "passthrough")) video_sync_method = VSYNC_PASSTHROUGH; else if (!av_strcasecmp(arg, "passthrough")) video_sync_method = VSYNC_PASSTHROUGH;
else if (!av_strcasecmp(arg, "drop")) video_sync_method = VSYNC_DROP; else if (!av_strcasecmp(arg, "drop")) video_sync_method = VSYNC_DROP;
if (video_sync_method == VSYNC_AUTO) if (video_sync_method == VSYNC_AUTO) {
video_sync_method = parse_number_or_die("vsync", arg, OPT_INT, VSYNC_AUTO, VSYNC_VFR); video_sync_method = parse_number_or_die("vsync", arg, OPT_INT, VSYNC_AUTO, VSYNC_VFR);
av_log(NULL, AV_LOG_WARNING, "Passing a number to -vsync is deprecated,"
" use a string argument as described in the manual.\n");
}
return 0; return 0;
} }