Commit 9ca5b272 authored by Carl Eugen Hoyos's avatar Carl Eugen Hoyos

lavf/adxdec: Add Autodetection.

parent 09b3a424
...@@ -34,6 +34,19 @@ typedef struct ADXDemuxerContext { ...@@ -34,6 +34,19 @@ typedef struct ADXDemuxerContext {
int header_size; int header_size;
} ADXDemuxerContext; } ADXDemuxerContext;
static int adx_probe(AVProbeData *p)
{
int offset;
if (AV_RB16(p->buf) != 0x8000)
return 0;
offset = AV_RB16(&p->buf[2]);
if ( offset < 8
|| offset > p->buf_size - 4
|| memcmp(p->buf + offset - 2, "(c)CRI", 6))
return 0;
return AVPROBE_SCORE_MAX * 3 / 4;
}
static int adx_read_packet(AVFormatContext *s, AVPacket *pkt) static int adx_read_packet(AVFormatContext *s, AVPacket *pkt)
{ {
ADXDemuxerContext *c = s->priv_data; ADXDemuxerContext *c = s->priv_data;
...@@ -107,6 +120,7 @@ static int adx_read_header(AVFormatContext *s) ...@@ -107,6 +120,7 @@ static int adx_read_header(AVFormatContext *s)
AVInputFormat ff_adx_demuxer = { AVInputFormat ff_adx_demuxer = {
.name = "adx", .name = "adx",
.long_name = NULL_IF_CONFIG_SMALL("CRI ADX"), .long_name = NULL_IF_CONFIG_SMALL("CRI ADX"),
.read_probe = adx_probe,
.priv_data_size = sizeof(ADXDemuxerContext), .priv_data_size = sizeof(ADXDemuxerContext),
.read_header = adx_read_header, .read_header = adx_read_header,
.read_packet = adx_read_packet, .read_packet = adx_read_packet,
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment