diff options
Diffstat (limited to 'src/kernel/qthread_unix.cpp')
-rw-r--r-- | src/kernel/qthread_unix.cpp | 40 |
1 files changed, 37 insertions, 3 deletions
diff --git a/src/kernel/qthread_unix.cpp b/src/kernel/qthread_unix.cpp index 6005c42..59c51f4 100644 --- a/src/kernel/qthread_unix.cpp +++ b/src/kernel/qthread_unix.cpp @@ -47,6 +47,7 @@ typedef pthread_mutex_t Q_MUTEX_T; #include <private/qmutex_p.h> #include <private/qmutexpool_p.h> #include <qthreadstorage.h> +#include <qapplication.h> #include <errno.h> #include <sched.h> @@ -109,6 +110,7 @@ void QThreadInstance::init(unsigned int stackSize) thread_id = 0; eventLoop = 0; + cleanupType = QThread::CleanupMergeObjects; // threads have not been initialized yet, do it now if (! qt_thread_mutexpool) QThread::initialize(); @@ -150,6 +152,8 @@ void QThreadInstance::finish( void * ) return; } + QApplication::threadTerminationHandler((QThread*)d->args[0]); + QMutexLocker locker( d->mutex() ); d->running = FALSE; d->finished = TRUE; @@ -179,7 +183,6 @@ void QThreadInstance::terminate() pthread_cancel( thread_id ); } - /************************************************************************** ** QThread *************************************************************************/ @@ -398,6 +401,9 @@ void QThread::start(Priority priority) d->args[0] = this; d->args[1] = d; #if defined(QT_USE_GLIBMAINLOOP) + // The correct thread_id is set in QThreadInstance::start using the value of d->args[1] + d->thread_id = NULL; + // Legacy glib versions require this threading system initialization call g_thread_init(NULL); @@ -408,8 +414,6 @@ void QThread::start(Priority priority) else { ret = -1; } - // The correct thread_id is set in QThreadInstance::start using the value of d->args[1] - d->thread_id = NULL; #else // QT_USE_GLIBMAINLOOP ret = pthread_create( &d->thread_id, &attr, (QtThreadCallback)QThreadInstance::start, d->args ); #if defined (Q_OS_HPUX) @@ -496,6 +500,36 @@ bool QThread::wait( unsigned long time ) } /*! + Returns the current cleanup behaviour of the thread. + + \sa setCleanupType + \sa CleanupType +*/ + +QThread::CleanupType QThread::cleanupType() { + return (QThread::CleanupType)d->cleanupType; +} + +/*! + Sets the current cleanup behaviour of the thread. The default, + QThread::CleanupMergeObjects, will merge any objects owned by this thread + with the main GUI thread when this thread is terminated. + + If faster thread termination performance is desired, QThread::CleanupNone + may be specified instead. However, this is not recommended as any objects + owned by this thread on termination can then cause events to become "stuck" + in the global event queue, leading to high CPU usage and other undesirable + behavior. You have been warned! + + \sa cleanupType + \sa CleanupType +*/ + +void QThread::setCleanupType(CleanupType type) { + d->cleanupType = type; +} + +/*! Returns a pointer to the currently executing QThread. If the current thread was not started using the QThread API, this function returns zero. |