Commit f9c17d2c authored by Francois Cartegnie's avatar Francois Cartegnie

Qt: saveAPlaylist: fix file extension logic (fix #7578)

parent e10b52d5
...@@ -595,21 +595,56 @@ void DialogsProvider::saveAPlaylist() ...@@ -595,21 +595,56 @@ void DialogsProvider::saveAPlaylist()
} }
QString selected; QString selected;
QString file = QFileDialog::getSaveFileName( NULL,
qtr( "Save playlist as..." ), QFileDialog *dialog = new QFileDialog( NULL,
p_intf->p_sys->filepath, filters.join( ";;" ), qtr( "Save playlist as..." ),
&selected ); QString( p_intf->p_sys->filepath ),
filters.join( ";;" ) );
dialog->setDefaultSuffix( qfu( types[0].filter_patterns ) );
dialog->setAcceptMode( QFileDialog::AcceptSave );
dialog->exec();
QString file = dialog->selectedFiles().first();
QString nameFilter = dialog->selectedNameFilter();
const char *psz_selected_module = NULL;
const char *psz_last_playlist_ext = NULL;
delete dialog;
if( file.isEmpty() ) if( file.isEmpty() )
return; return;
/* First test if the file extension is set, and different to selected filter */
for( size_t i = 0; i < sizeof (types) / sizeof (types[0]); i++) for( size_t i = 0; i < sizeof (types) / sizeof (types[0]); i++)
if( selected == qfu( vlc_gettext( types[i].filter_name ) ) + " (*." + qfu( types[i].filter_patterns ) + ")" ) {
if ( file.endsWith( QString( "." ) + qfu( types[i].filter_patterns ) ) )
{ {
playlist_Export( THEPL, qtu( toNativeSeparators( file ) ), psz_selected_module = types[i].module;
THEPL->p_playing, types[i].module ); psz_last_playlist_ext = types[i].filter_patterns;
getSettings()->setValue( "last-playlist-ext", types[i].filter_patterns );
break; break;
} }
}
/* otherwise apply the selected extension */
if ( !psz_last_playlist_ext )
{
for( size_t i = 0; i < sizeof (types) / sizeof (types[0]); i++)
{
if ( nameFilter.startsWith( vlc_gettext( types[i].filter_name ) ) )
{
psz_selected_module = types[i].module;
psz_last_playlist_ext = types[i].filter_patterns;
/* Fix file extension */
file = file.append( QString( "." ) + qfu( psz_last_playlist_ext ) );
break;
}
}
}
if ( psz_selected_module )
{
playlist_Export( THEPL, qtu( toNativeSeparators( file ) ),
THEPL->p_playing, psz_selected_module );
getSettings()->setValue( "last-playlist-ext", psz_last_playlist_ext );
}
} }
/**************************************************************************** /****************************************************************************
......
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