movenc: Deprecate the global RTP hinting flag, use a private AVOption instead
Instead of -fflags rtphint, set -movflags rtphint instead. Signed-off-by: Martin Storsjö <martin@martin.st>
This commit is contained in:
parent
91e3a25ef6
commit
28734ac995
@ -723,7 +723,9 @@ typedef struct AVFormatContext {
|
|||||||
#define AVFMT_FLAG_IGNDTS 0x0008 ///< Ignore DTS on frames that contain both DTS & PTS
|
#define AVFMT_FLAG_IGNDTS 0x0008 ///< Ignore DTS on frames that contain both DTS & PTS
|
||||||
#define AVFMT_FLAG_NOFILLIN 0x0010 ///< Do not infer any values from other values, just return what is stored in the container
|
#define AVFMT_FLAG_NOFILLIN 0x0010 ///< Do not infer any values from other values, just return what is stored in the container
|
||||||
#define AVFMT_FLAG_NOPARSE 0x0020 ///< Do not use AVParsers, you also must set AVFMT_FLAG_NOFILLIN as the fillin code works on frames and no parsing -> no frames. Also seeking to frames can not work if parsing to find frame boundaries has been disabled
|
#define AVFMT_FLAG_NOPARSE 0x0020 ///< Do not use AVParsers, you also must set AVFMT_FLAG_NOFILLIN as the fillin code works on frames and no parsing -> no frames. Also seeking to frames can not work if parsing to find frame boundaries has been disabled
|
||||||
#define AVFMT_FLAG_RTP_HINT 0x0040 ///< Add RTP hinting to the output file
|
#if FF_API_FLAG_RTP_HINT
|
||||||
|
#define AVFMT_FLAG_RTP_HINT 0x0040 ///< Deprecated, use the -movflags rtphint muxer specific AVOption instead
|
||||||
|
#endif
|
||||||
|
|
||||||
int loop_input;
|
int loop_input;
|
||||||
|
|
||||||
|
@ -38,6 +38,8 @@
|
|||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
|
||||||
static const AVOption options[] = {
|
static const AVOption options[] = {
|
||||||
|
{ "movflags", "MOV muxer flags", offsetof(MOVMuxContext, flags), FF_OPT_TYPE_FLAGS, {.dbl = 0}, INT_MIN, INT_MAX, AV_OPT_FLAG_ENCODING_PARAM, "movflags" },
|
||||||
|
{ "rtphint", "Add RTP hint tracks", 0, FF_OPT_TYPE_CONST, {.dbl = FF_MOV_FLAG_RTP_HINT}, INT_MIN, INT_MAX, AV_OPT_FLAG_ENCODING_PARAM, "movflags" },
|
||||||
{ NULL },
|
{ NULL },
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -2124,7 +2126,15 @@ static int mov_write_header(AVFormatContext *s)
|
|||||||
if (mov->mode & (MODE_MOV|MODE_IPOD) && s->nb_chapters)
|
if (mov->mode & (MODE_MOV|MODE_IPOD) && s->nb_chapters)
|
||||||
mov->chapter_track = mov->nb_streams++;
|
mov->chapter_track = mov->nb_streams++;
|
||||||
|
|
||||||
|
#if FF_API_FLAG_RTP_HINT
|
||||||
if (s->flags & AVFMT_FLAG_RTP_HINT) {
|
if (s->flags & AVFMT_FLAG_RTP_HINT) {
|
||||||
|
av_log(s, AV_LOG_WARNING, "The RTP_HINT flag is deprecated, enable it "
|
||||||
|
"via the -movflags rtphint muxer option "
|
||||||
|
"instead.\n");
|
||||||
|
mov->flags |= FF_MOV_FLAG_RTP_HINT;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
if (mov->flags & FF_MOV_FLAG_RTP_HINT) {
|
||||||
/* Add hint tracks for each audio and video stream */
|
/* Add hint tracks for each audio and video stream */
|
||||||
hint_track = mov->nb_streams;
|
hint_track = mov->nb_streams;
|
||||||
for (i = 0; i < s->nb_streams; i++) {
|
for (i = 0; i < s->nb_streams; i++) {
|
||||||
@ -2220,7 +2230,7 @@ static int mov_write_header(AVFormatContext *s)
|
|||||||
if (mov->chapter_track)
|
if (mov->chapter_track)
|
||||||
mov_create_chapter_track(s, mov->chapter_track);
|
mov_create_chapter_track(s, mov->chapter_track);
|
||||||
|
|
||||||
if (s->flags & AVFMT_FLAG_RTP_HINT) {
|
if (mov->flags & FF_MOV_FLAG_RTP_HINT) {
|
||||||
/* Initialize the hint tracks for each audio and video stream */
|
/* Initialize the hint tracks for each audio and video stream */
|
||||||
for (i = 0; i < s->nb_streams; i++) {
|
for (i = 0; i < s->nb_streams; i++) {
|
||||||
AVStream *st = s->streams[i];
|
AVStream *st = s->streams[i];
|
||||||
|
@ -109,8 +109,12 @@ typedef struct MOVMuxContext {
|
|||||||
int64_t mdat_pos;
|
int64_t mdat_pos;
|
||||||
uint64_t mdat_size;
|
uint64_t mdat_size;
|
||||||
MOVTrack *tracks;
|
MOVTrack *tracks;
|
||||||
|
|
||||||
|
int flags;
|
||||||
} MOVMuxContext;
|
} MOVMuxContext;
|
||||||
|
|
||||||
|
#define FF_MOV_FLAG_RTP_HINT 1
|
||||||
|
|
||||||
int ff_mov_write_packet(AVFormatContext *s, AVPacket *pkt);
|
int ff_mov_write_packet(AVFormatContext *s, AVPacket *pkt);
|
||||||
|
|
||||||
int ff_mov_init_hinting(AVFormatContext *s, int index, int src_index);
|
int ff_mov_init_hinting(AVFormatContext *s, int index, int src_index);
|
||||||
|
@ -49,7 +49,9 @@ static const AVOption options[]={
|
|||||||
{"nofillin", "do not fill in missing values that can be exactly calculated", 0, FF_OPT_TYPE_CONST, {.dbl = AVFMT_FLAG_NOFILLIN }, INT_MIN, INT_MAX, D, "fflags"},
|
{"nofillin", "do not fill in missing values that can be exactly calculated", 0, FF_OPT_TYPE_CONST, {.dbl = AVFMT_FLAG_NOFILLIN }, INT_MIN, INT_MAX, D, "fflags"},
|
||||||
{"noparse", "disable AVParsers, this needs nofillin too", 0, FF_OPT_TYPE_CONST, {.dbl = AVFMT_FLAG_NOPARSE }, INT_MIN, INT_MAX, D, "fflags"},
|
{"noparse", "disable AVParsers, this needs nofillin too", 0, FF_OPT_TYPE_CONST, {.dbl = AVFMT_FLAG_NOPARSE }, INT_MIN, INT_MAX, D, "fflags"},
|
||||||
{"igndts", "ignore dts", 0, FF_OPT_TYPE_CONST, {.dbl = AVFMT_FLAG_IGNDTS }, INT_MIN, INT_MAX, D, "fflags"},
|
{"igndts", "ignore dts", 0, FF_OPT_TYPE_CONST, {.dbl = AVFMT_FLAG_IGNDTS }, INT_MIN, INT_MAX, D, "fflags"},
|
||||||
{"rtphint", "add rtp hinting", 0, FF_OPT_TYPE_CONST, {.dbl = AVFMT_FLAG_RTP_HINT }, INT_MIN, INT_MAX, E, "fflags"},
|
#if FF_API_FLAG_RTP_HINT
|
||||||
|
{"rtphint", "add rtp hinting (deprecated, use the -movflags rtphint option instead)", 0, FF_OPT_TYPE_CONST, {.dbl = AVFMT_FLAG_RTP_HINT }, INT_MIN, INT_MAX, E, "fflags"},
|
||||||
|
#endif
|
||||||
{"analyzeduration", "how many microseconds are analyzed to estimate duration", OFFSET(max_analyze_duration), FF_OPT_TYPE_INT, {.dbl = 5*AV_TIME_BASE }, 0, INT_MAX, D},
|
{"analyzeduration", "how many microseconds are analyzed to estimate duration", OFFSET(max_analyze_duration), FF_OPT_TYPE_INT, {.dbl = 5*AV_TIME_BASE }, 0, INT_MAX, D},
|
||||||
{"cryptokey", "decryption key", OFFSET(key), FF_OPT_TYPE_BINARY, {.dbl = 0}, 0, 0, D},
|
{"cryptokey", "decryption key", OFFSET(key), FF_OPT_TYPE_BINARY, {.dbl = 0}, 0, 0, D},
|
||||||
{"indexmem", "max memory used for timestamp index (per stream)", OFFSET(max_index_size), FF_OPT_TYPE_INT, {.dbl = 1<<20 }, 0, INT_MAX, D},
|
{"indexmem", "max memory used for timestamp index (per stream)", OFFSET(max_index_size), FF_OPT_TYPE_INT, {.dbl = 1<<20 }, 0, INT_MAX, D},
|
||||||
|
@ -71,5 +71,8 @@
|
|||||||
#ifndef FF_API_FORMAT_PARAMETERS
|
#ifndef FF_API_FORMAT_PARAMETERS
|
||||||
#define FF_API_FORMAT_PARAMETERS (LIBAVFORMAT_VERSION_MAJOR < 54)
|
#define FF_API_FORMAT_PARAMETERS (LIBAVFORMAT_VERSION_MAJOR < 54)
|
||||||
#endif
|
#endif
|
||||||
|
#ifndef FF_API_FLAG_RTP_HINT
|
||||||
|
#define FF_API_FLAG_RTP_HINT (LIBAVFORMAT_VERSION_MAJOR < 54)
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif /* AVFORMAT_VERSION_H */
|
#endif /* AVFORMAT_VERSION_H */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user