match uids indenpendantly of the version byte

Originally committed as revision 9184 to svn://svn.ffmpeg.org/ffmpeg/trunk
pull/126/head
Baptiste Coudurier 18 years ago
parent 3c6b46d3a5
commit 6982462f50
  1. 18
      libavformat/mxf.c

@ -637,10 +637,24 @@ static const MXFCodecUL mxf_sound_essence_container_uls[] = {
{ { 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 }, CODEC_ID_NONE, Frame }, { { 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 }, CODEC_ID_NONE, Frame },
}; };
/*
* Match an uid independently of the version byte and up to len common bytes
* Returns: boolean
*/
static int mxf_match_uid(const UID key, const UID uid, int len)
{
int i;
for (i = 0; i < len; i++) {
if (i != 7 && key[i] != uid[i])
return 0;
}
return 1;
}
static const MXFCodecUL *mxf_get_codec_ul(const MXFCodecUL *uls, UID *uid) static const MXFCodecUL *mxf_get_codec_ul(const MXFCodecUL *uls, UID *uid)
{ {
while (uls->id != CODEC_ID_NONE) { while (uls->id != CODEC_ID_NONE) {
if(!memcmp(uls->uid, *uid, 16)) if(mxf_match_uid(uls->uid, *uid, 16))
break; break;
uls++; uls++;
} }
@ -650,7 +664,7 @@ static const MXFCodecUL *mxf_get_codec_ul(const MXFCodecUL *uls, UID *uid)
static enum CodecType mxf_get_codec_type(const MXFDataDefinitionUL *uls, UID *uid) static enum CodecType mxf_get_codec_type(const MXFDataDefinitionUL *uls, UID *uid)
{ {
while (uls->type != CODEC_TYPE_DATA) { while (uls->type != CODEC_TYPE_DATA) {
if(!memcmp(uls->uid, *uid, 16)) if(mxf_match_uid(uls->uid, *uid, 16))
break; break;
uls++; uls++;
} }

Loading…
Cancel
Save