mirror of
https://github.com/tomahawk-player/tomahawk.git
synced 2025-08-07 14:46:33 +02:00
* Made sure to call resolve in the right thread.
This commit is contained in:
@@ -20,6 +20,7 @@ public:
|
|||||||
virtual unsigned int preference() const { return 100; }
|
virtual unsigned int preference() const { return 100; }
|
||||||
virtual unsigned int timeout() const { return 2500; }
|
virtual unsigned int timeout() const { return 2500; }
|
||||||
|
|
||||||
|
public slots:
|
||||||
virtual void resolve( const Tomahawk::query_ptr& query );
|
virtual void resolve( const Tomahawk::query_ptr& query );
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
|
@@ -30,13 +30,15 @@ public:
|
|||||||
virtual unsigned int weight() const = 0;
|
virtual unsigned int weight() const = 0;
|
||||||
virtual unsigned int preference() const { return 100; };
|
virtual unsigned int preference() const { return 100; };
|
||||||
virtual unsigned int timeout() const = 0;
|
virtual unsigned int timeout() const = 0;
|
||||||
virtual void resolve( const Tomahawk::query_ptr& query ) = 0;
|
|
||||||
|
|
||||||
//virtual QWidget * configUI() { return 0; };
|
//virtual QWidget * configUI() { return 0; };
|
||||||
//etc
|
//etc
|
||||||
|
|
||||||
PluginAPI * api() const { return m_api; }
|
PluginAPI * api() const { return m_api; }
|
||||||
|
|
||||||
|
public slots:
|
||||||
|
virtual void resolve( const Tomahawk::query_ptr& query ) = 0;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
PluginAPI * m_api;
|
PluginAPI * m_api;
|
||||||
};
|
};
|
||||||
|
@@ -47,6 +47,13 @@ QtScriptResolver::~QtScriptResolver()
|
|||||||
void
|
void
|
||||||
QtScriptResolver::resolve( const Tomahawk::query_ptr& query )
|
QtScriptResolver::resolve( const Tomahawk::query_ptr& query )
|
||||||
{
|
{
|
||||||
|
if ( QThread::currentThread() != thread() )
|
||||||
|
{
|
||||||
|
qDebug() << "Reinvoking in correct thread:" << Q_FUNC_INFO;
|
||||||
|
QMetaObject::invokeMethod( this, "resolve", Qt::QueuedConnection, Q_ARG( Tomahawk::query_ptr, query ) );
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
qDebug() << Q_FUNC_INFO << query->toString();
|
qDebug() << Q_FUNC_INFO << query->toString();
|
||||||
QString eval = QString( "resolve( '%1', '%2', '%3', '%4' );" )
|
QString eval = QString( "resolve( '%1', '%2', '%3', '%4' );" )
|
||||||
.arg( query->id().replace( "'", "\\'" ) )
|
.arg( query->id().replace( "'", "\\'" ) )
|
||||||
|
@@ -45,9 +45,8 @@ public:
|
|||||||
virtual unsigned int preference() const { return m_preference; }
|
virtual unsigned int preference() const { return m_preference; }
|
||||||
virtual unsigned int timeout() const { return m_timeout; }
|
virtual unsigned int timeout() const { return m_timeout; }
|
||||||
|
|
||||||
virtual void resolve( const Tomahawk::query_ptr& query );
|
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
|
virtual void resolve( const Tomahawk::query_ptr& query );
|
||||||
virtual void stop();
|
virtual void stop();
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
|
@@ -24,13 +24,12 @@ public:
|
|||||||
virtual unsigned int preference() const { return m_preference; }
|
virtual unsigned int preference() const { return m_preference; }
|
||||||
virtual unsigned int timeout() const { return m_timeout; }
|
virtual unsigned int timeout() const { return m_timeout; }
|
||||||
|
|
||||||
virtual void resolve( const Tomahawk::query_ptr& query );
|
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
void finished();
|
void finished();
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
virtual void stop();
|
virtual void stop();
|
||||||
|
virtual void resolve( const Tomahawk::query_ptr& query );
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
void readStderr();
|
void readStderr();
|
||||||
|
Reference in New Issue
Block a user