diff options
author | Michael Bradshaw <mbradshaw@sorensonmedia.com> | 2012-06-17 22:20:09 -0700 |
---|---|---|
committer | Nicolas George <nicolas.george@normalesup.org> | 2012-06-18 09:36:34 +0200 |
commit | 2243f0d0783922054d10497fc1d6f6fb376f05ff (patch) | |
tree | 766ee982f8492615ccaba3ecda6b8904994dbc0d | |
parent | 3b3150ec9bfddd9bd57dcd378b43a8f363b0fc4f (diff) | |
download | ffmpeg-2243f0d0783922054d10497fc1d6f6fb376f05ff.tar.gz |
lavf: add field for how duration is estimated
Signed-off-by: Michael Bradshaw <mbradshaw@sorensonmedia.com>
-rw-r--r-- | libavformat/avformat.h | 17 | ||||
-rw-r--r-- | libavformat/options.c | 5 | ||||
-rw-r--r-- | libavformat/utils.c | 3 | ||||
-rw-r--r-- | libavformat/version.h | 4 |
4 files changed, 27 insertions, 2 deletions
diff --git a/libavformat/avformat.h b/libavformat/avformat.h index 19441f8e21..8650b0836a 100644 --- a/libavformat/avformat.h +++ b/libavformat/avformat.h @@ -1099,8 +1099,25 @@ typedef struct AVFormatContext { int raw_packet_buffer_remaining_size; int avio_flags; + + /** + * The duration field can be estimated through various ways, and this field can be used + * to know how the duration was estimated. + */ + enum { + AVFMT_DURATION_FROM_PTS, ///< duration accurately estimated from PTSes + AVFMT_DURATION_FROM_STREAM, ///< duration estimated from a stream with a known duration + AVFMT_DURATION_FROM_BITRATE ///< duration estimated from bitrate (less accurate) + } duration_estimation_method; } AVFormatContext; +/** + * Returns the method used to set ctx->duration. + * + * @return AVFMT_DURATION_FROM_PTS, AVFMT_DURATION_FROM_STREAM, or AVFMT_DURATION_FROM_BITRATE. + */ +int av_fmt_ctx_get_duration_estimation_method(const AVFormatContext* ctx); + typedef struct AVPacketList { AVPacket pkt; struct AVPacketList *next; diff --git a/libavformat/options.c b/libavformat/options.c index 832d058dd0..b1e8b0d45f 100644 --- a/libavformat/options.c +++ b/libavformat/options.c @@ -104,6 +104,11 @@ AVFormatContext *avformat_alloc_context(void) return ic; } +int av_fmt_ctx_get_duration_estimation_method(const AVFormatContext* ctx) +{ + return ctx->duration_estimation_method; +} + const AVClass *avformat_get_class(void) { return &av_format_context_class; diff --git a/libavformat/utils.c b/libavformat/utils.c index 6ac12922d5..284cb9f337 100644 --- a/libavformat/utils.c +++ b/libavformat/utils.c @@ -2228,14 +2228,17 @@ static void estimate_timings(AVFormatContext *ic, int64_t old_offset) file_size && ic->pb->seekable) { /* get accurate estimate from the PTSes */ estimate_timings_from_pts(ic, old_offset); + ic->duration_estimation_method = AVFMT_DURATION_FROM_PTS; } else if (has_duration(ic)) { /* at least one component has timings - we use them for all the components */ fill_all_stream_timings(ic); + ic->duration_estimation_method = AVFMT_DURATION_FROM_STREAM; } else { av_log(ic, AV_LOG_WARNING, "Estimating duration from bitrate, this may be inaccurate\n"); /* less precise: use bitrate info */ estimate_timings_from_bit_rate(ic); + ic->duration_estimation_method = AVFMT_DURATION_FROM_BITRATE; } update_stream_timings(ic); diff --git a/libavformat/version.h b/libavformat/version.h index 7042990579..cca6c1aea4 100644 --- a/libavformat/version.h +++ b/libavformat/version.h @@ -30,8 +30,8 @@ #include "libavutil/avutil.h" #define LIBAVFORMAT_VERSION_MAJOR 54 -#define LIBAVFORMAT_VERSION_MINOR 6 -#define LIBAVFORMAT_VERSION_MICRO 101 +#define LIBAVFORMAT_VERSION_MINOR 7 +#define LIBAVFORMAT_VERSION_MICRO 100 #define LIBAVFORMAT_VERSION_INT AV_VERSION_INT(LIBAVFORMAT_VERSION_MAJOR, \ LIBAVFORMAT_VERSION_MINOR, \ |