Blame SOURCES/dont-use-locale-archive.patch

2d519e
From f7e7d11a38437305ee31c195d8e910f2230a21b4 Mon Sep 17 00:00:00 2001
2d519e
From: Stefan Sperling <stsp@openbsd.org>
2d519e
Date: Wed, 28 Aug 2013 18:25:34 +0200
2d519e
Subject: [PATCH 1/4] Obtain supported locales from "locale -a" output.
2d519e
2d519e
Instead of parsing the locale archive file which is private to glibc
2d519e
(see https://bugzilla.redhat.com/show_bug.cgi?id=956993), run the
2d519e
"locale -a" command to obtain the list of supported locales.
2d519e
2d519e
"locale -a" is specified in POSIX and should thus exist on most UNIX-like
2d519e
systems (e.g. on OpenBSD, which triggered the related bugzilla entry
2d519e
because GNOME was unable to find a list of supported locales).
2d519e
2d519e
Keep scanning the /usr/share/locale directory as a fallback.
2d519e
2d519e
Remove code wrapped in #ifdef WITH_INCOMPLETE_LOCALES. This code was
2d519e
inherited from gdm but is now unused.
2d519e
2d519e
https://bugzilla.gnome.org/show_bug.cgi?id=698383
2d519e
---
2d519e
 libgnome-desktop/gnome-languages.c | 150 +++++++++----------------------------
2d519e
 1 file changed, 35 insertions(+), 115 deletions(-)
2d519e
2d519e
diff --git a/libgnome-desktop/gnome-languages.c b/libgnome-desktop/gnome-languages.c
2d519e
index 18e3705..667eb81 100644
2d519e
--- a/libgnome-desktop/gnome-languages.c
2d519e
+++ b/libgnome-desktop/gnome-languages.c
2d519e
@@ -17,64 +17,61 @@
2d519e
  * along with this program; if not, write to the Free Software
2d519e
  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
2d519e
  *
2d519e
  * Written by : William Jon McCann <mccann@jhu.edu>
2d519e
  *              Ray Strode <rstrode@redhat.com>
2d519e
  */
2d519e
 
2d519e
 #include "config.h"
2d519e
 
2d519e
 #include <stdlib.h>
2d519e
 #include <stdio.h>
2d519e
 #include <unistd.h>
2d519e
 #include <string.h>
2d519e
 #include <errno.h>
2d519e
 #include <dirent.h>
2d519e
 #include <locale.h>
2d519e
 #include <langinfo.h>
2d519e
 #include <sys/stat.h>
2d519e
 
2d519e
 #include <glib.h>
2d519e
 #include <glib/gi18n.h>
2d519e
 #include <glib/gstdio.h>
2d519e
 
2d519e
 #define GNOME_DESKTOP_USE_UNSTABLE_API
2d519e
 #include "gnome-languages.h"
2d519e
 
2d519e
 #include <langinfo.h>
2d519e
 #ifndef __LC_LAST
2d519e
 #define __LC_LAST       13
2d519e
 #endif
2d519e
-#include "locarchive.h"
2d519e
 
2d519e
-#define ARCHIVE_FILE LIBLOCALEDIR "/locale-archive"
2d519e
-#define SYSTEM_ARCHIVE_FILE "/usr/lib/locale/locale-archive"
2d519e
 #define ISO_CODES_DATADIR ISO_CODES_PREFIX "/share/xml/iso-codes"
2d519e
 #define ISO_CODES_LOCALESDIR ISO_CODES_PREFIX "/share/locale"
2d519e
 
2d519e
 #include "default-input-sources.h"
2d519e
 
2d519e
 typedef struct _GnomeLocale {
2d519e
         char *id;
2d519e
         char *name;
2d519e
         char *language_code;
2d519e
         char *territory_code;
2d519e
         char *codeset;
2d519e
         char *modifier;
2d519e
 } GnomeLocale;
2d519e
 
2d519e
 static GHashTable *gnome_languages_map;
2d519e
 static GHashTable *gnome_territories_map;
2d519e
 static GHashTable *gnome_available_locales_map;
2d519e
 static GHashTable *gnome_language_count_map;
2d519e
 static GHashTable *gnome_territory_count_map;
2d519e
 
2d519e
 static char * construct_language_name (const char *language,
2d519e
                                        const char *territory,
2d519e
                                        const char *codeset,
2d519e
                                        const char *modifier);
2d519e
 
2d519e
 static gboolean language_name_is_valid (const char *language_name);
2d519e
 
2d519e
 static void
2d519e
 gnome_locale_free (GnomeLocale *locale)
2d519e
 {
2d519e
@@ -283,65 +280,61 @@ gnome_normalize_locale (const char *locale)
2d519e
         char *modifier;
2d519e
         gboolean valid;
2d519e
 
2d519e
         if (locale[0] == '\0') {
2d519e
                 return NULL;
2d519e
         }
2d519e
 
2d519e
         valid = gnome_parse_locale (locale,
2d519e
                                     &language_code,
2d519e
                                     &territory_code,
2d519e
                                     &codeset, &modifier);
2d519e
         if (!valid)
2d519e
                 return NULL;
2d519e
 
2d519e
         normalized_name = construct_language_name (language_code,
2d519e
                                                    territory_code,
2d519e
                                                    codeset, modifier);
2d519e
         g_free (language_code);
2d519e
         g_free (territory_code);
2d519e
         g_free (codeset);
2d519e
         g_free (modifier);
2d519e
 
2d519e
         return normalized_name;
2d519e
 }
2d519e
 
2d519e
 static gboolean
2d519e
 language_name_is_valid (const char *language_name)
2d519e
 {
2d519e
         char     *old_locale;
2d519e
         gboolean  is_valid;
2d519e
-#ifdef WITH_INCOMPLETE_LOCALES
2d519e
-        int lc_type_id = LC_CTYPE;
2d519e
-#else
2d519e
         int lc_type_id = LC_MESSAGES;
2d519e
-#endif
2d519e
 
2d519e
         old_locale = g_strdup (setlocale (lc_type_id, NULL));
2d519e
         is_valid = setlocale (lc_type_id, language_name) != NULL;
2d519e
         setlocale (lc_type_id, old_locale);
2d519e
         g_free (old_locale);
2d519e
 
2d519e
         return is_valid;
2d519e
 }
2d519e
 
2d519e
 static void
2d519e
 language_name_get_codeset_details (const char  *language_name,
2d519e
                                    char       **pcodeset,
2d519e
                                    gboolean    *is_utf8)
2d519e
 {
2d519e
         char     *old_locale;
2d519e
         char     *codeset;
2d519e
 
2d519e
         old_locale = g_strdup (setlocale (LC_CTYPE, NULL));
2d519e
 
2d519e
         if (setlocale (LC_CTYPE, language_name) == NULL) {
2d519e
                 g_free (old_locale);
2d519e
                 return;
2d519e
         }
2d519e
 
2d519e
         codeset = nl_langinfo (CODESET);
2d519e
 
2d519e
         if (pcodeset != NULL) {
2d519e
                 *pcodeset = g_strdup (codeset);
2d519e
         }
2d519e
 
2d519e
@@ -418,304 +411,231 @@ add_locale (const char *language_name,
2d519e
 
2d519e
         if (is_utf8) {
2d519e
                 name = g_strdup (language_name);
2d519e
         } else if (utf8_only) {
2d519e
                 name = g_strdup_printf ("%s.utf8", language_name);
2d519e
 
2d519e
                 language_name_get_codeset_details (name, NULL, &is_utf8);
2d519e
                 if (!is_utf8) {
2d519e
                         g_free (name);
2d519e
                         return FALSE;
2d519e
                 }
2d519e
         } else {
2d519e
                 name = g_strdup (language_name);
2d519e
         }
2d519e
 
2d519e
         if (!language_name_is_valid (name)) {
2d519e
                 g_debug ("Ignoring '%s' as a locale, since it's invalid", name);
2d519e
                 g_free (name);
2d519e
                 return FALSE;
2d519e
         }
2d519e
 
2d519e
         locale = g_new0 (GnomeLocale, 1);
2d519e
         gnome_parse_locale (name,
2d519e
                             &locale->language_code,
2d519e
                             &locale->territory_code,
2d519e
                             &locale->codeset,
2d519e
                             &locale->modifier);
2d519e
         g_free (name);
2d519e
         name = NULL;
2d519e
 
2d519e
-#ifdef WITH_INCOMPLETE_LOCALES
2d519e
-        if (utf8_only) {
2d519e
-                if (locale->territory_code == NULL || locale->modifier) {
2d519e
-                        g_debug ("Ignoring '%s' as a locale, since it lacks territory code or modifier", name);
2d519e
-                        gnome_locale_free (locale);
2d519e
-                        return FALSE;
2d519e
-                }
2d519e
-        }
2d519e
-#endif
2d519e
-
2d519e
         locale->id = construct_language_name (locale->language_code, locale->territory_code,
2d519e
                                               NULL, locale->modifier);
2d519e
         locale->name = construct_language_name (locale->language_code, locale->territory_code,
2d519e
                                                 locale->codeset, locale->modifier);
2d519e
 
2d519e
-#ifndef WITH_INCOMPLETE_LOCALES
2d519e
         if (!gnome_language_has_translations (locale->name) &&
2d519e
             !gnome_language_has_translations (locale->id) &&
2d519e
             !gnome_language_has_translations (locale->language_code) &&
2d519e
             utf8_only) {
2d519e
                 g_debug ("Ignoring '%s' as a locale, since it lacks translations", locale->name);
2d519e
                 gnome_locale_free (locale);
2d519e
                 return FALSE;
2d519e
         }
2d519e
-#endif
2d519e
 
2d519e
         if (!utf8_only) {
2d519e
                 g_free (locale->id);
2d519e
                 locale->id = g_strdup (locale->name);
2d519e
         }
2d519e
 
2d519e
         old_locale = g_hash_table_lookup (gnome_available_locales_map, locale->id);
2d519e
         if (old_locale != NULL) {
2d519e
                 if (strlen (old_locale->name) > strlen (locale->name)) {
2d519e
                         gnome_locale_free (locale);
2d519e
                         return FALSE;
2d519e
                 }
2d519e
         }
2d519e
 
2d519e
         g_hash_table_insert (gnome_available_locales_map, g_strdup (locale->id), locale);
2d519e
 
2d519e
         return TRUE;
2d519e
 }
2d519e
 
2d519e
 struct nameent
2d519e
 {
2d519e
         char    *name;
2d519e
-        uint32_t locrec_offset;
2d519e
+        guint32 locrec_offset;
2d519e
 };
2d519e
 
2d519e
-static gboolean
2d519e
-mapped_file_new_allow_noent (const char   *path,
2d519e
-                             GMappedFile **out_mfile,
2d519e
-                             GError      **error)
2d519e
-{
2d519e
-        gboolean ret = FALSE;
2d519e
-        GError *tmp_error = NULL;
2d519e
-        GMappedFile *mfile = NULL;
2d519e
-
2d519e
-        mfile = g_mapped_file_new (path, FALSE, &tmp_error);
2d519e
-        if (mfile == NULL) {
2d519e
-                if (!g_error_matches (tmp_error, G_FILE_ERROR, G_FILE_ERROR_NOENT)) {
2d519e
-                        g_propagate_error (error, tmp_error);
2d519e
-                        goto out;
2d519e
-                }
2d519e
-                g_clear_error (&tmp_error);
2d519e
-        }
2d519e
-
2d519e
-        ret = TRUE;
2d519e
- out:
2d519e
-        *out_mfile = mfile;
2d519e
-        return ret;
2d519e
-}
2d519e
-
2d519e
-static gboolean
2d519e
-collect_locales_from_archive (gboolean  *out_found_locales,
2d519e
-                              GError   **error)
2d519e
-{
2d519e
-        gboolean            ret = FALSE;
2d519e
-        GMappedFile        *mapped;
2d519e
-        char               *addr;
2d519e
-        struct locarhead   *head;
2d519e
-        struct namehashent *namehashtab;
2d519e
-        struct nameent     *names = NULL;
2d519e
-        uint32_t            used;
2d519e
-        uint32_t            cnt;
2d519e
-        gsize               len;
2d519e
-        gboolean            locales_collected = FALSE;
2d519e
-
2d519e
-        if (!mapped_file_new_allow_noent (ARCHIVE_FILE, &mapped, error))
2d519e
-                goto out;
2d519e
-        if (!mapped) {
2d519e
-                if (!mapped_file_new_allow_noent (SYSTEM_ARCHIVE_FILE, &mapped, error))
2d519e
-                        goto out;
2d519e
-        }
2d519e
-        if (!mapped) {
2d519e
-                goto out_success;
2d519e
-        }
2d519e
-
2d519e
-        addr = g_mapped_file_get_contents (mapped);
2d519e
-        len = g_mapped_file_get_length (mapped);
2d519e
-
2d519e
-        head = (struct locarhead *) addr;
2d519e
-        if (head->namehash_offset + head->namehash_size > len
2d519e
-            || head->string_offset + head->string_size > len
2d519e
-            || head->locrectab_offset + head->locrectab_size > len
2d519e
-            || head->sumhash_offset + head->sumhash_size > len) {
2d519e
-                goto out;
2d519e
-        }
2d519e
-
2d519e
-        namehashtab = (struct namehashent *) (addr + head->namehash_offset);
2d519e
-
2d519e
-        names = (struct nameent *) g_new0 (struct nameent, head->namehash_used);
2d519e
-        for (cnt = used = 0; cnt < head->namehash_size; ++cnt) {
2d519e
-                if (namehashtab[cnt].locrec_offset != 0) {
2d519e
-                        names[used].name = addr + namehashtab[cnt].name_offset;
2d519e
-                        names[used++].locrec_offset = namehashtab[cnt].locrec_offset;
2d519e
-                }
2d519e
-        }
2d519e
-
2d519e
-        for (cnt = 0; cnt < used; ++cnt) {
2d519e
-                if (add_locale (names[cnt].name, TRUE))
2d519e
-                        locales_collected = TRUE;
2d519e
-        }
2d519e
-
2d519e
-
2d519e
- out_success:
2d519e
-        ret = TRUE;
2d519e
-        *out_found_locales = locales_collected;
2d519e
- out:
2d519e
-        g_free (names);
2d519e
-        g_clear_pointer (&mapped, g_mapped_file_unref);
2d519e
-        return ret;
2d519e
-}
2d519e
-
2d519e
 static int
2d519e
 select_dirs (const struct dirent *dirent)
2d519e
 {
2d519e
         int result = 0;
2d519e
 
2d519e
         if (strcmp (dirent->d_name, ".") != 0 && strcmp (dirent->d_name, "..") != 0) {
2d519e
                 mode_t mode = 0;
2d519e
 
2d519e
 #ifdef _DIRENT_HAVE_D_TYPE
2d519e
                 if (dirent->d_type != DT_UNKNOWN && dirent->d_type != DT_LNK) {
2d519e
                         mode = DTTOIF (dirent->d_type);
2d519e
                 } else
2d519e
 #endif
2d519e
                         {
2d519e
                                 struct stat st;
2d519e
                                 char       *path;
2d519e
 
2d519e
                                 path = g_build_filename (LIBLOCALEDIR, dirent->d_name, NULL);
2d519e
                                 if (g_stat (path, &st) == 0) {
2d519e
                                         mode = st.st_mode;
2d519e
                                 }
2d519e
                                 g_free (path);
2d519e
                         }
2d519e
 
2d519e
                 result = S_ISDIR (mode);
2d519e
         }
2d519e
 
2d519e
         return result;
2d519e
 }
2d519e
 
2d519e
 static gboolean
2d519e
 collect_locales_from_directory (void)
2d519e
 {
2d519e
         gboolean found_locales = FALSE;
2d519e
         struct dirent **dirents;
2d519e
         int             ndirents;
2d519e
         int             cnt;
2d519e
 
2d519e
         ndirents = scandir (LIBLOCALEDIR, &dirents, select_dirs, alphasort);
2d519e
 
2d519e
         for (cnt = 0; cnt < ndirents; ++cnt) {
2d519e
                 if (add_locale (dirents[cnt]->d_name, TRUE))
2d519e
                         found_locales = TRUE;
2d519e
         }
2d519e
 
2d519e
         if (ndirents > 0) {
2d519e
                 free (dirents);
2d519e
         }
2d519e
         return found_locales;
2d519e
 }
2d519e
 
2d519e
+static gboolean
2d519e
+collect_locales_from_localebin (void)
2d519e
+{
2d519e
+        gboolean found_locales = FALSE;
2d519e
+        gchar    *argv[] = { "locale", "-a", NULL };
2d519e
+        gchar    *output;
2d519e
+        gchar    **lines, **linep;
2d519e
+
2d519e
+        if (g_spawn_sync (NULL, argv, NULL,
2d519e
+                          G_SPAWN_SEARCH_PATH|G_SPAWN_STDERR_TO_DEV_NULL,
2d519e
+                          NULL, NULL, &output, NULL, NULL, NULL) == FALSE)
2d519e
+                return FALSE;
2d519e
+
2d519e
+        g_return_val_if_fail (output != NULL, FALSE);
2d519e
+
2d519e
+        lines = g_strsplit (output, "\n", 0);
2d519e
+        if (lines) {
2d519e
+                linep = lines;
2d519e
+                while (*linep) {
2d519e
+                        if (*linep[0] && add_locale (*linep, TRUE))
2d519e
+                                found_locales = TRUE;
2d519e
+                        linep++;
2d519e
+                }
2d519e
+                g_strfreev(lines);
2d519e
+        }
2d519e
+
2d519e
+        g_free(output);
2d519e
+
2d519e
+        return found_locales;
2d519e
+}
2d519e
+
2d519e
 static void
2d519e
 count_languages_and_territories (void)
2d519e
 {
2d519e
 	gpointer value;
2d519e
 	GHashTableIter iter;
2d519e
 
2d519e
 	gnome_language_count_map = g_hash_table_new_full (g_str_hash, g_str_equal, g_free, NULL);
2d519e
 	gnome_territory_count_map = g_hash_table_new_full (g_str_hash, g_str_equal, g_free, NULL);
2d519e
 
2d519e
         g_hash_table_iter_init (&iter, gnome_available_locales_map);
2d519e
         while (g_hash_table_iter_next (&iter, NULL, &value)) {
2d519e
                 GnomeLocale *locale;
2d519e
 
2d519e
                 locale = (GnomeLocale *) value;
2d519e
 
2d519e
 		if (locale->language_code != NULL) {
2d519e
 			int count;
2d519e
 
2d519e
 			count = GPOINTER_TO_INT (g_hash_table_lookup (gnome_language_count_map, locale->language_code));
2d519e
 			count++;
2d519e
 			g_hash_table_insert (gnome_language_count_map, g_strdup (locale->language_code), GINT_TO_POINTER (count));
2d519e
 		}
2d519e
 
2d519e
 		if (locale->territory_code != NULL) {
2d519e
 			int count;
2d519e
 
2d519e
 			count = GPOINTER_TO_INT (g_hash_table_lookup (gnome_territory_count_map, locale->territory_code));
2d519e
 			count++;
2d519e
 			g_hash_table_insert (gnome_territory_count_map, g_strdup (locale->territory_code), GINT_TO_POINTER (count));
2d519e
 		}
2d519e
         }
2d519e
 }
2d519e
 
2d519e
 static void
2d519e
 collect_locales (void)
2d519e
 {
2d519e
-        gboolean found_archive_locales = FALSE;
2d519e
+        gboolean found_localebin_locales = FALSE;
2d519e
         gboolean found_dir_locales = FALSE;
2d519e
-        GError *error = NULL;
2d519e
 
2d519e
         if (gnome_available_locales_map == NULL) {
2d519e
                 gnome_available_locales_map = g_hash_table_new_full (g_str_hash, g_str_equal, g_free, (GDestroyNotify) gnome_locale_free);
2d519e
         }
2d519e
 
2d519e
-
2d519e
-        if (!collect_locales_from_archive (&found_archive_locales, &error)) {
2d519e
-                g_warning ("Failed to load locales from archive: %s", error->message);
2d519e
-                g_clear_error (&error);
2d519e
-        }
2d519e
+        found_localebin_locales = collect_locales_from_localebin ();
2d519e
 
2d519e
         found_dir_locales = collect_locales_from_directory ();
2d519e
 
2d519e
-        if (!(found_archive_locales || found_dir_locales)) {
2d519e
-#ifndef WITH_INCOMPLETE_LOCALES
2d519e
+        if (!(found_localebin_locales || found_dir_locales)) {
2d519e
                 g_warning ("Could not read list of available locales from libc, "
2d519e
                            "guessing possible locales from available translations, "
2d519e
                            "but list may be incomplete!");
2d519e
-#endif
2d519e
         }
2d519e
 
2d519e
 	count_languages_and_territories ();
2d519e
 }
2d519e
 
2d519e
 static gint
2d519e
 get_language_count (const char *language)
2d519e
 {
2d519e
         if (gnome_language_count_map == NULL) {
2d519e
                 collect_locales ();
2d519e
         }
2d519e
 
2d519e
 	return GPOINTER_TO_INT (g_hash_table_lookup (gnome_language_count_map, language));
2d519e
 }
2d519e
 
2d519e
 static gboolean
2d519e
 is_unique_language (const char *language)
2d519e
 {
2d519e
         return get_language_count (language) == 1;
2d519e
 }
2d519e
 
2d519e
 static gint
2d519e
 get_territory_count (const char *territory)
2d519e
 {
2d519e
         if (gnome_territory_count_map == NULL) {
2d519e
                 collect_locales ();
2d519e
         }
2d519e
 
2d519e
 	return GPOINTER_TO_INT (g_hash_table_lookup (gnome_territory_count_map, territory));
2d519e
 }
2d519e
-- 
2d519e
1.8.4.2
2d519e
2d519e
2d519e
From 1dbefdc924691017e2ce9c3380b447bae8211723 Mon Sep 17 00:00:00 2001
2d519e
From: Stefan Sperling <stsp@stsp.name>
2d519e
Date: Wed, 2 Oct 2013 18:58:17 +0200
2d519e
Subject: [PATCH 2/4] languages: Style fix in collect_locales_from_localebin()
2d519e
2d519e
Use spare-before-paren syntax for function calls.
2d519e
---
2d519e
 libgnome-desktop/gnome-languages.c | 4 ++--
2d519e
 1 file changed, 2 insertions(+), 2 deletions(-)
2d519e
2d519e
diff --git a/libgnome-desktop/gnome-languages.c b/libgnome-desktop/gnome-languages.c
2d519e
index 667eb81..f3e3d06 100644
2d519e
--- a/libgnome-desktop/gnome-languages.c
2d519e
+++ b/libgnome-desktop/gnome-languages.c
2d519e
@@ -523,64 +523,64 @@ collect_locales_from_directory (void)
2d519e
 
2d519e
         if (ndirents > 0) {
2d519e
                 free (dirents);
2d519e
         }
2d519e
         return found_locales;
2d519e
 }
2d519e
 
2d519e
 static gboolean
2d519e
 collect_locales_from_localebin (void)
2d519e
 {
2d519e
         gboolean found_locales = FALSE;
2d519e
         gchar    *argv[] = { "locale", "-a", NULL };
2d519e
         gchar    *output;
2d519e
         gchar    **lines, **linep;
2d519e
 
2d519e
         if (g_spawn_sync (NULL, argv, NULL,
2d519e
                           G_SPAWN_SEARCH_PATH|G_SPAWN_STDERR_TO_DEV_NULL,
2d519e
                           NULL, NULL, &output, NULL, NULL, NULL) == FALSE)
2d519e
                 return FALSE;
2d519e
 
2d519e
         g_return_val_if_fail (output != NULL, FALSE);
2d519e
 
2d519e
         lines = g_strsplit (output, "\n", 0);
2d519e
         if (lines) {
2d519e
                 linep = lines;
2d519e
                 while (*linep) {
2d519e
                         if (*linep[0] && add_locale (*linep, TRUE))
2d519e
                                 found_locales = TRUE;
2d519e
                         linep++;
2d519e
                 }
2d519e
-                g_strfreev(lines);
2d519e
+                g_strfreev (lines);
2d519e
         }
2d519e
 
2d519e
-        g_free(output);
2d519e
+        g_free (output);
2d519e
 
2d519e
         return found_locales;
2d519e
 }
2d519e
 
2d519e
 static void
2d519e
 count_languages_and_territories (void)
2d519e
 {
2d519e
 	gpointer value;
2d519e
 	GHashTableIter iter;
2d519e
 
2d519e
 	gnome_language_count_map = g_hash_table_new_full (g_str_hash, g_str_equal, g_free, NULL);
2d519e
 	gnome_territory_count_map = g_hash_table_new_full (g_str_hash, g_str_equal, g_free, NULL);
2d519e
 
2d519e
         g_hash_table_iter_init (&iter, gnome_available_locales_map);
2d519e
         while (g_hash_table_iter_next (&iter, NULL, &value)) {
2d519e
                 GnomeLocale *locale;
2d519e
 
2d519e
                 locale = (GnomeLocale *) value;
2d519e
 
2d519e
 		if (locale->language_code != NULL) {
2d519e
 			int count;
2d519e
 
2d519e
 			count = GPOINTER_TO_INT (g_hash_table_lookup (gnome_language_count_map, locale->language_code));
2d519e
 			count++;
2d519e
 			g_hash_table_insert (gnome_language_count_map, g_strdup (locale->language_code), GINT_TO_POINTER (count));
2d519e
 		}
2d519e
 
2d519e
 		if (locale->territory_code != NULL) {
2d519e
 			int count;
2d519e
 
2d519e
-- 
2d519e
1.8.4.2
2d519e
2d519e
2d519e
From 9460a9fa6eff78d7ba1f176447550f66cecac770 Mon Sep 17 00:00:00 2001
2d519e
From: Stefan Sperling <stsp@stsp.name>
2d519e
Date: Wed, 2 Oct 2013 18:59:11 +0200
2d519e
Subject: [PATCH 3/4] languages: Remove unused struct "nameent"
2d519e
2d519e
This struct was a left-over from the libc locale archive parsing code
2d519e
removed in commit 91082e8d0ef7dc3fe372fb5228fd3bb5a26efa81.
2d519e
---
2d519e
 libgnome-desktop/gnome-languages.c | 6 ------
2d519e
 1 file changed, 6 deletions(-)
2d519e
2d519e
diff --git a/libgnome-desktop/gnome-languages.c b/libgnome-desktop/gnome-languages.c
2d519e
index f3e3d06..a4f9bd2 100644
2d519e
--- a/libgnome-desktop/gnome-languages.c
2d519e
+++ b/libgnome-desktop/gnome-languages.c
2d519e
@@ -443,66 +443,60 @@ add_locale (const char *language_name,
2d519e
         locale->name = construct_language_name (locale->language_code, locale->territory_code,
2d519e
                                                 locale->codeset, locale->modifier);
2d519e
 
2d519e
         if (!gnome_language_has_translations (locale->name) &&
2d519e
             !gnome_language_has_translations (locale->id) &&
2d519e
             !gnome_language_has_translations (locale->language_code) &&
2d519e
             utf8_only) {
2d519e
                 g_debug ("Ignoring '%s' as a locale, since it lacks translations", locale->name);
2d519e
                 gnome_locale_free (locale);
2d519e
                 return FALSE;
2d519e
         }
2d519e
 
2d519e
         if (!utf8_only) {
2d519e
                 g_free (locale->id);
2d519e
                 locale->id = g_strdup (locale->name);
2d519e
         }
2d519e
 
2d519e
         old_locale = g_hash_table_lookup (gnome_available_locales_map, locale->id);
2d519e
         if (old_locale != NULL) {
2d519e
                 if (strlen (old_locale->name) > strlen (locale->name)) {
2d519e
                         gnome_locale_free (locale);
2d519e
                         return FALSE;
2d519e
                 }
2d519e
         }
2d519e
 
2d519e
         g_hash_table_insert (gnome_available_locales_map, g_strdup (locale->id), locale);
2d519e
 
2d519e
         return TRUE;
2d519e
 }
2d519e
 
2d519e
-struct nameent
2d519e
-{
2d519e
-        char    *name;
2d519e
-        guint32 locrec_offset;
2d519e
-};
2d519e
-
2d519e
 static int
2d519e
 select_dirs (const struct dirent *dirent)
2d519e
 {
2d519e
         int result = 0;
2d519e
 
2d519e
         if (strcmp (dirent->d_name, ".") != 0 && strcmp (dirent->d_name, "..") != 0) {
2d519e
                 mode_t mode = 0;
2d519e
 
2d519e
 #ifdef _DIRENT_HAVE_D_TYPE
2d519e
                 if (dirent->d_type != DT_UNKNOWN && dirent->d_type != DT_LNK) {
2d519e
                         mode = DTTOIF (dirent->d_type);
2d519e
                 } else
2d519e
 #endif
2d519e
                         {
2d519e
                                 struct stat st;
2d519e
                                 char       *path;
2d519e
 
2d519e
                                 path = g_build_filename (LIBLOCALEDIR, dirent->d_name, NULL);
2d519e
                                 if (g_stat (path, &st) == 0) {
2d519e
                                         mode = st.st_mode;
2d519e
                                 }
2d519e
                                 g_free (path);
2d519e
                         }
2d519e
 
2d519e
                 result = S_ISDIR (mode);
2d519e
         }
2d519e
 
2d519e
         return result;
2d519e
 }
2d519e
 
2d519e
-- 
2d519e
1.8.4.2
2d519e
2d519e
2d519e
From c02734c975d121a8200a4de0628ab073720e7eae Mon Sep 17 00:00:00 2001
2d519e
From: Florian Weimer <fweimer@redhat.com>
2d519e
Date: Fri, 20 Dec 2013 11:59:08 +0100
2d519e
Subject: [PATCH 4/4] Remove locarchive.h
2d519e
2d519e
This include file is no longer needed since the switch to
2d519e
"locale -a" for listing locales.
2d519e
2d519e
https://bugzilla.gnome.org/show_bug.cgi?id=720815
2d519e
---
2d519e
 libgnome-desktop/Makefile.am | 3 +--
2d519e
 1 file changed, 1 insertion(+), 2 deletions(-)
2d519e
2d519e
diff --git a/libgnome-desktop/Makefile.am b/libgnome-desktop/Makefile.am
2d519e
index 7041be5..e2382b6 100644
2d519e
--- a/libgnome-desktop/Makefile.am
2d519e
+++ b/libgnome-desktop/Makefile.am
2d519e
@@ -19,62 +19,61 @@ AM_CPPFLAGS =							\
2d519e
 AM_CFLAGS = $(WARN_CFLAGS)
2d519e
 
2d519e
 libgsystem_srcpath := libgsystem
2d519e
 libgsystem_cflags = $(GNOME_DESKTOP_CFLAGS)
2d519e
 libgsystem_libs = $(GNOME_DESKTOP_LIBS)
2d519e
 include libgsystem/Makefile-libgsystem.am
2d519e
 
2d519e
 introspection_sources = 		\
2d519e
 	gnome-desktop-thumbnail.c 	\
2d519e
 	gnome-thumbnail-pixbuf-utils.c 	\
2d519e
 	gnome-bg.c			\
2d519e
 	gnome-bg-slide-show.c		\
2d519e
 	gnome-bg-crossfade.c		\
2d519e
 	display-name.c			\
2d519e
 	gnome-rr.c			\
2d519e
 	gnome-rr-config.c		\
2d519e
 	gnome-rr-output-info.c		\
2d519e
 	gnome-pnp-ids.c			\
2d519e
 	gnome-wall-clock.c		\
2d519e
 	gnome-xkb-info.c		\
2d519e
 	gnome-idle-monitor.c		\
2d519e
 	gnome-languages.c		\
2d519e
 	edid-parse.c
2d519e
 
2d519e
 libgnome_desktop_3_la_SOURCES = 	\
2d519e
 	$(introspection_sources)	\
2d519e
 	gnome-datetime-source.h		\
2d519e
 	gnome-datetime-source.c		\
2d519e
 	gnome-rr-private.h		\
2d519e
 	default-input-sources.h		\
2d519e
-	edid.h				\
2d519e
-	locarchive.h
2d519e
+	edid.h
2d519e
 
2d519e
 libgnome_desktop_3_la_LIBADD =	\
2d519e
 	$(XLIB_LIBS)		\
2d519e
 	$(LIBM)			\
2d519e
 	$(GNOME_DESKTOP_LIBS)	\
2d519e
 	libgsystem.la           \
2d519e
 	-lrt
2d519e
 
2d519e
 libgnome_desktop_3_la_LDFLAGS = \
2d519e
 	-version-info $(LT_VERSION) \
2d519e
 	-export-symbols-regex "^gnome_.*" \
2d519e
 	-no-undefined
2d519e
 
2d519e
 pkgconfigdir = $(libdir)/pkgconfig
2d519e
 pkgconfig_DATA = gnome-desktop-3.0.pc
2d519e
 
2d519e
 libgnome_desktopdir = $(includedir)/gnome-desktop-3.0/libgnome-desktop
2d519e
 libgnome_desktop_HEADERS = \
2d519e
         gnome-bg.h                      \
2d519e
         gnome-bg-crossfade.h            \
2d519e
 	gnome-bg-slide-show.h		\
2d519e
         gnome-desktop-thumbnail.h       \
2d519e
         gnome-rr.h                      \
2d519e
         gnome-rr-config.h               \
2d519e
         gnome-pnp-ids.h			\
2d519e
         gnome-wall-clock.h		\
2d519e
 	gnome-xkb-info.h		\
2d519e
 	gnome-idle-monitor.h		\
2d519e
 	gnome-languages.h
2d519e
 
2d519e
-- 
2d519e
1.8.4.2
2d519e