Adding elements to Eina_List

Creating an Eina_List and adding elements to it is very easy and can be understood from an example: First thing is always to include Eina.h, for this example we also include stdio.h so we can use printf.

#include <stdio.h>
#include <Eina.h>

Just some boilerplate code, declaring some variables and initializing eina.

int
main(int argc, char **argv)
{
(void)argc;
(void)argv;
Eina_List *list = NULL;
void *list_data;

Here we add a sequence of elements to our list. By using append we add elements to the end of the list, so the list will look like this:

eina_list_example_01_a.png
list = eina_list_append(list, "tigh");
list = eina_list_append(list, "adar");
list = eina_list_append(list, "baltar");
list = eina_list_append(list, "roslin");

There are a couple of interesting things happening here, first is that we are passing a NULL pointer to the first eina_list_append() call, when this is done a list is created. The other very important detail to notice is that the return value is attributed to the list variable, this needs to be done every time we use a a function that alters the contents of the list.

Now that we have a list with some elements in it we can look at its contents.

EINA_LIST_FOREACH(list, l, list_data)
printf("%s\n", (char*)list_data);

There are many ways of accessing elements in the list, including by its index:

printf("\n");
l = eina_list_nth_list(list, 1);
Note
It should be noted that the index starts at 0.

eina_list_append() is not the only way to add elements to a a list. A common requirement is to add an element in a specific position this can be accomplished using eina_list_append_relative() and eina_list_append_relative_list():

list = eina_list_append_relative_list(list, "cain", l);
list = eina_list_append_relative(list, "zarek", "cain");

First "cain" is added after the second element (remember that indexes are 0 based) and then we add "zarek" after "cain".

Eina_List also has prepend analogs to append functions we have used so far:

list = eina_list_prepend(list, "adama");
list = eina_list_prepend_relative(list, "gaeta", "cain");
list = eina_list_prepend_relative_list(list, "lampkin", l);

With this additions our list now looks like this:

eina_list_example_01_b.png

Once done using the list it needs to be freed, and since we are done with eina that also need to be shutdown:

EINA_LIST_FOREACH(list, l, list_data)
printf("%s\n", (char*)list_data);
return 0;
}

The full source code can be found on the examples folder on the eina_list_01.c file.