[FFmpeg-devel] [PATCH] avformat: export probe score

Paul B Mahol onemda at gmail.com
Wed Aug 28 01:43:28 CEST 2013


On 8/27/13, Michael Niedermayer <michaelni at gmx.at> wrote:
> On Tue, Aug 27, 2013 at 09:47:16PM +0000, Paul B Mahol wrote:
>> On 8/27/13, Michael Niedermayer <michaelni at gmx.at> wrote:
>> > Signed-off-by: Michael Niedermayer <michaelni at gmx.at>
>> > ---
>> >  doc/formats.texi            |    4 ++++
>> >  libavformat/avformat.h      |   18 ++++++++++++++++--
>> >  libavformat/options_table.h |    1 +
>> >  libavformat/utils.c         |   18 ++++++++++++++----
>> >  4 files changed, 35 insertions(+), 6 deletions(-)
>> >
>> > diff --git a/doc/formats.texi b/doc/formats.texi
>> > index e179755..21d4685 100644
>> > --- a/doc/formats.texi
>> > +++ b/doc/formats.texi
>> > @@ -137,6 +137,10 @@ non-monotonic negative timestamps.
>> >  Flush the underlying I/O stream after each packet. Default 1 enables
>> > it,
>> > and
>> >  has the effect of reducing the latency; 0 disables it and may slightly
>> >  increase performance in some cases.
>> > +
>> > + at item probe_score @var{integer} (@emph{input})
>> > +This field is only accessable programatically, its value represents
>> > the
>> > score
>> > +by which the format was detected.
>> >  @end table
>> >
>> >  @c man end FORMAT OPTIONS
>> > diff --git a/libavformat/avformat.h b/libavformat/avformat.h
>> > index 77efc61..b414a0c 100644
>> > --- a/libavformat/avformat.h
>> > +++ b/libavformat/avformat.h
>> > @@ -1237,6 +1237,13 @@ typedef struct AVFormatContext {
>> >       */
>> >      int flush_packets;
>> >
>> > +    /**
>> > +     * format probing score
>> > +     * - encoding: unused
>> > +     * - decoding: set by avformat, read by user via AVOptions (NO
>> > direct
>> > access)
>> > +     */
>> > +    int probe_score;
>> > +
>> >      /*****************************************************************
>> >       * All fields below this line are not part of the public API. They
>> >       * may not be used outside of libavformat and can be changed and
>> > @@ -1504,13 +1511,20 @@ AVInputFormat
>> > *av_probe_input_format3(AVProbeData
>> > *pd, int is_opened, int *score
>> >   * @param logctx the log context
>> >   * @param offset the offset within the bytestream to probe from
>> >   * @param max_probe_size the maximum probe buffer size (zero for
>> > default)
>> > - * @return 0 in case of success, a negative value corresponding to an
>> > + * @return the score in case of success, a negative value corresponding
>> > to
>> > an
>> > + *         the maximal score is AVPROBE_SCORE_MAX
>> >   * AVERROR code otherwise
>> >   */
>> > +int av_probe_input_buffer2(AVIOContext *pb, AVInputFormat **fmt,
>> > +                           const char *filename, void *logctx,
>> > +                           unsigned int offset, unsigned int
>> > max_probe_size);
>> > +
>> > +/**
>> > + * Like av_probe_input_buffer2() but returns 0 on success
>> > + */
>> >  int av_probe_input_buffer(AVIOContext *pb, AVInputFormat **fmt,
>> >                            const char *filename, void *logctx,
>> >                            unsigned int offset, unsigned int
>> > max_probe_size);
>> > -
>> >  /**
>> >   * Open an input stream and read the header. The codecs are not
>> > opened.
>> >   * The stream must be closed with avformat_close_input().
>> > diff --git a/libavformat/options_table.h b/libavformat/options_table.h
>> > index a87868e..5392e22 100644
>> > --- a/libavformat/options_table.h
>> > +++ b/libavformat/options_table.h
>> > @@ -76,6 +76,7 @@ static const AVOption avformat_options[] = {
>> >  {"skip_initial_bytes", "skip initial bytes",
>> > OFFSET(skip_initial_bytes),
>> > AV_OPT_TYPE_INT, {.i64 = 0}, 0, INT_MAX-1, D},
>> >  {"correct_ts_overflow", "correct single timestamp overflows",
>> > OFFSET(correct_ts_overflow), AV_OPT_TYPE_INT, {.i64 = 1}, 0, 1, D},
>> >  {"flush_packets", "enable flushing of the I/O context after each
>> > packet",
>> > OFFSET(flush_packets), AV_OPT_TYPE_INT, {.i64 = 1}, 0, 1, E},
>> > +{"probe_score", "score with which the format was probed",
>> > OFFSET(probe_score), AV_OPT_TYPE_INT, {.i64 = 0}, 0,
>> > AVPROBE_SCORE_MAX,},
>>
>> This stills allow user to set it? (for example with ffmpeg)
>
> it should not, and now it also does not

cmdutils.c is not part of lib.

>
> [...]
>
> --
> Michael     GnuPG fingerprint: 9FF2128B147EF6730BADF133611EC787040B0FAB
>
> What does censorship reveal? It reveals fear. -- Julian Assange
>


More information about the ffmpeg-devel mailing list