Commit 1a29c863 authored by Benjamin Pracht's avatar Benjamin Pracht

* Try the gnomevfs plugin last if we didn't find any other matching access

* Now MRLs such as ssh://user:pass@server work.
parent 2caff730
...@@ -70,7 +70,7 @@ vlc_module_begin(); ...@@ -70,7 +70,7 @@ vlc_module_begin();
set_category( CAT_INPUT ); set_category( CAT_INPUT );
set_subcategory( SUBCAT_INPUT_ACCESS ); set_subcategory( SUBCAT_INPUT_ACCESS );
add_integer( "gnomevfs-caching", DEFAULT_PTS_DELAY / 1000, NULL, CACHING_TEXT, CACHING_LONGTEXT, VLC_TRUE ); add_integer( "gnomevfs-caching", DEFAULT_PTS_DELAY / 1000, NULL, CACHING_TEXT, CACHING_LONGTEXT, VLC_TRUE );
set_capability( "access2", 0 ); set_capability( "access2", 10 );
add_shortcut( "gnomevfs" ); add_shortcut( "gnomevfs" );
set_callbacks( Open, Close ); set_callbacks( Open, Close );
vlc_module_end(); vlc_module_end();
...@@ -103,7 +103,7 @@ static int Open( vlc_object_t *p_this ) ...@@ -103,7 +103,7 @@ static int Open( vlc_object_t *p_this )
{ {
access_t *p_access = (access_t*)p_this; access_t *p_access = (access_t*)p_this;
access_sys_t *p_sys; access_sys_t *p_sys;
char *psz_name = strdup( p_access->psz_path ); char *psz_name;
char *psz, *psz_uri; char *psz, *psz_uri;
GnomeVFSURI *p_uri; GnomeVFSURI *p_uri;
GnomeVFSResult i_ret; GnomeVFSResult i_ret;
...@@ -128,6 +128,20 @@ static int Open( vlc_object_t *p_this ) ...@@ -128,6 +128,20 @@ static int Open( vlc_object_t *p_this )
p_sys->i_nb_reads = 0; p_sys->i_nb_reads = 0;
p_sys->b_pace_control = VLC_TRUE; p_sys->b_pace_control = VLC_TRUE;
if( strcmp( "gnomevfs", p_access->psz_access ) )
{
psz_name = malloc( strlen( p_access->psz_access ) +
strlen( p_access->psz_path ) + 3 );
strcpy( psz_name, p_access->psz_access );
strcat( psz_name, "://" );
strcat( psz_name, p_access->psz_path );
}
else
{
psz_name = strdup( p_access->psz_path );
}
psz = ToLocale( psz_name ); psz = ToLocale( psz_name );
psz_uri = gnome_vfs_make_uri_from_input_with_dirs( psz, psz_uri = gnome_vfs_make_uri_from_input_with_dirs( psz,
GNOME_VFS_MAKE_URI_DIR_CURRENT); GNOME_VFS_MAKE_URI_DIR_CURRENT);
...@@ -136,20 +150,20 @@ static int Open( vlc_object_t *p_this ) ...@@ -136,20 +150,20 @@ static int Open( vlc_object_t *p_this )
if( p_uri ) if( p_uri )
{ {
i_ret = gnome_vfs_open( &(p_sys->p_handle), psz_uri, 5 ); p_sys->p_file_info = gnome_vfs_file_info_new();
i_ret = gnome_vfs_get_file_info_uri( p_uri,
p_sys->p_file_info, 8 );
if( i_ret ) if( i_ret )
{ {
msg_Warn( p_access, "cannot open file %s: %s", psz_name, msg_Err( p_access, "cannot get file info %s",
gnome_vfs_result_to_string( i_ret ) ); gnome_vfs_result_to_string( i_ret ) );
gnome_vfs_file_info_unref( p_sys->p_file_info );
LocaleFree( psz );
g_free( psz_uri );
gnome_vfs_uri_unref( p_uri); gnome_vfs_uri_unref( p_uri);
free( p_sys ); free( p_sys );
free( psz_name ); free( psz_name );
return VLC_EGENERIC; return VLC_EGENERIC;
} }
gnome_vfs_uri_unref( p_uri);
} }
else else
{ {
...@@ -161,17 +175,16 @@ static int Open( vlc_object_t *p_this ) ...@@ -161,17 +175,16 @@ static int Open( vlc_object_t *p_this )
return VLC_EGENERIC; return VLC_EGENERIC;
} }
LocaleFree( psz ); LocaleFree( psz );
g_free( psz_uri );
p_sys->p_file_info = gnome_vfs_file_info_new();
i_ret = gnome_vfs_get_file_info_from_handle( p_sys->p_handle,
p_sys->p_file_info, 8 );
i_ret = gnome_vfs_open( &(p_sys->p_handle), psz_uri, 5 );
if( i_ret ) if( i_ret )
{ {
msg_Err( p_access, "cannot get file info %s", msg_Warn( p_access, "cannot open file %s: %s", psz_name,
gnome_vfs_result_to_string( i_ret ) ); gnome_vfs_result_to_string( i_ret ) );
gnome_vfs_file_info_unref( p_sys->p_file_info );
LocaleFree( psz );
g_free( psz_uri );
gnome_vfs_uri_unref( p_uri);
free( p_sys ); free( p_sys );
free( psz_name ); free( psz_name );
return VLC_EGENERIC; return VLC_EGENERIC;
...@@ -214,7 +227,9 @@ static int Open( vlc_object_t *p_this ) ...@@ -214,7 +227,9 @@ static int Open( vlc_object_t *p_this )
var_Create( p_access, "gnomevfs-caching", var_Create( p_access, "gnomevfs-caching",
VLC_VAR_INTEGER | VLC_VAR_DOINHERIT ); VLC_VAR_INTEGER | VLC_VAR_DOINHERIT );
g_free( psz_uri );
p_sys->psz_name = psz_name; p_sys->psz_name = psz_name;
gnome_vfs_uri_unref( p_uri);
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