Qore Programming Language
0.9.3.1
|
#include <cstdio>
#include <pthread.h>
Go to the source code of this file.
Classes | |
class | QoreForeignThreadHelper |
use this class to temporarily register and deregister a foreign thread to allow Qore code to be executed and the Qore library to be used from threads not created by the Qore library More... | |
class | ThreadCleanupList |
list of functions to be run when a thread ends; required for some external libraries that require explicit cleanup when a thread terminates More... | |
Macros | |
#define | QFT_ERROR -1 |
error when calling q_register_foreign_thread() | |
#define | QFT_OK 0 |
OK response when calling q_register_foreign_thread() | |
#define | QFT_REGISTERED -2 |
thread already registered when calling q_register_foreign_thread() | |
Typedefs | |
typedef void(* | q_thread_t) (ExceptionSink *xsink, void *arg) |
pointer to a function that can be started with q_start_thread() | |
typedef void(* | qtdest_t) (void *) |
pointer to a qore thread destructor function | |
typedef void(* | qtrdest_t) (void *, ExceptionSink *) |
pointer to a qore thread resource destructor function | |
Functions | |
DLLEXPORT bool | check_thread_resource (AbstractThreadResource *atr) |
check if a thread resouce has been saved More... | |
DLLEXPORT const AbstractQoreZoneInfo * | currentTZ () |
returns the current local time zone, note that if 0 = UTC | |
DLLEXPORT QoreProgram * | getProgram () |
returns the current QoreProgram | |
DLLEXPORT int | gettid () |
returns the current TID number | |
DLLEXPORT bool | is_valid_qore_thread () |
returns true if the current thread is a valid qore thread; it is not safe to call most Qore functions unless the thread is registered with Qore More... | |
DLLEXPORT int | q_deregister_foreign_thread () |
deregisters the current thread as a foreign thread More... | |
DLLEXPORT int | q_deregister_reserved_foreign_thread () |
deregisters a foreign qore thread but retains the TID as reserved More... | |
DLLEXPORT int | q_register_foreign_thread () |
registers the current thread as a Qore thread; returns QFT_OK (0) if the thread was successfully registered, QFT_ERROR (-1) if an error occurred, or QFT_REGISTERED (-2) if it was already registered More... | |
DLLEXPORT int | q_register_reserved_foreign_thread (int tid) |
registers a foreign qore thread as a Qore thread with a reserved TID More... | |
DLLEXPORT int | q_release_reserved_foreign_thread_id (int tid) |
releases a TID reserved with q_reserve_foreign_thread_id() More... | |
DLLEXPORT int | q_reserve_foreign_thread_id () |
reserves a thread ID for later registration and returns the TID reserved; use q_release_reserved_foreign_thread_id() to release the reservation More... | |
int | q_start_thread (ExceptionSink *xsink, q_thread_t f, void *arg=0) |
starts a new thread with the given arguments, when the thread terminates, it deregisters itself More... | |
DLLEXPORT q_trid_t | qore_get_trid () |
get a thread resource ID | |
DLLEXPORT int | remove_thread_resource (AbstractThreadResource *atr) |
remove the resource from the thread resource list for the current thread More... | |
DLLEXPORT int | remove_thread_resource (const ResolvedCallReferenceNode *rcr, ExceptionSink *xsink) |
remove the callable resource from the thread resource list for the current thread More... | |
DLLEXPORT void | set_thread_resource (AbstractThreadResource *atr) |
save a resource against a thread for thread resource handling More... | |
DLLEXPORT void | set_thread_resource (const ResolvedCallReferenceNode *rcr, const QoreValue arg) |
save a callable resource against a thread for thread resource handling More... | |
Variables | |
DLLEXPORT ThreadCleanupList | tclist |
the interface to the thread cleanup list | |
Provides definitions relative to threading in Qore.
DLLEXPORT bool check_thread_resource | ( | AbstractThreadResource * | atr | ) |
check if a thread resouce has been saved
atr | thread resource id to check |
DLLEXPORT bool is_valid_qore_thread | ( | ) |
returns true if the current thread is a valid qore thread; it is not safe to call most Qore functions unless the thread is registered with Qore
DLLEXPORT int q_deregister_foreign_thread | ( | ) |
deregisters the current thread as a foreign thread
DLLEXPORT int q_deregister_reserved_foreign_thread | ( | ) |
deregisters a foreign qore thread but retains the TID as reserved
DLLEXPORT int q_register_foreign_thread | ( | ) |
registers the current thread as a Qore thread; returns QFT_OK (0) if the thread was successfully registered, QFT_ERROR (-1) if an error occurred, or QFT_REGISTERED (-2) if it was already registered
call q_deregister_foreign_thread() when Qore functionality is no longer required; not calling q_deregister_foreign_thread() will cause a memory leak
DLLEXPORT int q_register_reserved_foreign_thread | ( | int | tid | ) |
registers a foreign qore thread as a Qore thread with a reserved TID
tid | the TID reserved with q_reserve_foreign_thread_id() |
DLLEXPORT int q_release_reserved_foreign_thread_id | ( | int | tid | ) |
releases a TID reserved with q_reserve_foreign_thread_id()
tid | the TID reserved with q_reserve_foreign_thread_id() |
DLLEXPORT int q_reserve_foreign_thread_id | ( | ) |
reserves a thread ID for later registration and returns the TID reserved; use q_release_reserved_foreign_thread_id() to release the reservation
int q_start_thread | ( | ExceptionSink * | xsink, |
q_thread_t | f, | ||
void * | arg = 0 |
||
) |
starts a new thread with the given arguments, when the thread terminates, it deregisters itself
arg | the argument to the function |
f | the function to start in the new thread |
xsink | any errors starting the new thread will be raised here and cause -1 to be returned |
DLLEXPORT int remove_thread_resource | ( | AbstractThreadResource * | atr | ) |
remove the resource from the thread resource list for the current thread
atr | a pointer to the thread resource to remove |
DLLEXPORT int remove_thread_resource | ( | const ResolvedCallReferenceNode * | rcr, |
ExceptionSink * | xsink | ||
) |
remove the callable resource from the thread resource list for the current thread
rcr | a pointer to the thread resource to remove |
xsink | any Qore-language exceptions raised when dereferencing the callable object will be saved here |
DLLEXPORT void set_thread_resource | ( | AbstractThreadResource * | atr | ) |
save a resource against a thread for thread resource handling
atr | a pointer to the thread resource to save |
DLLEXPORT void set_thread_resource | ( | const ResolvedCallReferenceNode * | rcr, |
const QoreValue | arg | ||
) |
save a callable resource against a thread for thread resource handling
rcr | a pointer to a callable node for thread resource handling |
arg | an argument to use when calling the thread resource handler |