X-Git-Url: https://git.gag.com/?a=blobdiff_plain;f=common-src%2Fglib-util.c;h=91985e500f4efa670c7ee69116af001ae4761a65;hb=2451141bb42e8e8d981b4843ea73f719fd544a22;hp=6320a1dea9e49549dcdb2850bae982e44b861f34;hpb=fd48f3e498442f0cbff5f3606c7c403d0566150e;p=debian%2Famanda diff --git a/common-src/glib-util.c b/common-src/glib-util.c index 6320a1d..91985e5 100644 --- a/common-src/glib-util.c +++ b/common-src/glib-util.c @@ -106,29 +106,19 @@ GValue* g_value_unset_copy(const GValue * from, GValue * to) { return to; } -void g_list_free_full(GList * list) { - GList * cur = list; - - while (cur != NULL) { - gpointer data = cur->data; - amfree(data); - cur = g_list_next(cur); - } - - g_list_free(list); -} - -void g_slist_free_full(GSList * list) { +#if (GLIB_MAJOR_VERSION < 2 || (GLIB_MAJOR_VERSION == 2 && GLIB_MINOR_VERSION < 28)) +void slist_free_full(GSList * list, GDestroyNotify free_fn) { GSList * cur = list; while (cur != NULL) { gpointer data = cur->data; - amfree(data); + free_fn(data); cur = g_slist_next(cur); } g_slist_free(list); } +#endif void g_queue_free_full(GQueue * queue) { while (!g_queue_is_empty(queue)) { @@ -497,25 +487,36 @@ g_ptr_array_foreach (GPtrArray *array, #endif guint -g_str_case_hash( +g_str_amanda_hash( gconstpointer key) { /* modified version of glib's hash function, copyright * GLib Team and others 1997-2000. */ - const char *p = key; - guint h = g_ascii_toupper(*p); + const char *p; + guint h = 0; - if (h) - for (p += 1; *p != '\0'; p++) - h = (h << 5) - h + g_ascii_toupper(*p); + for (p = key; *p != '\0'; p++) + h = (h << 5) - h + (('_' == *p) ? '-' : g_ascii_tolower(*p)); return h; } gboolean -g_str_case_equal( +g_str_amanda_equal( gconstpointer v1, gconstpointer v2) { - return (0 == g_ascii_strcasecmp((char *)v1, (char *)v2)); + const gchar *p1 = v1, *p2 = v2; + while (*p1) { + /* letting '-' == '_' */ + if (!('-' == *p1 || '_' == *p1) || !('-' == *p2 || '_' == *p2)) + if (g_ascii_tolower(*p1) != g_ascii_tolower(*p2)) + return FALSE; + + p1++; + p2++; + } + + /* p1 is at '\0' is p2 too? */ + return *p2? FALSE : TRUE; }