34 #ifndef _QORE_QORE_THREAD_H    35 #define _QORE_QORE_THREAD_H    45 class AbstractQoreZoneInfo;
    46 class ThreadCleanupNode;
    68 DLLEXPORT 
int gettid() noexcept;
    74 DLLEXPORT const AbstractQoreZoneInfo* 
currentTZ();
   123 DLLEXPORT 
int remove_thread_resource_id(
q_trid_t trid);
   129 DLLEXPORT 
bool check_thread_resource_id(
q_trid_t trid);
   145    static ThreadCleanupNode *head;
   149    DLLLOCAL ~ThreadCleanupList();
   150    DLLLOCAL 
void exec();
   161    DLLEXPORT 
void pop(
bool exec = 
true);
   172 #define QFT_REGISTERED -2     252    DLLLOCAL 
void* 
operator new(size_t);
   255    class qore_foreign_thread_priv* priv;
   259    DLLEXPORT QoreForeignThreadHelper();
   262    DLLEXPORT 
explicit QoreForeignThreadHelper(
int tid);
   265    DLLEXPORT ~QoreForeignThreadHelper();
   268 #endif  // ifndef _QORE_THREAD_H void(* qtdest_t)(void *)
pointer to a qore thread destructor function 
Definition: qore_thread.h:50
 
base class for saving data using Qore's thread resource management system 
Definition: AbstractThreadResource.h:51
 
DLLEXPORT int q_reserve_foreign_thread_id()
reserves a thread ID for later registration and returns the TID reserved; use q_release_reserved_fore...
 
DLLEXPORT void pop(bool exec=true)
must only be called in the module destructor/deletion function 
 
DLLEXPORT int gettid() noexcept
returns the current TID number 
 
DLLEXPORT bool check_thread_resource(AbstractThreadResource *atr)
check if a thread resouce has been saved 
 
DLLEXPORT ThreadCleanupList tclist
the interface to the thread cleanup list 
 
DLLEXPORT void set_thread_resource(AbstractThreadResource *atr)
save a resource against a thread for thread resource handling 
 
DLLEXPORT void push(qtdest_t func, void *arg)
must only be called in the module initialization function 
 
DLLEXPORT int remove_thread_resource(AbstractThreadResource *atr)
remove the resource from the thread resource list for the current thread 
 
DLLEXPORT QoreProgram * getProgram()
returns the current QoreProgram 
 
DLLEXPORT int q_deregister_foreign_thread()
deregisters the current thread as a foreign thread 
 
DLLEXPORT int q_release_reserved_foreign_thread_id(int tid)
releases a TID reserved with q_reserve_foreign_thread_id() 
 
void(* qtrdest_t)(void *, ExceptionSink *)
pointer to a qore thread resource destructor function 
Definition: qore_thread.h:53
 
unsigned q_trid_t
type for thread resource IDs (unique within a single running qore library process) ...
Definition: common.h:451
 
The main value class in Qore, designed to be passed by value. 
Definition: QoreValue.h:262
 
supports parsing and executing Qore-language code, reference counted, dynamically-allocated only ...
Definition: QoreProgram.h:126
 
container for holding Qore-language exception information and also for registering a "thread_exit" ca...
Definition: ExceptionSink.h:46
 
list of functions to be run when a thread ends; required for some external libraries that require exp...
Definition: qore_thread.h:143
 
void(* q_thread_t)(ExceptionSink *xsink, void *arg)
pointer to a function that can be started with q_start_thread() 
Definition: qore_thread.h:56
 
base class for resolved call references 
Definition: CallReferenceNode.h:105
 
DLLEXPORT int q_register_foreign_thread()
registers the current thread as a Qore thread; returns QFT_OK (0) if the thread was successfully regi...
 
use this class to temporarily register and deregister a foreign thread to allow Qore code to be execu...
Definition: qore_thread.h:247
 
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 ...
 
DLLEXPORT q_trid_t qore_get_trid()
get a thread resource ID 
 
DLLEXPORT int q_deregister_reserved_foreign_thread()
deregisters a foreign qore thread but retains the TID as reserved 
 
DLLEXPORT int q_register_reserved_foreign_thread(int tid)
registers a foreign qore thread as a Qore thread with a reserved TID 
 
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...
 
DLLEXPORT const AbstractQoreZoneInfo * currentTZ()
returns the current local time zone, note that if 0 = UTC