These functions provide double linked list management. More...
Data Structures | |
struct | _Eina_List |
Type for a generic double linked list. More... | |
struct | _Eina_List_Accounting |
Cache used to store the last element of a list and the number of elements, for fast access. More... | |
Macros | |
#define | EINA_LIST_FOREACH(list, l, _data) |
Definition for the macro to iterate over a list. More... | |
#define | EINA_LIST_REVERSE_FOREACH(list, l, _data) |
Definition for the macro to iterate over a list in the reverse order. More... | |
#define | EINA_LIST_FOREACH_SAFE(list, l, l_next, data) |
Definition for the macro to iterate over a list with support for node deletion. More... | |
#define | EINA_LIST_REVERSE_FOREACH_SAFE(list, l, l_prev, data) |
Definition for the macro to iterate over a list in the reverse order with support for deletion. More... | |
#define | EINA_LIST_FREE(list, data) |
Definition for the macro to remove each list node while having access to each node's data. More... | |
Typedefs | |
typedef struct _Eina_List | Eina_List |
Type for a generic double linked list. | |
typedef struct _Eina_List_Accounting | Eina_List_Accounting |
Cache used to store the last element of a list and the number of elements, for fast access. | |
Functions | |
EINA_API Eina_List * | eina_list_append (Eina_List *list, const void *data) |
Appends the given data to the given linked list. More... | |
EINA_API Eina_List * | eina_list_prepend (Eina_List *list, const void *data) |
Prepends the given data to the given linked list. More... | |
EINA_API Eina_List * | eina_list_append_relative (Eina_List *list, const void *data, const void *relative) |
Inserts the given data into the given linked list after the specified data. More... | |
EINA_API Eina_List * | eina_list_append_relative_list (Eina_List *list, const void *data, Eina_List *relative) |
Appends a list node to a linked list after the specified member. More... | |
EINA_API Eina_List * | eina_list_prepend_relative (Eina_List *list, const void *data, const void *relative) |
Prepends a data pointer to a linked list before the specified member. More... | |
EINA_API Eina_List * | eina_list_prepend_relative_list (Eina_List *list, const void *data, Eina_List *relative) |
Prepends a list node to a linked list before the specified member. More... | |
EINA_API Eina_List * | eina_list_sorted_insert (Eina_List *list, Eina_Compare_Cb func, const void *data) |
Inserts a new node into a sorted list. More... | |
EINA_API Eina_List * | eina_list_remove (Eina_List *list, const void *data) |
Removes the first instance of the specified data from the given list. More... | |
EINA_API Eina_List * | eina_list_remove_list (Eina_List *list, Eina_List *remove_list) |
Removes the specified list node. More... | |
EINA_API Eina_List * | eina_list_promote_list (Eina_List *list, Eina_List *move_list) |
Moves the specified data to the head of the list. More... | |
EINA_API Eina_List * | eina_list_demote_list (Eina_List *list, Eina_List *move_list) |
Moves the specified data to the tail of the list. More... | |
EINA_API void * | eina_list_data_find (const Eina_List *list, const void *data) |
Finds a member of a list and returns it. More... | |
EINA_API Eina_List * | eina_list_data_find_list (const Eina_List *list, const void *data) |
Finds a member of a list and returns it as a list node. More... | |
EINA_API Eina_Bool | eina_list_move (Eina_List **to, Eina_List **from, void *data) |
Moves a data pointer from one list to another. More... | |
EINA_API Eina_Bool | eina_list_move_list (Eina_List **to, Eina_List **from, Eina_List *data) |
Moves a list node from one list to another. More... | |
EINA_API Eina_List * | eina_list_free (Eina_List *list) |
Frees an entire list and all the nodes, ignoring the data contained. More... | |
EINA_API void * | eina_list_nth (const Eina_List *list, unsigned int n) |
Gets the nth member's data pointer in a list, or NULL on error. More... | |
EINA_API Eina_List * | eina_list_nth_list (const Eina_List *list, unsigned int n) |
Gets the nth member's list node in a list. More... | |
EINA_API Eina_List * | eina_list_reverse (Eina_List *list) |
Reverses all the elements in the list. More... | |
EINA_API Eina_List * | eina_list_reverse_clone (const Eina_List *list) |
Clones (copies) all the elements in the list in reverse order. More... | |
EINA_API Eina_List * | eina_list_clone (const Eina_List *list) |
Clones (copies) all the elements in the list in exactly same order. More... | |
EINA_API Eina_List * | eina_list_sort (Eina_List *list, unsigned int limit, Eina_Compare_Cb func) |
Sorts a list according to the ordering func will return. More... | |
EINA_API Eina_List * | eina_list_shuffle (Eina_List *list, Eina_Random_Cb func) |
Shuffles list. More... | |
EINA_API Eina_List * | eina_list_merge (Eina_List *left, Eina_List *right) |
Merges two list. More... | |
EINA_API Eina_List * | eina_list_sorted_merge (Eina_List *left, Eina_List *right, Eina_Compare_Cb func) |
Merges two sorted list according to the ordering func will return. More... | |
EINA_API Eina_List * | eina_list_split_list (Eina_List *list, Eina_List *relative, Eina_List **right) |
Splits a list into 2 lists. More... | |
EINA_API Eina_List * | eina_list_search_sorted_near_list (const Eina_List *list, Eina_Compare_Cb func, const void *data, int *result_cmp) |
Returns node nearest to data from the sorted list. More... | |
EINA_API Eina_List * | eina_list_search_sorted_list (const Eina_List *list, Eina_Compare_Cb func, const void *data) |
Returns node if data is in the sorted list. More... | |
EINA_API void * | eina_list_search_sorted (const Eina_List *list, Eina_Compare_Cb func, const void *data) |
Returns node data if it is in the sorted list. More... | |
EINA_API Eina_List * | eina_list_search_unsorted_list (const Eina_List *list, Eina_Compare_Cb func, const void *data) |
Returns node if data is in the unsorted list. More... | |
EINA_API void * | eina_list_search_unsorted (const Eina_List *list, Eina_Compare_Cb func, const void *data) |
Returns node data if it is in the unsorted list. More... | |
static Eina_List * | eina_list_last (const Eina_List *list) |
Gets the last list node in the list. More... | |
static Eina_List * | eina_list_next (const Eina_List *list) |
Gets the next list node after the specified list node. More... | |
static Eina_List * | eina_list_prev (const Eina_List *list) |
Gets the list node prior to the specified list node. More... | |
static void * | eina_list_data_get (const Eina_List *list) |
Gets the list node data member. More... | |
static void * | eina_list_data_set (Eina_List *list, const void *data) |
Sets the list node data member. More... | |
static unsigned int | eina_list_count (const Eina_List *list) |
Gets the count of the number of items in a list. More... | |
static void * | eina_list_last_data_get (const Eina_List *list) |
Returns the last list node's data. More... | |
EINA_API Eina_Iterator * | eina_list_iterator_new (const Eina_List *list) |
Returns a new iterator associated with a list. More... | |
EINA_API Eina_Iterator * | eina_list_iterator_reversed_new (const Eina_List *list) |
Returns a new reversed iterator associated with a list. More... | |
EINA_API Eina_Accessor * | eina_list_accessor_new (const Eina_List *list) |
Returns a new accessor associated with a list. More... | |
EINA_API int | eina_list_data_idx (const Eina_List *list, void *data) |
Finds the member of the list and returns the index. More... | |
These functions provide double linked list management.
Eina_List is a doubly linked list. It can store data of any type in the form of void pointers. It has convenience functions to do all the common operations which means it should rarely if ever be necessary to directly access the struct's fields. Nevertheless it can be useful to understand the inner workings of the data structure being used.
Eina_List nodes keep references to the previous node, the next node, its data and to an accounting structure.
Eina_List_Accounting is used to improve the performance of some functions. It is private and should not be modified. It contains a reference to the end of the list and the number of elements in the list.
Most functions have two versions that have the same effect but operate on different arguments, the plain functions operate over data(e.g..: eina_list_append_relative, eina_list_remove, eina_list_data_find), the list versions of these functions operate on Eina_List nodes.
Here are some examples of Eina_List usage:
#define EINA_LIST_FOREACH | ( | list, | |
l, | |||
_data | |||
) |
Definition for the macro to iterate over a list.
[in] | list | The list to iterate over. |
[out] | l | A list that is used as an iterator and points to the current node. |
[out] | _data | Current item's data. |
This macro iterates over list
from the first element to the last. data
is the data related to the current element. l
is an Eina_List used as the list iterator.
The following diagram illustrates this macro iterating over a list of four elements("one", "two", "three" and "four"):
It can be used to free list data, as in the following example:
list
must be a pointer to the first element of the list.#define EINA_LIST_REVERSE_FOREACH | ( | list, | |
l, | |||
_data | |||
) |
Definition for the macro to iterate over a list in the reverse order.
[in] | list | The list to iterate over. |
[out] | l | A list that is used as an iterator and points to the current node. |
[out] | _data | Current item's data. |
This macro works like EINA_LIST_FOREACH, but iterates from the last element of a list to the first. data
is the data related to the current element, while l
is an Eina_List that is used as the list iterator.
The following diagram illustrates this macro iterating over a list of four elements("one", "two", "three" and "four"):
It can be used to free list data, as in the following example:
list
must be a pointer to the first element of the list.#define EINA_LIST_FOREACH_SAFE | ( | list, | |
l, | |||
l_next, | |||
data | |||
) |
Definition for the macro to iterate over a list with support for node deletion.
[in] | list | The list to iterate over. |
[out] | l | A list that is used as an iterator and points to the current node. |
[out] | l_next | A list that is used as an iterator and points to the next node. |
[out] | data | Current item's data. |
This macro iterates over list
from the first element to the last. data
is the data related to the current element. l
is an Eina_List used as the list iterator.
Since this macro stores a pointer to the next list node in l_next
, deleting the current node and continuing looping is safe.
The following diagram illustrates this macro iterating over a list of four elements ("one", "two", "three" and "four"):
This macro can be used to free list nodes, as in the following example:
list
must be a pointer to the first element of the list. #define EINA_LIST_REVERSE_FOREACH_SAFE | ( | list, | |
l, | |||
l_prev, | |||
data | |||
) |
Definition for the macro to iterate over a list in the reverse order with support for deletion.
[in] | list | The list to iterate over. |
[out] | l | A list that is used as an iterator and points to the current node. |
[out] | l_prev | A list that is used as an iterator and points to the previous node. |
[out] | data | Current item's data. |
This macro works like EINA_LIST_FOREACH_SAFE, but iterates from the last element of a list to the first. data
is the data related to the current element, while l
is an Eina_List that is used as the list iterator.
Since this macro stores a pointer to the previous list node in l_prev
, deleting the current node and continuing looping is safe.
The following diagram illustrates this macro iterating over a list of four elements ("one", "two", "three" and "four"):
This macro can be used to free list nodes, as in the following example:
list
must be a pointer to the first element of the list. #define EINA_LIST_FREE | ( | list, | |
data | |||
) |
Definition for the macro to remove each list node while having access to each node's data.
[in,out] | list | The list that will be cleared. |
[out] | data | Current node's data. |
This macro will call eina_list_remove_list for each list node, and store the data contained in the current node in data
.
The following diagram illustrates this macro iterating over a list of four elements ("one", "two", "three" and "four"):
If you do not need to release node data, it is easier to call eina_list_free().
list
must be a pointer to the first element of the list.Appends the given data to the given linked list.
[in,out] | list | The given list. |
[in] | data | The data to append. |
NULL
on error.This function appends data
to list
. If list
is NULL
, a new list is returned. On success, a new list pointer that should be used in place of the one given to this function is returned. Otherwise, the old pointer is returned.
The following example code demonstrates how to ensure that the given data has been successfully appended.
list
must be a pointer to the first element of the list(or NULL). References _Eina_List::accounting, _Eina_List::data, _Eina_List_Accounting::last, _Eina_List::next, and _Eina_List::prev.
Referenced by ecore_con_eet_client_connect_callback_add(), ecore_con_eet_client_disconnect_callback_add(), ecore_con_eet_server_connect_callback_add(), ecore_con_eet_server_disconnect_callback_add(), ecore_con_lookup(), ecore_con_socks4_remote_add(), ecore_con_socks5_remote_add(), ecore_con_ssl_server_cafile_add(), ecore_con_ssl_server_cert_add(), ecore_con_ssl_server_crl_add(), ecore_con_ssl_server_privkey_add(), ecore_con_url_new(), ecore_drm2_plane_assign(), ecore_drm2_plane_fb_set(), ecore_drm2_plane_release(), ecore_drm_device_find(), ecore_evas_aux_hint_add(), ecore_evas_aux_hints_allowed_get(), ecore_evas_ecore_evas_list_get(), ecore_evas_vnc_start(), ecore_file_ls(), ecore_fork_reset_callback_add(), ecore_imf_context_event_callback_add(), ecore_imf_context_input_panel_event_callback_add(), ecore_main_fd_handler_prepare_callback_set(), ecore_thread_feedback_run(), ecore_thread_run(), ecore_wl2_offer_receive(), ecore_wl2_window_aux_hints_supported_get(), edje_available_modules_get(), edje_edit_color_class_add(), edje_edit_color_classes_list_get(), edje_edit_data_list_get(), edje_edit_externals_list_get(), edje_edit_fonts_list_get(), edje_edit_group_aliases_get(), edje_edit_group_data_list_get(), edje_edit_image_set_image_add(), edje_edit_image_set_images_list_get(), edje_edit_image_set_list_get(), edje_edit_images_list_get(), edje_edit_part_items_list_get(), edje_edit_parts_list_get(), edje_edit_program_after_add(), edje_edit_program_after_insert_at(), edje_edit_program_target_add(), edje_edit_program_target_insert_at(), edje_edit_programs_list_get(), edje_edit_size_class_add(), edje_edit_size_classes_list_get(), edje_edit_sound_samples_list_get(), edje_edit_sound_tones_list_get(), edje_edit_state_add(), edje_edit_state_external_param_set(), edje_edit_state_tweens_list_get(), edje_edit_style_add(), edje_edit_style_tag_add(), edje_edit_style_tags_list_get(), edje_edit_styles_list_get(), edje_edit_text_class_add(), edje_edit_text_classes_list_get(), edje_edit_vectors_list_get(), edje_mmap_collection_list(), edje_mmap_color_class_used_list(), edje_mmap_group_exists(), edje_object_access_part_list_get(), edje_object_perspective_set(), edje_object_text_insert_filter_callback_add(), edje_object_text_markup_filter_callback_add(), eet_eina_stream_data_descriptor_class_set(), eet_node_hash_new(), eet_node_list_append(), eeze_disk_eject(), eeze_disk_new_from_mount(), eeze_disk_unmount(), eeze_net_list(), eeze_udev_find_by_filter(), eeze_udev_find_by_subsystem_sysname(), eeze_udev_find_by_sysattr(), eeze_udev_find_by_type(), eeze_udev_syspath_get_parents(), eeze_udev_syspath_get_sysattr_list(), efreet_desktop_category_add(), efreet_desktop_command_local_get(), efreet_desktop_command_progress_get(), efreet_desktop_string_list_parse(), efreet_desktop_type_add(), efreet_icon_list_find(), efreet_util_desktop_categories_list(), efreet_util_desktop_environments_list(), efreet_util_desktop_exec_glob_list(), eina_benchmark_run(), eina_debug_opcodes_register(), eina_file_flush(), eina_hash_list_append(), eina_hash_list_direct_append(), eina_hash_list_direct_prepend(), eina_hash_list_prepend(), eina_list_append_relative(), eina_list_append_relative_list(), eina_list_clone(), eina_list_move(), eina_list_move_list(), eina_list_sorted_insert(), eina_multi_iterator_internal_new(), eina_rectangle_pool_new(), eldbus_connection_event_callback_del(), eldbus_name_owner_changed_callback_del(), eldbus_object_event_callback_del(), eldbus_object_signal_handler_add(), eldbus_proxy_event_callback_del(), eldbus_proxy_signal_handler_add(), elm_color_class_editor_add(), elm_color_class_util_edje_file_list(), elm_config_profile_derived_add(), elm_drag_item_container_add(), elm_drop_item_container_add(), elm_layout_content_swallow_list_get(), elm_radio_group_add(), elm_theme_copy(), elm_theme_extension_list_get(), elm_theme_list_get(), elm_theme_overlay_list_get(), elm_theme_ref_set(), elm_transit_chain_transit_add(), elm_transit_object_add(), elua_state_include_path_add(), elua_util_require(), ethumb_client_thumb_exists(), evas_device_add_full(), evas_font_path_global_append(), evas_object_box_children_get(), evas_object_clipees_get(), evas_object_image_video_surface_set(), evas_object_smart_members_get(), evas_object_textblock_cursor_new(), evas_textblock_cursor_range_formats_get(), and evas_textblock_cursor_range_simple_geometry_get().
Prepends the given data to the given linked list.
[in,out] | list | The given list. |
[in] | data | The data to prepend. |
NULL
on error.This function prepends data
to list
. If list
is NULL
, a new list is returned. On success, a new list pointer that should be used in place of the one given to this function is returned. Otherwise, the old pointer is returned.
The following example code demonstrates how to ensure that the given data has been successfully prepended.
Example:
list
must be a pointer to the first element of the list. References _Eina_List::data, _Eina_List::next, and _Eina_List::prev.
Referenced by edje_edit_group_add(), eet_node_struct_child_new(), eeze_udev_find_similar_from_syspath(), efreet_icon_extension_add(), eina_hash_list_direct_prepend(), eina_hash_list_prepend(), eina_list_prepend_relative(), eina_list_prepend_relative_list(), eina_list_reverse_clone(), evas_font_path_global_prepend(), evas_gl_pbuffer_surface_create(), evas_gl_surface_create(), evas_post_event_callback_push(), and evas_textblock_node_format_remove_pair().
EINA_API Eina_List * eina_list_append_relative | ( | Eina_List * | list, |
const void * | data, | ||
const void * | relative | ||
) |
Inserts the given data into the given linked list after the specified data.
[in,out] | list | The given linked list. |
[in] | data | The data to insert. |
[in] | relative | The data to insert after. |
NULL
on error.This function inserts data
into list
after relative
. If relative
is not in the list, data
is appended to the list. If list
is NULL
, a new list is returned. If there are multiple instances of relative
in the list, data
is inserted after the first instance. On success, a new list pointer that should be used in place of the one given to this function is returned. Otherwise, the old pointer is returned.
The following example code demonstrates how to ensure that the given data has been successfully inserted.
list
must be a pointer to the first element of the list. References eina_list_append(), eina_list_append_relative_list(), and EINA_LIST_FOREACH.
Referenced by elm_object_focus_custom_chain_append().
EINA_API Eina_List * eina_list_append_relative_list | ( | Eina_List * | list, |
const void * | data, | ||
Eina_List * | relative | ||
) |
Appends a list node to a linked list after the specified member.
[in,out] | list | The given linked list. |
[in] | data | The data to insert. |
[in] | relative | The list node to insert after. |
NULL
on error.This function inserts data
into list
after the list node relative
. If list
or relative
are NULL
, data
is just appended to list
using eina_list_append(). If list
is NULL
, a new list is returned. If there are multiple instances of relative
in the list, data
is inserted after the first instance. On success, a new list pointer that should be used in place of the one given to this function is returned. Otherwise, the old pointer is returned.
list
must be a pointer to the first element of the list. References _Eina_List::accounting, _Eina_List::data, eina_list_append(), _Eina_List_Accounting::last, _Eina_List::next, and _Eina_List::prev.
Referenced by eina_list_append_relative(), and eina_list_sorted_insert().
EINA_API Eina_List * eina_list_prepend_relative | ( | Eina_List * | list, |
const void * | data, | ||
const void * | relative | ||
) |
Prepends a data pointer to a linked list before the specified member.
[in,out] | list | The given linked list. |
[in] | data | The data to insert. |
[in] | relative | The member that data will be inserted before. |
NULL
on error.This function inserts data
to list
before relative
. If relative
is not in the list, data
is prepended to the list with eina_list_prepend(). If list
is NULL
, a new list is returned. If there are multiple instances of relative
in the list, data
is inserted before the first instance. On success, a new list pointer that should be used in place of the one given to this function is returned. Otherwise, the old pointer is returned.
The following code example demonstrates how to ensure that the given data has been successfully inserted.
list
must be a pointer to the first element of the list. References EINA_LIST_FOREACH, eina_list_prepend(), and eina_list_prepend_relative_list().
Referenced by elm_object_focus_custom_chain_prepend().
EINA_API Eina_List * eina_list_prepend_relative_list | ( | Eina_List * | list, |
const void * | data, | ||
Eina_List * | relative | ||
) |
Prepends a list node to a linked list before the specified member.
[in,out] | list | The given linked list. |
[in] | data | The data to insert. |
[in] | relative | The list node to insert before. |
NULL
on error.This function inserts data
to list
before the list node relative
. If list
or relative
are NULL
, data
is just prepended to list
using eina_list_prepend(). If list
is NULL
, a new list is returned. If there are multiple instances of relative
in the list, data
is inserted before the first instance. On success, a new list pointer that should be used in place of the one given to this function is returned. Otherwise, the old pointer is returned.
list
must be a pointer to the first element of the list. References _Eina_List::data, eina_list_prepend(), _Eina_List::next, and _Eina_List::prev.
Referenced by edje_edit_program_after_insert_at(), edje_edit_program_target_insert_at(), eina_list_prepend_relative(), and eina_list_sorted_insert().
EINA_API Eina_List * eina_list_sorted_insert | ( | Eina_List * | list, |
Eina_Compare_Cb | func, | ||
const void * | data | ||
) |
Inserts a new node into a sorted list.
[in,out] | list | The given linked list, must be sorted. |
[in] | func | The function called for the sort. |
[in] | data | The data to be inserted in sorted order. |
NULL
on error.This function inserts values into a linked list assuming it was sorted and the result will be sorted. If list
is NULL
, a new list is returned. On success, a new list pointer that should be used in place of the one given to this function is returned. Otherwise, the old pointer is returned.
func
) average/worst case performance as it uses eina_list_search_sorted_near_list() and thus is bounded to that. As said in eina_list_search_sorted_near_list(), lists do not have O(1) access time, so walking to the correct node can be costly, consider worst case to be almost O(n) pointer dereference (list walk).list
must be a pointer to the first element of the list. References eina_list_append(), eina_list_append_relative_list(), eina_list_prepend_relative_list(), and eina_list_search_sorted_near_list().
Removes the first instance of the specified data from the given list.
[in,out] | list | The given list. |
[in] | data | The specified data. |
NULL
on error.This function removes the first instance of data
from list
. If data
is not in the given list or is NULL
, nothing is done and the specified list
returned. If list
is NULL
, NULL
is returned, otherwise a new list pointer that should be used in place of the one passed to this function is returned.
list
must be a pointer to the first element of the list. References eina_list_data_find_list(), and eina_list_remove_list().
Referenced by ecore_con_socks4_remote_del(), ecore_con_socks5_remote_del(), ecore_con_socks_remote_del(), ecore_drm2_plane_assign(), ecore_evas_aux_hint_del(), ecore_fb_input_device_close(), ecore_imf_context_input_panel_event_callback_clear(), ecore_ipc_client_del(), ecore_ipc_server_del(), ecore_thread_feedback_run(), ecore_thread_run(), edje_edit_color_class_del(), edje_edit_size_class_del(), edje_edit_string_list_free(), edje_edit_style_del(), edje_edit_style_tag_del(), edje_edit_text_class_del(), edje_file_collection_list_free(), edje_object_perspective_set(), eeze_disk_free(), efreet_desktop_category_del(), efreet_menu_desktop_remove(), eina_hash_list_remove(), eina_quadtree_del(), elm_radio_group_add(), elm_transit_chain_transit_add(), elm_transit_chain_transit_del(), ethumb_client_thumb_exists_cancel(), evas_font_path_global_clear(), evas_gl_context_destroy(), evas_gl_surface_destroy(), evas_object_image_video_surface_set(), and evas_textblock_cursor_free().
Removes the specified list node.
[in,out] | list | The given linked list. |
[in] | remove_list | The list node which is to be removed. |
NULL
on error.This function removes the list node remove_list
from list
and frees the list node structure remove_list
. If list
is NULL
, this function returns NULL
. If remove_list
is NULL
, it returns list
; otherwise, a new list pointer that should be used in place of the one passed to this function.
The following code gives an example. (Notice we use EINA_LIST_FOREACH rather than EINA_LIST_FOREACH_SAFE because we stop the loop after removing the current node.)
list
must be a pointer to the first element of the list. References _Eina_List::accounting, _Eina_List_Accounting::last, _Eina_List::next, and _Eina_List::prev.
Referenced by ecore_con_eet_client_connect_callback_del(), ecore_con_eet_client_disconnect_callback_del(), ecore_con_eet_server_connect_callback_del(), ecore_con_eet_server_disconnect_callback_del(), ecore_fork_reset(), ecore_fork_reset_callback_del(), ecore_imf_context_event_callback_del(), ecore_imf_context_input_panel_event_callback_del(), ecore_thread_cancel(), edje_edit_group_del(), edje_edit_image_set_image_del(), edje_edit_program_after_del(), edje_edit_program_afters_clear(), edje_edit_program_del(), edje_edit_program_target_del(), edje_edit_program_targets_clear(), edje_object_text_insert_filter_callback_del(), edje_object_text_insert_filter_callback_del_full(), edje_object_text_markup_filter_callback_del(), edje_object_text_markup_filter_callback_del_full(), eina_debug_timer_del(), eina_file_common_map_free(), eina_list_move(), eina_list_move_list(), eina_list_remove(), elm_spinner_special_value_del(), and evas_textblock_node_format_remove_pair().
Moves the specified data to the head of the list.
[in,out] | list | The given linked list. |
[in] | move_list | The list node to move. |
NULL
on error.This function moves move_list
to the front of list
. If list is NULL
, NULL
is returned. If move_list
is NULL
, list
is returned. Otherwise, a new list pointer that should be used in place of the one passed to this function is returned.
Example:
list
must be a pointer to the first element of the list. References _Eina_List::accounting, _Eina_List_Accounting::last, _Eina_List::next, and _Eina_List::prev.
Referenced by efreet_icon_extension_add().
Moves the specified data to the tail of the list.
[in,out] | list | The given linked list. |
[in] | move_list | The list node to move. |
NULL
on error.This function move move_list
to the end of list
. If list is NULL
, NULL
is returned. If move_list
is NULL
, list
is returned. Otherwise, a new list pointer that should be used in place of the one passed to this function is returned.
Example:
list
must be a pointer to the first element of the list. References _Eina_List::accounting, _Eina_List_Accounting::last, _Eina_List::next, and _Eina_List::prev.
Finds a member of a list and returns it.
[in] | list | The linked list to search. |
[in] | data | The data member to find in the list. |
NULL
otherwise.This function searches in list
from beginning to end for the first member whose data pointer is data
. If it is found, data
will be returned, otherwise NULL
will be returned.
Example:
list
must be a pointer to the first element of the list. References eina_list_data_find_list().
Referenced by ecore_evas_focus_device_get(), and ecore_main_fd_handler_prepare_callback_set().
Finds a member of a list and returns it as a list node.
[in] | list | The list to search for data. |
[in] | data | The data pointer to find in the list. |
NULL
otherwise.This function searches list
from beginning to end for the first member whose data pointer is data
. If it is found, the list node containing the specified member is returned, otherwise NULL
is returned.
list
must be a pointer to the first element of the list. References EINA_LIST_FOREACH.
Referenced by efreet_icon_extension_add(), eina_debug_timer_del(), eina_list_data_find(), eina_list_move(), eina_list_remove(), and elm_transit_object_add().
Moves a data pointer from one list to another.
[in,out] | to | The list to move the data to. |
[in,out] | from | The list to move from. |
[in] | data | The data member to move. |
This function is a shortcut for doing the following: to = eina_list_append(to, data); from = eina_list_remove(from, data);
list
must be a pointer to the first element of the list. References EINA_FALSE, eina_list_append(), eina_list_data_find_list(), eina_list_remove_list(), EINA_SAFETY_ON_NULL_RETURN_VAL, and EINA_TRUE.
Moves a list node from one list to another.
[in,out] | to | The list to move the data to. |
[in,out] | from | The list to move from. |
[in] | data | The list node containing the data to move. |
This function is a shortcut for doing the following: to = eina_list_append(to, data->data); from = eina_list_remove_list(from, data);
list
must be a pointer to the first element of the list. References _Eina_List::data, EINA_FALSE, eina_list_append(), eina_list_remove_list(), EINA_SAFETY_ON_NULL_RETURN_VAL, and EINA_TRUE.
Frees an entire list and all the nodes, ignoring the data contained.
[in,out] | list | The list to free. |
NULL
pointer.This function frees all the nodes of list
. It does not free the data of the nodes. To free them, use EINA_LIST_FREE.
References _Eina_List::next.
Referenced by ecore_audio_shutdown(), ecore_evas_engines_free(), ecore_ipc_server_del(), edje_file_color_class_used_free(), edje_mmap_color_class_used_list(), edje_mmap_group_exists(), eet_eina_stream_data_descriptor_class_set(), efreet_desktop_command_progress_get(), efreet_icon_list_find(), elm_store_free(), elm_theme_extension_mmap_add(), elm_theme_extension_mmap_del(), elm_theme_overlay_mmap_add(), elm_theme_overlay_mmap_del(), elua_state_free(), evas_event_feed_hold(), evas_object_clipees_get(), and evas_textblock_node_format_remove_pair().
Gets the nth member's data pointer in a list, or NULL
on error.
[in] | list | The list to get the specified member number from. |
[in] | n | The number of the element (0 being the first). |
This function returns the data pointer of element number n
, in the list
. The first element in the array is element number 0. If the element number n
does not exist, NULL
is returned. Otherwise, the data of the found element is returned.
list
must be a pointer to the first element of the list. References _Eina_List::data, and eina_list_nth_list().
Referenced by edje_edit_image_set_image_border_get(), edje_edit_image_set_image_border_scale_get(), edje_edit_image_set_image_border_scale_set(), edje_edit_image_set_image_border_set(), edje_edit_image_set_image_del(), efreet_desktop_free(), efreet_desktop_get(), efreet_desktop_save(), efreet_desktop_type_alias(), evas_touch_point_list_nth_id_get(), and evas_touch_point_list_nth_state_get().
Gets the nth member's list node in a list.
[in] | list | The list to get the specified member number from. |
[in] | n | The number of the element (0 being the first). |
NULL
on error.This function returns the list node of element number n
, in list
. The first element in the array is element number 0. If the element number n
does not exist or list
is NULL
or n
is greater than the count of elements in list
minus 1, NULL
is returned. Otherwise the list node stored in the numbered element is returned.
list
must be a pointer to the first element of the list. References _Eina_List::accounting, _Eina_List_Accounting::count, _Eina_List_Accounting::last, _Eina_List::next, and _Eina_List::prev.
Referenced by edje_edit_image_set_image_del(), edje_edit_program_after_insert_at(), edje_edit_program_target_insert_at(), eina_list_nth(), and eina_list_sort().
Reverses all the elements in the list.
[in,out] | list | The list to reverse. |
NULL
on error.This function reverses the order of all elements in list
, so the last member is now first, and so on. If list
is NULL
, this function returns NULL
.
list
must be a pointer to the first element of the list.References _Eina_List::accounting, _Eina_List::data, _Eina_List_Accounting::last, _Eina_List::next, and _Eina_List::prev.
Clones (copies) all the elements in the list in reverse order.
[in] | list | The list to reverse. |
NULL
on error.This function reverses the order of all elements in list
, so the last member is now first, and so on. If list
is NULL
, this function returns NULL
. This returns a copy of the given list.
list
must be a pointer to the first element of the list.References EINA_LIST_FOREACH, and eina_list_prepend().
Clones (copies) all the elements in the list in exactly same order.
[in] | list | The list to clone. |
NULL
on error.This function clone in order of all elements in list
. If list
is NULL
, this function returns NULL
. This returns a copy of the given list.
list
must be a pointer to the first element of the list.References eina_list_append(), and EINA_LIST_FOREACH.
Referenced by ecore_evas_engines_get(), elm_object_focus_custom_chain_append(), and elm_object_focus_custom_chain_prepend().
EINA_API Eina_List * eina_list_sort | ( | Eina_List * | list, |
unsigned int | limit, | ||
Eina_Compare_Cb | func | ||
) |
Sorts a list according to the ordering func will return.
[in] | list | The list handle to sort. |
[in] | limit | The maximum number of list elements to sort. |
[in] | func | A function pointer that can handle comparing the list data nodes. |
This function sorts list
. If limit
is 0 or greater than the number of elements in list
, all the elements are sorted. func
is used to compare two elements of list
. If func
is NULL
, this function returns list
.
Example:
list
must be a pointer to the first element of the list. References _Eina_List::accounting, _Eina_List_Accounting::count, eina_list_nth_list(), EINA_SAFETY_ON_NULL_RETURN_VAL, _Eina_List_Accounting::last, _Eina_List::next, and _Eina_List::prev.
Referenced by ecore_file_ls(), eina_rectangle_pool_request(), elm_theme_color_class_list(), and elm_theme_group_base_list().
EINA_API Eina_List * eina_list_shuffle | ( | Eina_List * | list, |
Eina_Random_Cb | func | ||
) |
Shuffles list.
[in] | list | The list handle to shuffle. |
[in] | func | A function pointer that can return an int between 2 inclusive values |
This function shuffles list
. func
is used to generate random list indexes within the range of unshuffled list items. If func
is NULL
, rand is used.
list
must be a pointer to the first element of the list. References _Eina_List::accounting, _Eina_List_Accounting::count, _Eina_List_Accounting::last, _Eina_List::next, and _Eina_List::prev.
Merges two list.
[in] | left | Head list to merge. |
[in] | right | Tail list to merge. |
This function puts right at the end of left and returns the head.
Both left and right do not exist anymore after the merge.
list
must be a pointer to the first element of the list. References _Eina_List::accounting, _Eina_List_Accounting::count, _Eina_List_Accounting::last, _Eina_List::next, and _Eina_List::prev.
Referenced by eina_file_flush(), and evas_textblock_cursor_range_simple_geometry_get().
EINA_API Eina_List * eina_list_sorted_merge | ( | Eina_List * | left, |
Eina_List * | right, | ||
Eina_Compare_Cb | func | ||
) |
Merges two sorted list according to the ordering func will return.
[in] | left | First list to merge. |
[in] | right | Second list to merge. |
[in] | func | A function pointer that can handle comparing the list data nodes. |
This function compares the head of left
and right
, and choose the smallest one to be head of the returned list. It will continue this process for all entry of both list.
Both left and right lists are not valid anymore after the merge and should not be used. If func
is NULL
, it will return NULL
.
Example:
list
must be a pointer to the first element of the list. References _Eina_List::accounting, _Eina_List_Accounting::count, _Eina_List::data, EINA_SAFETY_ON_NULL_RETURN_VAL, _Eina_List_Accounting::last, _Eina_List::next, and _Eina_List::prev.
EINA_API Eina_List * eina_list_split_list | ( | Eina_List * | list, |
Eina_List * | relative, | ||
Eina_List ** | right | ||
) |
Splits a list into 2 lists.
[in] | list | List to split. |
[in] | relative | The list will be split after relative . |
[out] | right | The head of the new right list. |
This function splits list
into two lists ( left and right ) after the node relative
. Relative
will become the last node of the left list. If list
or right
are NULL
list is returns. If relative
is NULL right is set to list
and NULL
is returns. If relative
is the last node of list
list is returns and right
is set to NULL
.
list does not exist anymore after the split.
list
must be a pointer to the first element of the list. References _Eina_List::accounting, _Eina_List_Accounting::count, eina_list_last(), eina_list_next(), _Eina_List_Accounting::last, _Eina_List::next, and _Eina_List::prev.
EINA_API Eina_List * eina_list_search_sorted_near_list | ( | const Eina_List * | list, |
Eina_Compare_Cb | func, | ||
const void * | data, | ||
int * | result_cmp | ||
) |
Returns node nearest to data from the sorted list.
[in] | list | The list to search for data, must be sorted. |
[in] | func | A function pointer that can handle comparing the list data nodes. |
[in] | data | reference value to search. |
[out] | result_cmp | If provided returns the result of func(node->data, data) node being the last (returned) node. If node was found (exact match), then it is 0. If returned node is smaller than requested data, it is less than 0 and if it's bigger it's greater than 0. It is the last value returned by func(). |
NULL
if not found.This function searches for a node containing data
as its data in list
, if such a node exists it will be returned and result_cmp
will be 0
. If the data of no node in list
is equal to data
, the node with the nearest value to that will be returned and result_cmp
will be the return value of func
with data
and the returned node's data as arguments.
This function is useful for inserting an element in the list only in case it isn't already present in the list, the naive way of doing this would be:
However this has the downside of walking through the list twice, once to check if the data is already present and another to insert the element in the correct position. This can be done more efficiently:
If cmp_result is 0 the element is already in the list and we need not insert it, if cmp_result is greater than zero "my @a data" needs to come after l (the nearest node present), if less than zero before.
list
must be a pointer to the first element of the list.References _Eina_List::accounting, _Eina_List_Accounting::count, _Eina_List::data, _Eina_List_Accounting::last, and _Eina_List::next.
Referenced by eina_list_search_sorted_list(), and eina_list_sorted_insert().
EINA_API Eina_List * eina_list_search_sorted_list | ( | const Eina_List * | list, |
Eina_Compare_Cb | func, | ||
const void * | data | ||
) |
Returns node if data is in the sorted list.
[in] | list | The list to search for data, must be sorted. |
[in] | func | A function pointer that can handle comparing the list data nodes. |
[in] | data | reference value to search. |
NULL
if not found.This can be used to check if some value is inside the list and get the container node in this case. It should be used when list is known to be sorted as it will do binary search for results.
Example: imagine user gives a string, you check if it's in the list before duplicating its contents.
list
must be a pointer to the first element of the list.References eina_list_search_sorted_near_list().
Referenced by eina_list_search_sorted().
EINA_API void * eina_list_search_sorted | ( | const Eina_List * | list, |
Eina_Compare_Cb | func, | ||
const void * | data | ||
) |
Returns node data if it is in the sorted list.
[in] | list | The list to search for data, must be sorted. |
[in] | func | A function pointer that can handle comparing the list data nodes. |
[in] | data | reference value to search. |
node->data
) if func(node->data, data) == 0, NULL
if not found.This can be used to check if some value is inside the list and get the existing instance in this case. It should be used when list is known to be sorted as it will do binary search for results.
Example: imagine user gives a string, you check if it's in the list before duplicating its contents.
list
must be a pointer to the first element of the list.References eina_list_data_get(), and eina_list_search_sorted_list().
EINA_API Eina_List * eina_list_search_unsorted_list | ( | const Eina_List * | list, |
Eina_Compare_Cb | func, | ||
const void * | data | ||
) |
Returns node if data is in the unsorted list.
[in] | list | The list to search for data, may be unsorted. |
[in] | func | A function pointer that can handle comparing the list data nodes. |
[in] | data | reference value to search. |
NULL
if not found.This can be used to check if some value is inside the list and get the container node in this case.
Example: imagine user gives a string, you check if it's in the list before duplicating its contents.
list
must be a pointer to the first element of the list.References EINA_LIST_FOREACH.
Referenced by eina_list_search_unsorted().
EINA_API void * eina_list_search_unsorted | ( | const Eina_List * | list, |
Eina_Compare_Cb | func, | ||
const void * | data | ||
) |
Returns node data if it is in the unsorted list.
[in] | list | The list to search for data, may be unsorted. |
[in] | func | A function pointer that can handle comparing the list data nodes. |
[in] | data | reference value to search. |
node->data
) if func(node->data, data) == 0, NULL
if not found.This can be used to check if some value is inside the list and get the existing instance in this case.
Example: imagine user gives a string, you check if it's in the list before duplicating its contents.
list
must be a pointer to the first element of the list.References eina_list_data_get(), and eina_list_search_unsorted_list().
Referenced by efreet_desktop_category_add(), efreet_desktop_category_del(), efreet_menu_desktop_remove(), elm_drag_item_container_add(), and elm_drop_item_container_add().
Gets the last list node in the list.
[in] | list | The list to get the last list node from. |
This function returns the last list node in the list list
. If list
is NULL
or empty, NULL
is returned.
This is a order-1 operation (it takes the same short time regardless of the length of the list).
list
must be a pointer to the first element of the list. Referenced by eina_list_iterator_reversed_new(), and eina_list_split_list().
Gets the next list node after the specified list node.
[in] | list | The list node to get the next list node from |
NULL
otherwise.This function returns the next list node after the current one in list
. It is equivalent to list->next. If list
is NULL
or if no next list node exists, it returns NULL
.
list
must be a pointer to the first element of the list. Referenced by eet_eina_stream_data_descriptor_class_set(), eina_list_split_list(), and evas_textblock_node_format_remove_pair().
Gets the list node prior to the specified list node.
[in] | list | The list node to get the previous list node from. |
NULL
otherwise.This function returns the previous list node before the current one in list
. It is equivalent to list->prev. If list
is NULL
or if no previous list node exists, it returns NULL
.
list
must be a pointer to the first element of the list.
|
inlinestatic |
Gets the list node data member.
[in] | list | The list node to get the data member of. |
This function returns the data member of the specified list node list
. It is equivalent to list->data. If list
is NULL
, this function returns NULL
.
list
must be a pointer to the first element of the list. Referenced by ecore_wl2_window_output_find(), edje_edit_limits_list_free(), edje_edit_program_afters_clear(), edje_edit_program_targets_clear(), edje_edit_state_name_set(), edje_edit_string_list_free(), edje_file_collection_list_free(), eet_eina_stream_data_descriptor_class_set(), eina_list_search_sorted(), eina_list_search_unsorted(), elm_drop_target_del(), elm_transit_go(), evas_engine_info_get(), evas_engine_info_set(), and evas_output_size_set().
|
inlinestatic |
Sets the list node data member.
[in,out] | list | The list node to set the data member of. |
[in] | data | The data to be set. |
This function sets the data member data
of the specified list node list
. It returns the previous data of the node. If list
is NULL
, this function returns NULL
.
list
must be a pointer to the first element of the list.
|
inlinestatic |
Gets the count of the number of items in a list.
[in] | list | The list whose count to return. |
This function returns the quantity of members that list
contains. If the list is NULL
, 0
is returned.
NB: This is an order-1 operation and takes the same time regardless of the length of the list.
list
must be a pointer to the first element of the list. Referenced by ecore_drm2_outputs_create(), ecore_drm_inputs_device_axis_size_set(), ecore_file_ls(), ecore_thread_pending_feedback_get(), ecore_thread_pending_get(), ecore_thread_pending_total_get(), edje_edit_program_after_insert_at(), edje_edit_program_target_insert_at(), edje_edit_state_name_set(), eet_node_var_array_new(), efreet_desktop_category_count_get(), efreet_desktop_type_add(), elm_radio_group_add(), elput_input_pointer_xy_set(), ethumb_client_thumb_exists_cancel(), and evas_touch_point_list_count().
|
inlinestatic |
Returns the last list node's data.
[in] | list | The list. |
NULL
on being passed a NULL
pointerThis function is a shortcut for typing eina_list_data_get(eina_list_last())
EINA_API Eina_Iterator * eina_list_iterator_new | ( | const Eina_List * | list | ) |
Returns a new iterator associated with a list.
[in] | list | The list. |
NULL
on memory allocation failure.This function returns a newly allocated iterator associated with list
. If list
is NULL
or the count member of list
is less than or equal to 0, this function still returns a valid iterator that will always return false on eina_iterator_next(), thus keeping API sane.
list
must be a pointer to the first element of the list.References EINA_MAGIC_SET, FUNC_ITERATOR_FREE, FUNC_ITERATOR_GET_CONTAINER, and FUNC_ITERATOR_NEXT.
Referenced by ecore_win32_monitors_get().
EINA_API Eina_Iterator * eina_list_iterator_reversed_new | ( | const Eina_List * | list | ) |
Returns a new reversed iterator associated with a list.
[in] | list | The list. |
NULL
on memory allocation failure.This function returns a newly allocated iterator associated with list
. If list
is NULL
or the count member of list
is less than or equal to 0, this function still returns a valid iterator that will always return false on eina_iterator_next(), thus keeping API sane.
Unlike eina_list_iterator_new(), this will walk the list backwards.
list
must be a pointer to the first element of the list.References eina_list_last(), EINA_MAGIC_SET, FUNC_ITERATOR_FREE, FUNC_ITERATOR_GET_CONTAINER, and FUNC_ITERATOR_NEXT.
EINA_API Eina_Accessor * eina_list_accessor_new | ( | const Eina_List * | list | ) |
Returns a new accessor associated with a list.
[in] | list | The list. |
NULL
on error.This function returns a newly allocated accessor associated with list
. If list
is NULL
or the count member of list
is less or equal than 0, this function returns NULL
. If the memory can not be allocated, NULL
is returned; otherwise, a valid accessor is returned.
list
must be a pointer to the first element of the list. References EINA_MAGIC_SET, EINA_SAFETY_ON_NULL_RETURN_VAL, FUNC_ACCESSOR_CLONE, FUNC_ACCESSOR_FREE, FUNC_ACCESSOR_GET_AT, and FUNC_ACCESSOR_GET_CONTAINER.
Finds the member of the list and returns the index.
[in] | list | The list. |
[in] | data | The data member. |
-1
otherwise.This function searches in list
from beginning to end for the first member whose data pointer is data
. If it is found, the index of the data will be returned, otherwise -1
will be returned.
list
must be a pointer to the first element of the list.References EINA_LIST_FOREACH.