WorkerThread Class Reference

the supporting thread in order to run operations on a different thread instead of the GUI thread More...

Inheritance diagram for WorkerThread:

Signals

void exceptionDuringOperation (farsa::BaseException *e)
 The signal emitted when a ThreadOperation throws as exception. More...
 

Public Member Functions

 WorkerThread (QObject *parent)
 constructor More...
 
 ~WorkerThread ()
 destructor More...
 
void addOperation (ThreadOperation *operation, bool deleteAtEnd=true)
 Add an operation to the queue. More...
 
bool operationRunning ()
 Returns true if an operation is running. More...
 
void quit ()
 stop the current operation and quit from the thread terminating its cycle. More...
 
void run ()
 implement the main run routine More...
 
void stopCurrentOperation (bool wait)
 Stop the current operation. More...
 

Detailed Description

the supporting thread in order to run operations on a different thread instead of the GUI thread

Definition at line 126 of file workerthread.h.

Constructor & Destructor Documentation

WorkerThread ( QObject *  parent)

constructor

Definition at line 28 of file workerthread.cpp.

destructor

Definition at line 39 of file workerthread.cpp.

Member Function Documentation

void addOperation ( ThreadOperation operation,
bool  deleteAtEnd = true 
)

Add an operation to the queue.

If deleteAtEnd is true the operation is deleted when it has finished executing, otherwise it is not

Definition at line 45 of file workerthread.cpp.

void exceptionDuringOperation ( farsa::BaseException *  e)
signal

The signal emitted when a ThreadOperation throws as exception.

This signal is emitted when a ThreadOperation object throws an exception and terminates. The exception is cloned (or an instance of UnknownException is created) and stored here. We keep the list of all exceptions ever thrown to avoid problems (with the current implementation we don't know when it is safe to deleted the cloned object)

Parameters
ea clone of the exception thrown in the ThreadOperation
Note
The connection to this signal must be of type Qt::QueuedConnection or Qt::BlockingQueuedConnection because the signal is emitted from another thread. This should be fixed (use a QObject with the correct thread affinity)

Referenced by WorkerThread::run().

bool operationRunning ( )

Returns true if an operation is running.

Definition at line 126 of file workerthread.cpp.

void quit ( )

stop the current operation and quit from the thread terminating its cycle.

Note
this is the safe way to close the thread
Warning
this is a blocking method

Definition at line 117 of file workerthread.cpp.

References WorkerThread::stopCurrentOperation().

void run ( )

implement the main run routine

Definition at line 66 of file workerthread.cpp.

References WorkerThread::exceptionDuringOperation().

void stopCurrentOperation ( bool  wait)

Stop the current operation.

If wait is true, it waits until the operation actually stops

Definition at line 55 of file workerthread.cpp.

Referenced by WorkerThread::quit().


The documentation for this class was generated from the following files: