[FFmpeg-devel] [PATCH]lavf/img2dec: Auto-detect svg images

Carl Eugen Hoyos ceffmpeg at gmail.com
Sat Oct 7 04:43:35 EEST 2017


2017-10-02 11:42 GMT+02:00 Carl Eugen Hoyos <ceffmpeg at gmail.com>:
> 2017-10-02 7:52 GMT+02:00 Clément Bœsch <u at pkh.me>:
>> On Mon, Oct 02, 2017 at 01:20:15AM +0200, Carl Eugen Hoyos wrote:
>>> Hi!
>>>
>>> Attached patch implements auto-detection of svg images.
>>>
>>> Please review, Carl Eugen
>>
>>> From f06137f38f166740565e58d5c7c88777508f59ec Mon Sep 17 00:00:00 2001
>>> From: Carl Eugen Hoyos <ceffmpeg at gmail.com>
>>> Date: Mon, 2 Oct 2017 01:13:29 +0200
>>> Subject: [PATCH] lavf/img2dec: Auto-detect svg images.
>>>
>>> ---
>>>  libavformat/img2dec.c |   17 +++++++++++++++--
>>>  1 file changed, 15 insertions(+), 2 deletions(-)
>>>
>>> diff --git a/libavformat/img2dec.c b/libavformat/img2dec.c
>>> index 19cae87..468c820 100644
>>> --- a/libavformat/img2dec.c
>>> +++ b/libavformat/img2dec.c
>>> @@ -34,6 +34,7 @@
>>>  #include "internal.h"
>>>  #include "img2.h"
>>>  #include "libavcodec/mjpeg.h"
>>> +#include "subtitles.h"
>>>
>>>  #if HAVE_GLOB
>>>  /* Locally define as 0 (bitwise-OR no-op) any missing glob options that
>>> @@ -875,8 +876,20 @@ static int sunrast_probe(AVProbeData *p)
>>>
>>>  static int svg_probe(AVProbeData *p)
>>>  {
>>> -    if (av_match_ext(p->filename, "svg") || av_match_ext(p->filename, "svgz"))
>>> -        return AVPROBE_SCORE_EXTENSION + 1;
>>> +    const uint8_t *b = p->buf;
>>> +    const uint8_t *end = p->buf + p->buf_size;
>>> +    if (memcmp(p->buf, "<?xml", 5))
>>> +        return 0;
>>> +    while (b < end) {
>>> +        b += ff_subtitles_next_line(b);
>>> +        if (b >= end)
>>> +            return 0;
>>
>>> +        if (!strstr(b, "<!DOCTYPE "))
>>> +            continue;
>>
>> at least the svg from inkscape do not have a doctype
>
> Wrong check, thank you.
>
>>> +        b += 9;
>>> +        if (strstr(b, "svg"))
>>> +            return AVPROBE_SCORE_MAX;
>>> +    }
>>
>> don't you want to keep an extension fallback?
>
> That's done by the image2 demuxer.
>
>> also, I would guess strstr() is going to be slow, so maybe
>> just look for a line starting with "<svg".
>
> Done, thank you.
>
> New patch attached, Carl Eugen

Patch applied.

Carl Eugen


More information about the ffmpeg-devel mailing list