[FFmpeg-devel] [PATCH] avformat/tty: add probe function
Peter Ross
pross at xvid.org
Tue Jan 28 22:46:29 EET 2020
On Tue, Jan 28, 2020 at 02:17:35PM +0100, Paul B Mahol wrote:
> Signed-off-by: Paul B Mahol <onemda at gmail.com>
> ---
> libavformat/tty.c | 18 +++++++++++++++++-
> 1 file changed, 17 insertions(+), 1 deletion(-)
>
> diff --git a/libavformat/tty.c b/libavformat/tty.c
> index 8d48f2c45c..a8fb9dc8f3 100644
> --- a/libavformat/tty.c
> +++ b/libavformat/tty.c
> @@ -24,6 +24,8 @@
> * Tele-typewriter demuxer
> */
>
> +#include <ctype.h>
> +
> #include "libavutil/intreadwrite.h"
> #include "libavutil/avstring.h"
> #include "libavutil/log.h"
> @@ -34,6 +36,8 @@
> #include "internal.h"
> #include "sauce.h"
>
> +static const char tty_extensions[31] = "ans,art,asc,diz,ice,nfo,txt,vt";
> +
> typedef struct TtyDemuxContext {
> AVClass *class;
> int chars_per_frame;
> @@ -42,6 +46,17 @@ typedef struct TtyDemuxContext {
> AVRational framerate; /**< Set by a private option. */
> } TtyDemuxContext;
>
> +static int read_probe(const AVProbeData *p)
> +{
> + int cnt = 0;
> +
> + for (int i = 0; i < p->buf_size; i++)
> + cnt += !!isprint(p->buf[i]);
> +
> + return (cnt * 100LL / p->buf_size) * (cnt > 400) *
> + !!av_match_ext(p->filename, tty_extensions);
> +}
> +
> /**
> * Parse EFI header
> */
> @@ -153,8 +168,9 @@ AVInputFormat ff_tty_demuxer = {
> .name = "tty",
> .long_name = NULL_IF_CONFIG_SMALL("Tele-typewriter"),
> .priv_data_size = sizeof(TtyDemuxContext),
> + .read_probe = read_probe,
> .read_header = read_header,
> .read_packet = read_packet,
> - .extensions = "ans,art,asc,diz,ice,nfo,txt,vt",
> + .extensions = tty_extensions,
> .priv_class = &tty_demuxer_class,
> };
> --
> 2.17.1
i can't offer any more suggestions. recommend approve.
-- Peter
(A907 E02F A6E5 0CD2 34CD 20D2 6760 79C5 AC40 DD6B)
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 195 bytes
Desc: not available
URL: <https://ffmpeg.org/pipermail/ffmpeg-devel/attachments/20200129/8352a883/attachment.sig>
More information about the ffmpeg-devel
mailing list