diff options
Diffstat (limited to 'e-util/e-xml-utils.c')
-rw-r--r-- | e-util/e-xml-utils.c | 280 |
1 files changed, 203 insertions, 77 deletions
diff --git a/e-util/e-xml-utils.c b/e-util/e-xml-utils.c index 701598e000..8a931d07f6 100644 --- a/e-util/e-xml-utils.c +++ b/e-util/e-xml-utils.c @@ -21,21 +21,23 @@ */ #include <locale.h> +#include <libgnome/libgnome.h> #include "gal/util/e-i18n.h" #include <math.h> #include <gnome-xml/parser.h> #include <gnome-xml/xmlmemory.h> #include "e-xml-utils.h" -xmlNode *e_xml_get_child_by_name(const xmlNode *parent, const xmlChar *child_name) +xmlNode * +e_xml_get_child_by_name (const xmlNode *parent, const xmlChar *child_name) { xmlNode *child; - g_return_val_if_fail(parent != NULL, NULL); - g_return_val_if_fail(child_name != NULL, NULL); + g_return_val_if_fail (parent != NULL, NULL); + g_return_val_if_fail (child_name != NULL, NULL); - for (child = parent->childs; child; child = child->next) { - if ( !xmlStrcmp( child->name, child_name ) ) { + for (child = parent->childs; child != NULL; child = child->next) { + if (xmlStrcmp (child->name, child_name) == 0) { return child; } } @@ -47,52 +49,143 @@ xmlNode *e_xml_get_child_by_name(const xmlNode *parent, const xmlChar *child_nam * child with the name child_name and no "lang" attribute. */ xmlNode * -e_xml_get_child_by_name_by_lang(const xmlNode *parent, const xmlChar *child_name, const char *lang) +e_xml_get_child_by_name_by_lang (const xmlNode *parent, const xmlChar *child_name, const gchar *lang) { xmlNode *child; /* This is the default version of the string. */ xmlNode *C = NULL; - g_return_val_if_fail(parent != NULL, NULL); - g_return_val_if_fail(child_name != NULL, NULL); - - if (lang == NULL) - lang = setlocale(LC_MESSAGES, NULL); + g_return_val_if_fail (parent != NULL, NULL); + g_return_val_if_fail (child_name != NULL, NULL); - for (child = parent->childs; child; child = child->next) { - if ( !xmlStrcmp( child->name, child_name ) ) { - char *this_lang = xmlGetProp(child, "lang"); - if ( this_lang == NULL ) { + if (lang == NULL) { + lang = setlocale (LC_MESSAGES, NULL); + } + for (child = parent->childs; child != NULL; child = child->next) { + if (xmlStrcmp (child->name, child_name) == 0) { + xmlChar *this_lang = xmlGetProp (child, "lang"); + if (this_lang == NULL) { C = child; - } - else if (!strcmp(this_lang, "lang")) + } else if (xmlStrcmp(this_lang, "lang") == 0) { return child; + } } } return C; } -int -e_xml_get_integer_prop_by_name(const xmlNode *parent, const xmlChar *prop_name) +static xmlNode * +e_xml_get_child_by_name_by_lang_list_with_score (const xmlNode *parent, const gchar *name, GList *lang_list, gint *best_lang_score) +{ + xmlNodePtr best_node = NULL, node; + + for (node = parent->childs; node != NULL; node = node->next) { + xmlChar *lang; + + if (node->name == NULL || strcmp (node->name, name) != 0) { + continue; + } + lang = xmlGetProp (node, "xml:lang"); + if (lang != NULL) { + GList *l; + gint i; + + for (l = lang_list, i = 0; l != NULL && i < *best_lang_score; l = l->next, i++) { + if (strcmp ((gchar *) l->data, lang) == 0) { + best_node = node; + *best_lang_score = i; + } + } + } else { + if (best_node == NULL) { + best_node = node; + } + } + xmlFree (lang); + if (*best_lang_score == 0) { + return best_node; + } + } + + return best_node; +} + +/* + * e_xml_get_child_by_name_by_lang_list: + * + */ +xmlNode * +e_xml_get_child_by_name_by_lang_list (const xmlNode *parent, const gchar *name, GList *lang_list) +{ + gint best_lang_score = INT_MAX; + + g_return_val_if_fail (parent != NULL, NULL); + g_return_val_if_fail (name != NULL, NULL); + + if (lang_list == NULL) { + lang_list = gnome_i18n_get_language_list ("LC_MESSAGES"); + } + return e_xml_get_child_by_name_by_lang_list_with_score (parent, name, lang_list, &best_lang_score); +} + +/* + * e_xml_get_child_by_name_no_lang + * + */ +xmlNode * +e_xml_get_child_by_name_no_lang (const xmlNode *parent, const gchar *name) +{ + xmlNodePtr node; + + g_return_val_if_fail (parent != NULL, NULL); + g_return_val_if_fail (name != NULL, NULL); + + for (node = parent->childs; node != NULL; node = node->next) { + xmlChar *lang; + + if (node->name == NULL || strcmp (node->name, name) != 0) { + continue; + } + lang = xmlGetProp (node, "xml:lang"); + if (lang == NULL) { + return node; + } + xmlFree (lang); + } + + return NULL; +} + +gint +e_xml_get_integer_prop_by_name (const xmlNode *parent, const xmlChar *prop_name) +{ + g_return_val_if_fail (parent != NULL, 0); + g_return_val_if_fail (prop_name != NULL, 0); + + return e_xml_get_integer_prop_by_name_with_default (parent, prop_name, 0); +} + +gint +e_xml_get_integer_prop_by_name_with_default (const xmlNode *parent, const xmlChar *prop_name, gint def) { xmlChar *prop; - int ret_val = 0; + gint ret_val = def; g_return_val_if_fail (parent != NULL, 0); g_return_val_if_fail (prop_name != NULL, 0); - prop = xmlGetProp ((xmlNode *)parent, prop_name); - if (prop) { - ret_val = atoi (prop); + prop = xmlGetProp ((xmlNode *) parent, prop_name); + if (prop != NULL) { + (void) sscanf (prop, "%d", &ret_val); xmlFree (prop); } return ret_val; } void -e_xml_set_integer_prop_by_name(xmlNode *parent, const xmlChar *prop_name, int value) +e_xml_set_integer_prop_by_name (xmlNode *parent, const xmlChar *prop_name, gint value) { - xmlChar *valuestr; + gchar *valuestr; g_return_if_fail (parent != NULL); g_return_if_fail (prop_name != NULL); @@ -102,24 +195,54 @@ e_xml_set_integer_prop_by_name(xmlNode *parent, const xmlChar *prop_name, int va g_free (valuestr); } -gboolean -e_xml_get_bool_prop_by_name(const xmlNode *parent, const xmlChar *prop_name) +guint +e_xml_get_uint_prop_by_name (const xmlNode *parent, const xmlChar *prop_name) +{ + g_return_val_if_fail (parent != NULL, 0); + g_return_val_if_fail (prop_name != NULL, 0); + + return e_xml_get_uint_prop_by_name_with_default (parent, prop_name, 0); +} + +guint +e_xml_get_uint_prop_by_name_with_default (const xmlNode *parent, const xmlChar *prop_name, guint def) { xmlChar *prop; - gboolean ret_val = FALSE; + guint ret_val = def; g_return_val_if_fail (parent != NULL, 0); g_return_val_if_fail (prop_name != NULL, 0); - prop = xmlGetProp ((xmlNode *)parent, prop_name); - if (prop) { - if(!strcasecmp(prop, "true")) - ret_val = TRUE; - xmlFree(prop); + prop = xmlGetProp ((xmlNode *) parent, prop_name); + if (prop != NULL) { + (void) sscanf (prop, "%u", &ret_val); + xmlFree (prop); } return ret_val; } +void +e_xml_set_uint_prop_by_name (xmlNode *parent, const xmlChar *prop_name, guint value) +{ + gchar *valuestr; + + g_return_if_fail (parent != NULL); + g_return_if_fail (prop_name != NULL); + + valuestr = g_strdup_printf ("%u", value); + xmlSetProp (parent, prop_name, valuestr); + g_free (valuestr); +} + +gboolean +e_xml_get_bool_prop_by_name (const xmlNode *parent, const xmlChar *prop_name) +{ + g_return_val_if_fail (parent != NULL, 0); + g_return_val_if_fail (prop_name != NULL, 0); + + return e_xml_get_bool_prop_by_name_with_default (parent, prop_name, FALSE); +} + gboolean e_xml_get_bool_prop_by_name_with_default(const xmlNode *parent, const xmlChar *prop_name, gboolean def) { @@ -129,121 +252,124 @@ e_xml_get_bool_prop_by_name_with_default(const xmlNode *parent, const xmlChar *p g_return_val_if_fail (parent != NULL, 0); g_return_val_if_fail (prop_name != NULL, 0); - prop = xmlGetProp ((xmlNode *)parent, prop_name); - if (prop) { - if(!strcasecmp(prop, "true")) + prop = xmlGetProp ((xmlNode *) parent, prop_name); + if (prop != NULL) { + if (strcasecmp (prop, "true") == 0) { ret_val = TRUE; - else + } else if (strcasecmp (prop, "false") == 0) { ret_val = FALSE; + } xmlFree(prop); } return ret_val; } void -e_xml_set_bool_prop_by_name(xmlNode *parent, const xmlChar *prop_name, gboolean value) +e_xml_set_bool_prop_by_name (xmlNode *parent, const xmlChar *prop_name, gboolean value) { g_return_if_fail (parent != NULL); g_return_if_fail (prop_name != NULL); - if (value) + if (value) { xmlSetProp (parent, prop_name, "true"); - else + } else { xmlSetProp (parent, prop_name, "false"); + } } -double -e_xml_get_double_prop_by_name(const xmlNode *parent, const xmlChar *prop_name) +gdouble +e_xml_get_double_prop_by_name (const xmlNode *parent, const xmlChar *prop_name) { - xmlChar *prop; - double ret_val = 0; - g_return_val_if_fail (parent != NULL, 0); g_return_val_if_fail (prop_name != NULL, 0); - prop = xmlGetProp ((xmlNode *)parent, prop_name); - if (prop) { - sscanf (prop, "%lf", &ret_val); - xmlFree (prop); - } - return ret_val; + return e_xml_get_double_prop_by_name_with_default (parent, prop_name, 0.0); } -double -e_xml_get_double_prop_by_name_with_default(const xmlNode *parent, const xmlChar *prop_name, - gdouble def) +gdouble +e_xml_get_double_prop_by_name_with_default (const xmlNode *parent, const xmlChar *prop_name, gdouble def) { xmlChar *prop; - double ret_val = 0; + gdouble ret_val = def; g_return_val_if_fail (parent != NULL, 0); g_return_val_if_fail (prop_name != NULL, 0); - prop = xmlGetProp ((xmlNode *)parent, prop_name); - if (prop) { - sscanf (prop, "%lf", &ret_val); + prop = xmlGetProp ((xmlNode *) parent, prop_name); + if (prop != NULL) { + (void) sscanf (prop, "%lf", &ret_val); xmlFree (prop); - } else { - ret_val = def; } return ret_val; } void -e_xml_set_double_prop_by_name(xmlNode *parent, const xmlChar *prop_name, double value) +e_xml_set_double_prop_by_name(xmlNode *parent, const xmlChar *prop_name, gdouble value) { - xmlChar *valuestr; + gchar *valuestr; g_return_if_fail (parent != NULL); g_return_if_fail (prop_name != NULL); - if (fabs (value) < 1e9 && fabs (value) > 1e-5) + if (fabs (value) < 1e9 && fabs (value) > 1e-5) { valuestr = g_strdup_printf ("%f", value); - else + } else { valuestr = g_strdup_printf ("%.*g", DBL_DIG, value); + } xmlSetProp (parent, prop_name, valuestr); g_free (valuestr); } -char * -e_xml_get_string_prop_by_name(const xmlNode *parent, const xmlChar *prop_name) +gchar * +e_xml_get_string_prop_by_name (const xmlNode *parent, const xmlChar *prop_name) +{ + g_return_val_if_fail (parent != NULL, 0); + g_return_val_if_fail (prop_name != NULL, 0); + + return e_xml_get_string_prop_by_name_with_default (parent, prop_name, NULL); +} + +gchar * +e_xml_get_string_prop_by_name_with_default (const xmlNode *parent, const xmlChar *prop_name, const gchar *def) { xmlChar *prop; - char *ret_val = NULL; + gchar *ret_val; g_return_val_if_fail (parent != NULL, 0); g_return_val_if_fail (prop_name != NULL, 0); - prop = xmlGetProp ((xmlNode *)parent, prop_name); - if (prop) { + prop = xmlGetProp ((xmlNode *) parent, prop_name); + if (prop != NULL) { ret_val = g_strdup (prop); xmlFree (prop); + } else { + ret_val = g_strdup (def); } return ret_val; } void -e_xml_set_string_prop_by_name(xmlNode *parent, const xmlChar *prop_name, const char *value) +e_xml_set_string_prop_by_name (xmlNode *parent, const xmlChar *prop_name, const gchar *value) { g_return_if_fail (parent != NULL); g_return_if_fail (prop_name != NULL); - if (value) + if (value != NULL) { xmlSetProp (parent, prop_name, value); + } } - -char * -e_xml_get_translated_string_prop_by_name(const xmlNode *parent, const xmlChar *prop_name) +gchar * +e_xml_get_translated_string_prop_by_name (const xmlNode *parent, const xmlChar *prop_name) { xmlChar *prop; - char *ret_val = NULL; + gchar *ret_val = NULL; g_return_val_if_fail (parent != NULL, 0); g_return_val_if_fail (prop_name != NULL, 0); - prop = xmlGetProp ((xmlNode *)parent, prop_name); - if (prop) { + prop = xmlGetProp ((xmlNode *) parent, prop_name); + if (prop != NULL) { ret_val = g_strdup (_(prop)); xmlFree (prop); } |