1
0
mirror of https://github.com/tomahawk-player/tomahawk.git synced 2025-10-04 09:31:41 +02:00

Finish the work begun in 0c68f559 to make scanning more thread-safe

This commit is contained in:
Jeff Mitchell
2013-01-17 10:13:44 -05:00
parent a7f6a6e129
commit 8ea6d2dd96
4 changed files with 93 additions and 55 deletions

View File

@@ -35,6 +35,35 @@
#include <QTimer>
#include <QSet>
MusicScannerThreadController::MusicScannerThreadController( QObject* parent )
: QThread( parent )
, m_bs( 0 )
{
tDebug() << Q_FUNC_INFO;
}
MusicScannerThreadController::~MusicScannerThreadController()
{
tDebug() << Q_FUNC_INFO;
}
void
MusicScannerThreadController::run()
{
m_musicScanner = QPointer< MusicScanner >( new MusicScanner( m_mode, m_paths, m_bs ) );
connect( m_musicScanner.data(), SIGNAL( finished() ), parent(), SLOT( scannerFinished() ), Qt::QueuedConnection );
QMetaObject::invokeMethod( m_musicScanner.data(), "startScan", Qt::QueuedConnection );
exec();
if ( !m_musicScanner.isNull() )
delete m_musicScanner.data();
}
ScanManager* ScanManager::s_instance = 0;
@@ -50,7 +79,7 @@ ScanManager::ScanManager( QObject* parent )
, m_musicScannerThreadController( 0 )
, m_currScannerPaths()
, m_cachedScannerDirs()
, m_queuedScanType( None )
, m_queuedScanType( MusicScanner::None )
, m_updateGUI( true )
{
s_instance = this;
@@ -76,12 +105,11 @@ ScanManager::~ScanManager()
{
qDebug() << Q_FUNC_INFO;
if ( !m_scanner.isNull() )
if ( m_musicScannerThreadController )
{
m_musicScannerThreadController->quit();
m_musicScannerThreadController->wait( 60000 );
delete m_scanner.data();
delete m_musicScannerThreadController;
m_musicScannerThreadController = 0;
}
@@ -157,17 +185,17 @@ ScanManager::runNormalScan( bool manualFull )
tDebug( LOGVERBOSE ) << Q_FUNC_INFO;
if ( m_musicScannerThreadController || !m_scanner.isNull() ) //still running if these are not zero
if ( m_musicScannerThreadController ) //still running if these are not zero
{
if ( m_queuedScanType != Full )
m_queuedScanType = manualFull ? Full : Normal;
if ( m_queuedScanType != MusicScanner::Full )
m_queuedScanType = manualFull ? MusicScanner::Full : MusicScanner::Normal;
tDebug( LOGVERBOSE ) << "Could not run dir scan, old scan still running";
return;
}
m_scanTimer->stop();
m_musicScannerThreadController = new QThread( this );
m_currScanMode = DirScan;
m_musicScannerThreadController = new MusicScannerThreadController( this );
m_currScanMode = MusicScanner::DirScan;
if ( manualFull )
{
@@ -204,17 +232,17 @@ ScanManager::runFileScan( const QStringList& paths, bool updateGUI )
foreach( const QString& path, paths )
m_currScannerPaths.insert( path );
if ( m_musicScannerThreadController || !m_scanner.isNull() ) //still running if these are not zero
if ( m_musicScannerThreadController ) //still running if these are not zero
{
if ( m_queuedScanType == None )
m_queuedScanType = File;
if ( m_queuedScanType == MusicScanner::None )
m_queuedScanType = MusicScanner::File;
tDebug( LOGVERBOSE ) << "Could not run file scan, old scan still running";
return;
}
m_scanTimer->stop();
m_musicScannerThreadController = new QThread( this );
m_currScanMode = FileScan;
m_musicScannerThreadController = new MusicScannerThreadController( this );
m_currScanMode = MusicScanner::FileScan;
m_updateGUI = updateGUI;
QMetaObject::invokeMethod( this, "runScan", Qt::QueuedConnection );
@@ -224,7 +252,7 @@ ScanManager::runFileScan( const QStringList& paths, bool updateGUI )
void
ScanManager::fileMtimesCheck( const QMap< QString, QMap< unsigned int, unsigned int > >& mtimes )
{
if ( !mtimes.isEmpty() && m_currScanMode == DirScan && TomahawkSettings::instance()->scannerPaths().isEmpty() )
if ( !mtimes.isEmpty() && m_currScanMode == MusicScanner::DirScan && TomahawkSettings::instance()->scannerPaths().isEmpty() )
{
DatabaseCommand_DeleteFiles *cmd = new DatabaseCommand_DeleteFiles( SourceList::instance()->getLocal() );
connect( cmd, SIGNAL( finished() ), SLOT( filesDeleted() ) );
@@ -253,14 +281,9 @@ ScanManager::runScan()
QStringList paths = m_currScannerPaths.empty() ? TomahawkSettings::instance()->scannerPaths() : m_currScannerPaths.toList();
if ( m_musicScannerThreadController && m_scanner.isNull() )
{
m_scanner = QPointer< MusicScanner >( new MusicScanner( m_currScanMode, paths ) );
m_scanner.data()->moveToThread( m_musicScannerThreadController );
connect( m_scanner.data(), SIGNAL( finished() ), SLOT( scannerFinished() ) );
m_musicScannerThreadController->start( QThread::IdlePriority );
QMetaObject::invokeMethod( m_scanner.data(), "startScan" );
}
m_musicScannerThreadController->setScanMode( m_currScanMode );
m_musicScannerThreadController->setPaths( paths );
m_musicScannerThreadController->start( QThread::IdlePriority );
}
@@ -268,14 +291,11 @@ void
ScanManager::scannerFinished()
{
tLog( LOGVERBOSE ) << Q_FUNC_INFO;
if ( !m_scanner.isNull() || m_musicScannerThreadController )
if ( m_musicScannerThreadController )
{
m_musicScannerThreadController->quit();
m_musicScannerThreadController->wait( 60000 );
if ( !m_scanner.isNull() )
delete m_scanner.data();
delete m_musicScannerThreadController;
m_musicScannerThreadController = 0;
}
@@ -284,21 +304,21 @@ ScanManager::scannerFinished()
m_updateGUI = true;
emit finished();
if ( m_queuedScanType != File )
if ( m_queuedScanType != MusicScanner::File )
m_currScannerPaths.clear();
switch ( m_queuedScanType )
{
case Full:
case Normal:
QMetaObject::invokeMethod( this, "runNormalScan", Qt::QueuedConnection, Q_ARG( bool, m_queuedScanType == Full ) );
case MusicScanner::Full:
case MusicScanner::Normal:
QMetaObject::invokeMethod( this, "runNormalScan", Qt::QueuedConnection, Q_ARG( bool, m_queuedScanType == MusicScanner::Full ) );
break;
case File:
case MusicScanner::File:
QMetaObject::invokeMethod( this, "", Qt::QueuedConnection, Q_ARG( QStringList, QStringList() ) );
break;
default:
break;
}
m_queuedScanType = None;
m_queuedScanType = MusicScanner::None;
m_scanTimer->start();
}