Commit dc3b3c39 authored by Derk-Jan Hartman's avatar Derk-Jan Hartman

* modules/demux/util/sub.c: Fixed a crash when trying to autodetect files

  that don't have a . char in their name. Also fixed a problem where the
  code was trying to open a empty string subtitle after autodetect couldn't
  find a suitable filename.
parent 17f8ae60
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* sub.c * sub.c
***************************************************************************** *****************************************************************************
* Copyright (C) 1999-2003 VideoLAN * Copyright (C) 1999-2003 VideoLAN
* $Id: sub.c,v 1.21 2003/08/23 19:20:29 hartman Exp $ * $Id: sub.c,v 1.22 2003/08/23 22:02:45 hartman Exp $
* *
* Authors: Laurent Aimar <fenrir@via.ecp.fr> * Authors: Laurent Aimar <fenrir@via.ecp.fr>
* *
...@@ -294,8 +294,13 @@ char* sub_detect( subtitle_demux_t *p_sub, char *psz_filename) ...@@ -294,8 +294,13 @@ char* sub_detect( subtitle_demux_t *p_sub, char *psz_filename)
int i_found = 0; int i_found = 0;
while(( p_dir_afile = readdir( p_dir_handle ))) { while(( p_dir_afile = readdir( p_dir_handle ))) {
char* psz_afile_ext = strrchr( p_dir_afile->d_name, '.' );
if( psz_afile_ext )
{
++psz_afile_ext;
for (i = 0; ppsz_sub_exts[i]; i++) { for (i = 0; ppsz_sub_exts[i]; i++) {
if( strcmp( ppsz_sub_exts[i], 1 + strrchr( p_dir_afile->d_name, '.' ) ) == 0 ) { if( strcmp( ppsz_sub_exts[i], psz_afile_ext ) == 0 ) {
i_found = 1; i_found = 1;
break; break;
} }
...@@ -315,6 +320,7 @@ char* sub_detect( subtitle_demux_t *p_sub, char *psz_filename) ...@@ -315,6 +320,7 @@ char* sub_detect( subtitle_demux_t *p_sub, char *psz_filename)
else return strdup( p_dir_afile->d_name ); else return strdup( p_dir_afile->d_name );
} }
} }
}
closedir( p_dir_handle ); closedir( p_dir_handle );
} }
...@@ -346,16 +352,14 @@ static int sub_open ( subtitle_demux_t *p_sub, ...@@ -346,16 +352,14 @@ static int sub_open ( subtitle_demux_t *p_sub,
if( !psz_name || !*psz_name) if( !psz_name || !*psz_name)
{ {
msg_Dbg( p_sub, "variable psz_name empty" );
var_Get( p_sub, "sub-file", &val ); var_Get( p_sub, "sub-file", &val );
if( !val.psz_string || !*val.psz_string ) if( !val.psz_string || !*val.psz_string )
{ {
msg_Dbg( p_sub, "variable sub-file empty too" );
var_Get( p_sub, "sub-autodetect-file", &val ); var_Get( p_sub, "sub-autodetect-file", &val );
if( val.b_bool ) if( val.b_bool )
{ {
msg_Dbg( p_sub, "lets try autodetect" );
psz_name = strdup( sub_detect( p_sub, p_input->psz_source)); psz_name = strdup( sub_detect( p_sub, p_input->psz_source));
if( !psz_name || !*psz_name ) return VLC_EGENERIC;
} }
else else
{ {
......
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