mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-12 21:40:19 +00:00
Added g_list_insert_sorted and g_slist_insert_sorted to glib.
-Yosh
This commit is contained in:
parent
51a481d9e8
commit
82da232b12
@ -397,6 +397,9 @@ GList* g_list_prepend (GList *list,
|
|||||||
GList* g_list_insert (GList *list,
|
GList* g_list_insert (GList *list,
|
||||||
gpointer data,
|
gpointer data,
|
||||||
gint position);
|
gint position);
|
||||||
|
GList* g_list_insert_sorted (GList *list,
|
||||||
|
gpointer data,
|
||||||
|
GCompareFunc func);
|
||||||
GList* g_list_concat (GList *list1,
|
GList* g_list_concat (GList *list1,
|
||||||
GList *list2);
|
GList *list2);
|
||||||
GList* g_list_remove (GList *list,
|
GList* g_list_remove (GList *list,
|
||||||
@ -415,6 +418,8 @@ void g_list_foreach (GList *list,
|
|||||||
GFunc func,
|
GFunc func,
|
||||||
gpointer user_data);
|
gpointer user_data);
|
||||||
|
|
||||||
|
#define g_list_previous(list) (((GList *)list)->prev)
|
||||||
|
#define g_list_next(list) (((GList *)list)->next)
|
||||||
|
|
||||||
/* Singly linked lists
|
/* Singly linked lists
|
||||||
*/
|
*/
|
||||||
@ -428,6 +433,9 @@ GSList* g_slist_prepend (GSList *list,
|
|||||||
GSList* g_slist_insert (GSList *list,
|
GSList* g_slist_insert (GSList *list,
|
||||||
gpointer data,
|
gpointer data,
|
||||||
gint position);
|
gint position);
|
||||||
|
GSList* g_slist_insert_sorted (GSList *list,
|
||||||
|
gpointer data,
|
||||||
|
GCompareFunc func);
|
||||||
GSList* g_slist_concat (GSList *list1,
|
GSList* g_slist_concat (GSList *list1,
|
||||||
GSList *list2);
|
GSList *list2);
|
||||||
GSList* g_slist_remove (GSList *list,
|
GSList* g_slist_remove (GSList *list,
|
||||||
@ -445,6 +453,7 @@ void g_slist_foreach (GSList *list,
|
|||||||
GFunc func,
|
GFunc func,
|
||||||
gpointer user_data);
|
gpointer user_data);
|
||||||
|
|
||||||
|
#define g_slist_next(list) (((GSList *)list)->next)
|
||||||
|
|
||||||
/* List Allocators
|
/* List Allocators
|
||||||
*/
|
*/
|
||||||
|
52
glib/glist.c
52
glib/glist.c
@ -363,3 +363,55 @@ g_list_foreach (GList *list,
|
|||||||
list = list->next;
|
list = list->next;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
GList*
|
||||||
|
g_list_insert_sorted (GList *list,
|
||||||
|
gpointer data,
|
||||||
|
GCompareFunc func)
|
||||||
|
{
|
||||||
|
GList *tmp_list = list;
|
||||||
|
GList *new_list;
|
||||||
|
gint cmp;
|
||||||
|
|
||||||
|
if (!list)
|
||||||
|
{
|
||||||
|
new_list = g_list_alloc();
|
||||||
|
new_list->data = data;
|
||||||
|
return new_list;
|
||||||
|
}
|
||||||
|
|
||||||
|
cmp = (*func) (tmp_list->data, data);
|
||||||
|
|
||||||
|
while ((tmp_list->next) && (cmp > 0))
|
||||||
|
{
|
||||||
|
tmp_list = tmp_list->next;
|
||||||
|
cmp = (*func) (tmp_list->data, data);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (cmp == 0)
|
||||||
|
return list;
|
||||||
|
|
||||||
|
new_list = g_list_alloc();
|
||||||
|
new_list->data = data;
|
||||||
|
|
||||||
|
if ((!tmp_list->next) && (cmp > 0))
|
||||||
|
{
|
||||||
|
tmp_list->next = new_list;
|
||||||
|
new_list->prev = tmp_list;
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (tmp_list->prev)
|
||||||
|
{
|
||||||
|
tmp_list->prev->next = new_list;
|
||||||
|
new_list->prev = tmp_list->prev;
|
||||||
|
}
|
||||||
|
new_list->next = tmp_list;
|
||||||
|
tmp_list->prev = new_list;
|
||||||
|
|
||||||
|
if (tmp_list == list)
|
||||||
|
return new_list;
|
||||||
|
else
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
@ -336,3 +336,54 @@ g_slist_foreach (GSList *list,
|
|||||||
list = list->next;
|
list = list->next;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
GSList*
|
||||||
|
g_slist_insert_sorted (GSList *list,
|
||||||
|
gpointer data,
|
||||||
|
GCompareFunc func)
|
||||||
|
{
|
||||||
|
GSList *tmp_list = list;
|
||||||
|
GSList *prev_list = NULL;
|
||||||
|
GSList *new_list;
|
||||||
|
gint cmp;
|
||||||
|
|
||||||
|
if (!list)
|
||||||
|
{
|
||||||
|
new_list = g_slist_alloc();
|
||||||
|
new_list->data = data;
|
||||||
|
return new_list;
|
||||||
|
}
|
||||||
|
|
||||||
|
cmp = (*func) (tmp_list->data, data);
|
||||||
|
|
||||||
|
while ((tmp_list->next) && (cmp > 0))
|
||||||
|
{
|
||||||
|
prev_list = tmp_list;
|
||||||
|
tmp_list = tmp_list->next;
|
||||||
|
cmp = (*func) (tmp_list->data, data);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (cmp == 0)
|
||||||
|
return list;
|
||||||
|
|
||||||
|
new_list = g_slist_alloc();
|
||||||
|
new_list->data = data;
|
||||||
|
|
||||||
|
if ((!tmp_list->next) && (cmp > 0))
|
||||||
|
{
|
||||||
|
tmp_list->next = new_list;
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (prev_list)
|
||||||
|
{
|
||||||
|
prev_list->next = new_list;
|
||||||
|
new_list->next = tmp_list;
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
new_list->next = list;
|
||||||
|
return new_list;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -43,6 +43,29 @@ my_hash_compare (gpointer a,
|
|||||||
return *((gint*) a) == *((gint*) b);
|
return *((gint*) a) == *((gint*) b);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
gint
|
||||||
|
my_list_compare_one (gpointer a, gpointer b)
|
||||||
|
{
|
||||||
|
gint one = *((gint*)a);
|
||||||
|
gint two = *((gint*)b);
|
||||||
|
return one-two;
|
||||||
|
};
|
||||||
|
|
||||||
|
gint
|
||||||
|
my_list_compare_two (gpointer a, gpointer b)
|
||||||
|
{
|
||||||
|
gint one = *((gint*)a);
|
||||||
|
gint two = *((gint*)b);
|
||||||
|
return two-one;
|
||||||
|
};
|
||||||
|
|
||||||
|
/* void
|
||||||
|
my_list_print (gpointer a, gpointer b)
|
||||||
|
{
|
||||||
|
gint three = *((gint*)a);
|
||||||
|
g_print("%d", three);
|
||||||
|
}; */
|
||||||
|
|
||||||
gint
|
gint
|
||||||
my_compare (gpointer a,
|
my_compare (gpointer a,
|
||||||
gpointer b)
|
gpointer b)
|
||||||
@ -74,6 +97,8 @@ main (int argc,
|
|||||||
GStringChunk *string_chunk;
|
GStringChunk *string_chunk;
|
||||||
GTimer *timer;
|
GTimer *timer;
|
||||||
gint nums[10] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 };
|
gint nums[10] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 };
|
||||||
|
gint morenums[10] = { 8, 9, 7, 0, 3, 2, 5, 1, 4, 6};
|
||||||
|
|
||||||
gchar *mem[10000], *tmp_string, *tmp_string_2;
|
gchar *mem[10000], *tmp_string, *tmp_string_2;
|
||||||
gint i, j;
|
gint i, j;
|
||||||
GArray *garray;
|
GArray *garray;
|
||||||
@ -96,9 +121,45 @@ main (int argc,
|
|||||||
{
|
{
|
||||||
t = g_list_nth (list, i);
|
t = g_list_nth (list, i);
|
||||||
if (*((gint*) t->data) != (9 - i))
|
if (*((gint*) t->data) != (9 - i))
|
||||||
g_error ("failed");
|
g_error ("Regular insert failed");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
g_list_free (list);
|
||||||
|
list = NULL;
|
||||||
|
|
||||||
|
for (i = 0; i < 10; i++)
|
||||||
|
list = g_list_insert_sorted (list, &morenums[i], my_list_compare_one);
|
||||||
|
|
||||||
|
/*
|
||||||
|
g_print("\n");
|
||||||
|
g_list_foreach (list, my_list_print, NULL);
|
||||||
|
*/
|
||||||
|
|
||||||
|
for (i = 0; i < 10; i++)
|
||||||
|
{
|
||||||
|
t = g_list_nth (list, i);
|
||||||
|
if (*((gint*) t->data) != (9 - i))
|
||||||
|
g_error ("Sorted insert failed");
|
||||||
|
}
|
||||||
|
|
||||||
|
g_list_free (list);
|
||||||
|
list = NULL;
|
||||||
|
|
||||||
|
for (i = 0; i < 10; i++)
|
||||||
|
list = g_list_insert_sorted (list, &morenums[i], my_list_compare_two);
|
||||||
|
|
||||||
|
/*
|
||||||
|
g_print("\n");
|
||||||
|
g_list_foreach (list, my_list_print, NULL);
|
||||||
|
*/
|
||||||
|
|
||||||
|
for (i = 0; i < 10; i++)
|
||||||
|
{
|
||||||
|
t = g_list_nth (list, i);
|
||||||
|
if (*((gint*) t->data) != i)
|
||||||
|
g_error ("Sorted insert failed");
|
||||||
|
}
|
||||||
|
|
||||||
g_list_free (list);
|
g_list_free (list);
|
||||||
|
|
||||||
g_print ("ok\n");
|
g_print ("ok\n");
|
||||||
@ -119,6 +180,42 @@ main (int argc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
g_slist_free (slist);
|
g_slist_free (slist);
|
||||||
|
slist = NULL;
|
||||||
|
|
||||||
|
for (i = 0; i < 10; i++)
|
||||||
|
slist = g_slist_insert_sorted (slist, &morenums[i], my_list_compare_one);
|
||||||
|
|
||||||
|
/*
|
||||||
|
g_print("\n");
|
||||||
|
g_slist_foreach (slist, my_list_print, NULL);
|
||||||
|
*/
|
||||||
|
|
||||||
|
for (i = 0; i < 10; i++)
|
||||||
|
{
|
||||||
|
st = g_slist_nth (slist, i);
|
||||||
|
if (*((gint*) st->data) != (9 - i))
|
||||||
|
g_error ("Sorted insert failed");
|
||||||
|
}
|
||||||
|
|
||||||
|
g_slist_free(slist);
|
||||||
|
slist = NULL;
|
||||||
|
|
||||||
|
for (i = 0; i < 10; i++)
|
||||||
|
slist = g_slist_insert_sorted (slist, &morenums[i], my_list_compare_two);
|
||||||
|
|
||||||
|
/*
|
||||||
|
g_print("\n");
|
||||||
|
g_slist_foreach (slist, my_list_print, NULL);
|
||||||
|
*/
|
||||||
|
|
||||||
|
for (i = 0; i < 10; i++)
|
||||||
|
{
|
||||||
|
st = g_slist_nth (slist, i);
|
||||||
|
if (*((gint*) st->data) != i)
|
||||||
|
g_error("Sorted insert failed");
|
||||||
|
}
|
||||||
|
|
||||||
|
g_slist_free(slist);
|
||||||
|
|
||||||
g_print ("ok\n");
|
g_print ("ok\n");
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user