You can queue jobs that are to be done by the main loop when the current event is dealt with. More...
| Typedefs | |
| typedef struct _Ecore_Job | Ecore_Job | 
| A job handle.  More... | |
| Ecore_Job * | ecore_job_add (Ecore_Cb func, const void *data) | 
| Add a job to the event queue.  More... | |
| void * | ecore_job_del (Ecore_Job *obj) | 
| Delete a queued job that has not yet been executed.  More... | |
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 :
| typedef struct _Ecore_Job Ecore_Job | 
A job handle.
Add a job to the event queue.
| 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. | 
NULL is returned if the job could not be added to the queue. References ecore_event_add(), EINA_MAIN_LOOP_CHECK_RETURN_VAL, eina_main_loop_is(), EINA_UNLIKELY, and ERR.
Referenced by edje_message_signal_process(), efreet_icon_extra_list_get(), elm_genlist_item_class_unref(), and emotion_object_position_set().
| void* ecore_job_del | ( | Ecore_Job * | obj | ) | 
Delete a queued job that has not yet been executed.
| obj | Handle of the job to delete. | 
References ECORE_CALLBACK_DONE, ecore_event_del(), EINA_MAIN_LOOP_CHECK_RETURN_VAL, and EINA_UNUSED.
Referenced by edje_message_signal_process(), elm_genlist_item_class_unref(), elm_object_cursor_unset(), elm_store_free(), and emotion_object_position_set().