mirror of
https://github.com/tomahawk-player/tomahawk.git
synced 2025-08-14 18:14:50 +02:00
Use a hashmap for state tracking.
This commit is contained in:
@@ -46,7 +46,11 @@ DownloadManager::DownloadManager()
|
|||||||
QVariantList downloads = TomahawkSettings::instance()->downloadStates();
|
QVariantList downloads = TomahawkSettings::instance()->downloadStates();
|
||||||
foreach ( const QVariant& download, downloads )
|
foreach ( const QVariant& download, downloads )
|
||||||
{
|
{
|
||||||
m_downloadStates << download.toMap();
|
QVariantMap map = download.toMap();
|
||||||
|
QString localFile = map[ "localfile" ].toString();
|
||||||
|
QFileInfo fi( localFile );
|
||||||
|
if ( fi.exists() )
|
||||||
|
m_downloadStates[ map[ "url" ].toString() ] = map;
|
||||||
}
|
}
|
||||||
|
|
||||||
QTimer::singleShot( 0, this, SLOT( resumeJobs() ) );
|
QTimer::singleShot( 0, this, SLOT( resumeJobs() ) );
|
||||||
@@ -64,17 +68,15 @@ DownloadManager::~DownloadManager()
|
|||||||
QString
|
QString
|
||||||
DownloadManager::localFileForDownload( const QString& url ) const
|
DownloadManager::localFileForDownload( const QString& url ) const
|
||||||
{
|
{
|
||||||
foreach ( const QVariantMap& map, m_downloadStates )
|
if ( m_downloadStates.contains( url ) )
|
||||||
{
|
{
|
||||||
tDebug() << "Found known download:" << map["url"] << map["localfile"];
|
QVariantMap map = m_downloadStates[ url ];
|
||||||
tDebug() << "Looking for download:" << url;
|
// tDebug() << "Found known download:" << map["url"] << map["localfile"];
|
||||||
if ( map[ "url" ].toString() == url )
|
// tDebug() << "Looking for download:" << url;
|
||||||
{
|
QString localFile = map[ "localfile" ].toString();
|
||||||
QString localFile = map[ "localfile" ].toString();
|
QFileInfo fi( localFile );
|
||||||
QFileInfo fi( localFile );
|
if ( fi.exists() )
|
||||||
if ( fi.exists() )
|
return localFile;
|
||||||
return localFile;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return QString();
|
return QString();
|
||||||
@@ -94,7 +96,7 @@ DownloadManager::storeJobs( const QList<downloadjob_ptr>& jobs )
|
|||||||
map[ "url" ] = job->format().url;
|
map[ "url" ] = job->format().url;
|
||||||
map[ "localfile" ] = job->localFile();
|
map[ "localfile" ] = job->localFile();
|
||||||
|
|
||||||
m_downloadStates << map;
|
m_downloadStates[ map[ "url" ].toString() ] = map;
|
||||||
downloads << map;
|
downloads << map;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -67,7 +67,7 @@ private slots:
|
|||||||
private:
|
private:
|
||||||
QList< downloadjob_ptr > m_jobs;
|
QList< downloadjob_ptr > m_jobs;
|
||||||
bool m_globalState;
|
bool m_globalState;
|
||||||
QList<QVariantMap> m_downloadStates;
|
QHash<QString, QVariantMap> m_downloadStates;
|
||||||
|
|
||||||
static DownloadManager* s_instance;
|
static DownloadManager* s_instance;
|
||||||
};
|
};
|
||||||
|
Reference in New Issue
Block a user