X-Git-Url: https://git.gag.com/?a=blobdiff_plain;f=common-src%2Fglib-util.c;h=91985e500f4efa670c7ee69116af001ae4761a65;hb=3a9beabdb44ee1b2dcce141c2571fbb2b3fa90b1;hp=dd6b38e0e12397d01856a4be924171eb267cbf74;hpb=2627875b7d18858bc1f9f7652811e4d8c15a23eb;p=debian%2Famanda diff --git a/common-src/glib-util.c b/common-src/glib-util.c index dd6b38e..91985e5 100644 --- a/common-src/glib-util.c +++ b/common-src/glib-util.c @@ -1,21 +1,21 @@ /* - * Copyright (c) 2005-2008 Zmanda Inc. All Rights Reserved. - * - * This library is free software; you can redistribute it and/or modify it - * under the terms of the GNU Lesser General Public License version 2.1 as - * published by the Free Software Foundation. - * - * This library is distributed in the hope that it will be useful, but + * Copyright (c) 2007, 2008, 2009, 2010 Zmanda, Inc. All Rights Reserved. + * + * This program is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 as published + * by the Free Software Foundation. + * + * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY - * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public - * License for more details. - * - * You should have received a copy of the GNU Lesser General Public License - * along with this library; if not, write to the Free Software Foundation, - * Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. - * - * Contact information: Zmanda Inc., 465 S Mathlida Ave, Suite 300 - * Sunnyvale, CA 94086, USA, or: http://www.zmanda.com + * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * for more details. + * + * You should have received a copy of the GNU General Public License along + * with this program; if not, write to the Free Software Foundation, Inc., + * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + * + * Contact information: Zmanda Inc., 465 S. Mathilda Ave., Suite 300 + * Sunnyvale, CA 94085, USA, or: http://www.zmanda.com */ /* @@ -38,26 +38,15 @@ glib_init(void) { if (did_glib_init) return; did_glib_init = TRUE; - /* Initialize glib's type system */ - g_type_init(); - /* set up libcurl (this must happen before threading * is initialized) */ #ifdef HAVE_LIBCURL # ifdef G_THREADS_ENABLED - g_assert(!g_thread_supported()); + g_assert(!g_thread_supported()); /* assert threads aren't initialized yet */ # endif g_assert(curl_global_init(CURL_GLOBAL_ALL) == 0); #endif - /* And set up glib's threads */ -#if defined(G_THREADS_ENABLED) && !defined(G_THREADS_IMPL_NONE) - if (g_thread_supported()) { - return; - } - g_thread_init(NULL); -#endif - /* do a version check */ #if GLIB_CHECK_VERSION(2,6,0) { @@ -71,6 +60,16 @@ glib_init(void) { } } #endif + + /* Initialize glib's type system. On glib >= 2.24, this will initialize + * threads, so it must be done after curl is initialized. */ + g_type_init(); + + /* And set up glib's threads */ +#if defined(G_THREADS_ENABLED) && !defined(G_THREADS_IMPL_NONE) + if (!g_thread_supported()) + g_thread_init(NULL); +#endif } typedef enum { @@ -107,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)) { @@ -175,19 +164,17 @@ gboolean g_value_compare(GValue * a, GValue * b) { g_assert_not_reached(); } -static gboolean g_value_set_boolean_from_string(GValue * val, char * string) { - if (strcasecmp(string, "true") == 0 || - strcasecmp(string, "yes") == 0 || - strcmp(string, "1") == 0) { - g_value_set_boolean(val, TRUE); - } else if (strcasecmp(string, "false") == 0 || - strcasecmp(string, "no") == 0 || - strcmp(string, "0") == 0) { - g_value_set_boolean(val, FALSE); - } else { - return FALSE; - } +static gboolean +g_value_set_boolean_from_string( + GValue * val, + char * str) +{ + int b = string_to_boolean(str); + + if (b == -1) + return FALSE; + g_value_set_boolean(val, b); return TRUE; } @@ -500,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; }