# HG changeset patch # User reimar # Date 1189800522 0 # Node ID a365d70938b339ab6f5fec5acbe749841fb0998a # Parent 6fb4555fba27b36646335eae76977e610e0d1562 Simplify demux_ty_FindESPacket by reusing demux_ty_FindESHeader diff -r 6fb4555fba27 -r a365d70938b3 libmpdemux/demux_ty.c --- a/libmpdemux/demux_ty.c Fri Sep 14 19:55:09 2007 +0000 +++ b/libmpdemux/demux_ty.c Fri Sep 14 20:08:42 2007 +0000 @@ -377,38 +377,16 @@ static void demux_ty_FindESPacket( unsigned char *header, unsigned char *buffer, int bufferSize, int *esOffset1, int *esOffset2 ) { - int count; - - *esOffset1 = -1; - *esOffset2 = -1; - - for( count = 0 ; count < bufferSize ; count++ ) - { - if ( buffer[ count + 0 ] == header[ 0 ] && - buffer[ count + 1 ] == header[ 1 ] && - buffer[ count + 2 ] == header[ 2 ] && - buffer[ count + 3 ] == header[ 3 ] ) - { - *esOffset1 = count; - break; - } - } - - if ( *esOffset1 != -1 ) - { - for( count = *esOffset1 + 1 ; - count < bufferSize ; count++ ) - { - if ( buffer[ count + 0 ] == header[ 0 ] && - buffer[ count + 1 ] == header[ 1 ] && - buffer[ count + 2 ] == header[ 2 ] && - buffer[ count + 3 ] == header[ 3 ] ) - { - *esOffset2 = count; - break; - } - } - } + *esOffset1 = demux_ty_FindESHeader(header, buffer, bufferSize); + if (*esOffset1 == -1) { + *esOffset2 = -1; + return; + } + buffer += *esOffset1 + 1; + bufferSize -= *esOffset1 + 1; + *esOffset2 = demux_ty_FindESHeader(header, buffer, bufferSize); + if (*esOffset2 != -1) + *esOffset2 += *esOffset1 + 1; } static unsigned char ty_VideoPacket[] = { 0x00, 0x00, 0x01, 0xe0 };