mirror of
https://github.com/tomahawk-player/tomahawk.git
synced 2025-04-04 16:12:24 +02:00
more fixes
This commit is contained in:
parent
f414e92b74
commit
704c736046
@ -185,7 +185,11 @@ SpotifyAccount::resolverMessage( const QString &msgType, const QVariantMap &msg
|
||||
return;
|
||||
|
||||
SpotifyPlaylistUpdater* updater = m_updaters[ plid ];
|
||||
Q_ASSERT( updater->sync() );
|
||||
|
||||
// If we're not syncing with this, the resolver is quite misinformed.
|
||||
Q_ASSERT( updater && updater->sync() );
|
||||
if ( !updater || !updater->sync() )
|
||||
return;
|
||||
|
||||
const QVariantList tracksList = msg.value( "trackPositions" ).toList();
|
||||
const QString newRev = msg.value( "revid" ).toString();
|
||||
|
@ -142,6 +142,12 @@ SpotifyPlaylistUpdater::sync() const
|
||||
void
|
||||
SpotifyPlaylistUpdater::spotifyTracksAdded( const QVariantList& tracks, const QString& startPosId, const QString& newRev, const QString& oldRev )
|
||||
{
|
||||
if ( m_plRevisionBeforeSpotifyUpdate == playlist()->currentrevision() )
|
||||
{
|
||||
m_plRevisionBeforeSpotifyUpdate.clear();
|
||||
return;
|
||||
}
|
||||
|
||||
const QList< query_ptr > queries = variantToQueries( tracks );
|
||||
|
||||
qDebug() << Q_FUNC_INFO << "inserting tracks in middle of tomahawk playlist, from spotify command!" << tracks << startPosId << newRev << oldRev;
|
||||
@ -164,7 +170,7 @@ SpotifyPlaylistUpdater::spotifyTracksAdded( const QVariantList& tracks, const QS
|
||||
pos = entries.size();
|
||||
|
||||
qDebug() << Q_FUNC_INFO << "inserting tracks at position:" << pos;
|
||||
m_plRevisionBeforeUpdate = playlist()->currentrevision();
|
||||
m_plRevisionBeforeTomahawkUpdate = playlist()->currentrevision();
|
||||
|
||||
playlist()->insertEntries( queries, pos, playlist()->currentrevision() );
|
||||
}
|
||||
@ -173,6 +179,12 @@ SpotifyPlaylistUpdater::spotifyTracksAdded( const QVariantList& tracks, const QS
|
||||
void
|
||||
SpotifyPlaylistUpdater::spotifyTracksRemoved( const QVariantList& trackIds, const QString& newRev, const QString& oldRev )
|
||||
{
|
||||
if ( m_plRevisionBeforeSpotifyUpdate == playlist()->currentrevision() )
|
||||
{
|
||||
m_plRevisionBeforeSpotifyUpdate.clear();
|
||||
return;
|
||||
}
|
||||
|
||||
qDebug() << Q_FUNC_INFO << "remove tracks in middle of tomahawk playlist, from spotify command!" << trackIds << newRev << oldRev;
|
||||
// Uh oh, dont' want to get out of sync!!
|
||||
// Q_ASSERT( m_latestRev == oldRev );
|
||||
@ -207,7 +219,7 @@ SpotifyPlaylistUpdater::spotifyTracksRemoved( const QVariantList& trackIds, cons
|
||||
entries.removeAll( torm );
|
||||
|
||||
|
||||
m_plRevisionBeforeUpdate = playlist()->currentrevision();
|
||||
m_plRevisionBeforeTomahawkUpdate = playlist()->currentrevision();
|
||||
|
||||
const int sizeDiff = playlist()->entries().size() - entries.size();
|
||||
qDebug() << "We were asked to delete:" << trackIds.size() << "tracks from the playlist, and we deleted:" << sizeDiff;
|
||||
@ -229,9 +241,10 @@ SpotifyPlaylistUpdater::spotifyTracksMoved( const QVariantList& tracks, const QS
|
||||
void
|
||||
SpotifyPlaylistUpdater::tomahawkTracksInserted( const QList< plentry_ptr >& tracks, int pos )
|
||||
{
|
||||
if ( playlist()->currentrevision() == m_plRevisionBeforeUpdate )
|
||||
if ( playlist()->currentrevision() == m_plRevisionBeforeTomahawkUpdate )
|
||||
{
|
||||
// We did the insert. Don't get in an infinite loop!
|
||||
m_plRevisionBeforeTomahawkUpdate.clear();
|
||||
return;
|
||||
}
|
||||
|
||||
@ -270,6 +283,7 @@ SpotifyPlaylistUpdater::tomahawkTracksInserted( const QList< plentry_ptr >& trac
|
||||
}
|
||||
msg[ "tracks" ] = tracksJson;
|
||||
|
||||
m_plRevisionBeforeSpotifyUpdate = playlist()->currentrevision();
|
||||
m_spotify->sendMessage( msg, this, "onTracksInsertedReturn" );
|
||||
}
|
||||
|
||||
@ -287,6 +301,14 @@ SpotifyPlaylistUpdater::onTracksInsertedReturn( const QString& msgType, const QV
|
||||
void
|
||||
SpotifyPlaylistUpdater::tomahawkTracksRemoved( const QList< query_ptr >& tracks )
|
||||
{
|
||||
|
||||
if ( playlist()->currentrevision() == m_plRevisionBeforeTomahawkUpdate )
|
||||
{
|
||||
// We did the insert. Don't get in an infinite loop!
|
||||
m_plRevisionBeforeTomahawkUpdate.clear();
|
||||
return;
|
||||
}
|
||||
|
||||
qDebug() << Q_FUNC_INFO << "updating spotify resolver with removed tracks:" << tracks;
|
||||
QVariantMap msg;
|
||||
msg[ "_msgtype" ] = "removeTracksFromPlaylist";
|
||||
@ -294,6 +316,7 @@ SpotifyPlaylistUpdater::tomahawkTracksRemoved( const QList< query_ptr >& tracks
|
||||
msg[ "oldrev" ] = m_latestRev;
|
||||
msg[ "tracks" ] = queriesToVariant( tracks );
|
||||
|
||||
m_plRevisionBeforeSpotifyUpdate = playlist()->currentrevision();
|
||||
m_spotify->sendMessage( msg, this, "onTracksRemovedReturn" );
|
||||
}
|
||||
|
||||
|
@ -75,7 +75,7 @@ private:
|
||||
|
||||
Tomahawk::Accounts::SpotifyAccount* m_spotify;
|
||||
QString m_latestRev, m_spotifyId;
|
||||
QString m_plRevisionBeforeUpdate;
|
||||
QString m_plRevisionBeforeTomahawkUpdate, m_plRevisionBeforeSpotifyUpdate;
|
||||
bool m_sync;
|
||||
};
|
||||
|
||||
|
@ -134,6 +134,18 @@ DatabaseCommand_SetPlaylistRevision::exec( DatabaseImpl* lib )
|
||||
}
|
||||
else
|
||||
{
|
||||
// DEBUG only
|
||||
qDebug() << "Current entries in the playlist_item table for this playlist:" << m_playlistguid;
|
||||
TomahawkSqlQuery q = lib->newquery();
|
||||
q.prepare( "SELECT guid, playlist, trackname, artistname, annotation FROM playlist_item WHERE playlist = ?" );
|
||||
q.addBindValue( m_playlistguid );
|
||||
if ( q.exec() )
|
||||
{
|
||||
while ( q.next() )
|
||||
{
|
||||
qDebug() << "====" << q.value( 0 ).toString() << q.value( 1 ).toString() << q.value( 2 ).toString() << q.value( 3 ).toString() << q.value( 4 ).toString() << "====";
|
||||
}
|
||||
}
|
||||
QString sql = "INSERT INTO playlist_item( guid, playlist, trackname, artistname, albumname, "
|
||||
"annotation, duration, addedon, addedby, result_hint ) "
|
||||
"VALUES( ?, ?, ?, ?, ?, ?, ?, ?, ?, ? )";
|
||||
@ -142,6 +154,8 @@ DatabaseCommand_SetPlaylistRevision::exec( DatabaseImpl* lib )
|
||||
qDebug() << "Num new playlist_items to add:" << m_addedentries.length();
|
||||
foreach( const plentry_ptr& e, m_addedentries )
|
||||
{
|
||||
qDebug() << "Adding:" << e->guid() << e->query()->track() << e->query()->artist();
|
||||
|
||||
m_addedmap.insert( e->guid(), e ); // needed in postcommithook
|
||||
|
||||
QString resultHint;
|
||||
|
@ -2,6 +2,7 @@
|
||||
*
|
||||
* Copyright 2010-2011, Christian Muehlhaeuser <muesli@tomahawk-player.org>
|
||||
* Copyright 2010-2011, Jeff Mitchell <jeff@tomahawk-player.org>
|
||||
* Copyright 2010-2011, Leo Franchi <lfranchi@kde.org>
|
||||
*
|
||||
* Tomahawk is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
|
@ -1,6 +1,7 @@
|
||||
/* === This file is part of Tomahawk Player - <http://tomahawk-player.org> ===
|
||||
*
|
||||
* Copyright 2010-2011, Christian Muehlhaeuser <muesli@tomahawk-player.org>
|
||||
* Copyright 2010-2011, Leo Franchi <lfranchi@kde.org>
|
||||
*
|
||||
* Tomahawk is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
|
Loading…
x
Reference in New Issue
Block a user