Tizen Native API
|
Functions | |
void | eina_iterator_free (Eina_Iterator *iterator) |
Free an iterator. | |
void * | eina_iterator_container_get (Eina_Iterator *iterator) |
Return the container of an iterator. | |
Eina_Bool | eina_iterator_next (Eina_Iterator *iterator, void **data) |
Return the value of the current element and go to the next one. | |
void | eina_iterator_foreach (Eina_Iterator *iterator, Eina_Each_Cb callback, const void *fdata) |
Iterate over the container and execute a callback on each element. | |
Eina_Bool | eina_iterator_lock (Eina_Iterator *iterator) |
Lock the container of the iterator. | |
Eina_Bool | eina_iterator_unlock (Eina_Iterator *iterator) |
Unlock the container of the iterator. | |
Typedefs | |
typedef struct _Eina_Iterator | Eina_Iterator |
typedef Eina_Bool(* | Eina_Iterator_Next_Callback )(Eina_Iterator *it, void **data) |
typedef void *(* | Eina_Iterator_Get_Container_Callback )(Eina_Iterator *it) |
typedef void(* | Eina_Iterator_Free_Callback )(Eina_Iterator *it) |
typedef Eina_Bool(* | Eina_Iterator_Lock_Callback )(Eina_Iterator *it) |
Defines | |
#define | FUNC_ITERATOR_NEXT(Function) ((Eina_Iterator_Next_Callback)Function) |
#define | FUNC_ITERATOR_GET_CONTAINER(Function) ((Eina_Iterator_Get_Container_Callback)Function) |
#define | FUNC_ITERATOR_FREE(Function) ((Eina_Iterator_Free_Callback)Function) |
#define | FUNC_ITERATOR_LOCK(Function) ((Eina_Iterator_Lock_Callback)Function) |
#define | EINA_ITERATOR_FOREACH(itr,data) |
Macro to iterate over all elements easily. |
These functions manage iterators on containers.
These functions allow to access elements of a container in a generic way, without knowing which container is used (a bit like iterators in the C++ STL). Iterators only allows sequential access (that is, from an element to the next one). For random access, see Accessor Functions.
Getting an iterator to access elements of a given container is done through the functions of that particular container. There is no function to create a generic iterator as iterators absolutely depend on the container. This means you won't find iterator creation function here, those can be found on the documentation of the container type you're using. Though created with container specific functions iterators are always deleted with the same function: eina_iterator_free().
To get the data and iterate, use eina_iterator_next(). To call a function on all the elements of a container, use eina_iterator_foreach().
Here an example
Define Documentation
#define EINA_ITERATOR_FOREACH | ( | itr, | |
data | |||
) |
while (eina_iterator_next((itr), \ (void **)(void *)&(data)))
Macro to iterate over all elements easily.
- Parameters:
-
itr The iterator to use. data Where to store * data, must be a pointer support getting its address since * eina_iterator_next() requires a pointer to pointer!
This macro is a convenient way to use iterators, very similar to EINA_LIST_FOREACH().
This macro can be used for freeing the data of a list, like in the following example. It has the same goal as the one documented in EINA_LIST_FOREACH(), but using iterators:
Eina_List *list; Eina_Iterator *itr; char *data; // list is already filled, // its elements are just duplicated strings itr = eina_list_iterator_new(list); EINA_ITERATOR_FOREACH(itr, data) free(data); eina_iterator_free(itr); eina_list_free(list);
- Note:
- this example is not optimal algorithm to release a list since it will walk the list twice, but it serves as an example. For optimized version use EINA_LIST_FREE()
- Warning:
- The order in which the elements will be traversed depends on the underlying container and shouldn't be relied upon.
- unless explicitly stated in functions returning iterators, do not modify the iterated object while you walk it, in this example using lists, do not remove list nodes or you might crash! This is not a limitiation of iterators themselves, rather in the iterators implementations to keep them as simple and fast as possible.
#define FUNC_ITERATOR_FREE | ( | Function | ) | ((Eina_Iterator_Free_Callback)Function) |
Helper macro to cast Function
to a Eina_Iterator_Free_Callback.
#define FUNC_ITERATOR_GET_CONTAINER | ( | Function | ) | ((Eina_Iterator_Get_Container_Callback)Function) |
Helper macro to cast Function
to a Eina_Iterator_Get_Container_Callback.
#define FUNC_ITERATOR_LOCK | ( | Function | ) | ((Eina_Iterator_Lock_Callback)Function) |
Helper macro to cast Function
to a Eina_Iterator_Lock_Callback.
#define FUNC_ITERATOR_NEXT | ( | Function | ) | ((Eina_Iterator_Next_Callback)Function) |
Helper macro to cast Function
to a Eina_Iterator_Next_Callback.
Typedef Documentation
Abstract type for iterators.
Type for a callback that frees the container.
Type for a callback that returns the container.
Type for a callback that lock the container.
Type for a callback that returns the next element in a container.
Function Documentation
void* eina_iterator_container_get | ( | Eina_Iterator * | iterator | ) |
Return the container of an iterator.
- Since :
- 2.3
- Parameters:
-
[in] iterator The iterator.
- Returns:
- The container which created the iterator.
- Remarks:
- This function returns the container which created
iterator
. Ifiterator
isNULL
, this function returnsNULL
.
void eina_iterator_foreach | ( | Eina_Iterator * | iterator, |
Eina_Each_Cb | callback, | ||
const void * | fdata | ||
) |
Iterate over the container and execute a callback on each element.
- Since :
- 2.3
- Parameters:
-
[in] iterator The iterator. [in] callback The callback called on each iteration. [in] fdata The data passed to the callback.
- Remarks:
- This function iterates over the elements pointed by
iterator
, beginning from the current element. For Each element, the callbackcb
is called with the datafdata
. Ifiterator
isNULL
, the function returns immediately. Also, ifcb
returns EINA_FALSE, the iteration stops at that point, ifcb
returns EINA_TRUE the iteration continues.
void eina_iterator_free | ( | Eina_Iterator * | iterator | ) |
Free an iterator.
- Since :
- 2.3
- Parameters:
-
[in] iterator The iterator to free.
- Remarks:
- This function frees
iterator
if it is notNULL
;
Eina_Bool eina_iterator_lock | ( | Eina_Iterator * | iterator | ) |
Lock the container of the iterator.
- Since :
- 2.3
- Parameters:
-
iterator The iterator.
- Returns:
- EINA_TRUE on success, EINA_FALSE otherwise.
If the container of the iterator
permits it, it will be locked. When a container is locked calling eina_iterator_foreach() on it will return immediately. If iterator
is NULL
or if a problem occurred, EINA_FALSE is returned, otherwise EINA_TRUE is returned. If the container isn't lockable, it will return EINA_TRUE.
- Warning:
- None of the existing eina data structures are lockable.
Eina_Bool eina_iterator_next | ( | Eina_Iterator * | iterator, |
void ** | data | ||
) |
Return the value of the current element and go to the next one.
- Since :
- 2.3
- Parameters:
-
[in] iterator The iterator. [in] data The data of the element.
- Returns:
- EINA_TRUE on success, EINA_FALSE otherwise.
- Remarks:
- This function returns the value of the current element pointed by
iterator
indata
, then goes to the next element. Ifiterator
isNULL
or if a problem occurred, EINA_FALSE is returned, otherwise EINA_TRUE is returned.
Eina_Bool eina_iterator_unlock | ( | Eina_Iterator * | iterator | ) |
Unlock the container of the iterator.
- Since :
- 2.3
- Parameters:
-
iterator The iterator.
- Returns:
- EINA_TRUE on success, EINA_FALSE otherwise.
If the container of the iterator
permits it and was previously locked, it will be unlocked. If iterator
is NULL
or if a problem occurred, EINA_FALSE is returned, otherwise EINA_TRUE is returned. If the container is not lockable, it will return EINA_TRUE.
- Warning:
- None of the existing eina data structures are lockable.