Functions | |
Eldbus_Message_Iter * | eldbus_message_iter_container_new (Eldbus_Message_Iter *iter, int type, const char *contained_signature) |
Create and append a typed iterator to another iterator. More... | |
Eina_Bool | eldbus_message_iter_basic_append (Eldbus_Message_Iter *iter, int type,...) |
Append a basic type into an Eldbus_Iterator. More... | |
Eina_Bool | eldbus_message_iter_arguments_append (Eldbus_Message_Iter *iter, const char *signature,...) |
Append an argument into an Eldbus_Message_Iter. More... | |
Eina_Bool | eldbus_message_iter_arguments_vappend (Eldbus_Message_Iter *iter, const char *signature, va_list ap) |
Set data to Eldbus_Message_Iter. More... | |
Eina_Bool | eldbus_message_iter_fixed_array_append (Eldbus_Message_Iter *iter, int type, const void *array, unsigned int size) |
Append a array of basic type with fixed size to Eldbus_Message_Iter. More... | |
Eina_Bool | eldbus_message_iter_container_close (Eldbus_Message_Iter *iter, Eldbus_Message_Iter *sub) |
Closes a container-typed value appended to the message. More... | |
Eldbus_Message_Iter * | eldbus_message_iter_get (const Eldbus_Message *msg) |
Get the main Eldbus_Message_Iter from the Eldbus_Message. More... | |
void | eldbus_message_iter_basic_get (Eldbus_Message_Iter *iter, void *value) |
Get a basic type from Eldbus_Iterator. More... | |
char * | eldbus_message_iter_signature_get (Eldbus_Message_Iter *iter) |
Returns the current signature of a message iterator. More... | |
Eina_Bool | eldbus_message_iter_next (Eldbus_Message_Iter *iter) |
Moves the iterator to the next field, if any. More... | |
Eina_Bool | eldbus_message_iter_get_and_next (Eldbus_Message_Iter *iter, char signature,...) |
Get a complete type from Eldbus_Message_Iter if is not at the end of iterator and move to next field. More... | |
Eina_Bool | eldbus_message_iter_fixed_array_get (Eldbus_Message_Iter *iter, int signature, void *value, int *n_elements) |
Reads a block of fixed-length values from the message iterator. More... | |
Eina_Bool | eldbus_message_iter_arguments_get (Eldbus_Message_Iter *iter, const char *signature,...) |
Get data from Eldbus_Message_Iter, for each complete type must have a pointer to store his value, in case of complex type a Eldbus_Message_Iter will be need. More... | |
Eina_Bool | eldbus_message_iter_arguments_vget (Eldbus_Message_Iter *iter, const char *signature, va_list ap) |
Get data from Eldbus_Message_Iter, for each complete type must have a pointer to store his value, in case of complex type a Eldbus_Message_Iter will be need. More... | |
void | eldbus_message_iter_del (Eldbus_Message_Iter *iter) |
Manually delete the iterator. More... | |
Eldbus_Message_Iter * eldbus_message_iter_container_new | ( | Eldbus_Message_Iter * | iter, |
int | type, | ||
const char * | contained_signature | ||
) |
Create and append a typed iterator to another iterator.
After append data to returned iterator it must be closed calling eldbus_message_iter_container_close().
Container types are for example struct, variant, and array. For variants, the contained_signature should be the type of the single value inside the variant. For structs and dict entries, contained_signature should be NULL; it will be set to whatever types you write into the struct. For arrays, contained_signature should be the type of the array elements.
iter | parent of the new iterator |
type | of iterator (e.g struct, dict, variant or array) |
contained_signature | signature of what iterator will store |
References eina_inlist_append(), EINA_INLIST_GET, EINA_SAFETY_ON_NULL_RETURN_VAL, and EINA_TRUE.
Referenced by eldbus_proxy_property_set(), and eldbus_proxy_property_value_set().
Eina_Bool eldbus_message_iter_basic_append | ( | Eldbus_Message_Iter * | iter, |
int | type, | ||
... | |||
) |
Append a basic type into an Eldbus_Iterator.
iter | The iterator in which basic type will be appended. |
type | The basic type that will be appended. |
... | The values for the basic type. |
References EINA_FALSE, and EINA_SAFETY_ON_FALSE_RETURN_VAL.
Referenced by eldbus_proxy_property_set(), and eldbus_proxy_property_value_set().
Eina_Bool eldbus_message_iter_arguments_append | ( | Eldbus_Message_Iter * | iter, |
const char * | signature, | ||
... | |||
) |
Append an argument into an Eldbus_Message_Iter.
For each complete type you need to provide the correspondent value. In case of complex types you need to provide an Eldbus_Message_Iter** to be allocated and then filled in.
It's not possible to open two iterators at same iterator with this function. For example, to create a message with signature="aiai" you need to create the first container with eldbus_message_iter_container_new(), fill the array, close it with eldbus_message_iter_container_close() and then do the same for the second array.
iter | iterator in which data will be appended |
signature | signature of the contained data |
... | values for each complete type |
References EINA_FALSE, EINA_SAFETY_ON_NULL_RETURN_VAL, and eldbus_message_iter_arguments_vappend().
Eina_Bool eldbus_message_iter_arguments_vappend | ( | Eldbus_Message_Iter * | iter, |
const char * | signature, | ||
va_list | ap | ||
) |
Set data to Eldbus_Message_Iter.
For each complete in signature you need pass the value, in case of complex type a pointer to be allocated a Eldbus_Message_Iter that you need fill and close.
It's not possible open two iterators at same Iterator. Example: "aiai", to set this you need create and put the first array with eldbus_message_iter_container_new() fill array with data and close then you could open the second array with eldbus_message_iter_container_new().
iter | iterator |
signature | of data |
ap | va_list with the values |
Referenced by eldbus_message_iter_arguments_append().
Eina_Bool eldbus_message_iter_fixed_array_append | ( | Eldbus_Message_Iter * | iter, |
int | type, | ||
const void * | array, | ||
unsigned int | size | ||
) |
Append a array of basic type with fixed size to Eldbus_Message_Iter.
iter | iterator |
type | basic type that will be appended |
array | data to append |
size | of array |
References EINA_FALSE, EINA_SAFETY_ON_FALSE_RETURN_VAL, and EINA_SAFETY_ON_NULL_RETURN_VAL.
Eina_Bool eldbus_message_iter_container_close | ( | Eldbus_Message_Iter * | iter, |
Eldbus_Message_Iter * | sub | ||
) |
Closes a container-typed value appended to the message.
iter | parent of the sub-iterator |
sub | the iterator that will be closed |
References EINA_FALSE, and EINA_SAFETY_ON_FALSE_RETURN_VAL.
Referenced by eldbus_proxy_property_set(), and eldbus_proxy_property_value_set().
Eldbus_Message_Iter * eldbus_message_iter_get | ( | const Eldbus_Message * | msg | ) |
Get the main Eldbus_Message_Iter from the Eldbus_Message.
msg | The message to get the iterator from. |
References EINA_SAFETY_ON_NULL_RETURN_VAL.
Referenced by eldbus_message_from_eina_value(), eldbus_message_to_eina_value(), eldbus_proxy_property_set(), and eldbus_proxy_property_value_set().
void eldbus_message_iter_basic_get | ( | Eldbus_Message_Iter * | iter, |
void * | value | ||
) |
Get a basic type from Eldbus_Iterator.
iter | The iterator to get the basic type from. |
value | The basic type of the iterator. |
References EINA_SAFETY_ON_TRUE_RETURN.
char * eldbus_message_iter_signature_get | ( | Eldbus_Message_Iter * | iter | ) |
Returns the current signature of a message iterator.
iter | The iterator on which to query the signature. |
Referenced by eldbus_message_iter_dict_iterate().
Eina_Bool eldbus_message_iter_next | ( | Eldbus_Message_Iter * | iter | ) |
Moves the iterator to the next field, if any.
iter | iterator |
References EINA_FALSE, and EINA_SAFETY_ON_TRUE_RETURN_VAL.
Eina_Bool eldbus_message_iter_get_and_next | ( | Eldbus_Message_Iter * | iter, |
char | signature, | ||
... | |||
) |
Get a complete type from Eldbus_Message_Iter if is not at the end of iterator and move to next field.
Useful to iterate over arrays.
iter | iterator |
signature | of the next completed type in Iterator |
... | pointer of where data will be stored |
Get a complete type from Eldbus_Message_Iter if is not at the end of iterator and move to next field.
References EINA_FALSE, eina_inlist_append(), EINA_INLIST_GET, EINA_SAFETY_ON_TRUE_RETURN_VAL, and EINA_TRUE.
Referenced by efl_net_connman_access_point_update(), efl_net_connman_technology_new(), and eldbus_message_iter_dict_iterate().
Eina_Bool eldbus_message_iter_fixed_array_get | ( | Eldbus_Message_Iter * | iter, |
int | signature, | ||
void * | value, | ||
int * | n_elements | ||
) |
Reads a block of fixed-length values from the message iterator.
Fixed-length values are those basic types that are not string-like, such as integers, bool, double. The returned block will be from the current position in the array until the end of the array.
There is one exception here: although ELDBUS_TYPE_UNIX_FD is considered a 'fixed' type arrays of this type may not be read with this function.
The value argument should be the address of a location to store the returned array. So for int32 it should be a "const dbus_int32_t**" The returned value is by reference and should not be freed.
Because the array is not copied, this function runs in constant time and is fast; it's much preferred over walking the entire array with an iterator.
iter | The message iterator |
signature | |
value | |
n_elements |
References EINA_FALSE, EINA_SAFETY_ON_FALSE_RETURN_VAL, EINA_SAFETY_ON_NULL_RETURN_VAL, EINA_SAFETY_ON_TRUE_RETURN_VAL, and EINA_TRUE.
Eina_Bool eldbus_message_iter_arguments_get | ( | Eldbus_Message_Iter * | iter, |
const char * | signature, | ||
... | |||
) |
Get data from Eldbus_Message_Iter, for each complete type must have a pointer to store his value, in case of complex type a Eldbus_Message_Iter will be need.
iter | iterator |
signature | of the complete data types on iterator |
... | pointers of where data will be stored |
Referenced by eldbus_message_iter_dict_iterate().
Eina_Bool eldbus_message_iter_arguments_vget | ( | Eldbus_Message_Iter * | iter, |
const char * | signature, | ||
va_list | ap | ||
) |
Get data from Eldbus_Message_Iter, for each complete type must have a pointer to store his value, in case of complex type a Eldbus_Message_Iter will be need.
iter | iterator |
signature | of the complete data types on iterator |
ap | va_list of the pointers of where data will be stored |
void eldbus_message_iter_del | ( | Eldbus_Message_Iter * | iter | ) |
Manually delete the iterator.
Iterators are usually bound to the life of Message they were created from, being deleted automatically once the message is deleted.
However when dealing with huge arrays or dicts it may become a major memory impact to leave the unused iterators alive. By calling this function one states the iterator is not used anymore and can be deleted.
iter | the iterator to be deleted. |