#include <e32std.h>
| class RUndertaker : public RHandleBase |
| Public Member Functions | |
|---|---|
| IMPORT_C TInt | Create() |
| IMPORT_C TInt | Logon(TRequestStatus &, TInt &) |
| IMPORT_C TInt | LogonCancel() |
| Inherited Attributes | |
|---|---|
| RHandleBase::iHandle | |
| Inherited Enumerations | |
|---|---|
| RHandleBase:TAttributes | |
Handle to a thread death notifier.
The notifier allows threads to be notified of the death of another thread.
The thread-death notifier itself is a kernel object.
| IMPORT_C TInt | Create | ( | ) |
Creates a thread-death notifier, and opens this handle to that thread-death notifier.
Ownership of this thread-death notifier is vested in the current process.
| IMPORT_C TInt | Logon | ( | TRequestStatus & | aStatus, |
| TInt & | aThreadHandle | |||
| ) | const | |||
Issues a request for notification of the death of a thread.
When another thread dies, the request completes and the TRequestStatus object contains the value KErrDied; in addition, aThreadHandle contains the handle-number of the dying thread.
The requesting thread can construct a proper handle for the dying thread using the code:
{
RThread r;
r.SetHandle(aThreadHandle);
...r.Close();
}
Alternatively, if an outstanding request is cancelled by a call to LogonCancel(), then the request completes with the value KErrCancel.
Note that if a request completes normally, i.e. not as a result of a LogonCancel(), then the handle to the dying thread must be closed when there is no further interest in it.
See also: RUndertaker::LogonCancel()
| Parameters | |
|---|---|
| aStatus | A reference to the request status object. |
| aThreadHandle | The handle-number representing the dying thread. |
| IMPORT_C TInt | LogonCancel | ( | ) | const |
Cancels an outstanding notification request to the thread-death notifier.
See also: RUndertaker::Logon()