Summary: | Playlist length, modified by enqueing tracks in dynamic mode doesn't get resized after playing. | ||
---|---|---|---|
Product: | [Applications] amarok | Reporter: | Lorenz Röhrl <sheepshit> |
Component: | Playlist | Assignee: | Amarok Developers <amarok-bugs-dist> |
Status: | RESOLVED FIXED | ||
Severity: | normal | CC: | baum-im-wald, richlv |
Priority: | NOR | ||
Version: | 1.4-SVN | ||
Target Milestone: | --- | ||
Platform: | Gentoo Packages | ||
OS: | Linux | ||
Latest Commit: | Version Fixed In: | ||
Sentry Crash Report: |
Description
Lorenz Röhrl
2006-03-28 20:12:02 UTC
Not just enqueuing, but adding a track to the playlist in any way. When listening to a playlist, I often look at the suggested tracks or even artists and add a song, two, or a whole album. I can easily get into a mode where there are 50 tracks in the playlist and dynamic mode is still adding them even though I only ask for 10. see also bug 113276 i'd really like to see dynamic playlist add songs only if the playlist length is less than upcoming tracks, not on every chance - i quite often find myself in a situation described by eric. Yes, this would be really nice. I have quite a big collection playing in dynamic random mode. This random mode helps me determine what album to enqueue. This leads to a rapidly growing playlist that I must clean up every now and then if I want it to remain useable. From the described usage I would expect it to behave another way: I would expect tracks being added automatically only if the current track length becomes less then the number specified in the upcoming tracks. I would not like to get manual additions rejected because the upcoming tracks size is exceeded. Scenario would be: playlist shows 5 upcoming tracks, limit is five. Each time a song finished, a new one is added automatically. Now user adds manually an album with 10 tracks, playlist now contains 15. The next 10 times a track finishes, no track is added automatically but on the 11th one this starts again ... This way someone may add tracks without removing others (evtl. being added manually by someone else) but the playlist keeps somehow limited. Just my few cents on this. well, i guess most amarok users would see it work that way, but current behaviour is only annoying, not unbearable. a somewhat related issue to dynamic playlist length management is registered at bug 132447. that behaviour is exactly opposite if current adding of tracks - it overzealously reduces length. having both these issues resolved the way suggested would make dynamic playlist usage more pleasant indeed. SVN commit 604569 by seb: * Don't remove tracks from the playlist when reducing the upcoming count of the current dynamic mode * Only append tracks to the playlist if the playlist track count is greater than dynamic mode upcoming count BUG: 132447 BUG: 124440 M +13 -29 playlist.cpp --- trunk/extragear/multimedia/amarok/src/playlist.cpp #604568:604569 @@ -617,8 +617,6 @@ void Playlist::adjustDynamicUpcoming( bool saveUndo ) { - int x = 0; - /** * If m_currentTrack exists, we iterate until we find it * Else, we iterate until we find an item which is enabled @@ -636,36 +634,16 @@ if( m_currentTrack ) ++it; - + int x = 0; for ( ; *it && x < dynamicMode()->upcomingCount() ; ++it, ++x ); if ( x < dynamicMode()->upcomingCount() ) { addDynamicModeTracks( dynamicMode()->upcomingCount() - x ); } - else - { - if( isLocked() ) return; - //assemble a list of what needs removing - //calling removeItem() iteratively is more efficient if they are in _reverse_ order, hence the prepend() - QPtrList<QListViewItem> list; - for ( ; *it ; ++it ) { - list.append( it.current() ); - } - - if( list.isEmpty() ) return; - if( saveUndo ) - saveUndoState(); - - //remove the items - for( QListViewItem *item = list.last(); item; item = list.prev() ) - { - removeItem( static_cast<PlaylistItem*>( item ) ); - delete item; - } - //NOTE no need to emit childCountChanged(), removeItem() does that for us - } + if( saveUndo ) + saveUndoState(); } /** @@ -1212,13 +1190,15 @@ MyIterator it( this, MyIterator::Visible ); if( !item ) item = currentTrack(); - for( int x=0 ; *it; ++it, x++ ) + int x = 0; + for( ; *it; ++it, x++ ) { if( *it == item ) { for ( PlaylistItem *first = firstChild(); dynamicMode()->cycleTracks() && x >= dynamicMode()->previousCount() && first; - first = firstChild(), x-- ) { + first = firstChild(), x-- ) + { removeItem( first ); //first visible item delete first; } @@ -1226,9 +1206,13 @@ } } - //Just starting to play from stopped, don't append something needlessely - bool dontAppend = EngineController::instance()->engine()->state() == Engine::Empty; + const int upcomingTracks = childCount() - x; + // Just starting to play from stopped, don't append something needlessely + // or, we have more than enough items in the queue. + bool dontAppend = ( EngineController::instance()->engine()->state() == Engine::Empty ) || + upcomingTracks >= dynamicMode()->upcomingCount(); + //keep upcomingTracks requirement, this seems to break StopAfterCurrent if( !dontAppend && m_stopAfterTrack != m_currentTrack ) { |