Commit 4a7e027c authored by Jean-Baptiste Kempf's avatar Jean-Baptiste Kempf

Qt: factorize directory opening

parent 7f2ce08c
...@@ -491,26 +491,8 @@ void DialogsProvider::openUrlDialog() ...@@ -491,26 +491,8 @@ void DialogsProvider::openUrlDialog()
**/ **/
static void openDirectory( intf_thread_t *p_intf, bool pl, bool go ) static void openDirectory( intf_thread_t *p_intf, bool pl, bool go )
{ {
QString dir = QFileDialog::getExistingDirectory( NULL, qtr( I_OP_DIR_WINTITLE ), p_intf->p_sys->filepath ); QString uri = DialogsProvider::getDirectoryDialog( p_intf );
if( !uri.isEmpty() )
if( dir.isEmpty() )
return;
p_intf->p_sys->filepath = dir;
const char *scheme = "directory";
if( dir.endsWith( DIR_SEP "VIDEO_TS", Qt::CaseInsensitive ) )
scheme = "dvd";
else if( dir.endsWith( DIR_SEP "BDMV", Qt::CaseInsensitive ) )
{
scheme = "bluray";
dir.remove( "BDMV" );
}
char *uri = vlc_path2uri( qtu( toNativeSeparators( dir ) ), scheme );
if( unlikely(uri == NULL) )
return;
Open::openMRL( p_intf, uri, go, pl ); Open::openMRL( p_intf, uri, go, pl );
} }
...@@ -533,7 +515,9 @@ QString DialogsProvider::getDirectoryDialog( intf_thread_t *p_intf ) ...@@ -533,7 +515,9 @@ QString DialogsProvider::getDirectoryDialog( intf_thread_t *p_intf )
} }
char *uri = vlc_path2uri( qtu( toNativeSeparators( dir ) ), scheme ); char *uri = vlc_path2uri( qtu( toNativeSeparators( dir ) ), scheme );
if( unlikely(uri == NULL) ) return QString(); if( unlikely(uri == NULL) )
return QString();
dir = qfu( uri ); dir = qfu( uri );
free( uri ); free( uri );
......
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