Commit a43c6c83 authored by Rémi Denis-Courmont's avatar Rémi Denis-Courmont

smooth: memory leak

parent c84703a1
...@@ -72,41 +72,37 @@ static int Control( stream_t *, int , va_list ); ...@@ -72,41 +72,37 @@ static int Control( stream_t *, int , va_list );
static bool isSmoothStreaming( stream_t *s ) static bool isSmoothStreaming( stream_t *s )
{ {
const uint8_t *peek; const uint8_t *peek;
const char *needle = "<SmoothStreamingMedia";
const char *encoding = NULL;
bool ret = false;
int i_size = stream_Peek( s->p_source, &peek, 512 ); int i_size = stream_Peek( s->p_source, &peek, 512 );
if( i_size < 512 ) if( i_size < 512 )
return false; return false;
char *peeked = malloc( 512 ); char *peeked = malloc( 512 );
if( unlikely( !peeked ) ) if( unlikely( peeked == NULL ) )
return false; return false;
memcpy( peeked, peek, 512 ); memcpy( peeked, peek, 512 );
peeked[511] = peeked[510] = '\0'; peeked[511] = peeked[510] = '\0';
if( strstr( (const char *)peeked, needle ) != NULL ) char *str;
ret = true;
else
/* maybe it's utf-16 encoding, should we also test other encodings? */
{
if( !memcmp( peeked, "\xFF\xFE", 2 ) ) if( !memcmp( peeked, "\xFF\xFE", 2 ) )
encoding = "UTF-16LE"; {
str = FromCharset( "UTF-16LE", peeked, 512 );
free( peeked );
}
else if( !memcmp( peeked, "\xFE\xFF", 2 ) ) else if( !memcmp( peeked, "\xFE\xFF", 2 ) )
encoding = "UTF-16BE";
else
{ {
str = FromCharset( "UTF-16BE", peeked, 512 );
free( peeked ); free( peeked );
return false;
} }
peeked = FromCharset( encoding, peeked, 512 ); else
str = peeked;
if( peeked != NULL && strstr( peeked, needle ) != NULL ) if( str == NULL )
ret = true; return false;
}
free( peeked ); bool ret = strstr( str, "<SmoothStreamingMedia" ) != NULL;
free( str );
return ret; return ret;
} }
......
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