Commit af3f0b21 authored by Laurent Aimar's avatar Laurent Aimar

Added support for mpga in wav (close #2957).

parent 9645e735
...@@ -545,21 +545,32 @@ static int MpgaGetFrameSamples( uint32_t h ) ...@@ -545,21 +545,32 @@ static int MpgaGetFrameSamples( uint32_t h )
static int MpgaProbe( demux_t *p_demux, int64_t *pi_offset ) static int MpgaProbe( demux_t *p_demux, int64_t *pi_offset )
{ {
const int pi_wav[] = { WAVE_FORMAT_MPEG, WAVE_FORMAT_MPEGLAYER3, WAVE_FORMAT_UNKNOWN };
bool b_forced; bool b_forced;
bool b_forced_demux; bool b_forced_demux;
int64_t i_offset; int64_t i_offset;
const uint8_t *p_peek; const uint8_t *p_peek;
int i_skip;
b_forced = demux_IsPathExtension( p_demux, ".mp3" ); b_forced = demux_IsPathExtension( p_demux, ".mp3" );
b_forced_demux = demux_IsForced( p_demux, "mp3" ) || b_forced_demux = demux_IsForced( p_demux, "mp3" ) ||
demux_IsForced( p_demux, "mpga" ); demux_IsForced( p_demux, "mpga" );
i_offset = stream_Tell( p_demux->s ); i_offset = stream_Tell( p_demux->s );
if( stream_Peek( p_demux->s, &p_peek, 4 ) < 4 )
if( WavSkipHeader( p_demux, &i_skip, pi_wav ) )
{
if( !b_forced_demux )
return VLC_EGENERIC; return VLC_EGENERIC;
if( !MpgaCheckSync( p_peek ) ) return VLC_EGENERIC;
}
if( stream_Peek( p_demux->s, &p_peek, i_skip + 4 ) < i_skip + 4 )
return VLC_EGENERIC;
if( !MpgaCheckSync( &p_peek[i_skip] ) )
{ {
bool b_ok = false; bool b_ok = false;
int i_peek; int i_peek;
...@@ -567,22 +578,20 @@ static int MpgaProbe( demux_t *p_demux, int64_t *pi_offset ) ...@@ -567,22 +578,20 @@ static int MpgaProbe( demux_t *p_demux, int64_t *pi_offset )
if( !b_forced_demux && !b_forced ) if( !b_forced_demux && !b_forced )
return VLC_EGENERIC; return VLC_EGENERIC;
i_peek = stream_Peek( p_demux->s, &p_peek, 8096 ); i_peek = stream_Peek( p_demux->s, &p_peek, i_skip + 8096 );
while( i_peek > 4 ) while( i_skip + 4 < i_peek )
{ {
if( MpgaCheckSync( p_peek ) ) if( MpgaCheckSync( &p_peek[i_skip] ) )
{ {
b_ok = true; b_ok = true;
break; break;
} }
p_peek += 1; i_skip++;
i_peek -= 1;
i_offset++;
} }
if( !b_ok && !b_forced_demux ) if( !b_ok && !b_forced_demux )
return VLC_EGENERIC; return VLC_EGENERIC;
} }
*pi_offset = i_offset; *pi_offset = i_offset + i_skip;
return VLC_SUCCESS; return VLC_SUCCESS;
} }
......
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