[vlc-devel] commit: When adding an URL, create the name without login and password. ( Rémi Duraffort )
git version control
git at videolan.org
Wed May 20 18:53:44 CEST 2009
vlc | branch: master | Rémi Duraffort <ivoire at videolan.org> | Sat May 16 23:37:10 2009 +0200| [1a77308678e53dddba8ddb6a9f3650774525e719] | committer: Rémi Duraffort
When adding an URL, create the name without login and password.
This fix partially #2142
> http://git.videolan.org/gitweb.cgi/vlc.git/?a=commit;h=1a77308678e53dddba8ddb6a9f3650774525e719
---
src/input/item.c | 28 +++++++++++++++++++++++++++-
1 files changed, 27 insertions(+), 1 deletions(-)
diff --git a/src/input/item.c b/src/input/item.c
index eac924c..c82b2a0 100644
--- a/src/input/item.c
+++ b/src/input/item.c
@@ -27,6 +27,7 @@
#include <assert.h>
#include <vlc_common.h>
+#include <vlc_url.h>
#include "vlc_playlist.h"
#include "vlc_interface.h"
@@ -367,8 +368,33 @@ void input_item_SetURI( input_item_t *p_i, const char *psz_uri )
p_i->psz_name = strdup( psz_filename );
}
+ /* The name is NULL: fill it with everything except login and password */
if( !p_i->psz_name )
- p_i->psz_name = strdup( p_i->psz_uri );
+ {
+ vlc_url_t url;
+ vlc_UrlParse( &url, psz_uri, 0 );
+ if( url.psz_protocol )
+ {
+ if( url.i_port > 0 )
+ asprintf( &p_i->psz_name, "%s://%s:%d%s", url.psz_protocol,
+ url.psz_host, url.i_port,
+ url.psz_path ? url.psz_path : "" );
+ else
+ asprintf( &p_i->psz_name, "%s://%s%s", url.psz_protocol,
+ url.psz_host ? url.psz_host : "",
+ url.psz_path ? url.psz_path : "" );
+ }
+ else
+ {
+ if( url.i_port > 0 )
+ asprintf( &p_i->psz_name, "%s:%d%s", url.psz_host, url.i_port,
+ url.psz_path ? url.psz_path : "" );
+ else
+ asprintf( &p_i->psz_name, "%s%s", url.psz_host,
+ url.psz_path ? url.psz_path : "" );
+ }
+ vlc_UrlClean( &url );
+ }
vlc_mutex_unlock( &p_i->lock );
}
More information about the vlc-devel
mailing list