You can queue jobs that are to be done by the main loop when the current event is dealt with. More...
Macros | |
| #define | ECORE_JOB_CLASS ecore_job_class_get() |
| #define | ECORE_JOB_ID(sub_id) (ECORE_JOB_BASE_ID + sub_id) |
| #define | ecore_job_constructor(func, data) ECORE_JOB_ID(ECORE_JOB_SUB_ID_CONSTRUCTOR), EO_TYPECHECK(Ecore_Cb, func), EO_TYPECHECK(const void *, data) |
Typedefs | |
| typedef Eo | Ecore_Job |
| A job handle. | |
Enumerations | |
| enum | { ECORE_JOB_SUB_ID_CONSTRUCTOR, ECORE_JOB_SUB_ID_LAST } |
Functions | |
| const Eo_Class * | ecore_job_class_get (void) |
| Ecore_Job * | ecore_job_add (Ecore_Cb func, const void *data) |
| Add a job to the event queue. | |
| void * | ecore_job_del (Ecore_Job *obj) |
| Delete a queued job that has not yet been executed. | |
| static void | _job_constructor (Eo *obj, void *_pd, va_list *list EINA_UNUSED) |
| static void | _constructor (Eo *obj, void *_pd EINA_UNUSED, va_list *list EINA_UNUSED) |
| static void | _destructor (Eo *obj, void *_pd EINA_UNUSED, va_list *list EINA_UNUSED) |
Variables | |
| Eo_Op | ECORE_JOB_BASE_ID |
Detailed Description
You can queue jobs that are to be done by the main loop when the current event is dealt with.
Jobs are processed by the main loop similarly to events. They also will be executed in the order in which they were added.
A good use for them is when you don't want to execute an action immediately, but want to give the control back to the main loop so that it will call your job callback when jobs start being processed (and if there are other jobs added before yours, they will be processed first). This also gives the chance to other actions in your program to cancel the job before it is started.
Examples of using Ecore_Job :
- ecore_job_example_c
Macro Definition Documentation
| #define ecore_job_constructor | ( | func, | |
| data | |||
| ) | ECORE_JOB_ID(ECORE_JOB_SUB_ID_CONSTRUCTOR), EO_TYPECHECK(Ecore_Cb, func), EO_TYPECHECK(const void *, data) |
Function Documentation
Add a job to the event queue.
- Parameters
-
func The function to call when the job gets handled. data Data pointer to be passed to the job function when the job is handled.
- Returns
- The handle of the job.
NULLis returned if the job could not be added to the queue.
- Note
- Once the job has been executed, the job handle is invalid.
References ecore_job_constructor, eo_add_custom, and eo_unref().
| void * ecore_job_del | ( | Ecore_Job * | obj | ) |
Delete a queued job that has not yet been executed.
- Parameters
-
job Handle of the job to delete.
- Returns
- The data pointer that was to be passed to the job.
References ecore_event_del(), EINA_MAIN_LOOP_CHECK_RETURN_VAL, eo_data_get(), and eo_parent_set().
