|
|
ce426f |
Add --list-archive FILE support to localedef.
|
|
|
ce426f |
|
|
|
ce426f |
This feature largely supports the integrated work
|
|
|
ce426f |
for InstLang support, and does not explicitly change
|
|
|
ce426f |
any help text or behaviour at the API level for these
|
|
|
ce426f |
routines. The basic purpose is to allow a file name to
|
|
|
ce426f |
propagate to through the internal APIs to be used instead
|
|
|
ce426f |
of the default locale archive. Given that build-locale-archive
|
|
|
ce426f |
links against copies of the internal API it can use these
|
|
|
ce426f |
non-public APIs without problem.
|
|
|
ce426f |
|
|
|
ce426f |
commit eaa1d42819c1d43f27552dfa55accfcc4ac25d54
|
|
|
ce426f |
Author: Carlos O'Donell <carlos@redhat.com>
|
|
|
ce426f |
Date: Mon Feb 24 22:33:35 2014 -0500
|
|
|
ce426f |
|
|
|
ce426f |
Fix failure load locale template.
|
|
|
ce426f |
|
|
|
ce426f |
The call to open_tmpl_archive was being passed a pointer to an
|
|
|
ce426f |
object allocated on the stack. The object on the stack is not
|
|
|
ce426f |
guaranteed to be initialized to zero so we need to minimally
|
|
|
ce426f |
initialize `fname' in the struct locarhandle to ensure that
|
|
|
ce426f |
open_tml_archive loads the default tempalte.
|
|
|
ce426f |
|
|
|
ce426f |
This error was seen while debugging glibc installs in a qemu
|
|
|
ce426f |
VM where it is more likely the stack pages were dirty. It has
|
|
|
ce426f |
not been reported on non-VM systems.
|
|
|
ce426f |
|
|
|
ce426f |
commit f6520166f41d58832351d35cfa987ecbb44f5986
|
|
|
ce426f |
Author: Carlos O'Donell <carlos@redhat.com>
|
|
|
ce426f |
Date: Fri Oct 18 23:27:45 2013 -0400
|
|
|
ce426f |
|
|
|
ce426f |
Allow fill_archive to be called with NULL fname.
|
|
|
ce426f |
|
|
|
ce426f |
The fill_archive function should support being
|
|
|
ce426f |
called with a NULL fname argument. A NULL fname
|
|
|
ce426f |
argument indicates that the default archive should
|
|
|
ce426f |
be opened. We enable this by setting ah.fname to
|
|
|
ce426f |
NULL before initializing ah or calling open_archive.
|
|
|
ce426f |
This way if fname is NULL then ah.fname remains NULL
|
|
|
ce426f |
and open_archive opens the default archive.
|
|
|
ce426f |
|
|
|
ce426f |
commit c2021d0b305d436734709186c8c5dca254f77770
|
|
|
ce426f |
Author: Carlos O'Donell <carlos@redhat.com>
|
|
|
ce426f |
Date: Thu Oct 3 05:22:51 2013 -0400
|
|
|
ce426f |
|
|
|
ce426f |
[snip]
|
|
|
ce426f |
- Support `--list-archive FILE' in localedef utility.
|
|
|
ce426f |
|
|
|
ce426f |
Index: glibc-2.17-c758a686/locale/locarchive.h
|
|
|
ce426f |
===================================================================
|
|
|
ce426f |
--- glibc-2.17-c758a686.orig/locale/locarchive.h
|
|
|
ce426f |
+++ glibc-2.17-c758a686/locale/locarchive.h
|
|
|
ce426f |
@@ -80,6 +80,8 @@ struct locrecent
|
|
|
ce426f |
|
|
|
ce426f |
struct locarhandle
|
|
|
ce426f |
{
|
|
|
ce426f |
+ /* Full path to the locale archive file. */
|
|
|
ce426f |
+ const char *fname;
|
|
|
ce426f |
int fd;
|
|
|
ce426f |
void *addr;
|
|
|
ce426f |
size_t mmaped;
|
|
|
ce426f |
Index: glibc-2.17-c758a686/locale/programs/localedef.c
|
|
|
ce426f |
===================================================================
|
|
|
ce426f |
--- glibc-2.17-c758a686.orig/locale/programs/localedef.c
|
|
|
ce426f |
+++ glibc-2.17-c758a686/locale/programs/localedef.c
|
|
|
ce426f |
@@ -202,7 +202,7 @@ main (int argc, char *argv[])
|
|
|
ce426f |
|
|
|
ce426f |
/* Handle a few special cases. */
|
|
|
ce426f |
if (list_archive)
|
|
|
ce426f |
- show_archive_content (verbose);
|
|
|
ce426f |
+ show_archive_content (remaining > 1 ? argv[remaining] : NULL, verbose);
|
|
|
ce426f |
if (add_to_archive)
|
|
|
ce426f |
return add_locales_to_archive (argc - remaining, &argv[remaining],
|
|
|
ce426f |
replace_archive);
|
|
|
ce426f |
Index: glibc-2.17-c758a686/locale/programs/localedef.h
|
|
|
ce426f |
===================================================================
|
|
|
ce426f |
--- glibc-2.17-c758a686.orig/locale/programs/localedef.h
|
|
|
ce426f |
+++ glibc-2.17-c758a686/locale/programs/localedef.h
|
|
|
ce426f |
@@ -176,7 +176,8 @@ extern int add_locales_to_archive (size_
|
|
|
ce426f |
/* Removed named locales from archive. */
|
|
|
ce426f |
extern int delete_locales_from_archive (size_t nlist, char *list[]);
|
|
|
ce426f |
|
|
|
ce426f |
-/* List content of locale archive. */
|
|
|
ce426f |
-extern void show_archive_content (int verbose) __attribute__ ((noreturn));
|
|
|
ce426f |
+/* List content of locale archive. If FNAME is non-null use that as
|
|
|
ce426f |
+ the locale archive to list, otherwise the default. */
|
|
|
ce426f |
+extern void show_archive_content (char *fname, int verbose) __attribute__ ((noreturn));
|
|
|
ce426f |
|
|
|
ce426f |
#endif /* localedef.h */
|
|
|
ce426f |
Index: glibc-2.17-c758a686/locale/programs/locarchive.c
|
|
|
ce426f |
===================================================================
|
|
|
ce426f |
--- glibc-2.17-c758a686.orig/locale/programs/locarchive.c
|
|
|
ce426f |
+++ glibc-2.17-c758a686/locale/programs/locarchive.c
|
|
|
ce426f |
@@ -197,6 +197,7 @@ create_archive (const char *archivefname
|
|
|
ce426f |
_("cannot change mode of new locale archive"));
|
|
|
ce426f |
}
|
|
|
ce426f |
|
|
|
ce426f |
+ ah->fname = NULL;
|
|
|
ce426f |
ah->fd = fd;
|
|
|
ce426f |
ah->addr = p;
|
|
|
ce426f |
ah->mmaped = total;
|
|
|
ce426f |
@@ -519,11 +520,19 @@ open_archive (struct locarhandle *ah, bo
|
|
|
ce426f |
struct locarhead head;
|
|
|
ce426f |
int retry = 0;
|
|
|
ce426f |
size_t prefix_len = output_prefix ? strlen (output_prefix) : 0;
|
|
|
ce426f |
- char archivefname[prefix_len + sizeof (ARCHIVE_NAME)];
|
|
|
ce426f |
-
|
|
|
ce426f |
- if (output_prefix)
|
|
|
ce426f |
- memcpy (archivefname, output_prefix, prefix_len);
|
|
|
ce426f |
- strcpy (archivefname + prefix_len, ARCHIVE_NAME);
|
|
|
ce426f |
+ char fname[prefix_len + sizeof (ARCHIVE_NAME)];
|
|
|
ce426f |
+ char *archivefname = ah->fname;
|
|
|
ce426f |
+ bool defaultfname = false;
|
|
|
ce426f |
+
|
|
|
ce426f |
+ /* If ah has a non-NULL fname open that otherwise open the default. */
|
|
|
ce426f |
+ if (archivefname == NULL)
|
|
|
ce426f |
+ {
|
|
|
ce426f |
+ defaultfname = true;
|
|
|
ce426f |
+ archivefname = fname;
|
|
|
ce426f |
+ if (output_prefix)
|
|
|
ce426f |
+ memcpy (archivefname, output_prefix, prefix_len);
|
|
|
ce426f |
+ strcpy (archivefname + prefix_len, ARCHIVE_NAME);
|
|
|
ce426f |
+ }
|
|
|
ce426f |
|
|
|
ce426f |
while (1)
|
|
|
ce426f |
{
|
|
|
ce426f |
@@ -531,8 +540,11 @@ open_archive (struct locarhandle *ah, bo
|
|
|
ce426f |
fd = open64 (archivefname, readonly ? O_RDONLY : O_RDWR);
|
|
|
ce426f |
if (fd == -1)
|
|
|
ce426f |
{
|
|
|
ce426f |
- /* Maybe the file does not yet exist. */
|
|
|
ce426f |
- if (errno == ENOENT)
|
|
|
ce426f |
+ /* Maybe the file does not yet exist? If we are opening
|
|
|
ce426f |
+ the default locale archive we ignore the failure and
|
|
|
ce426f |
+ list an empty archive, otherwise we print an error
|
|
|
ce426f |
+ and exit. */
|
|
|
ce426f |
+ if (errno == ENOENT && defaultfname)
|
|
|
ce426f |
{
|
|
|
ce426f |
if (readonly)
|
|
|
ce426f |
{
|
|
|
ce426f |
@@ -1258,6 +1270,7 @@ add_locales_to_archive (nlist, list, rep
|
|
|
ce426f |
|
|
|
ce426f |
/* Open the archive. This call never returns if we cannot
|
|
|
ce426f |
successfully open the archive. */
|
|
|
ce426f |
+ ah.fname = NULL;
|
|
|
ce426f |
open_archive (&ah, false);
|
|
|
ce426f |
|
|
|
ce426f |
while (nlist-- > 0)
|
|
|
ce426f |
@@ -1457,6 +1470,7 @@ delete_locales_from_archive (nlist, list
|
|
|
ce426f |
|
|
|
ce426f |
/* Open the archive. This call never returns if we cannot
|
|
|
ce426f |
successfully open the archive. */
|
|
|
ce426f |
+ ah.fname = NULL;
|
|
|
ce426f |
open_archive (&ah, false);
|
|
|
ce426f |
|
|
|
ce426f |
head = ah.addr;
|
|
|
ce426f |
@@ -1545,7 +1559,7 @@ dataentcmp (const void *a, const void *b
|
|
|
ce426f |
|
|
|
ce426f |
|
|
|
ce426f |
void
|
|
|
ce426f |
-show_archive_content (int verbose)
|
|
|
ce426f |
+show_archive_content (char *fname, int verbose)
|
|
|
ce426f |
{
|
|
|
ce426f |
struct locarhandle ah;
|
|
|
ce426f |
struct locarhead *head;
|
|
|
ce426f |
@@ -1555,6 +1569,7 @@ show_archive_content (int verbose)
|
|
|
ce426f |
|
|
|
ce426f |
/* Open the archive. This call never returns if we cannot
|
|
|
ce426f |
successfully open the archive. */
|
|
|
ce426f |
+ ah.fname = fname;
|
|
|
ce426f |
open_archive (&ah, true);
|
|
|
ce426f |
|
|
|
ce426f |
head = ah.addr;
|
|
|
ce426f |
Index: glibc-2.17-c758a686/locale/programs/locfile.c
|
|
|
ce426f |
===================================================================
|
|
|
ce426f |
--- glibc-2.17-c758a686.orig/locale/programs/locfile.c
|
|
|
ce426f |
+++ glibc-2.17-c758a686/locale/programs/locfile.c
|
|
|
ce426f |
@@ -337,6 +337,7 @@ write_all_categories (struct localedef_t
|
|
|
ce426f |
|
|
|
ce426f |
/* Open the archive. This call never returns if we cannot
|
|
|
ce426f |
successfully open the archive. */
|
|
|
ce426f |
+ ah.fname = NULL;
|
|
|
ce426f |
open_archive (&ah, false);
|
|
|
ce426f |
|
|
|
ce426f |
if (add_locale_to_archive (&ah, locname, to_archive, true) != 0)
|