Commit e3d08b79 authored by Geoffroy Couprie's avatar Geoffroy Couprie

zip access: fix #2467. Now it's able to open files with non ASCII names, but...

zip access: fix #2467. Now it's able to open files with non ASCII names, but can't open files with non ASCII names inside of the zip file
parent ae3edf03
...@@ -64,7 +64,7 @@ int AccessOpen( vlc_object_t *p_this ) ...@@ -64,7 +64,7 @@ int AccessOpen( vlc_object_t *p_this )
int i_ret = VLC_EGENERIC; int i_ret = VLC_EGENERIC;
unzFile file = 0; unzFile file = 0;
char *psz_pathToZip = NULL, *psz_path = NULL, *psz_sep = NULL; char *psz_path = NULL, *psz_sep = NULL;
p_access->p_sys = p_sys = (access_sys_t*) p_access->p_sys = p_sys = (access_sys_t*)
calloc( 1, sizeof( access_sys_t ) ); calloc( 1, sizeof( access_sys_t ) );
...@@ -78,7 +78,6 @@ int AccessOpen( vlc_object_t *p_this ) ...@@ -78,7 +78,6 @@ int AccessOpen( vlc_object_t *p_this )
return VLC_EGENERIC; return VLC_EGENERIC;
*psz_sep = '\0'; *psz_sep = '\0';
psz_pathToZip = unescape_URI_duplicate( psz_path );
p_sys->psz_fileInzip = strdup( psz_sep + 1 ); p_sys->psz_fileInzip = strdup( psz_sep + 1 );
/* Define IO functions */ /* Define IO functions */
...@@ -94,10 +93,10 @@ int AccessOpen( vlc_object_t *p_this ) ...@@ -94,10 +93,10 @@ int AccessOpen( vlc_object_t *p_this )
p_func->opaque = p_access; p_func->opaque = p_access;
/* Open zip archive */ /* Open zip archive */
file = p_access->p_sys->zipFile = unzOpen2( psz_pathToZip, p_func ); file = p_access->p_sys->zipFile = unzOpen2( psz_path, p_func );
if( !file ) if( !file )
{ {
msg_Err( p_access, "not a valid zip archive: '%s'", psz_pathToZip ); msg_Err( p_access, "not a valid zip archive: '%s'", psz_path );
goto exit; goto exit;
} }
...@@ -131,7 +130,6 @@ exit: ...@@ -131,7 +130,6 @@ exit:
free( p_sys ); free( p_sys );
} }
free( psz_pathToZip );
free( psz_path ); free( psz_path );
return i_ret; return i_ret;
} }
......
...@@ -488,8 +488,8 @@ static int WriteXSPF( char **pp_buffer, vlc_array_t *p_filenames, ...@@ -488,8 +488,8 @@ static int WriteXSPF( char **pp_buffer, vlc_array_t *p_filenames,
/* Root node */ /* Root node */
node *playlist = new_node( psz_zip ); node *playlist = new_node( psz_zip );
/* Web-Encode the URI and append '!' */ /* Web-Encode the URI and append '|' */
char *psz_pathtozip = vlc_UrlEncode( psz_zippath ); char *psz_pathtozip = make_URI( psz_zippath );
if( astrcatf( &psz_pathtozip, ZIP_SEP ) < 0 ) return -1; if( astrcatf( &psz_pathtozip, ZIP_SEP ) < 0 ) return -1;
int i_track = 0; int i_track = 0;
...@@ -516,11 +516,6 @@ static int WriteXSPF( char **pp_buffer, vlc_array_t *p_filenames, ...@@ -516,11 +516,6 @@ static int WriteXSPF( char **pp_buffer, vlc_array_t *p_filenames,
char *psz_path = strdup( psz_pathtozip ); char *psz_path = strdup( psz_pathtozip );
if( astrcatf( &psz_path, psz_name ) < 0 ) return -1; if( astrcatf( &psz_path, psz_name ) < 0 ) return -1;
/* Double url-encode */
char *psz_tmp = psz_path;
psz_path = vlc_UrlEncode( psz_tmp );
free( psz_tmp );
/* Track information */ /* Track information */
if( astrcatf( pp_buffer, if( astrcatf( pp_buffer,
" <track>\n" " <track>\n"
...@@ -572,8 +567,6 @@ static int WriteXSPF( char **pp_buffer, vlc_array_t *p_filenames, ...@@ -572,8 +567,6 @@ static int WriteXSPF( char **pp_buffer, vlc_array_t *p_filenames,
/* Close extension and playlist */ /* Close extension and playlist */
if( astrcatf( pp_buffer, " </extension>\n</playlist>\n" ) < 0 ) return -1; if( astrcatf( pp_buffer, " </extension>\n</playlist>\n" ) < 0 ) return -1;
/* printf( "%s", *pp_buffer ); */
free_all_node( playlist ); free_all_node( playlist );
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