/* -*- mode: C; c-basic-offset: 4; indent-tabs-mode: nil; -*- */ /* vim:set et sts=4: */ /* bus - The Input Bus * Copyright (C) 2008-2015 Peng Huang * Copyright (C) 2010-2017 Takao Fujiwara * Copyright (C) 2008-2016 Red Hat, Inc. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 * USA */ #ifdef HAVE_CONFIG_H #include #endif #include #include #include #include #include "ibusxml.h" #ifdef ENABLE_NLS #include #endif /* gettext macro */ #define N_(t) t static GHashTable *__languages_dict; static gboolean _iso_codes_parse_xml_node (XMLNode *node) { GList *p; g_assert (node); if (G_UNLIKELY (g_strcmp0 (node->name, "iso_639_entries") != 0)) { return FALSE; } for (p = node->sub_nodes; p != NULL; p = p->next) { XMLNode *sub_node = (XMLNode *)p->data; gchar **attributes = NULL; int i, j; struct { const gchar *key; gchar *value; } entries[] = { { "iso_639_2B_code", NULL }, { "iso_639_2T_code", NULL }, { "iso_639_1_code", NULL }, }; if (sub_node->attributes == NULL) { continue; } attributes = sub_node->attributes; for (i = 0; attributes[i]; i += 2) { if (g_strcmp0 (attributes[i], "name") == 0) { for (j = 0; j < G_N_ELEMENTS (entries); j++) { if (entries[j].value == NULL) continue; g_hash_table_insert (__languages_dict, (gpointer) g_strdup (entries[j].value), (gpointer) g_strdup (attributes[i + 1])); entries[j].value = NULL; } } else { for (j = 0; j < G_N_ELEMENTS (entries); j++) { if (g_strcmp0 (attributes[i], entries[j].key) == 0 && attributes[i + 1] != NULL) { entries[j].value = attributes[i + 1]; } } } } } return TRUE; } void _load_lang() { gchar *filename; XMLNode *node; struct stat buf; #ifdef ENABLE_NLS bindtextdomain ("iso_639", GLIB_LOCALE_DIR); bind_textdomain_codeset ("iso_639", "UTF-8"); #endif __languages_dict = g_hash_table_new_full (g_str_hash, g_str_equal, g_free, g_free); filename = g_build_filename (ISOCODES_PREFIX, "share/xml/iso-codes/iso_639.xml", NULL); if (g_stat (filename, &buf) != 0) { g_warning ("Can not get stat of file %s", filename); g_free (filename); return; } node = ibus_xml_parse_file (filename); g_free (filename); if (!node) { return; } _iso_codes_parse_xml_node (node); ibus_xml_free (node); } const gchar * ibus_get_untranslated_language_name (const gchar *_locale) { const gchar *retval; gchar *p = NULL; gchar *lang = NULL; if (__languages_dict == NULL ) _load_lang(); if ((p = strchr (_locale, '_')) != NULL) p = g_strndup (_locale, p - _locale); else p = g_strdup (_locale); lang = g_ascii_strdown (p, -1); g_free (p); retval = (const gchar *) g_hash_table_lookup (__languages_dict, lang); g_free (lang); if (retval != NULL) return retval; else return "Other"; } const gchar * ibus_get_language_name (const gchar *_locale) { const gchar *retval = ibus_get_untranslated_language_name (_locale); #ifdef ENABLE_NLS if (g_strcmp0 (retval, "Other") == 0) return dgettext (GETTEXT_PACKAGE, N_("Other")); else return dgettext ("iso_639", retval); #else return retval; #endif } void ibus_g_variant_get_child_string (GVariant *variant, gsize index, char **str) { g_return_if_fail (str != NULL); g_free (*str); g_variant_get_child (variant, index, "s", str); }