Tizen Native API

The idler functionality in Ecore allows for callbacks to be called when the program isn't handling events, timers, or fd handlers.

There are three types of idlers: Enterers, Idlers(proper), and Exiters. They are called respectively when the program is about to enter an idle state, when the program is in an idle state and when the program has just left an idle state and begins processing events, timers, or fd handlers.

Enterer callbacks are good for updating your program's state, if it has a state engine. Once all of the enterer handlers are called, the program enters a "sleeping" state.

Idler callbacks are called when the main loop has called all enterer handlers. They are useful for interfaces that require polling and timers without which they would be too slow to use.

Exiter callbacks are called when the main loop wakes up from an idle state.

If no idler callbacks are specified, then the process literally goes to sleep. Otherwise, the idler callbacks are called continuously while the loop is "idle", using as much CPU as is available to the process.

Idle state doesn't mean that the program is idle, but that the main loop is idle. It doesn't have any timers, events, fd handlers, or anything else to process (which in most event driven programs also means that the program is idle too, but it's not a rule). The program itself may be doing a lot of processing in the idler, or in another thread, for example.

Functions

Ecore_Idlerecore_idler_add (Ecore_Task_Cb func, const void *data)
 Adds an idler handler.
void * ecore_idler_del (Ecore_Idler *idler)
 Deletes an idler callback from the list to be executed.
Ecore_Idle_Entererecore_idle_enterer_add (Ecore_Task_Cb func, const void *data)
 Add an idle enterer handler.
Ecore_Idle_Entererecore_idle_enterer_before_add (Ecore_Task_Cb func, const void *data)
 Add an idle enterer handler at the start of the list so it gets called earlier than others.
void * ecore_idle_enterer_del (Ecore_Idle_Enterer *idle_enterer)
 Delete an idle enterer callback.
Ecore_Idle_Exiterecore_idle_exiter_add (Ecore_Task_Cb func, const void *data)
 Add an idle exiter handler.
void * ecore_idle_exiter_del (Ecore_Idle_Exiter *idle_exiter)
 Delete an idle exiter handler from the list to be run on exiting idle state.

Typedefs

typedef struct _Ecore_Idler Ecore_Idler
 A handle for idlers.
typedef struct _Ecore_Idle_Enterer Ecore_Idle_Enterer
 A handle for idle enterers.
typedef struct _Ecore_Idle_Exiter Ecore_Idle_Exiter
 A handle for idle exiters.

Function Documentation

Ecore_Idle_Enterer* ecore_idle_enterer_add ( Ecore_Task_Cb  func,
const void *  data 
)

Add an idle enterer handler.

Since :
2.3.1
Remarks:
The function func will be called every time the main loop is entering idle state, as long as it returns 1 (or ECORE_CALLBACK_RENEW). A return of 0 (or ECORE_CALLBACK_CANCEL) deletes the idle enterer.
Parameters:
[in]funcThe function to call when entering an idle state.
[in]dataThe data to be passed to the func call
Returns:
A handle to the idle enterer callback if successful. Otherwise, NULL is returned.

Add an idle enterer handler at the start of the list so it gets called earlier than others.

Since :
2.3.1
Remarks:
The function func will be called every time the main loop is entering idle state, as long as it returns 1 (or ECORE_CALLBACK_RENEW). A return of 0 (or ECORE_CALLBACK_CANCEL) deletes the idle enterer.
Parameters:
[in]funcThe function to call when entering an idle state.
[in]dataThe data to be passed to the func call
Returns:
A handle to the idle enterer callback if successful. Otherwise, NULL is returned.
void* ecore_idle_enterer_del ( Ecore_Idle_Enterer idle_enterer)

Delete an idle enterer callback.

Since :
2.3.1
Parameters:
[in]idle_entererThe idle enterer to delete
Returns:
The data pointer passed to the idler enterer callback on success. NULL otherwise.
Ecore_Idle_Exiter* ecore_idle_exiter_add ( Ecore_Task_Cb  func,
const void *  data 
)

Add an idle exiter handler.

Since :
2.3.1
Remarks:
The function func will be called every time the main loop is exiting idle state, as long as it returns 1 (or ECORE_CALLBACK_RENEW). A return of 0 (or ECORE_CALLBACK_CANCEL) deletes the idle exiter.
Parameters:
[in]funcThe function to call when exiting an idle state.
[in]dataThe data to be passed to the func call
Returns:
A handle to the idle exiter callback on success. NULL otherwise.
void* ecore_idle_exiter_del ( Ecore_Idle_Exiter idle_exiter)

Delete an idle exiter handler from the list to be run on exiting idle state.

Since :
2.3.1
Parameters:
[in]idle_exiterThe idle exiter to delete
Returns:
The data pointer that was being being passed to the handler if successful. NULL otherwise.
Ecore_Idler* ecore_idler_add ( Ecore_Task_Cb  func,
const void *  data 
)

Adds an idler handler.

This adds an idler handle to the event loop, returning a handle on success and NULL otherwise. The function func is called repeatedly while no other events are ready to be processed, as long as it returns 1 (or ECORE_CALLBACK_RENEW). A return of 0 (or ECORE_CALLBACK_CANCEL) deletes the idler.

Since :
2.3.1
Remarks:
Idlers are useful for progressively processing data without blocking.
Parameters:
[in]funcThe function to call when idling
[in]dataThe data to be passed to this func call
Returns:
A idler handle if successfully added, otherwise NULL
void* ecore_idler_del ( Ecore_Idler idler)

Deletes an idler callback from the list to be executed.

Since :
2.3.1
Parameters:
[in]idlerThe handle of the idler callback to delete
Returns:
The data pointer passed to the idler callback on success, otherwise NULL