From 73b5f5312a00236f264403e995d268641212b61f Mon Sep 17 00:00:00 2001 From: trialuser02 Date: Fri, 23 Aug 2013 08:12:25 +0000 Subject: improved sorting implementation git-svn-id: http://svn.code.sf.net/p/qmmp-dev/code/trunk/qmmp@3648 90c681e8-e032-0410-971d-27865f9a5e38 --- src/qmmpui/playlistcontainer.cpp | 43 ++++------------------------------------ 1 file changed, 4 insertions(+), 39 deletions(-) (limited to 'src/qmmpui/playlistcontainer.cpp') diff --git a/src/qmmpui/playlistcontainer.cpp b/src/qmmpui/playlistcontainer.cpp index 0952b2e9c..cb774726c 100644 --- a/src/qmmpui/playlistcontainer.cpp +++ b/src/qmmpui/playlistcontainer.cpp @@ -30,34 +30,6 @@ void PlayListContainer::addTracks(QList tracks) addTrack(t); } -void PlayListContainer::sort(int mode) -{ - QList tracks = takeAllTracks(); - doSort(mode, tracks); - addTracks(tracks); -} - -void PlayListContainer::sortSelection(int mode) -{ - QList tracks = takeAllTracks(); - QList selected_tracks; - QList selected_indexes; - for(int i = 0; i < tracks.count(); ++i) - { - if(tracks[i]->isSelected()) - { - selected_tracks.append(tracks[i]); - selected_indexes.append(i); - } - } - doSort(mode, selected_tracks); - - for (int i = 0; i < selected_indexes.count(); i++) - tracks.replace(selected_indexes[i], selected_tracks[i]); - - addTracks(tracks); -} - ////===============THE BEGINNING OF SORT IMPLEMENTATION =======================//// // First we'll implement bundle of static compare procedures @@ -168,7 +140,7 @@ static bool _fileModificationDateGreaterComparator(PlayListTrack* s1,PlayListTra return QFileInfo(s1->value(Qmmp::URL)).lastModified() > QFileInfo(s2->value(Qmmp::URL)).lastModified(); } -void PlayListContainer::doSort(int sort_mode, QList& list_to_sort) +void PlayListContainer::doSort(int sort_mode, QList& list_to_sort, bool reverted) { QList::iterator begin; QList::iterator end; @@ -226,17 +198,10 @@ void PlayListContainer::doSort(int sort_mode, QList& list_to_sor compareGreaterFunc = _titleGreaterComparator; } - static bool sorted_asc = false; - if (!sorted_asc) - { - qStableSort(begin,end,compareLessFunc); - sorted_asc = true; - } - else - { + if(reverted) qStableSort(begin,end,compareGreaterFunc); - sorted_asc = false; - } + else + qStableSort(begin,end,compareLessFunc); } ////=============== THE END OF SORT IMPLEMENTATION =======================//// -- cgit v1.2.3-13-gbd6f