summaryrefslogtreecommitdiffstats
path: root/meta-oe/recipes-support
diff options
context:
space:
mode:
authorKhem Raj <raj.khem@gmail.com>2019-12-07 00:57:23 -0800
committerKhem Raj <raj.khem@gmail.com>2019-12-08 23:00:57 -0800
commitc55a5670227fd02385350493b53dba79f3d21fe4 (patch)
treec5b33f4653ec104f8463586521e2326686f2b446 /meta-oe/recipes-support
parent53e62e4e57c701dd546a2e27d8b72b7a4698551a (diff)
downloadmeta-openembedded-c55a5670227fd02385350493b53dba79f3d21fe4.tar.gz
libnih: Fix build with latest gettext
Run gettextize and fix up the resulting problems so that it builds Fixes | make[2]: *** No rule to make target 'libgnuintl.@INTL_LIBTOOL_SUFFIX_PREFIX@a', needed by 'all-no-yes'. Stop. Signed-off-by: Khem Raj <raj.khem@gmail.com>
Diffstat (limited to 'meta-oe/recipes-support')
-rw-r--r--meta-oe/recipes-support/libnih/libnih-1.0.3/0001-Update-autotool-files-also-make-it-work-with-latest-.patch24310
-rw-r--r--meta-oe/recipes-support/libnih/libnih_1.0.3.bb8
2 files changed, 24314 insertions, 4 deletions
diff --git a/meta-oe/recipes-support/libnih/libnih-1.0.3/0001-Update-autotool-files-also-make-it-work-with-latest-.patch b/meta-oe/recipes-support/libnih/libnih-1.0.3/0001-Update-autotool-files-also-make-it-work-with-latest-.patch
new file mode 100644
index 000000000..2c857c26f
--- /dev/null
+++ b/meta-oe/recipes-support/libnih/libnih-1.0.3/0001-Update-autotool-files-also-make-it-work-with-latest-.patch
@@ -0,0 +1,24310 @@
1From 0f1cc1bc615807e81fd2709d4177ca41168446c0 Mon Sep 17 00:00:00 2001
2From: Khem Raj <raj.khem@gmail.com>
3Date: Sat, 7 Dec 2019 00:45:23 -0800
4Subject: [PATCH] Update autotool files, also make it work with latest gettext
5
6Upstream-Status: Inappropriate [Dead upstream]
7Signed-off-by: Khem Raj <raj.khem@gmail.com>
8---
9 ABOUT-NLS | 1069 +--
10 ChangeLog | 7 +
11 Makefile.am | 2 +-
12 configure.ac | 6 +-
13 intl/ChangeLog | 4 -
14 intl/Makefile.in | 587 --
15 intl/VERSION | 1 -
16 intl/bindtextdom.c | 340 -
17 intl/config.charset | 640 --
18 intl/dcgettext.c | 56 -
19 intl/dcigettext.c | 1689 -----
20 intl/dcngettext.c | 57 -
21 intl/dgettext.c | 58 -
22 intl/dngettext.c | 59 -
23 intl/eval-plural.h | 108 -
24 intl/explodename.c | 135 -
25 intl/export.h | 6 -
26 intl/finddomain.c | 212 -
27 intl/gettext.c | 63 -
28 intl/gettextP.h | 297 -
29 intl/gmo.h | 152 -
30 intl/hash-string.c | 51 -
31 intl/hash-string.h | 36 -
32 intl/intl-compat.c | 133 -
33 intl/intl-exports.c | 36 -
34 intl/l10nflist.c | 400 --
35 intl/langprefs.c | 130 -
36 intl/libgnuintl.h.in | 419 --
37 intl/libintl.rc | 38 -
38 intl/loadinfo.h | 132 -
39 intl/loadmsgcat.c | 1336 ----
40 intl/localcharset.c | 461 --
41 intl/localcharset.h | 42 -
42 intl/locale.alias | 77 -
43 intl/localealias.c | 439 --
44 intl/localename.c | 1507 ----
45 intl/lock.c | 922 ---
46 intl/lock.h | 1105 ---
47 intl/log.c | 116 -
48 intl/ngettext.c | 65 -
49 intl/os2compat.c | 98 -
50 intl/os2compat.h | 46 -
51 intl/osdep.c | 26 -
52 intl/plural-exp.c | 155 -
53 intl/plural-exp.h | 129 -
54 intl/plural.c | 1981 ------
55 intl/plural.y | 385 --
56 intl/printf-args.c | 188 -
57 intl/printf-args.h | 155 -
58 intl/printf-parse.c | 590 --
59 intl/printf-parse.h | 75 -
60 intl/printf.c | 427 --
61 intl/ref-add.sin | 31 -
62 intl/ref-del.sin | 26 -
63 intl/relocatable.c | 468 --
64 intl/relocatable.h | 79 -
65 intl/textdomain.c | 127 -
66 intl/tsearch.c | 684 --
67 intl/tsearch.h | 83 -
68 intl/vasnprintf.c | 4677 -------------
69 intl/vasnprintf.h | 78 -
70 intl/vasnwprintf.h | 46 -
71 intl/version.c | 26 -
72 intl/wprintf-parse.h | 75 -
73 intl/xsize.h | 109 -
74 m4/intlmacosx.m4 | 55 +-
75 po/ChangeLog | 8 +
76 po/Rules-quot | 19 +-
77 po/en@boldquot.header | 2 +-
78 po/en@quot.header | 2 +-
79 po/insert-header.sin | 5 +
80 po/remove-potcdate.sin | 8 +-
81 74 files changed, 1335 insertions(+), 38646 deletions(-)
82 delete mode 100644 intl/ChangeLog
83 delete mode 100644 intl/Makefile.in
84 delete mode 100644 intl/VERSION
85 delete mode 100644 intl/bindtextdom.c
86 delete mode 100755 intl/config.charset
87 delete mode 100644 intl/dcgettext.c
88 delete mode 100644 intl/dcigettext.c
89 delete mode 100644 intl/dcngettext.c
90 delete mode 100644 intl/dgettext.c
91 delete mode 100644 intl/dngettext.c
92 delete mode 100644 intl/eval-plural.h
93 delete mode 100644 intl/explodename.c
94 delete mode 100644 intl/export.h
95 delete mode 100644 intl/finddomain.c
96 delete mode 100644 intl/gettext.c
97 delete mode 100644 intl/gettextP.h
98 delete mode 100644 intl/gmo.h
99 delete mode 100644 intl/hash-string.c
100 delete mode 100644 intl/hash-string.h
101 delete mode 100644 intl/intl-compat.c
102 delete mode 100644 intl/intl-exports.c
103 delete mode 100644 intl/l10nflist.c
104 delete mode 100644 intl/langprefs.c
105 delete mode 100644 intl/libgnuintl.h.in
106 delete mode 100644 intl/libintl.rc
107 delete mode 100644 intl/loadinfo.h
108 delete mode 100644 intl/loadmsgcat.c
109 delete mode 100644 intl/localcharset.c
110 delete mode 100644 intl/localcharset.h
111 delete mode 100644 intl/locale.alias
112 delete mode 100644 intl/localealias.c
113 delete mode 100644 intl/localename.c
114 delete mode 100644 intl/lock.c
115 delete mode 100644 intl/lock.h
116 delete mode 100644 intl/log.c
117 delete mode 100644 intl/ngettext.c
118 delete mode 100644 intl/os2compat.c
119 delete mode 100644 intl/os2compat.h
120 delete mode 100644 intl/osdep.c
121 delete mode 100644 intl/plural-exp.c
122 delete mode 100644 intl/plural-exp.h
123 delete mode 100644 intl/plural.c
124 delete mode 100644 intl/plural.y
125 delete mode 100644 intl/printf-args.c
126 delete mode 100644 intl/printf-args.h
127 delete mode 100644 intl/printf-parse.c
128 delete mode 100644 intl/printf-parse.h
129 delete mode 100644 intl/printf.c
130 delete mode 100644 intl/ref-add.sin
131 delete mode 100644 intl/ref-del.sin
132 delete mode 100644 intl/relocatable.c
133 delete mode 100644 intl/relocatable.h
134 delete mode 100644 intl/textdomain.c
135 delete mode 100644 intl/tsearch.c
136 delete mode 100644 intl/tsearch.h
137 delete mode 100644 intl/vasnprintf.c
138 delete mode 100644 intl/vasnprintf.h
139 delete mode 100644 intl/vasnwprintf.h
140 delete mode 100644 intl/version.c
141 delete mode 100644 intl/wprintf-parse.h
142 delete mode 100644 intl/xsize.h
143
144--- a/ABOUT-NLS
145+++ b/ABOUT-NLS
146@@ -1,1068 +1 @@
147-1 Notes on the Free Translation Project
148-***************************************
149-
150-Free software is going international! The Free Translation Project is
151-a way to get maintainers of free software, translators, and users all
152-together, so that free software will gradually become able to speak many
153-languages. A few packages already provide translations for their
154-messages.
155-
156- If you found this `ABOUT-NLS' file inside a distribution, you may
157-assume that the distributed package does use GNU `gettext' internally,
158-itself available at your nearest GNU archive site. But you do _not_
159-need to install GNU `gettext' prior to configuring, installing or using
160-this package with messages translated.
161-
162- Installers will find here some useful hints. These notes also
163-explain how users should proceed for getting the programs to use the
164-available translations. They tell how people wanting to contribute and
165-work on translations can contact the appropriate team.
166-
167- When reporting bugs in the `intl/' directory or bugs which may be
168-related to internationalization, you should tell about the version of
169-`gettext' which is used. The information can be found in the
170-`intl/VERSION' file, in internationalized packages.
171-
172-1.1 Quick configuration advice
173-==============================
174-
175-If you want to exploit the full power of internationalization, you
176-should configure it using
177-
178- ./configure --with-included-gettext
179-
180-to force usage of internationalizing routines provided within this
181-package, despite the existence of internationalizing capabilities in the
182-operating system where this package is being installed. So far, only
183-the `gettext' implementation in the GNU C library version 2 provides as
184-many features (such as locale alias, message inheritance, automatic
185-charset conversion or plural form handling) as the implementation here.
186-It is also not possible to offer this additional functionality on top
187-of a `catgets' implementation. Future versions of GNU `gettext' will
188-very likely convey even more functionality. So it might be a good idea
189-to change to GNU `gettext' as soon as possible.
190-
191- So you need _not_ provide this option if you are using GNU libc 2 or
192-you have installed a recent copy of the GNU gettext package with the
193-included `libintl'.
194-
195-1.2 INSTALL Matters
196-===================
197-
198-Some packages are "localizable" when properly installed; the programs
199-they contain can be made to speak your own native language. Most such
200-packages use GNU `gettext'. Other packages have their own ways to
201-internationalization, predating GNU `gettext'.
202-
203- By default, this package will be installed to allow translation of
204-messages. It will automatically detect whether the system already
205-provides the GNU `gettext' functions. If not, the included GNU
206-`gettext' library will be used. This library is wholly contained
207-within this package, usually in the `intl/' subdirectory, so prior
208-installation of the GNU `gettext' package is _not_ required.
209-Installers may use special options at configuration time for changing
210-the default behaviour. The commands:
211-
212- ./configure --with-included-gettext
213- ./configure --disable-nls
214-
215-will, respectively, bypass any pre-existing `gettext' to use the
216-internationalizing routines provided within this package, or else,
217-_totally_ disable translation of messages.
218-
219- When you already have GNU `gettext' installed on your system and run
220-configure without an option for your new package, `configure' will
221-probably detect the previously built and installed `libintl.a' file and
222-will decide to use this. This might not be desirable. You should use
223-the more recent version of the GNU `gettext' library. I.e. if the file
224-`intl/VERSION' shows that the library which comes with this package is
225-more recent, you should use
226-
227- ./configure --with-included-gettext
228-
229-to prevent auto-detection.
230-
231- The configuration process will not test for the `catgets' function
232-and therefore it will not be used. The reason is that even an
233-emulation of `gettext' on top of `catgets' could not provide all the
234-extensions of the GNU `gettext' library.
235-
236- Internationalized packages usually have many `po/LL.po' files, where
237-LL gives an ISO 639 two-letter code identifying the language. Unless
238-translations have been forbidden at `configure' time by using the
239-`--disable-nls' switch, all available translations are installed
240-together with the package. However, the environment variable `LINGUAS'
241-may be set, prior to configuration, to limit the installed set.
242-`LINGUAS' should then contain a space separated list of two-letter
243-codes, stating which languages are allowed.
244-
245-1.3 Using This Package
246-======================
247-
248-As a user, if your language has been installed for this package, you
249-only have to set the `LANG' environment variable to the appropriate
250-`LL_CC' combination. If you happen to have the `LC_ALL' or some other
251-`LC_xxx' environment variables set, you should unset them before
252-setting `LANG', otherwise the setting of `LANG' will not have the
253-desired effect. Here `LL' is an ISO 639 two-letter language code, and
254-`CC' is an ISO 3166 two-letter country code. For example, let's
255-suppose that you speak German and live in Germany. At the shell
256-prompt, merely execute `setenv LANG de_DE' (in `csh'),
257-`export LANG; LANG=de_DE' (in `sh') or `export LANG=de_DE' (in `bash').
258-This can be done from your `.login' or `.profile' file, once and for
259-all.
260-
261- You might think that the country code specification is redundant.
262-But in fact, some languages have dialects in different countries. For
263-example, `de_AT' is used for Austria, and `pt_BR' for Brazil. The
264-country code serves to distinguish the dialects.
265-
266- The locale naming convention of `LL_CC', with `LL' denoting the
267-language and `CC' denoting the country, is the one use on systems based
268-on GNU libc. On other systems, some variations of this scheme are
269-used, such as `LL' or `LL_CC.ENCODING'. You can get the list of
270-locales supported by your system for your language by running the
271-command `locale -a | grep '^LL''.
272-
273- Not all programs have translations for all languages. By default, an
274-English message is shown in place of a nonexistent translation. If you
275-understand other languages, you can set up a priority list of languages.
276-This is done through a different environment variable, called
277-`LANGUAGE'. GNU `gettext' gives preference to `LANGUAGE' over `LANG'
278-for the purpose of message handling, but you still need to have `LANG'
279-set to the primary language; this is required by other parts of the
280-system libraries. For example, some Swedish users who would rather
281-read translations in German than English for when Swedish is not
282-available, set `LANGUAGE' to `sv:de' while leaving `LANG' to `sv_SE'.
283-
284- Special advice for Norwegian users: The language code for Norwegian
285-bokma*l changed from `no' to `nb' recently (in 2003). During the
286-transition period, while some message catalogs for this language are
287-installed under `nb' and some older ones under `no', it's recommended
288-for Norwegian users to set `LANGUAGE' to `nb:no' so that both newer and
289-older translations are used.
290-
291- In the `LANGUAGE' environment variable, but not in the `LANG'
292-environment variable, `LL_CC' combinations can be abbreviated as `LL'
293-to denote the language's main dialect. For example, `de' is equivalent
294-to `de_DE' (German as spoken in Germany), and `pt' to `pt_PT'
295-(Portuguese as spoken in Portugal) in this context.
296-
297-1.4 Translating Teams
298-=====================
299-
300-For the Free Translation Project to be a success, we need interested
301-people who like their own language and write it well, and who are also
302-able to synergize with other translators speaking the same language.
303-Each translation team has its own mailing list. The up-to-date list of
304-teams can be found at the Free Translation Project's homepage,
305-`http://translationproject.org/', in the "Teams" area.
306-
307- If you'd like to volunteer to _work_ at translating messages, you
308-should become a member of the translating team for your own language.
309-The subscribing address is _not_ the same as the list itself, it has
310-`-request' appended. For example, speakers of Swedish can send a
311-message to `sv-request@li.org', having this message body:
312-
313- subscribe
314-
315- Keep in mind that team members are expected to participate
316-_actively_ in translations, or at solving translational difficulties,
317-rather than merely lurking around. If your team does not exist yet and
318-you want to start one, or if you are unsure about what to do or how to
319-get started, please write to `coordinator@translationproject.org' to
320-reach the coordinator for all translator teams.
321-
322- The English team is special. It works at improving and uniformizing
323-the terminology in use. Proven linguistic skills are praised more than
324-programming skills, here.
325-
326-1.5 Available Packages
327-======================
328-
329-Languages are not equally supported in all packages. The following
330-matrix shows the current state of internationalization, as of November
331-2007. The matrix shows, in regard of each package, for which languages
332-PO files have been submitted to translation coordination, with a
333-translation percentage of at least 50%.
334-
335- Ready PO files af am ar az be bg bs ca cs cy da de el en en_GB eo
336- +----------------------------------------------------+
337- Compendium | [] [] [] [] |
338- a2ps | [] [] [] [] [] |
339- aegis | () |
340- ant-phone | () |
341- anubis | [] |
342- ap-utils | |
343- aspell | [] [] [] [] [] |
344- bash | [] |
345- bfd | |
346- bibshelf | [] |
347- binutils | |
348- bison | [] [] |
349- bison-runtime | [] |
350- bluez-pin | [] [] [] [] [] |
351- cflow | [] |
352- clisp | [] [] [] |
353- console-tools | [] [] |
354- coreutils | [] [] [] [] |
355- cpio | |
356- cpplib | [] [] [] |
357- cryptonit | [] |
358- dialog | |
359- diffutils | [] [] [] [] [] [] |
360- doodle | [] |
361- e2fsprogs | [] [] |
362- enscript | [] [] [] [] |
363- fetchmail | [] [] () [] [] |
364- findutils | [] |
365- findutils_stable | [] [] [] |
366- flex | [] [] [] |
367- fslint | |
368- gas | |
369- gawk | [] [] [] |
370- gcal | [] |
371- gcc | [] |
372- gettext-examples | [] [] [] [] [] |
373- gettext-runtime | [] [] [] [] [] |
374- gettext-tools | [] [] |
375- gip | [] |
376- gliv | [] [] |
377- glunarclock | [] |
378- gmult | [] [] |
379- gnubiff | () |
380- gnucash | [] [] () () [] |
381- gnuedu | |
382- gnulib | [] |
383- gnunet | |
384- gnunet-gtk | |
385- gnutls | [] |
386- gpe-aerial | [] [] |
387- gpe-beam | [] [] |
388- gpe-calendar | |
389- gpe-clock | [] [] |
390- gpe-conf | [] [] |
391- gpe-contacts | |
392- gpe-edit | [] |
393- gpe-filemanager | |
394- gpe-go | [] |
395- gpe-login | [] [] |
396- gpe-ownerinfo | [] [] |
397- gpe-package | |
398- gpe-sketchbook | [] [] |
399- gpe-su | [] [] |
400- gpe-taskmanager | [] [] |
401- gpe-timesheet | [] |
402- gpe-today | [] [] |
403- gpe-todo | |
404- gphoto2 | [] [] [] [] |
405- gprof | [] [] |
406- gpsdrive | |
407- gramadoir | [] [] |
408- grep | [] [] |
409- gretl | () |
410- gsasl | |
411- gss | |
412- gst-plugins-bad | [] [] |
413- gst-plugins-base | [] [] |
414- gst-plugins-good | [] [] [] |
415- gst-plugins-ugly | [] [] |
416- gstreamer | [] [] [] [] [] [] [] |
417- gtick | () |
418- gtkam | [] [] [] [] |
419- gtkorphan | [] [] |
420- gtkspell | [] [] [] [] |
421- gutenprint | [] |
422- hello | [] [] [] [] [] |
423- herrie | [] |
424- hylafax | |
425- idutils | [] [] |
426- indent | [] [] [] [] |
427- iso_15924 | |
428- iso_3166 | [] [] [] [] [] [] [] [] [] [] [] |
429- iso_3166_2 | |
430- iso_4217 | [] [] [] |
431- iso_639 | [] [] [] [] |
432- jpilot | [] |
433- jtag | |
434- jwhois | |
435- kbd | [] [] [] [] |
436- keytouch | [] [] |
437- keytouch-editor | [] |
438- keytouch-keyboa... | [] |
439- latrine | () |
440- ld | [] |
441- leafpad | [] [] [] [] [] |
442- libc | [] [] [] [] |
443- libexif | [] |
444- libextractor | [] |
445- libgpewidget | [] [] [] |
446- libgpg-error | [] |
447- libgphoto2 | [] [] |
448- libgphoto2_port | [] [] |
449- libgsasl | |
450- libiconv | [] [] |
451- libidn | [] [] [] |
452- lifelines | [] () |
453- lilypond | [] |
454- lingoteach | |
455- lprng | |
456- lynx | [] [] [] [] |
457- m4 | [] [] [] [] |
458- mailfromd | |
459- mailutils | [] |
460- make | [] [] |
461- man-db | [] [] [] |
462- minicom | [] [] [] |
463- nano | [] [] [] |
464- opcodes | [] |
465- parted | [] [] |
466- pilot-qof | |
467- popt | [] [] [] |
468- psmisc | [] |
469- pwdutils | |
470- qof | |
471- radius | [] |
472- recode | [] [] [] [] [] [] |
473- rpm | [] |
474- screem | |
475- scrollkeeper | [] [] [] [] [] [] [] [] |
476- sed | [] [] [] |
477- shared-mime-info | [] [] [] [] () [] [] [] |
478- sharutils | [] [] [] [] [] [] |
479- shishi | |
480- skencil | [] () |
481- solfege | |
482- soundtracker | [] [] |
483- sp | [] |
484- system-tools-ba... | [] [] [] [] [] [] [] [] [] |
485- tar | [] [] |
486- texinfo | [] [] [] |
487- tin | () () |
488- tuxpaint | [] [] [] [] [] [] |
489- unicode-han-tra... | |
490- unicode-transla... | |
491- util-linux | [] [] [] [] |
492- util-linux-ng | [] [] [] [] |
493- vorbis-tools | [] |
494- wastesedge | () |
495- wdiff | [] [] [] [] |
496- wget | [] [] [] |
497- xchat | [] [] [] [] [] [] [] |
498- xkeyboard-config | [] |
499- xpad | [] [] [] |
500- +----------------------------------------------------+
501- af am ar az be bg bs ca cs cy da de el en en_GB eo
502- 6 0 2 1 8 26 2 40 48 2 56 88 15 1 15 18
503-
504- es et eu fa fi fr ga gl gu he hi hr hu id is it
505- +--------------------------------------------------+
506- Compendium | [] [] [] [] [] |
507- a2ps | [] [] [] () |
508- aegis | |
509- ant-phone | [] |
510- anubis | [] |
511- ap-utils | [] [] |
512- aspell | [] [] [] |
513- bash | [] |
514- bfd | [] [] |
515- bibshelf | [] [] [] |
516- binutils | [] [] [] |
517- bison | [] [] [] [] [] [] |
518- bison-runtime | [] [] [] [] [] |
519- bluez-pin | [] [] [] [] [] |
520- cflow | [] |
521- clisp | [] [] |
522- console-tools | |
523- coreutils | [] [] [] [] [] [] |
524- cpio | [] [] [] |
525- cpplib | [] [] |
526- cryptonit | [] |
527- dialog | [] [] [] |
528- diffutils | [] [] [] [] [] [] [] [] [] |
529- doodle | [] [] |
530- e2fsprogs | [] [] [] |
531- enscript | [] [] [] |
532- fetchmail | [] |
533- findutils | [] [] [] |
534- findutils_stable | [] [] [] [] |
535- flex | [] [] [] |
536- fslint | |
537- gas | [] [] |
538- gawk | [] [] [] [] () |
539- gcal | [] [] |
540- gcc | [] |
541- gettext-examples | [] [] [] [] [] [] [] |
542- gettext-runtime | [] [] [] [] [] [] |
543- gettext-tools | [] [] [] [] |
544- gip | [] [] [] [] |
545- gliv | () |
546- glunarclock | [] [] [] |
547- gmult | [] [] [] |
548- gnubiff | () () |
549- gnucash | () () () |
550- gnuedu | [] |
551- gnulib | [] [] [] |
552- gnunet | |
553- gnunet-gtk | |
554- gnutls | |
555- gpe-aerial | [] [] |
556- gpe-beam | [] [] |
557- gpe-calendar | |
558- gpe-clock | [] [] [] [] |
559- gpe-conf | [] |
560- gpe-contacts | [] [] |
561- gpe-edit | [] [] [] [] |
562- gpe-filemanager | [] |
563- gpe-go | [] [] [] |
564- gpe-login | [] [] [] |
565- gpe-ownerinfo | [] [] [] [] [] |
566- gpe-package | [] |
567- gpe-sketchbook | [] [] |
568- gpe-su | [] [] [] [] |
569- gpe-taskmanager | [] [] [] |
570- gpe-timesheet | [] [] [] [] |
571- gpe-today | [] [] [] [] |
572- gpe-todo | [] |
573- gphoto2 | [] [] [] [] [] |
574- gprof | [] [] [] [] [] |
575- gpsdrive | [] |
576- gramadoir | [] [] |
577- grep | [] [] [] |
578- gretl | [] [] [] () |
579- gsasl | [] [] |
580- gss | [] [] |
581- gst-plugins-bad | [] [] [] [] |
582- gst-plugins-base | [] [] [] [] |
583- gst-plugins-good | [] [] [] [] [] |
584- gst-plugins-ugly | [] [] [] [] |
585- gstreamer | [] [] [] |
586- gtick | [] [] [] |
587- gtkam | [] [] [] [] |
588- gtkorphan | [] [] |
589- gtkspell | [] [] [] [] [] [] [] |
590- gutenprint | [] |
591- hello | [] [] [] [] [] [] [] [] [] [] [] [] [] |
592- herrie | [] |
593- hylafax | |
594- idutils | [] [] [] [] [] |
595- indent | [] [] [] [] [] [] [] [] [] [] |
596- iso_15924 | [] |
597- iso_3166 | [] [] [] [] [] [] [] [] [] [] [] [] [] |
598- iso_3166_2 | [] |
599- iso_4217 | [] [] [] [] [] [] |
600- iso_639 | [] [] [] [] [] [] |
601- jpilot | [] [] |
602- jtag | [] |
603- jwhois | [] [] [] [] [] |
604- kbd | [] [] |
605- keytouch | [] [] [] |
606- keytouch-editor | [] |
607- keytouch-keyboa... | [] [] |
608- latrine | [] [] |
609- ld | [] [] [] [] |
610- leafpad | [] [] [] [] [] [] |
611- libc | [] [] [] [] [] |
612- libexif | [] |
613- libextractor | [] |
614- libgpewidget | [] [] [] [] [] |
615- libgpg-error | [] |
616- libgphoto2 | [] [] [] |
617- libgphoto2_port | [] [] |
618- libgsasl | [] [] |
619- libiconv | [] [] [] |
620- libidn | [] [] |
621- lifelines | () |
622- lilypond | [] [] [] |
623- lingoteach | [] [] [] |
624- lprng | |
625- lynx | [] [] [] |
626- m4 | [] [] [] [] |
627- mailfromd | |
628- mailutils | [] [] |
629- make | [] [] [] [] [] [] [] [] |
630- man-db | [] |
631- minicom | [] [] [] [] |
632- nano | [] [] [] [] [] [] [] |
633- opcodes | [] [] [] [] |
634- parted | [] [] [] |
635- pilot-qof | |
636- popt | [] [] [] [] |
637- psmisc | [] [] |
638- pwdutils | |
639- qof | [] |
640- radius | [] [] |
641- recode | [] [] [] [] [] [] [] [] |
642- rpm | [] [] |
643- screem | |
644- scrollkeeper | [] [] [] |
645- sed | [] [] [] [] [] |
646- shared-mime-info | [] [] [] [] [] [] |
647- sharutils | [] [] [] [] [] [] [] [] |
648- shishi | [] |
649- skencil | [] [] |
650- solfege | [] |
651- soundtracker | [] [] [] |
652- sp | [] |
653- system-tools-ba... | [] [] [] [] [] [] [] [] [] |
654- tar | [] [] [] [] [] |
655- texinfo | [] [] [] |
656- tin | [] () |
657- tuxpaint | [] [] |
658- unicode-han-tra... | |
659- unicode-transla... | [] [] |
660- util-linux | [] [] [] [] [] [] [] |
661- util-linux-ng | [] [] [] [] [] [] [] |
662- vorbis-tools | |
663- wastesedge | () |
664- wdiff | [] [] [] [] [] [] [] [] |
665- wget | [] [] [] [] [] [] [] [] |
666- xchat | [] [] [] [] [] [] [] |
667- xkeyboard-config | [] [] [] [] |
668- xpad | [] [] [] |
669- +--------------------------------------------------+
670- es et eu fa fi fr ga gl gu he hi hr hu id is it
671- 85 22 14 2 48 101 61 12 2 8 2 6 53 29 1 52
672-
673- ja ka ko ku ky lg lt lv mk mn ms mt nb ne nl nn
674- +--------------------------------------------------+
675- Compendium | [] |
676- a2ps | () [] [] |
677- aegis | () |
678- ant-phone | [] |
679- anubis | [] [] [] |
680- ap-utils | [] |
681- aspell | [] [] |
682- bash | [] |
683- bfd | |
684- bibshelf | [] |
685- binutils | |
686- bison | [] [] [] |
687- bison-runtime | [] [] [] |
688- bluez-pin | [] [] [] |
689- cflow | |
690- clisp | [] |
691- console-tools | |
692- coreutils | [] |
693- cpio | [] |
694- cpplib | [] |
695- cryptonit | [] |
696- dialog | [] [] |
697- diffutils | [] [] [] |
698- doodle | |
699- e2fsprogs | [] |
700- enscript | [] |
701- fetchmail | [] [] |
702- findutils | [] |
703- findutils_stable | [] |
704- flex | [] [] |
705- fslint | |
706- gas | |
707- gawk | [] [] |
708- gcal | |
709- gcc | |
710- gettext-examples | [] [] [] |
711- gettext-runtime | [] [] [] |
712- gettext-tools | [] [] |
713- gip | [] [] |
714- gliv | [] |
715- glunarclock | [] [] |
716- gmult | [] [] [] |
717- gnubiff | |
718- gnucash | () () () |
719- gnuedu | |
720- gnulib | [] [] |
721- gnunet | |
722- gnunet-gtk | |
723- gnutls | [] |
724- gpe-aerial | [] |
725- gpe-beam | [] |
726- gpe-calendar | [] |
727- gpe-clock | [] [] [] |
728- gpe-conf | [] [] [] |
729- gpe-contacts | [] |
730- gpe-edit | [] [] [] |
731- gpe-filemanager | [] [] |
732- gpe-go | [] [] [] |
733- gpe-login | [] [] [] |
734- gpe-ownerinfo | [] [] |
735- gpe-package | [] [] |
736- gpe-sketchbook | [] [] |
737- gpe-su | [] [] [] |
738- gpe-taskmanager | [] [] [] [] |
739- gpe-timesheet | [] |
740- gpe-today | [] [] |
741- gpe-todo | [] |
742- gphoto2 | [] [] |
743- gprof | [] |
744- gpsdrive | [] |
745- gramadoir | () |
746- grep | [] [] |
747- gretl | |
748- gsasl | [] |
749- gss | |
750- gst-plugins-bad | [] |
751- gst-plugins-base | [] |
752- gst-plugins-good | [] |
753- gst-plugins-ugly | [] |
754- gstreamer | [] |
755- gtick | [] |
756- gtkam | [] [] |
757- gtkorphan | [] |
758- gtkspell | [] [] |
759- gutenprint | [] |
760- hello | [] [] [] [] [] [] [] |
761- herrie | [] |
762- hylafax | |
763- idutils | [] |
764- indent | [] [] |
765- iso_15924 | [] |
766- iso_3166 | [] [] [] [] [] [] [] [] |
767- iso_3166_2 | [] |
768- iso_4217 | [] [] [] |
769- iso_639 | [] [] [] [] |
770- jpilot | () () |
771- jtag | |
772- jwhois | [] |
773- kbd | [] |
774- keytouch | [] |
775- keytouch-editor | [] |
776- keytouch-keyboa... | |
777- latrine | [] |
778- ld | |
779- leafpad | [] [] |
780- libc | [] [] [] |
781- libexif | |
782- libextractor | |
783- libgpewidget | [] |
784- libgpg-error | |
785- libgphoto2 | [] |
786- libgphoto2_port | [] |
787- libgsasl | [] |
788- libiconv | [] |
789- libidn | [] [] |
790- lifelines | [] |
791- lilypond | [] |
792- lingoteach | [] |
793- lprng | |
794- lynx | [] [] |
795- m4 | [] [] |
796- mailfromd | |
797- mailutils | |
798- make | [] [] [] |
799- man-db | |
800- minicom | [] |
801- nano | [] [] [] |
802- opcodes | [] |
803- parted | [] [] |
804- pilot-qof | |
805- popt | [] [] [] |
806- psmisc | [] [] [] |
807- pwdutils | |
808- qof | |
809- radius | |
810- recode | [] |
811- rpm | [] [] |
812- screem | [] |
813- scrollkeeper | [] [] [] [] |
814- sed | [] [] |
815- shared-mime-info | [] [] [] [] [] [] [] |
816- sharutils | [] [] |
817- shishi | |
818- skencil | |
819- solfege | () () |
820- soundtracker | |
821- sp | () |
822- system-tools-ba... | [] [] [] [] |
823- tar | [] [] [] |
824- texinfo | [] [] |
825- tin | |
826- tuxpaint | () [] [] |
827- unicode-han-tra... | |
828- unicode-transla... | |
829- util-linux | [] [] |
830- util-linux-ng | [] [] |
831- vorbis-tools | |
832- wastesedge | [] |
833- wdiff | [] [] |
834- wget | [] [] |
835- xchat | [] [] [] [] |
836- xkeyboard-config | [] [] [] |
837- xpad | [] [] [] |
838- +--------------------------------------------------+
839- ja ka ko ku ky lg lt lv mk mn ms mt nb ne nl nn
840- 51 2 25 3 2 0 6 0 2 2 20 0 11 1 103 6
841-
842- or pa pl pt pt_BR rm ro ru rw sk sl sq sr sv ta
843- +--------------------------------------------------+
844- Compendium | [] [] [] [] [] |
845- a2ps | () [] [] [] [] [] [] |
846- aegis | () () |
847- ant-phone | [] [] |
848- anubis | [] [] [] |
849- ap-utils | () |
850- aspell | [] [] [] |
851- bash | [] [] |
852- bfd | |
853- bibshelf | [] |
854- binutils | [] [] |
855- bison | [] [] [] [] [] |
856- bison-runtime | [] [] [] [] [] |
857- bluez-pin | [] [] [] [] [] [] [] [] [] |
858- cflow | [] |
859- clisp | [] |
860- console-tools | [] |
861- coreutils | [] [] [] [] |
862- cpio | [] [] [] |
863- cpplib | [] |
864- cryptonit | [] [] |
865- dialog | [] |
866- diffutils | [] [] [] [] [] [] |
867- doodle | [] [] |
868- e2fsprogs | [] [] |
869- enscript | [] [] [] [] [] |
870- fetchmail | [] [] [] |
871- findutils | [] [] [] |
872- findutils_stable | [] [] [] [] [] [] |
873- flex | [] [] [] [] [] |
874- fslint | [] |
875- gas | |
876- gawk | [] [] [] [] |
877- gcal | [] |
878- gcc | [] [] |
879- gettext-examples | [] [] [] [] [] [] [] [] |
880- gettext-runtime | [] [] [] [] [] [] [] [] |
881- gettext-tools | [] [] [] [] [] [] [] |
882- gip | [] [] [] [] |
883- gliv | [] [] [] [] [] [] |
884- glunarclock | [] [] [] [] [] [] |
885- gmult | [] [] [] [] |
886- gnubiff | () [] |
887- gnucash | () [] |
888- gnuedu | |
889- gnulib | [] [] [] |
890- gnunet | |
891- gnunet-gtk | [] |
892- gnutls | [] [] |
893- gpe-aerial | [] [] [] [] [] [] [] |
894- gpe-beam | [] [] [] [] [] [] [] |
895- gpe-calendar | [] [] [] [] |
896- gpe-clock | [] [] [] [] [] [] [] [] |
897- gpe-conf | [] [] [] [] [] [] [] |
898- gpe-contacts | [] [] [] [] [] |
899- gpe-edit | [] [] [] [] [] [] [] [] [] |
900- gpe-filemanager | [] [] |
901- gpe-go | [] [] [] [] [] [] [] [] |
902- gpe-login | [] [] [] [] [] [] [] [] |
903- gpe-ownerinfo | [] [] [] [] [] [] [] [] |
904- gpe-package | [] [] |
905- gpe-sketchbook | [] [] [] [] [] [] [] [] |
906- gpe-su | [] [] [] [] [] [] [] [] |
907- gpe-taskmanager | [] [] [] [] [] [] [] [] |
908- gpe-timesheet | [] [] [] [] [] [] [] [] |
909- gpe-today | [] [] [] [] [] [] [] [] |
910- gpe-todo | [] [] [] [] |
911- gphoto2 | [] [] [] [] [] [] |
912- gprof | [] [] [] |
913- gpsdrive | [] [] |
914- gramadoir | [] [] |
915- grep | [] [] [] [] |
916- gretl | [] [] [] |
917- gsasl | [] [] [] |
918- gss | [] [] [] [] |
919- gst-plugins-bad | [] [] [] |
920- gst-plugins-base | [] [] |
921- gst-plugins-good | [] [] |
922- gst-plugins-ugly | [] [] [] |
923- gstreamer | [] [] [] [] |
924- gtick | [] |
925- gtkam | [] [] [] [] [] |
926- gtkorphan | [] |
927- gtkspell | [] [] [] [] [] [] [] [] |
928- gutenprint | [] |
929- hello | [] [] [] [] [] [] [] [] |
930- herrie | [] [] [] |
931- hylafax | |
932- idutils | [] [] [] [] [] |
933- indent | [] [] [] [] [] [] [] |
934- iso_15924 | |
935- iso_3166 | [] [] [] [] [] [] [] [] [] [] [] [] [] |
936- iso_3166_2 | |
937- iso_4217 | [] [] [] [] [] [] [] |
938- iso_639 | [] [] [] [] [] [] [] |
939- jpilot | |
940- jtag | [] |
941- jwhois | [] [] [] [] |
942- kbd | [] [] [] |
943- keytouch | [] |
944- keytouch-editor | [] |
945- keytouch-keyboa... | [] |
946- latrine | |
947- ld | [] |
948- leafpad | [] [] [] [] [] [] |
949- libc | [] [] [] [] |
950- libexif | [] [] |
951- libextractor | [] [] |
952- libgpewidget | [] [] [] [] [] [] [] [] |
953- libgpg-error | [] [] [] |
954- libgphoto2 | [] |
955- libgphoto2_port | [] [] [] |
956- libgsasl | [] [] [] [] |
957- libiconv | [] [] [] |
958- libidn | [] [] () |
959- lifelines | [] [] |
960- lilypond | |
961- lingoteach | [] |
962- lprng | [] |
963- lynx | [] [] [] |
964- m4 | [] [] [] [] [] |
965- mailfromd | [] |
966- mailutils | [] [] [] |
967- make | [] [] [] [] |
968- man-db | [] [] [] [] |
969- minicom | [] [] [] [] [] |
970- nano | [] [] [] [] |
971- opcodes | [] [] |
972- parted | [] |
973- pilot-qof | |
974- popt | [] [] [] [] |
975- psmisc | [] [] |
976- pwdutils | [] [] |
977- qof | [] [] |
978- radius | [] [] |
979- recode | [] [] [] [] [] [] [] |
980- rpm | [] [] [] [] |
981- screem | |
982- scrollkeeper | [] [] [] [] [] [] [] |
983- sed | [] [] [] [] [] [] [] [] [] |
984- shared-mime-info | [] [] [] [] [] [] |
985- sharutils | [] [] [] [] |
986- shishi | [] |
987- skencil | [] [] [] |
988- solfege | [] |
989- soundtracker | [] [] |
990- sp | |
991- system-tools-ba... | [] [] [] [] [] [] [] [] [] |
992- tar | [] [] [] [] |
993- texinfo | [] [] [] [] |
994- tin | () |
995- tuxpaint | [] [] [] [] [] [] |
996- unicode-han-tra... | |
997- unicode-transla... | |
998- util-linux | [] [] [] [] |
999- util-linux-ng | [] [] [] [] |
1000- vorbis-tools | [] |
1001- wastesedge | |
1002- wdiff | [] [] [] [] [] [] [] |
1003- wget | [] [] [] [] |
1004- xchat | [] [] [] [] [] [] [] |
1005- xkeyboard-config | [] [] [] |
1006- xpad | [] [] [] |
1007- +--------------------------------------------------+
1008- or pa pl pt pt_BR rm ro ru rw sk sl sq sr sv ta
1009- 0 5 77 31 53 4 58 72 3 45 46 9 45 122 3
1010-
1011- tg th tk tr uk ven vi wa xh zh_CN zh_HK zh_TW zu
1012- +---------------------------------------------------+
1013- Compendium | [] [] [] [] | 19
1014- a2ps | [] [] [] | 19
1015- aegis | [] | 1
1016- ant-phone | [] [] | 6
1017- anubis | [] [] [] | 11
1018- ap-utils | () [] | 4
1019- aspell | [] [] [] | 16
1020- bash | [] | 6
1021- bfd | | 2
1022- bibshelf | [] | 7
1023- binutils | [] [] [] [] | 9
1024- bison | [] [] [] [] | 20
1025- bison-runtime | [] [] [] [] | 18
1026- bluez-pin | [] [] [] [] [] [] | 28
1027- cflow | [] [] | 5
1028- clisp | | 9
1029- console-tools | [] [] | 5
1030- coreutils | [] [] [] | 18
1031- cpio | [] [] [] [] | 11
1032- cpplib | [] [] [] [] [] | 12
1033- cryptonit | [] | 6
1034- dialog | [] [] [] | 9
1035- diffutils | [] [] [] [] [] | 29
1036- doodle | [] | 6
1037- e2fsprogs | [] [] | 10
1038- enscript | [] [] [] | 16
1039- fetchmail | [] [] | 12
1040- findutils | [] [] [] | 11
1041- findutils_stable | [] [] [] [] | 18
1042- flex | [] [] | 15
1043- fslint | [] | 2
1044- gas | [] | 3
1045- gawk | [] [] [] | 16
1046- gcal | [] | 5
1047- gcc | [] [] [] | 7
1048- gettext-examples | [] [] [] [] [] [] | 29
1049- gettext-runtime | [] [] [] [] [] [] | 28
1050- gettext-tools | [] [] [] [] [] | 20
1051- gip | [] [] | 13
1052- gliv | [] [] | 11
1053- glunarclock | [] [] [] | 15
1054- gmult | [] [] [] [] | 16
1055- gnubiff | [] | 2
1056- gnucash | () [] | 5
1057- gnuedu | [] | 2
1058- gnulib | [] | 10
1059- gnunet | | 0
1060- gnunet-gtk | [] [] | 3
1061- gnutls | | 4
1062- gpe-aerial | [] [] | 14
1063- gpe-beam | [] [] | 14
1064- gpe-calendar | [] [] | 7
1065- gpe-clock | [] [] [] [] | 21
1066- gpe-conf | [] [] [] | 16
1067- gpe-contacts | [] [] | 10
1068- gpe-edit | [] [] [] [] [] | 22
1069- gpe-filemanager | [] [] | 7
1070- gpe-go | [] [] [] [] | 19
1071- gpe-login | [] [] [] [] [] | 21
1072- gpe-ownerinfo | [] [] [] [] | 21
1073- gpe-package | [] | 6
1074- gpe-sketchbook | [] [] | 16
1075- gpe-su | [] [] [] [] | 21
1076- gpe-taskmanager | [] [] [] [] | 21
1077- gpe-timesheet | [] [] [] [] | 18
1078- gpe-today | [] [] [] [] [] | 21
1079- gpe-todo | [] [] | 8
1080- gphoto2 | [] [] [] [] | 21
1081- gprof | [] [] | 13
1082- gpsdrive | [] | 5
1083- gramadoir | [] | 7
1084- grep | [] | 12
1085- gretl | | 6
1086- gsasl | [] [] [] | 9
1087- gss | [] | 7
1088- gst-plugins-bad | [] [] [] | 13
1089- gst-plugins-base | [] [] | 11
1090- gst-plugins-good | [] [] [] [] [] | 16
1091- gst-plugins-ugly | [] [] [] | 13
1092- gstreamer | [] [] [] | 18
1093- gtick | [] [] | 7
1094- gtkam | [] | 16
1095- gtkorphan | [] | 7
1096- gtkspell | [] [] [] [] [] [] | 27
1097- gutenprint | | 4
1098- hello | [] [] [] [] [] | 38
1099- herrie | [] [] | 8
1100- hylafax | | 0
1101- idutils | [] [] | 15
1102- indent | [] [] [] [] [] | 28
1103- iso_15924 | [] [] | 4
1104- iso_3166 | [] [] [] [] [] [] [] [] [] | 54
1105- iso_3166_2 | [] [] | 4
1106- iso_4217 | [] [] [] [] [] | 24
1107- iso_639 | [] [] [] [] [] | 26
1108- jpilot | [] [] [] [] | 7
1109- jtag | [] | 3
1110- jwhois | [] [] [] | 13
1111- kbd | [] [] [] | 13
1112- keytouch | [] | 8
1113- keytouch-editor | [] | 5
1114- keytouch-keyboa... | [] | 5
1115- latrine | [] [] | 5
1116- ld | [] [] [] [] | 10
1117- leafpad | [] [] [] [] [] | 24
1118- libc | [] [] [] | 19
1119- libexif | [] | 5
1120- libextractor | [] | 5
1121- libgpewidget | [] [] [] | 20
1122- libgpg-error | [] | 6
1123- libgphoto2 | [] [] | 9
1124- libgphoto2_port | [] [] [] | 11
1125- libgsasl | [] | 8
1126- libiconv | [] [] | 11
1127- libidn | [] [] | 11
1128- lifelines | | 4
1129- lilypond | [] | 6
1130- lingoteach | [] | 6
1131- lprng | [] | 2
1132- lynx | [] [] [] | 15
1133- m4 | [] [] [] | 18
1134- mailfromd | [] [] | 3
1135- mailutils | [] [] | 8
1136- make | [] [] [] | 20
1137- man-db | [] | 9
1138- minicom | [] | 14
1139- nano | [] [] [] | 20
1140- opcodes | [] [] | 10
1141- parted | [] [] [] | 11
1142- pilot-qof | [] | 1
1143- popt | [] [] [] [] | 18
1144- psmisc | [] [] | 10
1145- pwdutils | [] | 3
1146- qof | [] | 4
1147- radius | [] [] | 7
1148- recode | [] [] [] | 25
1149- rpm | [] [] [] [] | 13
1150- screem | [] | 2
1151- scrollkeeper | [] [] [] [] | 26
1152- sed | [] [] [] [] | 23
1153- shared-mime-info | [] [] [] | 29
1154- sharutils | [] [] [] | 23
1155- shishi | [] | 3
1156- skencil | [] | 7
1157- solfege | [] | 3
1158- soundtracker | [] [] | 9
1159- sp | [] | 3
1160- system-tools-ba... | [] [] [] [] [] [] [] | 38
1161- tar | [] [] [] | 17
1162- texinfo | [] [] [] | 15
1163- tin | | 1
1164- tuxpaint | [] [] [] | 19
1165- unicode-han-tra... | | 0
1166- unicode-transla... | | 2
1167- util-linux | [] [] [] | 20
1168- util-linux-ng | [] [] [] | 20
1169- vorbis-tools | [] [] | 4
1170- wastesedge | | 1
1171- wdiff | [] [] | 23
1172- wget | [] [] [] | 20
1173- xchat | [] [] [] [] | 29
1174- xkeyboard-config | [] [] [] | 14
1175- xpad | [] [] [] | 15
1176- +---------------------------------------------------+
1177- 76 teams tg th tk tr uk ven vi wa xh zh_CN zh_HK zh_TW zu
1178- 163 domains 0 3 1 74 51 0 143 21 1 57 7 45 0 2036
1179-
1180- Some counters in the preceding matrix are higher than the number of
1181-visible blocks let us expect. This is because a few extra PO files are
1182-used for implementing regional variants of languages, or language
1183-dialects.
1184-
1185- For a PO file in the matrix above to be effective, the package to
1186-which it applies should also have been internationalized and
1187-distributed as such by its maintainer. There might be an observable
1188-lag between the mere existence a PO file and its wide availability in a
1189-distribution.
1190-
1191- If November 2007 seems to be old, you may fetch a more recent copy
1192-of this `ABOUT-NLS' file on most GNU archive sites. The most
1193-up-to-date matrix with full percentage details can be found at
1194-`http://translationproject.org/extra/matrix.html'.
1195-
1196-1.6 Using `gettext' in new packages
1197-===================================
1198-
1199-If you are writing a freely available program and want to
1200-internationalize it you are welcome to use GNU `gettext' in your
1201-package. Of course you have to respect the GNU Library General Public
1202-License which covers the use of the GNU `gettext' library. This means
1203-in particular that even non-free programs can use `libintl' as a shared
1204-library, whereas only free software can use `libintl' as a static
1205-library or use modified versions of `libintl'.
1206-
1207- Once the sources are changed appropriately and the setup can handle
1208-the use of `gettext' the only thing missing are the translations. The
1209-Free Translation Project is also available for packages which are not
1210-developed inside the GNU project. Therefore the information given above
1211-applies also for every other Free Software Project. Contact
1212-`coordinator@translationproject.org' to make the `.pot' files available
1213-to the translation teams.
1214-
1215+<https://www.gnu.org/software/gettext/manual/html_node/Users.html>
1216--- a/ChangeLog
1217+++ b/ChangeLog
1218@@ -1,3 +1,10 @@
1219+2019-12-07 gettextize <bug-gnu-gettext@gnu.org>
1220+
1221+ * m4/intlmacosx.m4: Upgrade to gettext-0.20.1.
1222+ * Makefile.am (SUBDIRS): Remove intl.
1223+ * configure.ac (AC_CONFIG_FILES): Remove intl/Makefile.
1224+ (AM_GNU_GETTEXT_VERSION): Bump to 0.20.
1225+
1226 2013-03-13 Steve Langasek <steve.langasek@ubuntu.com>
1227
1228 * nih/watch.c (nih_watch_walk_filter): New NihFileFilter function
1229--- a/Makefile.am
1230+++ b/Makefile.am
1231@@ -1,6 +1,6 @@
1232 ## Process this file with automake to produce Makefile.in
1233
1234-SUBDIRS = m4 intl nih nih-dbus nih-dbus-tool po
1235+SUBDIRS = m4 nih nih-dbus nih-dbus-tool po
1236
1237 EXTRA_DIST = HACKING
1238
1239--- a/configure.ac
1240+++ b/configure.ac
1241@@ -15,8 +15,8 @@ AM_MAINTAINER_MODE([enable])
1242 LT_PREREQ(2.2.4)
1243 LT_INIT
1244
1245-AM_GNU_GETTEXT_VERSION([0.17])
1246-AM_GNU_GETTEXT()
1247+AM_GNU_GETTEXT_VERSION([0.20])
1248+AM_GNU_GETTEXT([external])
1249
1250 # Checks for programs.
1251 AC_PROG_CC
1252@@ -58,7 +58,7 @@ AS_IF([test "$cross_compiling" = "yes"],
1253 AC_SUBST([NIH_DBUS_TOOL], ["\${top_builddir}/nih-dbus-tool/nih-dbus-tool"])])],
1254 [AC_SUBST([NIH_DBUS_TOOL], ["\${top_builddir}/nih-dbus-tool/nih-dbus-tool"])])
1255
1256-AC_CONFIG_FILES([ Makefile m4/Makefile intl/Makefile
1257+AC_CONFIG_FILES([ Makefile m4/Makefile
1258 nih/Makefile nih/libnih.pc
1259 nih-dbus/Makefile nih-dbus/libnih-dbus.pc
1260 nih-dbus-tool/Makefile
1261--- a/intl/ChangeLog
1262+++ /dev/null
1263@@ -1,4 +0,0 @@
1264-2007-11-07 GNU <bug-gnu-gettext@gnu.org>
1265-
1266- * Version 0.17 released.
1267-
1268--- a/intl/Makefile.in
1269+++ /dev/null
1270@@ -1,587 +0,0 @@
1271-# Makefile for directory with message catalog handling library of GNU gettext
1272-# Copyright (C) 1995-1998, 2000-2007 Free Software Foundation, Inc.
1273-#
1274-# This program is free software; you can redistribute it and/or modify it
1275-# under the terms of the GNU Library General Public License as published
1276-# by the Free Software Foundation; either version 2, or (at your option)
1277-# any later version.
1278-#
1279-# This program is distributed in the hope that it will be useful,
1280-# but WITHOUT ANY WARRANTY; without even the implied warranty of
1281-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
1282-# Library General Public License for more details.
1283-#
1284-# You should have received a copy of the GNU Library General Public
1285-# License along with this program; if not, write to the Free Software
1286-# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
1287-# USA.
1288-
1289-PACKAGE = @PACKAGE@
1290-VERSION = @VERSION@
1291-
1292-SHELL = /bin/sh
1293-
1294-srcdir = @srcdir@
1295-top_srcdir = @top_srcdir@
1296-top_builddir = ..
1297-
1298-# The VPATH variables allows builds with $builddir != $srcdir, assuming a
1299-# 'make' program that supports VPATH (such as GNU make). This line is removed
1300-# by autoconf automatically when "$(srcdir)" = ".".
1301-# In this directory, the VPATH handling is particular:
1302-# 1. If INTL_LIBTOOL_SUFFIX_PREFIX is 'l' (indicating a build with libtool),
1303-# the .c -> .lo rules carefully use $(srcdir), so that VPATH can be omitted.
1304-# 2. If PACKAGE = gettext-tools, VPATH _must_ be omitted, because otherwise
1305-# 'make' does the wrong thing if GNU gettext was configured with
1306-# "./configure --srcdir=`pwd`", namely it gets confused by the .lo and .la
1307-# files it finds in srcdir = ../../gettext-runtime/intl.
1308-VPATH = $(srcdir)
1309-
1310-prefix = @prefix@
1311-exec_prefix = @exec_prefix@
1312-transform = @program_transform_name@
1313-libdir = @libdir@
1314-includedir = @includedir@
1315-datarootdir = @datarootdir@
1316-datadir = @datadir@
1317-localedir = $(datadir)/locale
1318-gettextsrcdir = $(datadir)/gettext/intl
1319-aliaspath = $(localedir)
1320-subdir = intl
1321-
1322-INSTALL = @INSTALL@
1323-INSTALL_DATA = @INSTALL_DATA@
1324-
1325-# We use $(mkdir_p).
1326-# In automake <= 1.9.x, $(mkdir_p) is defined either as "mkdir -p --" or as
1327-# "$(mkinstalldirs)" or as "$(install_sh) -d". For these automake versions,
1328-# @install_sh@ does not start with $(SHELL), so we add it.
1329-# In automake >= 1.10, @mkdir_p@ is derived from ${MKDIR_P}, which is defined
1330-# either as "/path/to/mkdir -p" or ".../install-sh -c -d". For these automake
1331-# versions, $(mkinstalldirs) and $(install_sh) are unused.
1332-mkinstalldirs = $(SHELL) @install_sh@ -d
1333-install_sh = $(SHELL) @install_sh@
1334-MKDIR_P = @MKDIR_P@
1335-mkdir_p = @mkdir_p@
1336-
1337-l = @INTL_LIBTOOL_SUFFIX_PREFIX@
1338-
1339-AR = ar
1340-CC = @CC@
1341-LIBTOOL = @LIBTOOL@
1342-RANLIB = @RANLIB@
1343-YACC = @INTLBISON@ -y -d
1344-YFLAGS = --name-prefix=__gettext
1345-WINDRES = @WINDRES@
1346-
1347-# -DBUILDING_LIBINTL: Change expansion of LIBINTL_DLL_EXPORTED macro.
1348-# -DBUILDING_DLL: Change expansion of RELOCATABLE_DLL_EXPORTED macro.
1349-DEFS = -DLOCALEDIR=\"$(localedir)\" -DLOCALE_ALIAS_PATH=\"$(aliaspath)\" \
1350--DLIBDIR=\"$(libdir)\" -DBUILDING_LIBINTL -DBUILDING_DLL -DIN_LIBINTL \
1351--DENABLE_RELOCATABLE=1 -DIN_LIBRARY -DINSTALLDIR=\"$(libdir)\" -DNO_XMALLOC \
1352--Dset_relocation_prefix=libintl_set_relocation_prefix \
1353--Drelocate=libintl_relocate \
1354--DDEPENDS_ON_LIBICONV=1 @DEFS@
1355-CPPFLAGS = @CPPFLAGS@
1356-CFLAGS = @CFLAGS@ @CFLAG_VISIBILITY@
1357-LDFLAGS = @LDFLAGS@ $(LDFLAGS_@WOE32DLL@)
1358-LDFLAGS_yes = -Wl,--export-all-symbols
1359-LDFLAGS_no =
1360-LIBS = @LIBS@
1361-
1362-COMPILE = $(CC) -c $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) $(XCFLAGS)
1363-
1364-HEADERS = \
1365- gmo.h \
1366- gettextP.h \
1367- hash-string.h \
1368- loadinfo.h \
1369- plural-exp.h \
1370- eval-plural.h \
1371- localcharset.h \
1372- lock.h \
1373- relocatable.h \
1374- tsearch.h tsearch.c \
1375- xsize.h \
1376- printf-args.h printf-args.c \
1377- printf-parse.h wprintf-parse.h printf-parse.c \
1378- vasnprintf.h vasnwprintf.h vasnprintf.c \
1379- os2compat.h \
1380- libgnuintl.h.in
1381-SOURCES = \
1382- bindtextdom.c \
1383- dcgettext.c \
1384- dgettext.c \
1385- gettext.c \
1386- finddomain.c \
1387- hash-string.c \
1388- loadmsgcat.c \
1389- localealias.c \
1390- textdomain.c \
1391- l10nflist.c \
1392- explodename.c \
1393- dcigettext.c \
1394- dcngettext.c \
1395- dngettext.c \
1396- ngettext.c \
1397- plural.y \
1398- plural-exp.c \
1399- localcharset.c \
1400- lock.c \
1401- relocatable.c \
1402- langprefs.c \
1403- localename.c \
1404- log.c \
1405- printf.c \
1406- version.c \
1407- osdep.c \
1408- os2compat.c \
1409- intl-exports.c \
1410- intl-compat.c
1411-OBJECTS = \
1412- bindtextdom.$lo \
1413- dcgettext.$lo \
1414- dgettext.$lo \
1415- gettext.$lo \
1416- finddomain.$lo \
1417- hash-string.$lo \
1418- loadmsgcat.$lo \
1419- localealias.$lo \
1420- textdomain.$lo \
1421- l10nflist.$lo \
1422- explodename.$lo \
1423- dcigettext.$lo \
1424- dcngettext.$lo \
1425- dngettext.$lo \
1426- ngettext.$lo \
1427- plural.$lo \
1428- plural-exp.$lo \
1429- localcharset.$lo \
1430- lock.$lo \
1431- relocatable.$lo \
1432- langprefs.$lo \
1433- localename.$lo \
1434- log.$lo \
1435- printf.$lo \
1436- version.$lo \
1437- osdep.$lo \
1438- intl-compat.$lo
1439-OBJECTS_RES_yes = libintl.res
1440-OBJECTS_RES_no =
1441-DISTFILES.common = Makefile.in \
1442-config.charset locale.alias ref-add.sin ref-del.sin export.h libintl.rc \
1443-$(HEADERS) $(SOURCES)
1444-DISTFILES.generated = plural.c
1445-DISTFILES.normal = VERSION
1446-DISTFILES.gettext = COPYING.LIB-2.0 COPYING.LIB-2.1 libintl.glibc README.woe32
1447-DISTFILES.obsolete = xopen-msg.sed linux-msg.sed po2tbl.sed.in cat-compat.c \
1448-COPYING.LIB-2 gettext.h libgettext.h plural-eval.c libgnuintl.h \
1449-libgnuintl.h_vms Makefile.vms libgnuintl.h.msvc-static \
1450-libgnuintl.h.msvc-shared Makefile.msvc
1451-
1452-all: all-@USE_INCLUDED_LIBINTL@
1453-all-yes: libintl.$la libintl.h charset.alias ref-add.sed ref-del.sed
1454-all-no: all-no-@BUILD_INCLUDED_LIBINTL@
1455-all-no-yes: libgnuintl.$la
1456-all-no-no:
1457-
1458-libintl.a libgnuintl.a: $(OBJECTS)
1459- rm -f $@
1460- $(AR) cru $@ $(OBJECTS)
1461- $(RANLIB) $@
1462-
1463-libintl.la libgnuintl.la: $(OBJECTS) $(OBJECTS_RES_@WOE32@)
1464- $(LIBTOOL) --mode=link \
1465- $(CC) $(CPPFLAGS) $(CFLAGS) $(XCFLAGS) $(LDFLAGS) -o $@ \
1466- $(OBJECTS) @LTLIBICONV@ @INTL_MACOSX_LIBS@ $(LIBS) @LTLIBTHREAD@ @LTLIBC@ \
1467- $(OBJECTS_RES_@WOE32@) \
1468- -version-info $(LTV_CURRENT):$(LTV_REVISION):$(LTV_AGE) \
1469- -rpath $(libdir) \
1470- -no-undefined
1471-
1472-# Libtool's library version information for libintl.
1473-# Before making a gettext release, the gettext maintainer must change this
1474-# according to the libtool documentation, section "Library interface versions".
1475-# Maintainers of other packages that include the intl directory must *not*
1476-# change these values.
1477-LTV_CURRENT=8
1478-LTV_REVISION=2
1479-LTV_AGE=0
1480-
1481-.SUFFIXES:
1482-.SUFFIXES: .c .y .o .lo .sin .sed
1483-
1484-.c.o:
1485- $(COMPILE) $<
1486-
1487-.y.c:
1488- $(YACC) $(YFLAGS) --output $@ $<
1489- rm -f $*.h
1490-
1491-bindtextdom.lo: $(srcdir)/bindtextdom.c
1492- $(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/bindtextdom.c
1493-dcgettext.lo: $(srcdir)/dcgettext.c
1494- $(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/dcgettext.c
1495-dgettext.lo: $(srcdir)/dgettext.c
1496- $(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/dgettext.c
1497-gettext.lo: $(srcdir)/gettext.c
1498- $(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/gettext.c
1499-finddomain.lo: $(srcdir)/finddomain.c
1500- $(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/finddomain.c
1501-hash-string.lo: $(srcdir)/hash-string.c
1502- $(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/hash-string.c
1503-loadmsgcat.lo: $(srcdir)/loadmsgcat.c
1504- $(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/loadmsgcat.c
1505-localealias.lo: $(srcdir)/localealias.c
1506- $(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/localealias.c
1507-textdomain.lo: $(srcdir)/textdomain.c
1508- $(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/textdomain.c
1509-l10nflist.lo: $(srcdir)/l10nflist.c
1510- $(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/l10nflist.c
1511-explodename.lo: $(srcdir)/explodename.c
1512- $(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/explodename.c
1513-dcigettext.lo: $(srcdir)/dcigettext.c
1514- $(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/dcigettext.c
1515-dcngettext.lo: $(srcdir)/dcngettext.c
1516- $(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/dcngettext.c
1517-dngettext.lo: $(srcdir)/dngettext.c
1518- $(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/dngettext.c
1519-ngettext.lo: $(srcdir)/ngettext.c
1520- $(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/ngettext.c
1521-plural.lo: $(srcdir)/plural.c
1522- $(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/plural.c
1523-plural-exp.lo: $(srcdir)/plural-exp.c
1524- $(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/plural-exp.c
1525-localcharset.lo: $(srcdir)/localcharset.c
1526- $(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/localcharset.c
1527-lock.lo: $(srcdir)/lock.c
1528- $(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/lock.c
1529-relocatable.lo: $(srcdir)/relocatable.c
1530- $(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/relocatable.c
1531-langprefs.lo: $(srcdir)/langprefs.c
1532- $(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/langprefs.c
1533-localename.lo: $(srcdir)/localename.c
1534- $(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/localename.c
1535-log.lo: $(srcdir)/log.c
1536- $(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/log.c
1537-printf.lo: $(srcdir)/printf.c
1538- $(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/printf.c
1539-version.lo: $(srcdir)/version.c
1540- $(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/version.c
1541-osdep.lo: $(srcdir)/osdep.c
1542- $(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/osdep.c
1543-intl-compat.lo: $(srcdir)/intl-compat.c
1544- $(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/intl-compat.c
1545-
1546-# This rule is executed only on Woe32 systems.
1547-# The following sed expressions come from the windres-options script. They are
1548-# inlined here, so that they can be written in a Makefile without requiring a
1549-# temporary file. They must contain literal newlines rather than semicolons,
1550-# so that they work with the sed-3.02 that is shipped with MSYS. We can use
1551-# GNU bash's $'\n' syntax to obtain such a newline.
1552-libintl.res: $(srcdir)/libintl.rc
1553- nl=$$'\n'; \
1554- sed_extract_major='/^[0-9]/{'$${nl}'s/^\([0-9]*\).*/\1/p'$${nl}q$${nl}'}'$${nl}'c\'$${nl}0$${nl}q; \
1555- sed_extract_minor='/^[0-9][0-9]*[.][0-9]/{'$${nl}'s/^[0-9]*[.]\([0-9]*\).*/\1/p'$${nl}q$${nl}'}'$${nl}'c\'$${nl}0$${nl}q; \
1556- sed_extract_subminor='/^[0-9][0-9]*[.][0-9][0-9]*[.][0-9]/{'$${nl}'s/^[0-9]*[.][0-9]*[.]\([0-9]*\).*/\1/p'$${nl}q$${nl}'}'$${nl}'c\'$${nl}0$${nl}q; \
1557- $(WINDRES) \
1558- "-DPACKAGE_VERSION_STRING=\\\"$(VERSION)\\\"" \
1559- "-DPACKAGE_VERSION_MAJOR="`echo '$(VERSION)' | sed -n -e "$$sed_extract_major"` \
1560- "-DPACKAGE_VERSION_MINOR="`echo '$(VERSION)' | sed -n -e "$$sed_extract_minor"` \
1561- "-DPACKAGE_VERSION_SUBMINOR="`echo '$(VERSION)' | sed -n -e "$$sed_extract_subminor"` \
1562- -i $(srcdir)/libintl.rc -o libintl.res --output-format=coff
1563-
1564-ref-add.sed: $(srcdir)/ref-add.sin
1565- sed -e '/^#/d' -e 's/@''PACKAGE''@/@PACKAGE@/g' $(srcdir)/ref-add.sin > t-ref-add.sed
1566- mv t-ref-add.sed ref-add.sed
1567-ref-del.sed: $(srcdir)/ref-del.sin
1568- sed -e '/^#/d' -e 's/@''PACKAGE''@/@PACKAGE@/g' $(srcdir)/ref-del.sin > t-ref-del.sed
1569- mv t-ref-del.sed ref-del.sed
1570-
1571-INCLUDES = -I. -I$(srcdir) -I..
1572-
1573-libgnuintl.h: $(srcdir)/libgnuintl.h.in
1574- sed -e '/IN_LIBGLOCALE/d' \
1575- -e 's,@''HAVE_POSIX_PRINTF''@,@HAVE_POSIX_PRINTF@,g' \
1576- -e 's,@''HAVE_ASPRINTF''@,@HAVE_ASPRINTF@,g' \
1577- -e 's,@''HAVE_SNPRINTF''@,@HAVE_SNPRINTF@,g' \
1578- -e 's,@''HAVE_WPRINTF''@,@HAVE_WPRINTF@,g' \
1579- < $(srcdir)/libgnuintl.h.in \
1580- | if test '@WOE32DLL@' = yes; then \
1581- sed -e 's/extern \([^()]*\);/extern __declspec (dllimport) \1;/'; \
1582- else \
1583- cat; \
1584- fi \
1585- | sed -e 's/extern \([^"]\)/extern LIBINTL_DLL_EXPORTED \1/' \
1586- -e "/#define _LIBINTL_H/r $(srcdir)/export.h" \
1587- | sed -e 's,@''HAVE_VISIBILITY''@,@HAVE_VISIBILITY@,g' \
1588- > libgnuintl.h
1589-
1590-libintl.h: $(srcdir)/libgnuintl.h.in
1591- sed -e '/IN_LIBGLOCALE/d' \
1592- -e 's,@''HAVE_POSIX_PRINTF''@,@HAVE_POSIX_PRINTF@,g' \
1593- -e 's,@''HAVE_ASPRINTF''@,@HAVE_ASPRINTF@,g' \
1594- -e 's,@''HAVE_SNPRINTF''@,@HAVE_SNPRINTF@,g' \
1595- -e 's,@''HAVE_WPRINTF''@,@HAVE_WPRINTF@,g' \
1596- < $(srcdir)/libgnuintl.h.in > libintl.h
1597-
1598-charset.alias: $(srcdir)/config.charset
1599- $(SHELL) $(srcdir)/config.charset '@host@' > t-$@
1600- mv t-$@ $@
1601-
1602-check: all
1603-
1604-# We must not install the libintl.h/libintl.a files if we are on a
1605-# system which has the GNU gettext() function in its C library or in a
1606-# separate library.
1607-# If you want to use the one which comes with this version of the
1608-# package, you have to use `configure --with-included-gettext'.
1609-install: install-exec install-data
1610-install-exec: all
1611- if { test "$(PACKAGE)" = "gettext-runtime" || test "$(PACKAGE)" = "gettext-tools"; } \
1612- && test '@USE_INCLUDED_LIBINTL@' = yes; then \
1613- $(mkdir_p) $(DESTDIR)$(libdir) $(DESTDIR)$(includedir); \
1614- $(INSTALL_DATA) libintl.h $(DESTDIR)$(includedir)/libintl.h; \
1615- $(LIBTOOL) --mode=install \
1616- $(INSTALL_DATA) libintl.$la $(DESTDIR)$(libdir)/libintl.$la; \
1617- if test "@RELOCATABLE@" = yes; then \
1618- dependencies=`sed -n -e 's,^dependency_libs=\(.*\),\1,p' < $(DESTDIR)$(libdir)/libintl.la | sed -e "s,^',," -e "s,'\$$,,"`; \
1619- if test -n "$$dependencies"; then \
1620- rm -f $(DESTDIR)$(libdir)/libintl.la; \
1621- fi; \
1622- fi; \
1623- else \
1624- : ; \
1625- fi
1626- if test "$(PACKAGE)" = "gettext-tools" \
1627- && test '@USE_INCLUDED_LIBINTL@' = no \
1628- && test @GLIBC2@ != no; then \
1629- $(mkdir_p) $(DESTDIR)$(libdir); \
1630- $(LIBTOOL) --mode=install \
1631- $(INSTALL_DATA) libgnuintl.$la $(DESTDIR)$(libdir)/libgnuintl.$la; \
1632- rm -f $(DESTDIR)$(libdir)/preloadable_libintl.so; \
1633- $(INSTALL_DATA) $(DESTDIR)$(libdir)/libgnuintl.so $(DESTDIR)$(libdir)/preloadable_libintl.so; \
1634- $(LIBTOOL) --mode=uninstall \
1635- rm -f $(DESTDIR)$(libdir)/libgnuintl.$la; \
1636- else \
1637- : ; \
1638- fi
1639- if test '@USE_INCLUDED_LIBINTL@' = yes; then \
1640- test @GLIBC21@ != no || $(mkdir_p) $(DESTDIR)$(libdir); \
1641- temp=$(DESTDIR)$(libdir)/t-charset.alias; \
1642- dest=$(DESTDIR)$(libdir)/charset.alias; \
1643- if test -f $(DESTDIR)$(libdir)/charset.alias; then \
1644- orig=$(DESTDIR)$(libdir)/charset.alias; \
1645- sed -f ref-add.sed $$orig > $$temp; \
1646- $(INSTALL_DATA) $$temp $$dest; \
1647- rm -f $$temp; \
1648- else \
1649- if test @GLIBC21@ = no; then \
1650- orig=charset.alias; \
1651- sed -f ref-add.sed $$orig > $$temp; \
1652- $(INSTALL_DATA) $$temp $$dest; \
1653- rm -f $$temp; \
1654- fi; \
1655- fi; \
1656- $(mkdir_p) $(DESTDIR)$(localedir); \
1657- test -f $(DESTDIR)$(localedir)/locale.alias \
1658- && orig=$(DESTDIR)$(localedir)/locale.alias \
1659- || orig=$(srcdir)/locale.alias; \
1660- temp=$(DESTDIR)$(localedir)/t-locale.alias; \
1661- dest=$(DESTDIR)$(localedir)/locale.alias; \
1662- sed -f ref-add.sed $$orig > $$temp; \
1663- $(INSTALL_DATA) $$temp $$dest; \
1664- rm -f $$temp; \
1665- else \
1666- : ; \
1667- fi
1668-install-data: all
1669- if test "$(PACKAGE)" = "gettext-tools"; then \
1670- $(mkdir_p) $(DESTDIR)$(gettextsrcdir); \
1671- $(INSTALL_DATA) VERSION $(DESTDIR)$(gettextsrcdir)/VERSION; \
1672- $(INSTALL_DATA) ChangeLog.inst $(DESTDIR)$(gettextsrcdir)/ChangeLog; \
1673- dists="COPYING.LIB-2.0 COPYING.LIB-2.1 $(DISTFILES.common)"; \
1674- for file in $$dists; do \
1675- $(INSTALL_DATA) $(srcdir)/$$file \
1676- $(DESTDIR)$(gettextsrcdir)/$$file; \
1677- done; \
1678- chmod a+x $(DESTDIR)$(gettextsrcdir)/config.charset; \
1679- dists="$(DISTFILES.generated)"; \
1680- for file in $$dists; do \
1681- if test -f $$file; then dir=.; else dir=$(srcdir); fi; \
1682- $(INSTALL_DATA) $$dir/$$file \
1683- $(DESTDIR)$(gettextsrcdir)/$$file; \
1684- done; \
1685- dists="$(DISTFILES.obsolete)"; \
1686- for file in $$dists; do \
1687- rm -f $(DESTDIR)$(gettextsrcdir)/$$file; \
1688- done; \
1689- else \
1690- : ; \
1691- fi
1692-
1693-install-strip: install
1694-
1695-install-dvi install-html install-info install-ps install-pdf:
1696-
1697-installdirs:
1698- if { test "$(PACKAGE)" = "gettext-runtime" || test "$(PACKAGE)" = "gettext-tools"; } \
1699- && test '@USE_INCLUDED_LIBINTL@' = yes; then \
1700- $(mkdir_p) $(DESTDIR)$(libdir) $(DESTDIR)$(includedir); \
1701- else \
1702- : ; \
1703- fi
1704- if test "$(PACKAGE)" = "gettext-tools" \
1705- && test '@USE_INCLUDED_LIBINTL@' = no \
1706- && test @GLIBC2@ != no; then \
1707- $(mkdir_p) $(DESTDIR)$(libdir); \
1708- else \
1709- : ; \
1710- fi
1711- if test '@USE_INCLUDED_LIBINTL@' = yes; then \
1712- test @GLIBC21@ != no || $(mkdir_p) $(DESTDIR)$(libdir); \
1713- $(mkdir_p) $(DESTDIR)$(localedir); \
1714- else \
1715- : ; \
1716- fi
1717- if test "$(PACKAGE)" = "gettext-tools"; then \
1718- $(mkdir_p) $(DESTDIR)$(gettextsrcdir); \
1719- else \
1720- : ; \
1721- fi
1722-
1723-# Define this as empty until I found a useful application.
1724-installcheck:
1725-
1726-uninstall:
1727- if { test "$(PACKAGE)" = "gettext-runtime" || test "$(PACKAGE)" = "gettext-tools"; } \
1728- && test '@USE_INCLUDED_LIBINTL@' = yes; then \
1729- rm -f $(DESTDIR)$(includedir)/libintl.h; \
1730- $(LIBTOOL) --mode=uninstall \
1731- rm -f $(DESTDIR)$(libdir)/libintl.$la; \
1732- else \
1733- : ; \
1734- fi
1735- if test "$(PACKAGE)" = "gettext-tools" \
1736- && test '@USE_INCLUDED_LIBINTL@' = no \
1737- && test @GLIBC2@ != no; then \
1738- rm -f $(DESTDIR)$(libdir)/preloadable_libintl.so; \
1739- else \
1740- : ; \
1741- fi
1742- if test '@USE_INCLUDED_LIBINTL@' = yes; then \
1743- if test -f $(DESTDIR)$(libdir)/charset.alias; then \
1744- temp=$(DESTDIR)$(libdir)/t-charset.alias; \
1745- dest=$(DESTDIR)$(libdir)/charset.alias; \
1746- sed -f ref-del.sed $$dest > $$temp; \
1747- if grep '^# Packages using this file: $$' $$temp > /dev/null; then \
1748- rm -f $$dest; \
1749- else \
1750- $(INSTALL_DATA) $$temp $$dest; \
1751- fi; \
1752- rm -f $$temp; \
1753- fi; \
1754- if test -f $(DESTDIR)$(localedir)/locale.alias; then \
1755- temp=$(DESTDIR)$(localedir)/t-locale.alias; \
1756- dest=$(DESTDIR)$(localedir)/locale.alias; \
1757- sed -f ref-del.sed $$dest > $$temp; \
1758- if grep '^# Packages using this file: $$' $$temp > /dev/null; then \
1759- rm -f $$dest; \
1760- else \
1761- $(INSTALL_DATA) $$temp $$dest; \
1762- fi; \
1763- rm -f $$temp; \
1764- fi; \
1765- else \
1766- : ; \
1767- fi
1768- if test "$(PACKAGE)" = "gettext-tools"; then \
1769- for file in VERSION ChangeLog COPYING.LIB-2.0 COPYING.LIB-2.1 $(DISTFILES.common) $(DISTFILES.generated); do \
1770- rm -f $(DESTDIR)$(gettextsrcdir)/$$file; \
1771- done; \
1772- else \
1773- : ; \
1774- fi
1775-
1776-info dvi ps pdf html:
1777-
1778-$(OBJECTS): ../config.h libgnuintl.h
1779-bindtextdom.$lo dcgettext.$lo dcigettext.$lo dcngettext.$lo dgettext.$lo dngettext.$lo finddomain.$lo gettext.$lo intl-compat.$lo loadmsgcat.$lo localealias.$lo ngettext.$lo textdomain.$lo: $(srcdir)/gettextP.h $(srcdir)/gmo.h $(srcdir)/loadinfo.h
1780-hash-string.$lo dcigettext.$lo loadmsgcat.$lo: $(srcdir)/hash-string.h
1781-explodename.$lo l10nflist.$lo: $(srcdir)/loadinfo.h
1782-dcigettext.$lo loadmsgcat.$lo plural.$lo plural-exp.$lo: $(srcdir)/plural-exp.h
1783-dcigettext.$lo: $(srcdir)/eval-plural.h
1784-localcharset.$lo: $(srcdir)/localcharset.h
1785-bindtextdom.$lo dcigettext.$lo finddomain.$lo loadmsgcat.$lo localealias.$lo lock.$lo log.$lo: $(srcdir)/lock.h
1786-localealias.$lo localcharset.$lo relocatable.$lo: $(srcdir)/relocatable.h
1787-printf.$lo: $(srcdir)/printf-args.h $(srcdir)/printf-args.c $(srcdir)/printf-parse.h $(srcdir)/wprintf-parse.h $(srcdir)/xsize.h $(srcdir)/printf-parse.c $(srcdir)/vasnprintf.h $(srcdir)/vasnwprintf.h $(srcdir)/vasnprintf.c
1788-
1789-# A bison-2.1 generated plural.c includes <libintl.h> if ENABLE_NLS.
1790-PLURAL_DEPS_yes = libintl.h
1791-PLURAL_DEPS_no =
1792-plural.$lo: $(PLURAL_DEPS_@USE_INCLUDED_LIBINTL@)
1793-
1794-tags: TAGS
1795-
1796-TAGS: $(HEADERS) $(SOURCES)
1797- here=`pwd`; cd $(srcdir) && etags -o $$here/TAGS $(HEADERS) $(SOURCES)
1798-
1799-ctags: CTAGS
1800-
1801-CTAGS: $(HEADERS) $(SOURCES)
1802- here=`pwd`; cd $(srcdir) && ctags -o $$here/CTAGS $(HEADERS) $(SOURCES)
1803-
1804-id: ID
1805-
1806-ID: $(HEADERS) $(SOURCES)
1807- here=`pwd`; cd $(srcdir) && mkid -f$$here/ID $(HEADERS) $(SOURCES)
1808-
1809-
1810-mostlyclean:
1811- rm -f *.a *.la *.o *.obj *.lo libintl.res core core.*
1812- rm -f libgnuintl.h libintl.h charset.alias ref-add.sed ref-del.sed
1813- rm -f -r .libs _libs
1814-
1815-clean: mostlyclean
1816-
1817-distclean: clean
1818- rm -f Makefile ID TAGS
1819- if test "$(PACKAGE)" = "gettext-runtime" || test "$(PACKAGE)" = "gettext-tools"; then \
1820- rm -f ChangeLog.inst $(DISTFILES.normal); \
1821- else \
1822- : ; \
1823- fi
1824-
1825-maintainer-clean: distclean
1826- @echo "This command is intended for maintainers to use;"
1827- @echo "it deletes files that may require special tools to rebuild."
1828-
1829-
1830-# GNU gettext needs not contain the file `VERSION' but contains some
1831-# other files which should not be distributed in other packages.
1832-distdir = ../$(PACKAGE)-$(VERSION)/$(subdir)
1833-dist distdir: Makefile
1834- if test "$(PACKAGE)" = "gettext-tools"; then \
1835- : ; \
1836- else \
1837- if test "$(PACKAGE)" = "gettext-runtime"; then \
1838- additional="$(DISTFILES.gettext)"; \
1839- else \
1840- additional="$(DISTFILES.normal)"; \
1841- fi; \
1842- $(MAKE) $(DISTFILES.common) $(DISTFILES.generated) $$additional; \
1843- for file in ChangeLog $(DISTFILES.common) $(DISTFILES.generated) $$additional; do \
1844- if test -f $$file; then dir=.; else dir=$(srcdir); fi; \
1845- cp -p $$dir/$$file $(distdir) || test $$file = Makefile.in || exit 1; \
1846- done; \
1847- fi
1848-
1849-Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
1850- cd $(top_builddir) && $(SHELL) ./config.status
1851-# This would be more efficient, but doesn't work any more with autoconf-2.57,
1852-# when AC_CONFIG_FILES([intl/Makefile:somedir/Makefile.in]) is used.
1853-# cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@
1854-
1855-# Tell versions [3.59,3.63) of GNU make not to export all variables.
1856-# Otherwise a system limit (for SysV at least) may be exceeded.
1857-.NOEXPORT:
1858--- a/intl/VERSION
1859+++ /dev/null
1860@@ -1 +0,0 @@
1861-GNU gettext library from gettext-0.17
1862--- a/intl/bindtextdom.c
1863+++ /dev/null
1864@@ -1,340 +0,0 @@
1865-/* Implementation of the bindtextdomain(3) function
1866- Copyright (C) 1995-1998, 2000-2003, 2005-2006 Free Software Foundation, Inc.
1867-
1868- This program is free software; you can redistribute it and/or modify it
1869- under the terms of the GNU Library General Public License as published
1870- by the Free Software Foundation; either version 2, or (at your option)
1871- any later version.
1872-
1873- This program is distributed in the hope that it will be useful,
1874- but WITHOUT ANY WARRANTY; without even the implied warranty of
1875- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
1876- Library General Public License for more details.
1877-
1878- You should have received a copy of the GNU Library General Public
1879- License along with this program; if not, write to the Free Software
1880- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
1881- USA. */
1882-
1883-#ifdef HAVE_CONFIG_H
1884-# include <config.h>
1885-#endif
1886-
1887-#include <stddef.h>
1888-#include <stdlib.h>
1889-#include <string.h>
1890-
1891-#include "gettextP.h"
1892-#ifdef _LIBC
1893-# include <libintl.h>
1894-#else
1895-# include "libgnuintl.h"
1896-#endif
1897-
1898-/* Handle multi-threaded applications. */
1899-#ifdef _LIBC
1900-# include <bits/libc-lock.h>
1901-# define gl_rwlock_define __libc_rwlock_define
1902-# define gl_rwlock_wrlock __libc_rwlock_wrlock
1903-# define gl_rwlock_unlock __libc_rwlock_unlock
1904-#else
1905-# include "lock.h"
1906-#endif
1907-
1908-/* Some compilers, like SunOS4 cc, don't have offsetof in <stddef.h>. */
1909-#ifndef offsetof
1910-# define offsetof(type,ident) ((size_t)&(((type*)0)->ident))
1911-#endif
1912-
1913-/* @@ end of prolog @@ */
1914-
1915-/* Lock variable to protect the global data in the gettext implementation. */
1916-gl_rwlock_define (extern, _nl_state_lock attribute_hidden)
1917-
1918-
1919-/* Names for the libintl functions are a problem. They must not clash
1920- with existing names and they should follow ANSI C. But this source
1921- code is also used in GNU C Library where the names have a __
1922- prefix. So we have to make a difference here. */
1923-#ifdef _LIBC
1924-# define BINDTEXTDOMAIN __bindtextdomain
1925-# define BIND_TEXTDOMAIN_CODESET __bind_textdomain_codeset
1926-# ifndef strdup
1927-# define strdup(str) __strdup (str)
1928-# endif
1929-#else
1930-# define BINDTEXTDOMAIN libintl_bindtextdomain
1931-# define BIND_TEXTDOMAIN_CODESET libintl_bind_textdomain_codeset
1932-#endif
1933-
1934-/* Specifies the directory name *DIRNAMEP and the output codeset *CODESETP
1935- to be used for the DOMAINNAME message catalog.
1936- If *DIRNAMEP or *CODESETP is NULL, the corresponding attribute is not
1937- modified, only the current value is returned.
1938- If DIRNAMEP or CODESETP is NULL, the corresponding attribute is neither
1939- modified nor returned. */
1940-static void
1941-set_binding_values (const char *domainname,
1942- const char **dirnamep, const char **codesetp)
1943-{
1944- struct binding *binding;
1945- int modified;
1946-
1947- /* Some sanity checks. */
1948- if (domainname == NULL || domainname[0] == '\0')
1949- {
1950- if (dirnamep)
1951- *dirnamep = NULL;
1952- if (codesetp)
1953- *codesetp = NULL;
1954- return;
1955- }
1956-
1957- gl_rwlock_wrlock (_nl_state_lock);
1958-
1959- modified = 0;
1960-
1961- for (binding = _nl_domain_bindings; binding != NULL; binding = binding->next)
1962- {
1963- int compare = strcmp (domainname, binding->domainname);
1964- if (compare == 0)
1965- /* We found it! */
1966- break;
1967- if (compare < 0)
1968- {
1969- /* It is not in the list. */
1970- binding = NULL;
1971- break;
1972- }
1973- }
1974-
1975- if (binding != NULL)
1976- {
1977- if (dirnamep)
1978- {
1979- const char *dirname = *dirnamep;
1980-
1981- if (dirname == NULL)
1982- /* The current binding has be to returned. */
1983- *dirnamep = binding->dirname;
1984- else
1985- {
1986- /* The domain is already bound. If the new value and the old
1987- one are equal we simply do nothing. Otherwise replace the
1988- old binding. */
1989- char *result = binding->dirname;
1990- if (strcmp (dirname, result) != 0)
1991- {
1992- if (strcmp (dirname, _nl_default_dirname) == 0)
1993- result = (char *) _nl_default_dirname;
1994- else
1995- {
1996-#if defined _LIBC || defined HAVE_STRDUP
1997- result = strdup (dirname);
1998-#else
1999- size_t len = strlen (dirname) + 1;
2000- result = (char *) malloc (len);
2001- if (__builtin_expect (result != NULL, 1))
2002- memcpy (result, dirname, len);
2003-#endif
2004- }
2005-
2006- if (__builtin_expect (result != NULL, 1))
2007- {
2008- if (binding->dirname != _nl_default_dirname)
2009- free (binding->dirname);
2010-
2011- binding->dirname = result;
2012- modified = 1;
2013- }
2014- }
2015- *dirnamep = result;
2016- }
2017- }
2018-
2019- if (codesetp)
2020- {
2021- const char *codeset = *codesetp;
2022-
2023- if (codeset == NULL)
2024- /* The current binding has be to returned. */
2025- *codesetp = binding->codeset;
2026- else
2027- {
2028- /* The domain is already bound. If the new value and the old
2029- one are equal we simply do nothing. Otherwise replace the
2030- old binding. */
2031- char *result = binding->codeset;
2032- if (result == NULL || strcmp (codeset, result) != 0)
2033- {
2034-#if defined _LIBC || defined HAVE_STRDUP
2035- result = strdup (codeset);
2036-#else
2037- size_t len = strlen (codeset) + 1;
2038- result = (char *) malloc (len);
2039- if (__builtin_expect (result != NULL, 1))
2040- memcpy (result, codeset, len);
2041-#endif
2042-
2043- if (__builtin_expect (result != NULL, 1))
2044- {
2045- if (binding->codeset != NULL)
2046- free (binding->codeset);
2047-
2048- binding->codeset = result;
2049- modified = 1;
2050- }
2051- }
2052- *codesetp = result;
2053- }
2054- }
2055- }
2056- else if ((dirnamep == NULL || *dirnamep == NULL)
2057- && (codesetp == NULL || *codesetp == NULL))
2058- {
2059- /* Simply return the default values. */
2060- if (dirnamep)
2061- *dirnamep = _nl_default_dirname;
2062- if (codesetp)
2063- *codesetp = NULL;
2064- }
2065- else
2066- {
2067- /* We have to create a new binding. */
2068- size_t len = strlen (domainname) + 1;
2069- struct binding *new_binding =
2070- (struct binding *) malloc (offsetof (struct binding, domainname) + len);
2071-
2072- if (__builtin_expect (new_binding == NULL, 0))
2073- goto failed;
2074-
2075- memcpy (new_binding->domainname, domainname, len);
2076-
2077- if (dirnamep)
2078- {
2079- const char *dirname = *dirnamep;
2080-
2081- if (dirname == NULL)
2082- /* The default value. */
2083- dirname = _nl_default_dirname;
2084- else
2085- {
2086- if (strcmp (dirname, _nl_default_dirname) == 0)
2087- dirname = _nl_default_dirname;
2088- else
2089- {
2090- char *result;
2091-#if defined _LIBC || defined HAVE_STRDUP
2092- result = strdup (dirname);
2093- if (__builtin_expect (result == NULL, 0))
2094- goto failed_dirname;
2095-#else
2096- size_t len = strlen (dirname) + 1;
2097- result = (char *) malloc (len);
2098- if (__builtin_expect (result == NULL, 0))
2099- goto failed_dirname;
2100- memcpy (result, dirname, len);
2101-#endif
2102- dirname = result;
2103- }
2104- }
2105- *dirnamep = dirname;
2106- new_binding->dirname = (char *) dirname;
2107- }
2108- else
2109- /* The default value. */
2110- new_binding->dirname = (char *) _nl_default_dirname;
2111-
2112- if (codesetp)
2113- {
2114- const char *codeset = *codesetp;
2115-
2116- if (codeset != NULL)
2117- {
2118- char *result;
2119-
2120-#if defined _LIBC || defined HAVE_STRDUP
2121- result = strdup (codeset);
2122- if (__builtin_expect (result == NULL, 0))
2123- goto failed_codeset;
2124-#else
2125- size_t len = strlen (codeset) + 1;
2126- result = (char *) malloc (len);
2127- if (__builtin_expect (result == NULL, 0))
2128- goto failed_codeset;
2129- memcpy (result, codeset, len);
2130-#endif
2131- codeset = result;
2132- }
2133- *codesetp = codeset;
2134- new_binding->codeset = (char *) codeset;
2135- }
2136- else
2137- new_binding->codeset = NULL;
2138-
2139- /* Now enqueue it. */
2140- if (_nl_domain_bindings == NULL
2141- || strcmp (domainname, _nl_domain_bindings->domainname) < 0)
2142- {
2143- new_binding->next = _nl_domain_bindings;
2144- _nl_domain_bindings = new_binding;
2145- }
2146- else
2147- {
2148- binding = _nl_domain_bindings;
2149- while (binding->next != NULL
2150- && strcmp (domainname, binding->next->domainname) > 0)
2151- binding = binding->next;
2152-
2153- new_binding->next = binding->next;
2154- binding->next = new_binding;
2155- }
2156-
2157- modified = 1;
2158-
2159- /* Here we deal with memory allocation failures. */
2160- if (0)
2161- {
2162- failed_codeset:
2163- if (new_binding->dirname != _nl_default_dirname)
2164- free (new_binding->dirname);
2165- failed_dirname:
2166- free (new_binding);
2167- failed:
2168- if (dirnamep)
2169- *dirnamep = NULL;
2170- if (codesetp)
2171- *codesetp = NULL;
2172- }
2173- }
2174-
2175- /* If we modified any binding, we flush the caches. */
2176- if (modified)
2177- ++_nl_msg_cat_cntr;
2178-
2179- gl_rwlock_unlock (_nl_state_lock);
2180-}
2181-
2182-/* Specify that the DOMAINNAME message catalog will be found
2183- in DIRNAME rather than in the system locale data base. */
2184-char *
2185-BINDTEXTDOMAIN (const char *domainname, const char *dirname)
2186-{
2187- set_binding_values (domainname, &dirname, NULL);
2188- return (char *) dirname;
2189-}
2190-
2191-/* Specify the character encoding in which the messages from the
2192- DOMAINNAME message catalog will be returned. */
2193-char *
2194-BIND_TEXTDOMAIN_CODESET (const char *domainname, const char *codeset)
2195-{
2196- set_binding_values (domainname, NULL, &codeset);
2197- return (char *) codeset;
2198-}
2199-
2200-#ifdef _LIBC
2201-/* Aliases for function names in GNU C Library. */
2202-weak_alias (__bindtextdomain, bindtextdomain);
2203-weak_alias (__bind_textdomain_codeset, bind_textdomain_codeset);
2204-#endif
2205--- a/intl/config.charset
2206+++ /dev/null
2207@@ -1,640 +0,0 @@
2208-#! /bin/sh
2209-# Output a system dependent table of character encoding aliases.
2210-#
2211-# Copyright (C) 2000-2004, 2006 Free Software Foundation, Inc.
2212-#
2213-# This program is free software; you can redistribute it and/or modify it
2214-# under the terms of the GNU Library General Public License as published
2215-# by the Free Software Foundation; either version 2, or (at your option)
2216-# any later version.
2217-#
2218-# This program is distributed in the hope that it will be useful,
2219-# but WITHOUT ANY WARRANTY; without even the implied warranty of
2220-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
2221-# Library General Public License for more details.
2222-#
2223-# You should have received a copy of the GNU Library General Public
2224-# License along with this program; if not, write to the Free Software
2225-# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
2226-# USA.
2227-#
2228-# The table consists of lines of the form
2229-# ALIAS CANONICAL
2230-#
2231-# ALIAS is the (system dependent) result of "nl_langinfo (CODESET)".
2232-# ALIAS is compared in a case sensitive way.
2233-#
2234-# CANONICAL is the GNU canonical name for this character encoding.
2235-# It must be an encoding supported by libiconv. Support by GNU libc is
2236-# also desirable. CANONICAL is case insensitive. Usually an upper case
2237-# MIME charset name is preferred.
2238-# The current list of GNU canonical charset names is as follows.
2239-#
2240-# name MIME? used by which systems
2241-# ASCII, ANSI_X3.4-1968 glibc solaris freebsd netbsd darwin
2242-# ISO-8859-1 Y glibc aix hpux irix osf solaris freebsd netbsd darwin
2243-# ISO-8859-2 Y glibc aix hpux irix osf solaris freebsd netbsd darwin
2244-# ISO-8859-3 Y glibc solaris
2245-# ISO-8859-4 Y osf solaris freebsd netbsd darwin
2246-# ISO-8859-5 Y glibc aix hpux irix osf solaris freebsd netbsd darwin
2247-# ISO-8859-6 Y glibc aix hpux solaris
2248-# ISO-8859-7 Y glibc aix hpux irix osf solaris netbsd darwin
2249-# ISO-8859-8 Y glibc aix hpux osf solaris
2250-# ISO-8859-9 Y glibc aix hpux irix osf solaris darwin
2251-# ISO-8859-13 glibc netbsd darwin
2252-# ISO-8859-14 glibc
2253-# ISO-8859-15 glibc aix osf solaris freebsd darwin
2254-# KOI8-R Y glibc solaris freebsd netbsd darwin
2255-# KOI8-U Y glibc freebsd netbsd darwin
2256-# KOI8-T glibc
2257-# CP437 dos
2258-# CP775 dos
2259-# CP850 aix osf dos
2260-# CP852 dos
2261-# CP855 dos
2262-# CP856 aix
2263-# CP857 dos
2264-# CP861 dos
2265-# CP862 dos
2266-# CP864 dos
2267-# CP865 dos
2268-# CP866 freebsd netbsd darwin dos
2269-# CP869 dos
2270-# CP874 woe32 dos
2271-# CP922 aix
2272-# CP932 aix woe32 dos
2273-# CP943 aix
2274-# CP949 osf woe32 dos
2275-# CP950 woe32 dos
2276-# CP1046 aix
2277-# CP1124 aix
2278-# CP1125 dos
2279-# CP1129 aix
2280-# CP1250 woe32
2281-# CP1251 glibc solaris netbsd darwin woe32
2282-# CP1252 aix woe32
2283-# CP1253 woe32
2284-# CP1254 woe32
2285-# CP1255 glibc woe32
2286-# CP1256 woe32
2287-# CP1257 woe32
2288-# GB2312 Y glibc aix hpux irix solaris freebsd netbsd darwin
2289-# EUC-JP Y glibc aix hpux irix osf solaris freebsd netbsd darwin
2290-# EUC-KR Y glibc aix hpux irix osf solaris freebsd netbsd darwin
2291-# EUC-TW glibc aix hpux irix osf solaris netbsd
2292-# BIG5 Y glibc aix hpux osf solaris freebsd netbsd darwin
2293-# BIG5-HKSCS glibc solaris
2294-# GBK glibc aix osf solaris woe32 dos
2295-# GB18030 glibc solaris netbsd
2296-# SHIFT_JIS Y hpux osf solaris freebsd netbsd darwin
2297-# JOHAB glibc solaris woe32
2298-# TIS-620 glibc aix hpux osf solaris
2299-# VISCII Y glibc
2300-# TCVN5712-1 glibc
2301-# GEORGIAN-PS glibc
2302-# HP-ROMAN8 hpux
2303-# HP-ARABIC8 hpux
2304-# HP-GREEK8 hpux
2305-# HP-HEBREW8 hpux
2306-# HP-TURKISH8 hpux
2307-# HP-KANA8 hpux
2308-# DEC-KANJI osf
2309-# DEC-HANYU osf
2310-# UTF-8 Y glibc aix hpux osf solaris netbsd darwin
2311-#
2312-# Note: Names which are not marked as being a MIME name should not be used in
2313-# Internet protocols for information interchange (mail, news, etc.).
2314-#
2315-# Note: ASCII and ANSI_X3.4-1968 are synonymous canonical names. Applications
2316-# must understand both names and treat them as equivalent.
2317-#
2318-# The first argument passed to this file is the canonical host specification,
2319-# CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM
2320-# or
2321-# CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM
2322-
2323-host="$1"
2324-os=`echo "$host" | sed -e 's/^[^-]*-[^-]*-\(.*\)$/\1/'`
2325-echo "# This file contains a table of character encoding aliases,"
2326-echo "# suitable for operating system '${os}'."
2327-echo "# It was automatically generated from config.charset."
2328-# List of references, updated during installation:
2329-echo "# Packages using this file: "
2330-case "$os" in
2331- linux-gnulibc1*)
2332- # Linux libc5 doesn't have nl_langinfo(CODESET); therefore
2333- # localcharset.c falls back to using the full locale name
2334- # from the environment variables.
2335- echo "C ASCII"
2336- echo "POSIX ASCII"
2337- for l in af af_ZA ca ca_ES da da_DK de de_AT de_BE de_CH de_DE de_LU \
2338- en en_AU en_BW en_CA en_DK en_GB en_IE en_NZ en_US en_ZA \
2339- en_ZW es es_AR es_BO es_CL es_CO es_DO es_EC es_ES es_GT \
2340- es_HN es_MX es_PA es_PE es_PY es_SV es_US es_UY es_VE et \
2341- et_EE eu eu_ES fi fi_FI fo fo_FO fr fr_BE fr_CA fr_CH fr_FR \
2342- fr_LU ga ga_IE gl gl_ES id id_ID in in_ID is is_IS it it_CH \
2343- it_IT kl kl_GL nl nl_BE nl_NL no no_NO pt pt_BR pt_PT sv \
2344- sv_FI sv_SE; do
2345- echo "$l ISO-8859-1"
2346- echo "$l.iso-8859-1 ISO-8859-1"
2347- echo "$l.iso-8859-15 ISO-8859-15"
2348- echo "$l.iso-8859-15@euro ISO-8859-15"
2349- echo "$l@euro ISO-8859-15"
2350- echo "$l.cp-437 CP437"
2351- echo "$l.cp-850 CP850"
2352- echo "$l.cp-1252 CP1252"
2353- echo "$l.cp-1252@euro CP1252"
2354- #echo "$l.atari-st ATARI-ST" # not a commonly used encoding
2355- echo "$l.utf-8 UTF-8"
2356- echo "$l.utf-8@euro UTF-8"
2357- done
2358- for l in cs cs_CZ hr hr_HR hu hu_HU pl pl_PL ro ro_RO sk sk_SK sl \
2359- sl_SI sr sr_CS sr_YU; do
2360- echo "$l ISO-8859-2"
2361- echo "$l.iso-8859-2 ISO-8859-2"
2362- echo "$l.cp-852 CP852"
2363- echo "$l.cp-1250 CP1250"
2364- echo "$l.utf-8 UTF-8"
2365- done
2366- for l in mk mk_MK ru ru_RU; do
2367- echo "$l ISO-8859-5"
2368- echo "$l.iso-8859-5 ISO-8859-5"
2369- echo "$l.koi8-r KOI8-R"
2370- echo "$l.cp-866 CP866"
2371- echo "$l.cp-1251 CP1251"
2372- echo "$l.utf-8 UTF-8"
2373- done
2374- for l in ar ar_SA; do
2375- echo "$l ISO-8859-6"
2376- echo "$l.iso-8859-6 ISO-8859-6"
2377- echo "$l.cp-864 CP864"
2378- #echo "$l.cp-868 CP868" # not a commonly used encoding
2379- echo "$l.cp-1256 CP1256"
2380- echo "$l.utf-8 UTF-8"
2381- done
2382- for l in el el_GR gr gr_GR; do
2383- echo "$l ISO-8859-7"
2384- echo "$l.iso-8859-7 ISO-8859-7"
2385- echo "$l.cp-869 CP869"
2386- echo "$l.cp-1253 CP1253"
2387- echo "$l.cp-1253@euro CP1253"
2388- echo "$l.utf-8 UTF-8"
2389- echo "$l.utf-8@euro UTF-8"
2390- done
2391- for l in he he_IL iw iw_IL; do
2392- echo "$l ISO-8859-8"
2393- echo "$l.iso-8859-8 ISO-8859-8"
2394- echo "$l.cp-862 CP862"
2395- echo "$l.cp-1255 CP1255"
2396- echo "$l.utf-8 UTF-8"
2397- done
2398- for l in tr tr_TR; do
2399- echo "$l ISO-8859-9"
2400- echo "$l.iso-8859-9 ISO-8859-9"
2401- echo "$l.cp-857 CP857"
2402- echo "$l.cp-1254 CP1254"
2403- echo "$l.utf-8 UTF-8"
2404- done
2405- for l in lt lt_LT lv lv_LV; do
2406- #echo "$l BALTIC" # not a commonly used encoding, wrong encoding name
2407- echo "$l ISO-8859-13"
2408- done
2409- for l in ru_UA uk uk_UA; do
2410- echo "$l KOI8-U"
2411- done
2412- for l in zh zh_CN; do
2413- #echo "$l GB_2312-80" # not a commonly used encoding, wrong encoding name
2414- echo "$l GB2312"
2415- done
2416- for l in ja ja_JP ja_JP.EUC; do
2417- echo "$l EUC-JP"
2418- done
2419- for l in ko ko_KR; do
2420- echo "$l EUC-KR"
2421- done
2422- for l in th th_TH; do
2423- echo "$l TIS-620"
2424- done
2425- for l in fa fa_IR; do
2426- #echo "$l ISIRI-3342" # a broken encoding
2427- echo "$l.utf-8 UTF-8"
2428- done
2429- ;;
2430- linux* | *-gnu*)
2431- # With glibc-2.1 or newer, we don't need any canonicalization,
2432- # because glibc has iconv and both glibc and libiconv support all
2433- # GNU canonical names directly. Therefore, the Makefile does not
2434- # need to install the alias file at all.
2435- # The following applies only to glibc-2.0.x and older libcs.
2436- echo "ISO_646.IRV:1983 ASCII"
2437- ;;
2438- aix*)
2439- echo "ISO8859-1 ISO-8859-1"
2440- echo "ISO8859-2 ISO-8859-2"
2441- echo "ISO8859-5 ISO-8859-5"
2442- echo "ISO8859-6 ISO-8859-6"
2443- echo "ISO8859-7 ISO-8859-7"
2444- echo "ISO8859-8 ISO-8859-8"
2445- echo "ISO8859-9 ISO-8859-9"
2446- echo "ISO8859-15 ISO-8859-15"
2447- echo "IBM-850 CP850"
2448- echo "IBM-856 CP856"
2449- echo "IBM-921 ISO-8859-13"
2450- echo "IBM-922 CP922"
2451- echo "IBM-932 CP932"
2452- echo "IBM-943 CP943"
2453- echo "IBM-1046 CP1046"
2454- echo "IBM-1124 CP1124"
2455- echo "IBM-1129 CP1129"
2456- echo "IBM-1252 CP1252"
2457- echo "IBM-eucCN GB2312"
2458- echo "IBM-eucJP EUC-JP"
2459- echo "IBM-eucKR EUC-KR"
2460- echo "IBM-eucTW EUC-TW"
2461- echo "big5 BIG5"
2462- echo "GBK GBK"
2463- echo "TIS-620 TIS-620"
2464- echo "UTF-8 UTF-8"
2465- ;;
2466- hpux*)
2467- echo "iso88591 ISO-8859-1"
2468- echo "iso88592 ISO-8859-2"
2469- echo "iso88595 ISO-8859-5"
2470- echo "iso88596 ISO-8859-6"
2471- echo "iso88597 ISO-8859-7"
2472- echo "iso88598 ISO-8859-8"
2473- echo "iso88599 ISO-8859-9"
2474- echo "iso885915 ISO-8859-15"
2475- echo "roman8 HP-ROMAN8"
2476- echo "arabic8 HP-ARABIC8"
2477- echo "greek8 HP-GREEK8"
2478- echo "hebrew8 HP-HEBREW8"
2479- echo "turkish8 HP-TURKISH8"
2480- echo "kana8 HP-KANA8"
2481- echo "tis620 TIS-620"
2482- echo "big5 BIG5"
2483- echo "eucJP EUC-JP"
2484- echo "eucKR EUC-KR"
2485- echo "eucTW EUC-TW"
2486- echo "hp15CN GB2312"
2487- #echo "ccdc ?" # what is this?
2488- echo "SJIS SHIFT_JIS"
2489- echo "utf8 UTF-8"
2490- ;;
2491- irix*)
2492- echo "ISO8859-1 ISO-8859-1"
2493- echo "ISO8859-2 ISO-8859-2"
2494- echo "ISO8859-5 ISO-8859-5"
2495- echo "ISO8859-7 ISO-8859-7"
2496- echo "ISO8859-9 ISO-8859-9"
2497- echo "eucCN GB2312"
2498- echo "eucJP EUC-JP"
2499- echo "eucKR EUC-KR"
2500- echo "eucTW EUC-TW"
2501- ;;
2502- osf*)
2503- echo "ISO8859-1 ISO-8859-1"
2504- echo "ISO8859-2 ISO-8859-2"
2505- echo "ISO8859-4 ISO-8859-4"
2506- echo "ISO8859-5 ISO-8859-5"
2507- echo "ISO8859-7 ISO-8859-7"
2508- echo "ISO8859-8 ISO-8859-8"
2509- echo "ISO8859-9 ISO-8859-9"
2510- echo "ISO8859-15 ISO-8859-15"
2511- echo "cp850 CP850"
2512- echo "big5 BIG5"
2513- echo "dechanyu DEC-HANYU"
2514- echo "dechanzi GB2312"
2515- echo "deckanji DEC-KANJI"
2516- echo "deckorean EUC-KR"
2517- echo "eucJP EUC-JP"
2518- echo "eucKR EUC-KR"
2519- echo "eucTW EUC-TW"
2520- echo "GBK GBK"
2521- echo "KSC5601 CP949"
2522- echo "sdeckanji EUC-JP"
2523- echo "SJIS SHIFT_JIS"
2524- echo "TACTIS TIS-620"
2525- echo "UTF-8 UTF-8"
2526- ;;
2527- solaris*)
2528- echo "646 ASCII"
2529- echo "ISO8859-1 ISO-8859-1"
2530- echo "ISO8859-2 ISO-8859-2"
2531- echo "ISO8859-3 ISO-8859-3"
2532- echo "ISO8859-4 ISO-8859-4"
2533- echo "ISO8859-5 ISO-8859-5"
2534- echo "ISO8859-6 ISO-8859-6"
2535- echo "ISO8859-7 ISO-8859-7"
2536- echo "ISO8859-8 ISO-8859-8"
2537- echo "ISO8859-9 ISO-8859-9"
2538- echo "ISO8859-15 ISO-8859-15"
2539- echo "koi8-r KOI8-R"
2540- echo "ansi-1251 CP1251"
2541- echo "BIG5 BIG5"
2542- echo "Big5-HKSCS BIG5-HKSCS"
2543- echo "gb2312 GB2312"
2544- echo "GBK GBK"
2545- echo "GB18030 GB18030"
2546- echo "cns11643 EUC-TW"
2547- echo "5601 EUC-KR"
2548- echo "ko_KR.johap92 JOHAB"
2549- echo "eucJP EUC-JP"
2550- echo "PCK SHIFT_JIS"
2551- echo "TIS620.2533 TIS-620"
2552- #echo "sun_eu_greek ?" # what is this?
2553- echo "UTF-8 UTF-8"
2554- ;;
2555- freebsd* | os2*)
2556- # FreeBSD 4.2 doesn't have nl_langinfo(CODESET); therefore
2557- # localcharset.c falls back to using the full locale name
2558- # from the environment variables.
2559- # Likewise for OS/2. OS/2 has XFree86 just like FreeBSD. Just
2560- # reuse FreeBSD's locale data for OS/2.
2561- echo "C ASCII"
2562- echo "US-ASCII ASCII"
2563- for l in la_LN lt_LN; do
2564- echo "$l.ASCII ASCII"
2565- done
2566- for l in da_DK de_AT de_CH de_DE en_AU en_CA en_GB en_US es_ES \
2567- fi_FI fr_BE fr_CA fr_CH fr_FR is_IS it_CH it_IT la_LN \
2568- lt_LN nl_BE nl_NL no_NO pt_PT sv_SE; do
2569- echo "$l.ISO_8859-1 ISO-8859-1"
2570- echo "$l.DIS_8859-15 ISO-8859-15"
2571- done
2572- for l in cs_CZ hr_HR hu_HU la_LN lt_LN pl_PL sl_SI; do
2573- echo "$l.ISO_8859-2 ISO-8859-2"
2574- done
2575- for l in la_LN lt_LT; do
2576- echo "$l.ISO_8859-4 ISO-8859-4"
2577- done
2578- for l in ru_RU ru_SU; do
2579- echo "$l.KOI8-R KOI8-R"
2580- echo "$l.ISO_8859-5 ISO-8859-5"
2581- echo "$l.CP866 CP866"
2582- done
2583- echo "uk_UA.KOI8-U KOI8-U"
2584- echo "zh_TW.BIG5 BIG5"
2585- echo "zh_TW.Big5 BIG5"
2586- echo "zh_CN.EUC GB2312"
2587- echo "ja_JP.EUC EUC-JP"
2588- echo "ja_JP.SJIS SHIFT_JIS"
2589- echo "ja_JP.Shift_JIS SHIFT_JIS"
2590- echo "ko_KR.EUC EUC-KR"
2591- ;;
2592- netbsd*)
2593- echo "646 ASCII"
2594- echo "ISO8859-1 ISO-8859-1"
2595- echo "ISO8859-2 ISO-8859-2"
2596- echo "ISO8859-4 ISO-8859-4"
2597- echo "ISO8859-5 ISO-8859-5"
2598- echo "ISO8859-7 ISO-8859-7"
2599- echo "ISO8859-13 ISO-8859-13"
2600- echo "ISO8859-15 ISO-8859-15"
2601- echo "eucCN GB2312"
2602- echo "eucJP EUC-JP"
2603- echo "eucKR EUC-KR"
2604- echo "eucTW EUC-TW"
2605- echo "BIG5 BIG5"
2606- echo "SJIS SHIFT_JIS"
2607- ;;
2608- darwin[56]*)
2609- # Darwin 6.8 doesn't have nl_langinfo(CODESET); therefore
2610- # localcharset.c falls back to using the full locale name
2611- # from the environment variables.
2612- echo "C ASCII"
2613- for l in en_AU en_CA en_GB en_US la_LN; do
2614- echo "$l.US-ASCII ASCII"
2615- done
2616- for l in da_DK de_AT de_CH de_DE en_AU en_CA en_GB en_US es_ES \
2617- fi_FI fr_BE fr_CA fr_CH fr_FR is_IS it_CH it_IT nl_BE \
2618- nl_NL no_NO pt_PT sv_SE; do
2619- echo "$l ISO-8859-1"
2620- echo "$l.ISO8859-1 ISO-8859-1"
2621- echo "$l.ISO8859-15 ISO-8859-15"
2622- done
2623- for l in la_LN; do
2624- echo "$l.ISO8859-1 ISO-8859-1"
2625- echo "$l.ISO8859-15 ISO-8859-15"
2626- done
2627- for l in cs_CZ hr_HR hu_HU la_LN pl_PL sl_SI; do
2628- echo "$l.ISO8859-2 ISO-8859-2"
2629- done
2630- for l in la_LN lt_LT; do
2631- echo "$l.ISO8859-4 ISO-8859-4"
2632- done
2633- for l in ru_RU; do
2634- echo "$l.KOI8-R KOI8-R"
2635- echo "$l.ISO8859-5 ISO-8859-5"
2636- echo "$l.CP866 CP866"
2637- done
2638- for l in bg_BG; do
2639- echo "$l.CP1251 CP1251"
2640- done
2641- echo "uk_UA.KOI8-U KOI8-U"
2642- echo "zh_TW.BIG5 BIG5"
2643- echo "zh_TW.Big5 BIG5"
2644- echo "zh_CN.EUC GB2312"
2645- echo "ja_JP.EUC EUC-JP"
2646- echo "ja_JP.SJIS SHIFT_JIS"
2647- echo "ko_KR.EUC EUC-KR"
2648- ;;
2649- darwin*)
2650- # Darwin 7.5 has nl_langinfo(CODESET), but it is useless:
2651- # - It returns the empty string when LANG is set to a locale of the
2652- # form ll_CC, although ll_CC/LC_CTYPE is a symlink to an UTF-8
2653- # LC_CTYPE file.
2654- # - The environment variables LANG, LC_CTYPE, LC_ALL are not set by
2655- # the system; nl_langinfo(CODESET) returns "US-ASCII" in this case.
2656- # - The documentation says:
2657- # "... all code that calls BSD system routines should ensure
2658- # that the const *char parameters of these routines are in UTF-8
2659- # encoding. All BSD system functions expect their string
2660- # parameters to be in UTF-8 encoding and nothing else."
2661- # It also says
2662- # "An additional caveat is that string parameters for files,
2663- # paths, and other file-system entities must be in canonical
2664- # UTF-8. In a canonical UTF-8 Unicode string, all decomposable
2665- # characters are decomposed ..."
2666- # but this is not true: You can pass non-decomposed UTF-8 strings
2667- # to file system functions, and it is the OS which will convert
2668- # them to decomposed UTF-8 before accessing the file system.
2669- # - The Apple Terminal application displays UTF-8 by default.
2670- # - However, other applications are free to use different encodings:
2671- # - xterm uses ISO-8859-1 by default.
2672- # - TextEdit uses MacRoman by default.
2673- # We prefer UTF-8 over decomposed UTF-8-MAC because one should
2674- # minimize the use of decomposed Unicode. Unfortunately, through the
2675- # Darwin file system, decomposed UTF-8 strings are leaked into user
2676- # space nevertheless.
2677- echo "* UTF-8"
2678- ;;
2679- beos*)
2680- # BeOS has a single locale, and it has UTF-8 encoding.
2681- echo "* UTF-8"
2682- ;;
2683- msdosdjgpp*)
2684- # DJGPP 2.03 doesn't have nl_langinfo(CODESET); therefore
2685- # localcharset.c falls back to using the full locale name
2686- # from the environment variables.
2687- echo "#"
2688- echo "# The encodings given here may not all be correct."
2689- echo "# If you find that the encoding given for your language and"
2690- echo "# country is not the one your DOS machine actually uses, just"
2691- echo "# correct it in this file, and send a mail to"
2692- echo "# Juan Manuel Guerrero <juan.guerrero@gmx.de>"
2693- echo "# and Bruno Haible <bruno@clisp.org>."
2694- echo "#"
2695- echo "C ASCII"
2696- # ISO-8859-1 languages
2697- echo "ca CP850"
2698- echo "ca_ES CP850"
2699- echo "da CP865" # not CP850 ??
2700- echo "da_DK CP865" # not CP850 ??
2701- echo "de CP850"
2702- echo "de_AT CP850"
2703- echo "de_CH CP850"
2704- echo "de_DE CP850"
2705- echo "en CP850"
2706- echo "en_AU CP850" # not CP437 ??
2707- echo "en_CA CP850"
2708- echo "en_GB CP850"
2709- echo "en_NZ CP437"
2710- echo "en_US CP437"
2711- echo "en_ZA CP850" # not CP437 ??
2712- echo "es CP850"
2713- echo "es_AR CP850"
2714- echo "es_BO CP850"
2715- echo "es_CL CP850"
2716- echo "es_CO CP850"
2717- echo "es_CR CP850"
2718- echo "es_CU CP850"
2719- echo "es_DO CP850"
2720- echo "es_EC CP850"
2721- echo "es_ES CP850"
2722- echo "es_GT CP850"
2723- echo "es_HN CP850"
2724- echo "es_MX CP850"
2725- echo "es_NI CP850"
2726- echo "es_PA CP850"
2727- echo "es_PY CP850"
2728- echo "es_PE CP850"
2729- echo "es_SV CP850"
2730- echo "es_UY CP850"
2731- echo "es_VE CP850"
2732- echo "et CP850"
2733- echo "et_EE CP850"
2734- echo "eu CP850"
2735- echo "eu_ES CP850"
2736- echo "fi CP850"
2737- echo "fi_FI CP850"
2738- echo "fr CP850"
2739- echo "fr_BE CP850"
2740- echo "fr_CA CP850"
2741- echo "fr_CH CP850"
2742- echo "fr_FR CP850"
2743- echo "ga CP850"
2744- echo "ga_IE CP850"
2745- echo "gd CP850"
2746- echo "gd_GB CP850"
2747- echo "gl CP850"
2748- echo "gl_ES CP850"
2749- echo "id CP850" # not CP437 ??
2750- echo "id_ID CP850" # not CP437 ??
2751- echo "is CP861" # not CP850 ??
2752- echo "is_IS CP861" # not CP850 ??
2753- echo "it CP850"
2754- echo "it_CH CP850"
2755- echo "it_IT CP850"
2756- echo "lt CP775"
2757- echo "lt_LT CP775"
2758- echo "lv CP775"
2759- echo "lv_LV CP775"
2760- echo "nb CP865" # not CP850 ??
2761- echo "nb_NO CP865" # not CP850 ??
2762- echo "nl CP850"
2763- echo "nl_BE CP850"
2764- echo "nl_NL CP850"
2765- echo "nn CP865" # not CP850 ??
2766- echo "nn_NO CP865" # not CP850 ??
2767- echo "no CP865" # not CP850 ??
2768- echo "no_NO CP865" # not CP850 ??
2769- echo "pt CP850"
2770- echo "pt_BR CP850"
2771- echo "pt_PT CP850"
2772- echo "sv CP850"
2773- echo "sv_SE CP850"
2774- # ISO-8859-2 languages
2775- echo "cs CP852"
2776- echo "cs_CZ CP852"
2777- echo "hr CP852"
2778- echo "hr_HR CP852"
2779- echo "hu CP852"
2780- echo "hu_HU CP852"
2781- echo "pl CP852"
2782- echo "pl_PL CP852"
2783- echo "ro CP852"
2784- echo "ro_RO CP852"
2785- echo "sk CP852"
2786- echo "sk_SK CP852"
2787- echo "sl CP852"
2788- echo "sl_SI CP852"
2789- echo "sq CP852"
2790- echo "sq_AL CP852"
2791- echo "sr CP852" # CP852 or CP866 or CP855 ??
2792- echo "sr_CS CP852" # CP852 or CP866 or CP855 ??
2793- echo "sr_YU CP852" # CP852 or CP866 or CP855 ??
2794- # ISO-8859-3 languages
2795- echo "mt CP850"
2796- echo "mt_MT CP850"
2797- # ISO-8859-5 languages
2798- echo "be CP866"
2799- echo "be_BE CP866"
2800- echo "bg CP866" # not CP855 ??
2801- echo "bg_BG CP866" # not CP855 ??
2802- echo "mk CP866" # not CP855 ??
2803- echo "mk_MK CP866" # not CP855 ??
2804- echo "ru CP866"
2805- echo "ru_RU CP866"
2806- echo "uk CP1125"
2807- echo "uk_UA CP1125"
2808- # ISO-8859-6 languages
2809- echo "ar CP864"
2810- echo "ar_AE CP864"
2811- echo "ar_DZ CP864"
2812- echo "ar_EG CP864"
2813- echo "ar_IQ CP864"
2814- echo "ar_IR CP864"
2815- echo "ar_JO CP864"
2816- echo "ar_KW CP864"
2817- echo "ar_MA CP864"
2818- echo "ar_OM CP864"
2819- echo "ar_QA CP864"
2820- echo "ar_SA CP864"
2821- echo "ar_SY CP864"
2822- # ISO-8859-7 languages
2823- echo "el CP869"
2824- echo "el_GR CP869"
2825- # ISO-8859-8 languages
2826- echo "he CP862"
2827- echo "he_IL CP862"
2828- # ISO-8859-9 languages
2829- echo "tr CP857"
2830- echo "tr_TR CP857"
2831- # Japanese
2832- echo "ja CP932"
2833- echo "ja_JP CP932"
2834- # Chinese
2835- echo "zh_CN GBK"
2836- echo "zh_TW CP950" # not CP938 ??
2837- # Korean
2838- echo "kr CP949" # not CP934 ??
2839- echo "kr_KR CP949" # not CP934 ??
2840- # Thai
2841- echo "th CP874"
2842- echo "th_TH CP874"
2843- # Other
2844- echo "eo CP850"
2845- echo "eo_EO CP850"
2846- ;;
2847-esac
2848--- a/intl/dcgettext.c
2849+++ /dev/null
2850@@ -1,56 +0,0 @@
2851-/* Implementation of the dcgettext(3) function.
2852- Copyright (C) 1995-1999, 2000-2003 Free Software Foundation, Inc.
2853-
2854- This program is free software; you can redistribute it and/or modify it
2855- under the terms of the GNU Library General Public License as published
2856- by the Free Software Foundation; either version 2, or (at your option)
2857- any later version.
2858-
2859- This program is distributed in the hope that it will be useful,
2860- but WITHOUT ANY WARRANTY; without even the implied warranty of
2861- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
2862- Library General Public License for more details.
2863-
2864- You should have received a copy of the GNU Library General Public
2865- License along with this program; if not, write to the Free Software
2866- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
2867- USA. */
2868-
2869-#ifdef HAVE_CONFIG_H
2870-# include <config.h>
2871-#endif
2872-
2873-#include "gettextP.h"
2874-#ifdef _LIBC
2875-# include <libintl.h>
2876-#else
2877-# include "libgnuintl.h"
2878-#endif
2879-
2880-/* @@ end of prolog @@ */
2881-
2882-/* Names for the libintl functions are a problem. They must not clash
2883- with existing names and they should follow ANSI C. But this source
2884- code is also used in GNU C Library where the names have a __
2885- prefix. So we have to make a difference here. */
2886-#ifdef _LIBC
2887-# define DCGETTEXT __dcgettext
2888-# define DCIGETTEXT __dcigettext
2889-#else
2890-# define DCGETTEXT libintl_dcgettext
2891-# define DCIGETTEXT libintl_dcigettext
2892-#endif
2893-
2894-/* Look up MSGID in the DOMAINNAME message catalog for the current CATEGORY
2895- locale. */
2896-char *
2897-DCGETTEXT (const char *domainname, const char *msgid, int category)
2898-{
2899- return DCIGETTEXT (domainname, msgid, NULL, 0, 0, category);
2900-}
2901-
2902-#ifdef _LIBC
2903-/* Alias for function name in GNU C Library. */
2904-INTDEF(__dcgettext)
2905-weak_alias (__dcgettext, dcgettext);
2906-#endif
2907--- a/intl/dcigettext.c
2908+++ /dev/null
2909@@ -1,1689 +0,0 @@
2910-/* Implementation of the internal dcigettext function.
2911- Copyright (C) 1995-1999, 2000-2007 Free Software Foundation, Inc.
2912-
2913- This program is free software; you can redistribute it and/or modify it
2914- under the terms of the GNU Library General Public License as published
2915- by the Free Software Foundation; either version 2, or (at your option)
2916- any later version.
2917-
2918- This program is distributed in the hope that it will be useful,
2919- but WITHOUT ANY WARRANTY; without even the implied warranty of
2920- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
2921- Library General Public License for more details.
2922-
2923- You should have received a copy of the GNU Library General Public
2924- License along with this program; if not, write to the Free Software
2925- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
2926- USA. */
2927-
2928-/* Tell glibc's <string.h> to provide a prototype for mempcpy().
2929- This must come before <config.h> because <config.h> may include
2930- <features.h>, and once <features.h> has been included, it's too late. */
2931-#ifndef _GNU_SOURCE
2932-# define _GNU_SOURCE 1
2933-#endif
2934-
2935-#ifdef HAVE_CONFIG_H
2936-# include <config.h>
2937-#endif
2938-
2939-/* NL_LOCALE_NAME does not work in glibc-2.4. Ignore it. */
2940-#undef HAVE_NL_LOCALE_NAME
2941-
2942-#include <sys/types.h>
2943-
2944-#ifdef __GNUC__
2945-# define alloca __builtin_alloca
2946-# define HAVE_ALLOCA 1
2947-#else
2948-# ifdef _MSC_VER
2949-# include <malloc.h>
2950-# define alloca _alloca
2951-# else
2952-# if defined HAVE_ALLOCA_H || defined _LIBC
2953-# include <alloca.h>
2954-# else
2955-# ifdef _AIX
2956- #pragma alloca
2957-# else
2958-# ifndef alloca
2959-char *alloca ();
2960-# endif
2961-# endif
2962-# endif
2963-# endif
2964-#endif
2965-
2966-#include <errno.h>
2967-#ifndef errno
2968-extern int errno;
2969-#endif
2970-#ifndef __set_errno
2971-# define __set_errno(val) errno = (val)
2972-#endif
2973-
2974-#include <stddef.h>
2975-#include <stdlib.h>
2976-#include <string.h>
2977-
2978-#if defined HAVE_UNISTD_H || defined _LIBC
2979-# include <unistd.h>
2980-#endif
2981-
2982-#include <locale.h>
2983-
2984-#ifdef _LIBC
2985- /* Guess whether integer division by zero raises signal SIGFPE.
2986- Set to 1 only if you know for sure. In case of doubt, set to 0. */
2987-# if defined __alpha__ || defined __arm__ || defined __i386__ \
2988- || defined __m68k__ || defined __s390__
2989-# define INTDIV0_RAISES_SIGFPE 1
2990-# else
2991-# define INTDIV0_RAISES_SIGFPE 0
2992-# endif
2993-#endif
2994-#if !INTDIV0_RAISES_SIGFPE
2995-# include <signal.h>
2996-#endif
2997-
2998-#if defined HAVE_SYS_PARAM_H || defined _LIBC
2999-# include <sys/param.h>
3000-#endif
3001-
3002-#if !defined _LIBC
3003-# if HAVE_NL_LOCALE_NAME
3004-# include <langinfo.h>
3005-# endif
3006-# include "localcharset.h"
3007-#endif
3008-
3009-#include "gettextP.h"
3010-#include "plural-exp.h"
3011-#ifdef _LIBC
3012-# include <libintl.h>
3013-#else
3014-# ifdef IN_LIBGLOCALE
3015-# include <libintl.h>
3016-# endif
3017-# include "libgnuintl.h"
3018-#endif
3019-#include "hash-string.h"
3020-
3021-/* Handle multi-threaded applications. */
3022-#ifdef _LIBC
3023-# include <bits/libc-lock.h>
3024-# define gl_rwlock_define_initialized __libc_rwlock_define_initialized
3025-# define gl_rwlock_rdlock __libc_rwlock_rdlock
3026-# define gl_rwlock_wrlock __libc_rwlock_wrlock
3027-# define gl_rwlock_unlock __libc_rwlock_unlock
3028-#else
3029-# include "lock.h"
3030-#endif
3031-
3032-/* Alignment of types. */
3033-#if defined __GNUC__ && __GNUC__ >= 2
3034-# define alignof(TYPE) __alignof__ (TYPE)
3035-#else
3036-# define alignof(TYPE) \
3037- ((int) &((struct { char dummy1; TYPE dummy2; } *) 0)->dummy2)
3038-#endif
3039-
3040-/* Some compilers, like SunOS4 cc, don't have offsetof in <stddef.h>. */
3041-#ifndef offsetof
3042-# define offsetof(type,ident) ((size_t)&(((type*)0)->ident))
3043-#endif
3044-
3045-/* @@ end of prolog @@ */
3046-
3047-#ifdef _LIBC
3048-/* Rename the non ANSI C functions. This is required by the standard
3049- because some ANSI C functions will require linking with this object
3050- file and the name space must not be polluted. */
3051-# define getcwd __getcwd
3052-# ifndef stpcpy
3053-# define stpcpy __stpcpy
3054-# endif
3055-# define tfind __tfind
3056-#else
3057-# if !defined HAVE_GETCWD
3058-char *getwd ();
3059-# define getcwd(buf, max) getwd (buf)
3060-# else
3061-# if VMS
3062-# define getcwd(buf, max) (getcwd) (buf, max, 0)
3063-# else
3064-char *getcwd ();
3065-# endif
3066-# endif
3067-# ifndef HAVE_STPCPY
3068-static char *stpcpy (char *dest, const char *src);
3069-# endif
3070-# ifndef HAVE_MEMPCPY
3071-static void *mempcpy (void *dest, const void *src, size_t n);
3072-# endif
3073-#endif
3074-
3075-/* Use a replacement if the system does not provide the `tsearch' function
3076- family. */
3077-#if HAVE_TSEARCH || defined _LIBC
3078-# include <search.h>
3079-#else
3080-# define tsearch libintl_tsearch
3081-# define tfind libintl_tfind
3082-# define tdelete libintl_tdelete
3083-# define twalk libintl_twalk
3084-# include "tsearch.h"
3085-#endif
3086-
3087-#ifdef _LIBC
3088-# define tsearch __tsearch
3089-#endif
3090-
3091-/* Amount to increase buffer size by in each try. */
3092-#define PATH_INCR 32
3093-
3094-/* The following is from pathmax.h. */
3095-/* Non-POSIX BSD systems might have gcc's limits.h, which doesn't define
3096- PATH_MAX but might cause redefinition warnings when sys/param.h is
3097- later included (as on MORE/BSD 4.3). */
3098-#if defined _POSIX_VERSION || (defined HAVE_LIMITS_H && !defined __GNUC__)
3099-# include <limits.h>
3100-#endif
3101-
3102-#ifndef _POSIX_PATH_MAX
3103-# define _POSIX_PATH_MAX 255
3104-#endif
3105-
3106-#if !defined PATH_MAX && defined _PC_PATH_MAX
3107-# define PATH_MAX (pathconf ("/", _PC_PATH_MAX) < 1 ? 1024 : pathconf ("/", _PC_PATH_MAX))
3108-#endif
3109-
3110-/* Don't include sys/param.h if it already has been. */
3111-#if defined HAVE_SYS_PARAM_H && !defined PATH_MAX && !defined MAXPATHLEN
3112-# include <sys/param.h>
3113-#endif
3114-
3115-#if !defined PATH_MAX && defined MAXPATHLEN
3116-# define PATH_MAX MAXPATHLEN
3117-#endif
3118-
3119-#ifndef PATH_MAX
3120-# define PATH_MAX _POSIX_PATH_MAX
3121-#endif
3122-
3123-/* Pathname support.
3124- ISSLASH(C) tests whether C is a directory separator character.
3125- IS_ABSOLUTE_PATH(P) tests whether P is an absolute path. If it is not,
3126- it may be concatenated to a directory pathname.
3127- IS_PATH_WITH_DIR(P) tests whether P contains a directory specification.
3128- */
3129-#if defined _WIN32 || defined __WIN32__ || defined __CYGWIN__ || defined __EMX__ || defined __DJGPP__
3130- /* Win32, Cygwin, OS/2, DOS */
3131-# define ISSLASH(C) ((C) == '/' || (C) == '\\')
3132-# define HAS_DEVICE(P) \
3133- ((((P)[0] >= 'A' && (P)[0] <= 'Z') || ((P)[0] >= 'a' && (P)[0] <= 'z')) \
3134- && (P)[1] == ':')
3135-# define IS_ABSOLUTE_PATH(P) (ISSLASH ((P)[0]) || HAS_DEVICE (P))
3136-# define IS_PATH_WITH_DIR(P) \
3137- (strchr (P, '/') != NULL || strchr (P, '\\') != NULL || HAS_DEVICE (P))
3138-#else
3139- /* Unix */
3140-# define ISSLASH(C) ((C) == '/')
3141-# define IS_ABSOLUTE_PATH(P) ISSLASH ((P)[0])
3142-# define IS_PATH_WITH_DIR(P) (strchr (P, '/') != NULL)
3143-#endif
3144-
3145-/* Whether to support different locales in different threads. */
3146-#if defined _LIBC || HAVE_NL_LOCALE_NAME || (HAVE_STRUCT___LOCALE_STRUCT___NAMES && defined USE_IN_GETTEXT_TESTS) || defined IN_LIBGLOCALE
3147-# define HAVE_PER_THREAD_LOCALE
3148-#endif
3149-
3150-/* This is the type used for the search tree where known translations
3151- are stored. */
3152-struct known_translation_t
3153-{
3154- /* Domain in which to search. */
3155- const char *domainname;
3156-
3157- /* The category. */
3158- int category;
3159-
3160-#ifdef HAVE_PER_THREAD_LOCALE
3161- /* Name of the relevant locale category, or "" for the global locale. */
3162- const char *localename;
3163-#endif
3164-
3165-#ifdef IN_LIBGLOCALE
3166- /* The character encoding. */
3167- const char *encoding;
3168-#endif
3169-
3170- /* State of the catalog counter at the point the string was found. */
3171- int counter;
3172-
3173- /* Catalog where the string was found. */
3174- struct loaded_l10nfile *domain;
3175-
3176- /* And finally the translation. */
3177- const char *translation;
3178- size_t translation_length;
3179-
3180- /* Pointer to the string in question. */
3181- char msgid[ZERO];
3182-};
3183-
3184-gl_rwlock_define_initialized (static, tree_lock)
3185-
3186-/* Root of the search tree with known translations. */
3187-static void *root;
3188-
3189-/* Function to compare two entries in the table of known translations. */
3190-static int
3191-transcmp (const void *p1, const void *p2)
3192-{
3193- const struct known_translation_t *s1;
3194- const struct known_translation_t *s2;
3195- int result;
3196-
3197- s1 = (const struct known_translation_t *) p1;
3198- s2 = (const struct known_translation_t *) p2;
3199-
3200- result = strcmp (s1->msgid, s2->msgid);
3201- if (result == 0)
3202- {
3203- result = strcmp (s1->domainname, s2->domainname);
3204- if (result == 0)
3205- {
3206-#ifdef HAVE_PER_THREAD_LOCALE
3207- result = strcmp (s1->localename, s2->localename);
3208- if (result == 0)
3209-#endif
3210- {
3211-#ifdef IN_LIBGLOCALE
3212- result = strcmp (s1->encoding, s2->encoding);
3213- if (result == 0)
3214-#endif
3215- /* We compare the category last (though this is the cheapest
3216- operation) since it is hopefully always the same (namely
3217- LC_MESSAGES). */
3218- result = s1->category - s2->category;
3219- }
3220- }
3221- }
3222-
3223- return result;
3224-}
3225-
3226-/* Name of the default domain used for gettext(3) prior any call to
3227- textdomain(3). The default value for this is "messages". */
3228-const char _nl_default_default_domain[] attribute_hidden = "messages";
3229-
3230-#ifndef IN_LIBGLOCALE
3231-/* Value used as the default domain for gettext(3). */
3232-const char *_nl_current_default_domain attribute_hidden
3233- = _nl_default_default_domain;
3234-#endif
3235-
3236-/* Contains the default location of the message catalogs. */
3237-#if defined __EMX__
3238-extern const char _nl_default_dirname[];
3239-#else
3240-# ifdef _LIBC
3241-extern const char _nl_default_dirname[];
3242-libc_hidden_proto (_nl_default_dirname)
3243-# endif
3244-const char _nl_default_dirname[] = LOCALEDIR;
3245-# ifdef _LIBC
3246-libc_hidden_data_def (_nl_default_dirname)
3247-# endif
3248-#endif
3249-
3250-#ifndef IN_LIBGLOCALE
3251-/* List with bindings of specific domains created by bindtextdomain()
3252- calls. */
3253-struct binding *_nl_domain_bindings;
3254-#endif
3255-
3256-/* Prototypes for local functions. */
3257-static char *plural_lookup (struct loaded_l10nfile *domain,
3258- unsigned long int n,
3259- const char *translation, size_t translation_len)
3260- internal_function;
3261-
3262-#ifdef IN_LIBGLOCALE
3263-static const char *guess_category_value (int category,
3264- const char *categoryname,
3265- const char *localename)
3266- internal_function;
3267-#else
3268-static const char *guess_category_value (int category,
3269- const char *categoryname)
3270- internal_function;
3271-#endif
3272-
3273-#ifdef _LIBC
3274-# include "../locale/localeinfo.h"
3275-# define category_to_name(category) \
3276- _nl_category_names.str + _nl_category_name_idxs[category]
3277-#else
3278-static const char *category_to_name (int category) internal_function;
3279-#endif
3280-#if (defined _LIBC || HAVE_ICONV) && !defined IN_LIBGLOCALE
3281-static const char *get_output_charset (struct binding *domainbinding)
3282- internal_function;
3283-#endif
3284-
3285-
3286-/* For those loosing systems which don't have `alloca' we have to add
3287- some additional code emulating it. */
3288-#ifdef HAVE_ALLOCA
3289-/* Nothing has to be done. */
3290-# define freea(p) /* nothing */
3291-# define ADD_BLOCK(list, address) /* nothing */
3292-# define FREE_BLOCKS(list) /* nothing */
3293-#else
3294-struct block_list
3295-{
3296- void *address;
3297- struct block_list *next;
3298-};
3299-# define ADD_BLOCK(list, addr) \
3300- do { \
3301- struct block_list *newp = (struct block_list *) malloc (sizeof (*newp)); \
3302- /* If we cannot get a free block we cannot add the new element to \
3303- the list. */ \
3304- if (newp != NULL) { \
3305- newp->address = (addr); \
3306- newp->next = (list); \
3307- (list) = newp; \
3308- } \
3309- } while (0)
3310-# define FREE_BLOCKS(list) \
3311- do { \
3312- while (list != NULL) { \
3313- struct block_list *old = list; \
3314- list = list->next; \
3315- free (old->address); \
3316- free (old); \
3317- } \
3318- } while (0)
3319-# undef alloca
3320-# define alloca(size) (malloc (size))
3321-# define freea(p) free (p)
3322-#endif /* have alloca */
3323-
3324-
3325-#ifdef _LIBC
3326-/* List of blocks allocated for translations. */
3327-typedef struct transmem_list
3328-{
3329- struct transmem_list *next;
3330- char data[ZERO];
3331-} transmem_block_t;
3332-static struct transmem_list *transmem_list;
3333-#else
3334-typedef unsigned char transmem_block_t;
3335-#endif
3336-
3337-
3338-/* Names for the libintl functions are a problem. They must not clash
3339- with existing names and they should follow ANSI C. But this source
3340- code is also used in GNU C Library where the names have a __
3341- prefix. So we have to make a difference here. */
3342-#ifdef _LIBC
3343-# define DCIGETTEXT __dcigettext
3344-#else
3345-# define DCIGETTEXT libintl_dcigettext
3346-#endif
3347-
3348-/* Lock variable to protect the global data in the gettext implementation. */
3349-gl_rwlock_define_initialized (, _nl_state_lock attribute_hidden)
3350-
3351-/* Checking whether the binaries runs SUID must be done and glibc provides
3352- easier methods therefore we make a difference here. */
3353-#ifdef _LIBC
3354-# define ENABLE_SECURE __libc_enable_secure
3355-# define DETERMINE_SECURE
3356-#else
3357-# ifndef HAVE_GETUID
3358-# define getuid() 0
3359-# endif
3360-# ifndef HAVE_GETGID
3361-# define getgid() 0
3362-# endif
3363-# ifndef HAVE_GETEUID
3364-# define geteuid() getuid()
3365-# endif
3366-# ifndef HAVE_GETEGID
3367-# define getegid() getgid()
3368-# endif
3369-static int enable_secure;
3370-# define ENABLE_SECURE (enable_secure == 1)
3371-# define DETERMINE_SECURE \
3372- if (enable_secure == 0) \
3373- { \
3374- if (getuid () != geteuid () || getgid () != getegid ()) \
3375- enable_secure = 1; \
3376- else \
3377- enable_secure = -1; \
3378- }
3379-#endif
3380-
3381-/* Get the function to evaluate the plural expression. */
3382-#include "eval-plural.h"
3383-
3384-/* Look up MSGID in the DOMAINNAME message catalog for the current
3385- CATEGORY locale and, if PLURAL is nonzero, search over string
3386- depending on the plural form determined by N. */
3387-#ifdef IN_LIBGLOCALE
3388-char *
3389-gl_dcigettext (const char *domainname,
3390- const char *msgid1, const char *msgid2,
3391- int plural, unsigned long int n,
3392- int category,
3393- const char *localename, const char *encoding)
3394-#else
3395-char *
3396-DCIGETTEXT (const char *domainname, const char *msgid1, const char *msgid2,
3397- int plural, unsigned long int n, int category)
3398-#endif
3399-{
3400-#ifndef HAVE_ALLOCA
3401- struct block_list *block_list = NULL;
3402-#endif
3403- struct loaded_l10nfile *domain;
3404- struct binding *binding;
3405- const char *categoryname;
3406- const char *categoryvalue;
3407- const char *dirname;
3408- char *xdomainname;
3409- char *single_locale;
3410- char *retval;
3411- size_t retlen;
3412- int saved_errno;
3413- struct known_translation_t *search;
3414- struct known_translation_t **foundp = NULL;
3415- size_t msgid_len;
3416-#if defined HAVE_PER_THREAD_LOCALE && !defined IN_LIBGLOCALE
3417- const char *localename;
3418-#endif
3419- size_t domainname_len;
3420-
3421- /* If no real MSGID is given return NULL. */
3422- if (msgid1 == NULL)
3423- return NULL;
3424-
3425-#ifdef _LIBC
3426- if (category < 0 || category >= __LC_LAST || category == LC_ALL)
3427- /* Bogus. */
3428- return (plural == 0
3429- ? (char *) msgid1
3430- /* Use the Germanic plural rule. */
3431- : n == 1 ? (char *) msgid1 : (char *) msgid2);
3432-#endif
3433-
3434- /* Preserve the `errno' value. */
3435- saved_errno = errno;
3436-
3437- gl_rwlock_rdlock (_nl_state_lock);
3438-
3439- /* If DOMAINNAME is NULL, we are interested in the default domain. If
3440- CATEGORY is not LC_MESSAGES this might not make much sense but the
3441- definition left this undefined. */
3442- if (domainname == NULL)
3443- domainname = _nl_current_default_domain;
3444-
3445- /* OS/2 specific: backward compatibility with older libintl versions */
3446-#ifdef LC_MESSAGES_COMPAT
3447- if (category == LC_MESSAGES_COMPAT)
3448- category = LC_MESSAGES;
3449-#endif
3450-
3451- msgid_len = strlen (msgid1) + 1;
3452-
3453- /* Try to find the translation among those which we found at
3454- some time. */
3455- search = (struct known_translation_t *)
3456- alloca (offsetof (struct known_translation_t, msgid) + msgid_len);
3457- memcpy (search->msgid, msgid1, msgid_len);
3458- search->domainname = domainname;
3459- search->category = category;
3460-#ifdef HAVE_PER_THREAD_LOCALE
3461-# ifndef IN_LIBGLOCALE
3462-# ifdef _LIBC
3463- localename = __current_locale_name (category);
3464-# else
3465-# if HAVE_NL_LOCALE_NAME
3466- /* NL_LOCALE_NAME is public glibc API introduced in glibc-2.4. */
3467- localename = nl_langinfo (NL_LOCALE_NAME (category));
3468-# else
3469-# if HAVE_STRUCT___LOCALE_STRUCT___NAMES && defined USE_IN_GETTEXT_TESTS
3470- /* The __names field is not public glibc API and must therefore not be used
3471- in code that is installed in public locations. */
3472- {
3473- locale_t thread_locale = uselocale (NULL);
3474- if (thread_locale != LC_GLOBAL_LOCALE)
3475- localename = thread_locale->__names[category];
3476- else
3477- localename = "";
3478- }
3479-# endif
3480-# endif
3481-# endif
3482-# endif
3483- search->localename = localename;
3484-# ifdef IN_LIBGLOCALE
3485- search->encoding = encoding;
3486-# endif
3487-
3488- /* Since tfind/tsearch manage a balanced tree, concurrent tfind and
3489- tsearch calls can be fatal. */
3490- gl_rwlock_rdlock (tree_lock);
3491-
3492- foundp = (struct known_translation_t **) tfind (search, &root, transcmp);
3493-
3494- gl_rwlock_unlock (tree_lock);
3495-
3496- freea (search);
3497- if (foundp != NULL && (*foundp)->counter == _nl_msg_cat_cntr)
3498- {
3499- /* Now deal with plural. */
3500- if (plural)
3501- retval = plural_lookup ((*foundp)->domain, n, (*foundp)->translation,
3502- (*foundp)->translation_length);
3503- else
3504- retval = (char *) (*foundp)->translation;
3505-
3506- gl_rwlock_unlock (_nl_state_lock);
3507- __set_errno (saved_errno);
3508- return retval;
3509- }
3510-#endif
3511-
3512- /* See whether this is a SUID binary or not. */
3513- DETERMINE_SECURE;
3514-
3515- /* First find matching binding. */
3516-#ifdef IN_LIBGLOCALE
3517- /* We can use a trivial binding, since _nl_find_msg will ignore it anyway,
3518- and _nl_load_domain and _nl_find_domain just pass it through. */
3519- binding = NULL;
3520- dirname = bindtextdomain (domainname, NULL);
3521-#else
3522- for (binding = _nl_domain_bindings; binding != NULL; binding = binding->next)
3523- {
3524- int compare = strcmp (domainname, binding->domainname);
3525- if (compare == 0)
3526- /* We found it! */
3527- break;
3528- if (compare < 0)
3529- {
3530- /* It is not in the list. */
3531- binding = NULL;
3532- break;
3533- }
3534- }
3535-
3536- if (binding == NULL)
3537- dirname = _nl_default_dirname;
3538- else
3539- {
3540- dirname = binding->dirname;
3541-#endif
3542- if (!IS_ABSOLUTE_PATH (dirname))
3543- {
3544- /* We have a relative path. Make it absolute now. */
3545- size_t dirname_len = strlen (dirname) + 1;
3546- size_t path_max;
3547- char *resolved_dirname;
3548- char *ret;
3549-
3550- path_max = (unsigned int) PATH_MAX;
3551- path_max += 2; /* The getcwd docs say to do this. */
3552-
3553- for (;;)
3554- {
3555- resolved_dirname = (char *) alloca (path_max + dirname_len);
3556- ADD_BLOCK (block_list, tmp_dirname);
3557-
3558- __set_errno (0);
3559- ret = getcwd (resolved_dirname, path_max);
3560- if (ret != NULL || errno != ERANGE)
3561- break;
3562-
3563- path_max += path_max / 2;
3564- path_max += PATH_INCR;
3565- }
3566-
3567- if (ret == NULL)
3568- /* We cannot get the current working directory. Don't signal an
3569- error but simply return the default string. */
3570- goto return_untranslated;
3571-
3572- stpcpy (stpcpy (strchr (resolved_dirname, '\0'), "/"), dirname);
3573- dirname = resolved_dirname;
3574- }
3575-#ifndef IN_LIBGLOCALE
3576- }
3577-#endif
3578-
3579- /* Now determine the symbolic name of CATEGORY and its value. */
3580- categoryname = category_to_name (category);
3581-#ifdef IN_LIBGLOCALE
3582- categoryvalue = guess_category_value (category, categoryname, localename);
3583-#else
3584- categoryvalue = guess_category_value (category, categoryname);
3585-#endif
3586-
3587- domainname_len = strlen (domainname);
3588- xdomainname = (char *) alloca (strlen (categoryname)
3589- + domainname_len + 5);
3590- ADD_BLOCK (block_list, xdomainname);
3591-
3592- stpcpy ((char *) mempcpy (stpcpy (stpcpy (xdomainname, categoryname), "/"),
3593- domainname, domainname_len),
3594- ".mo");
3595-
3596- /* Creating working area. */
3597- single_locale = (char *) alloca (strlen (categoryvalue) + 1);
3598- ADD_BLOCK (block_list, single_locale);
3599-
3600-
3601- /* Search for the given string. This is a loop because we perhaps
3602- got an ordered list of languages to consider for the translation. */
3603- while (1)
3604- {
3605- /* Make CATEGORYVALUE point to the next element of the list. */
3606- while (categoryvalue[0] != '\0' && categoryvalue[0] == ':')
3607- ++categoryvalue;
3608- if (categoryvalue[0] == '\0')
3609- {
3610- /* The whole contents of CATEGORYVALUE has been searched but
3611- no valid entry has been found. We solve this situation
3612- by implicitly appending a "C" entry, i.e. no translation
3613- will take place. */
3614- single_locale[0] = 'C';
3615- single_locale[1] = '\0';
3616- }
3617- else
3618- {
3619- char *cp = single_locale;
3620- while (categoryvalue[0] != '\0' && categoryvalue[0] != ':')
3621- *cp++ = *categoryvalue++;
3622- *cp = '\0';
3623-
3624- /* When this is a SUID binary we must not allow accessing files
3625- outside the dedicated directories. */
3626- if (ENABLE_SECURE && IS_PATH_WITH_DIR (single_locale))
3627- /* Ingore this entry. */
3628- continue;
3629- }
3630-
3631- /* If the current locale value is C (or POSIX) we don't load a
3632- domain. Return the MSGID. */
3633- if (strcmp (single_locale, "C") == 0
3634- || strcmp (single_locale, "POSIX") == 0)
3635- break;
3636-
3637- /* Find structure describing the message catalog matching the
3638- DOMAINNAME and CATEGORY. */
3639- domain = _nl_find_domain (dirname, single_locale, xdomainname, binding);
3640-
3641- if (domain != NULL)
3642- {
3643-#if defined IN_LIBGLOCALE
3644- retval = _nl_find_msg (domain, binding, encoding, msgid1, &retlen);
3645-#else
3646- retval = _nl_find_msg (domain, binding, msgid1, 1, &retlen);
3647-#endif
3648-
3649- if (retval == NULL)
3650- {
3651- int cnt;
3652-
3653- for (cnt = 0; domain->successor[cnt] != NULL; ++cnt)
3654- {
3655-#if defined IN_LIBGLOCALE
3656- retval = _nl_find_msg (domain->successor[cnt], binding,
3657- encoding, msgid1, &retlen);
3658-#else
3659- retval = _nl_find_msg (domain->successor[cnt], binding,
3660- msgid1, 1, &retlen);
3661-#endif
3662-
3663- if (retval != NULL)
3664- {
3665- domain = domain->successor[cnt];
3666- break;
3667- }
3668- }
3669- }
3670-
3671- /* Returning -1 means that some resource problem exists
3672- (likely memory) and that the strings could not be
3673- converted. Return the original strings. */
3674- if (__builtin_expect (retval == (char *) -1, 0))
3675- break;
3676-
3677- if (retval != NULL)
3678- {
3679- /* Found the translation of MSGID1 in domain DOMAIN:
3680- starting at RETVAL, RETLEN bytes. */
3681- FREE_BLOCKS (block_list);
3682- if (foundp == NULL)
3683- {
3684- /* Create a new entry and add it to the search tree. */
3685- size_t size;
3686- struct known_translation_t *newp;
3687-
3688- size = offsetof (struct known_translation_t, msgid)
3689- + msgid_len + domainname_len + 1;
3690-#ifdef HAVE_PER_THREAD_LOCALE
3691- size += strlen (localename) + 1;
3692-#endif
3693- newp = (struct known_translation_t *) malloc (size);
3694- if (newp != NULL)
3695- {
3696- char *new_domainname;
3697-#ifdef HAVE_PER_THREAD_LOCALE
3698- char *new_localename;
3699-#endif
3700-
3701- new_domainname =
3702- (char *) mempcpy (newp->msgid, msgid1, msgid_len);
3703- memcpy (new_domainname, domainname, domainname_len + 1);
3704-#ifdef HAVE_PER_THREAD_LOCALE
3705- new_localename = new_domainname + domainname_len + 1;
3706- strcpy (new_localename, localename);
3707-#endif
3708- newp->domainname = new_domainname;
3709- newp->category = category;
3710-#ifdef HAVE_PER_THREAD_LOCALE
3711- newp->localename = new_localename;
3712-#endif
3713-#ifdef IN_LIBGLOCALE
3714- newp->encoding = encoding;
3715-#endif
3716- newp->counter = _nl_msg_cat_cntr;
3717- newp->domain = domain;
3718- newp->translation = retval;
3719- newp->translation_length = retlen;
3720-
3721- gl_rwlock_wrlock (tree_lock);
3722-
3723- /* Insert the entry in the search tree. */
3724- foundp = (struct known_translation_t **)
3725- tsearch (newp, &root, transcmp);
3726-
3727- gl_rwlock_unlock (tree_lock);
3728-
3729- if (foundp == NULL
3730- || __builtin_expect (*foundp != newp, 0))
3731- /* The insert failed. */
3732- free (newp);
3733- }
3734- }
3735- else
3736- {
3737- /* We can update the existing entry. */
3738- (*foundp)->counter = _nl_msg_cat_cntr;
3739- (*foundp)->domain = domain;
3740- (*foundp)->translation = retval;
3741- (*foundp)->translation_length = retlen;
3742- }
3743-
3744- __set_errno (saved_errno);
3745-
3746- /* Now deal with plural. */
3747- if (plural)
3748- retval = plural_lookup (domain, n, retval, retlen);
3749-
3750- gl_rwlock_unlock (_nl_state_lock);
3751- return retval;
3752- }
3753- }
3754- }
3755-
3756- return_untranslated:
3757- /* Return the untranslated MSGID. */
3758- FREE_BLOCKS (block_list);
3759- gl_rwlock_unlock (_nl_state_lock);
3760-#ifndef _LIBC
3761- if (!ENABLE_SECURE)
3762- {
3763- extern void _nl_log_untranslated (const char *logfilename,
3764- const char *domainname,
3765- const char *msgid1, const char *msgid2,
3766- int plural);
3767- const char *logfilename = getenv ("GETTEXT_LOG_UNTRANSLATED");
3768-
3769- if (logfilename != NULL && logfilename[0] != '\0')
3770- _nl_log_untranslated (logfilename, domainname, msgid1, msgid2, plural);
3771- }
3772-#endif
3773- __set_errno (saved_errno);
3774- return (plural == 0
3775- ? (char *) msgid1
3776- /* Use the Germanic plural rule. */
3777- : n == 1 ? (char *) msgid1 : (char *) msgid2);
3778-}
3779-
3780-
3781-/* Look up the translation of msgid within DOMAIN_FILE and DOMAINBINDING.
3782- Return it if found. Return NULL if not found or in case of a conversion
3783- failure (problem in the particular message catalog). Return (char *) -1
3784- in case of a memory allocation failure during conversion (only if
3785- ENCODING != NULL resp. CONVERT == true). */
3786-char *
3787-internal_function
3788-#ifdef IN_LIBGLOCALE
3789-_nl_find_msg (struct loaded_l10nfile *domain_file,
3790- struct binding *domainbinding, const char *encoding,
3791- const char *msgid,
3792- size_t *lengthp)
3793-#else
3794-_nl_find_msg (struct loaded_l10nfile *domain_file,
3795- struct binding *domainbinding,
3796- const char *msgid, int convert,
3797- size_t *lengthp)
3798-#endif
3799-{
3800- struct loaded_domain *domain;
3801- nls_uint32 nstrings;
3802- size_t act;
3803- char *result;
3804- size_t resultlen;
3805-
3806- if (domain_file->decided <= 0)
3807- _nl_load_domain (domain_file, domainbinding);
3808-
3809- if (domain_file->data == NULL)
3810- return NULL;
3811-
3812- domain = (struct loaded_domain *) domain_file->data;
3813-
3814- nstrings = domain->nstrings;
3815-
3816- /* Locate the MSGID and its translation. */
3817- if (domain->hash_tab != NULL)
3818- {
3819- /* Use the hashing table. */
3820- nls_uint32 len = strlen (msgid);
3821- nls_uint32 hash_val = __hash_string (msgid);
3822- nls_uint32 idx = hash_val % domain->hash_size;
3823- nls_uint32 incr = 1 + (hash_val % (domain->hash_size - 2));
3824-
3825- while (1)
3826- {
3827- nls_uint32 nstr =
3828- W (domain->must_swap_hash_tab, domain->hash_tab[idx]);
3829-
3830- if (nstr == 0)
3831- /* Hash table entry is empty. */
3832- return NULL;
3833-
3834- nstr--;
3835-
3836- /* Compare msgid with the original string at index nstr.
3837- We compare the lengths with >=, not ==, because plural entries
3838- are represented by strings with an embedded NUL. */
3839- if (nstr < nstrings
3840- ? W (domain->must_swap, domain->orig_tab[nstr].length) >= len
3841- && (strcmp (msgid,
3842- domain->data + W (domain->must_swap,
3843- domain->orig_tab[nstr].offset))
3844- == 0)
3845- : domain->orig_sysdep_tab[nstr - nstrings].length > len
3846- && (strcmp (msgid,
3847- domain->orig_sysdep_tab[nstr - nstrings].pointer)
3848- == 0))
3849- {
3850- act = nstr;
3851- goto found;
3852- }
3853-
3854- if (idx >= domain->hash_size - incr)
3855- idx -= domain->hash_size - incr;
3856- else
3857- idx += incr;
3858- }
3859- /* NOTREACHED */
3860- }
3861- else
3862- {
3863- /* Try the default method: binary search in the sorted array of
3864- messages. */
3865- size_t top, bottom;
3866-
3867- bottom = 0;
3868- top = nstrings;
3869- while (bottom < top)
3870- {
3871- int cmp_val;
3872-
3873- act = (bottom + top) / 2;
3874- cmp_val = strcmp (msgid, (domain->data
3875- + W (domain->must_swap,
3876- domain->orig_tab[act].offset)));
3877- if (cmp_val < 0)
3878- top = act;
3879- else if (cmp_val > 0)
3880- bottom = act + 1;
3881- else
3882- goto found;
3883- }
3884- /* No translation was found. */
3885- return NULL;
3886- }
3887-
3888- found:
3889- /* The translation was found at index ACT. If we have to convert the
3890- string to use a different character set, this is the time. */
3891- if (act < nstrings)
3892- {
3893- result = (char *)
3894- (domain->data + W (domain->must_swap, domain->trans_tab[act].offset));
3895- resultlen = W (domain->must_swap, domain->trans_tab[act].length) + 1;
3896- }
3897- else
3898- {
3899- result = (char *) domain->trans_sysdep_tab[act - nstrings].pointer;
3900- resultlen = domain->trans_sysdep_tab[act - nstrings].length;
3901- }
3902-
3903-#if defined _LIBC || HAVE_ICONV
3904-# ifdef IN_LIBGLOCALE
3905- if (encoding != NULL)
3906-# else
3907- if (convert)
3908-# endif
3909- {
3910- /* We are supposed to do a conversion. */
3911-# ifndef IN_LIBGLOCALE
3912- const char *encoding = get_output_charset (domainbinding);
3913-# endif
3914- size_t nconversions;
3915- struct converted_domain *convd;
3916- size_t i;
3917-
3918- /* Protect against reallocation of the table. */
3919- gl_rwlock_rdlock (domain->conversions_lock);
3920-
3921- /* Search whether a table with converted translations for this
3922- encoding has already been allocated. */
3923- nconversions = domain->nconversions;
3924- convd = NULL;
3925-
3926- for (i = nconversions; i > 0; )
3927- {
3928- i--;
3929- if (strcmp (domain->conversions[i].encoding, encoding) == 0)
3930- {
3931- convd = &domain->conversions[i];
3932- break;
3933- }
3934- }
3935-
3936- gl_rwlock_unlock (domain->conversions_lock);
3937-
3938- if (convd == NULL)
3939- {
3940- /* We have to allocate a new conversions table. */
3941- gl_rwlock_wrlock (domain->conversions_lock);
3942-
3943- /* Maybe in the meantime somebody added the translation.
3944- Recheck. */
3945- for (i = nconversions; i > 0; )
3946- {
3947- i--;
3948- if (strcmp (domain->conversions[i].encoding, encoding) == 0)
3949- {
3950- convd = &domain->conversions[i];
3951- goto found_convd;
3952- }
3953- }
3954-
3955- {
3956- /* Allocate a table for the converted translations for this
3957- encoding. */
3958- struct converted_domain *new_conversions =
3959- (struct converted_domain *)
3960- (domain->conversions != NULL
3961- ? realloc (domain->conversions,
3962- (nconversions + 1) * sizeof (struct converted_domain))
3963- : malloc ((nconversions + 1) * sizeof (struct converted_domain)));
3964-
3965- if (__builtin_expect (new_conversions == NULL, 0))
3966- {
3967- /* Nothing we can do, no more memory. We cannot use the
3968- translation because it might be encoded incorrectly. */
3969- unlock_fail:
3970- gl_rwlock_unlock (domain->conversions_lock);
3971- return (char *) -1;
3972- }
3973-
3974- domain->conversions = new_conversions;
3975-
3976- /* Copy the 'encoding' string to permanent storage. */
3977- encoding = strdup (encoding);
3978- if (__builtin_expect (encoding == NULL, 0))
3979- /* Nothing we can do, no more memory. We cannot use the
3980- translation because it might be encoded incorrectly. */
3981- goto unlock_fail;
3982-
3983- convd = &new_conversions[nconversions];
3984- convd->encoding = encoding;
3985-
3986- /* Find out about the character set the file is encoded with.
3987- This can be found (in textual form) in the entry "". If this
3988- entry does not exist or if this does not contain the 'charset='
3989- information, we will assume the charset matches the one the
3990- current locale and we don't have to perform any conversion. */
3991-# ifdef _LIBC
3992- convd->conv = (__gconv_t) -1;
3993-# else
3994-# if HAVE_ICONV
3995- convd->conv = (iconv_t) -1;
3996-# endif
3997-# endif
3998- {
3999- char *nullentry;
4000- size_t nullentrylen;
4001-
4002- /* Get the header entry. This is a recursion, but it doesn't
4003- reallocate domain->conversions because we pass
4004- encoding = NULL or convert = 0, respectively. */
4005- nullentry =
4006-# ifdef IN_LIBGLOCALE
4007- _nl_find_msg (domain_file, domainbinding, NULL, "",
4008- &nullentrylen);
4009-# else
4010- _nl_find_msg (domain_file, domainbinding, "", 0, &nullentrylen);
4011-# endif
4012-
4013- if (nullentry != NULL)
4014- {
4015- const char *charsetstr;
4016-
4017- charsetstr = strstr (nullentry, "charset=");
4018- if (charsetstr != NULL)
4019- {
4020- size_t len;
4021- char *charset;
4022- const char *outcharset;
4023-
4024- charsetstr += strlen ("charset=");
4025- len = strcspn (charsetstr, " \t\n");
4026-
4027- charset = (char *) alloca (len + 1);
4028-# if defined _LIBC || HAVE_MEMPCPY
4029- *((char *) mempcpy (charset, charsetstr, len)) = '\0';
4030-# else
4031- memcpy (charset, charsetstr, len);
4032- charset[len] = '\0';
4033-# endif
4034-
4035- outcharset = encoding;
4036-
4037-# ifdef _LIBC
4038- /* We always want to use transliteration. */
4039- outcharset = norm_add_slashes (outcharset, "TRANSLIT");
4040- charset = norm_add_slashes (charset, "");
4041- int r = __gconv_open (outcharset, charset, &convd->conv,
4042- GCONV_AVOID_NOCONV);
4043- if (__builtin_expect (r != __GCONV_OK, 0))
4044- {
4045- /* If the output encoding is the same there is
4046- nothing to do. Otherwise do not use the
4047- translation at all. */
4048- if (__builtin_expect (r != __GCONV_NULCONV, 1))
4049- {
4050- gl_rwlock_unlock (domain->conversions_lock);
4051- free ((char *) encoding);
4052- return NULL;
4053- }
4054-
4055- convd->conv = (__gconv_t) -1;
4056- }
4057-# else
4058-# if HAVE_ICONV
4059- /* When using GNU libc >= 2.2 or GNU libiconv >= 1.5,
4060- we want to use transliteration. */
4061-# if (__GLIBC__ == 2 && __GLIBC_MINOR__ >= 2) || __GLIBC__ > 2 \
4062- || _LIBICONV_VERSION >= 0x0105
4063- if (strchr (outcharset, '/') == NULL)
4064- {
4065- char *tmp;
4066-
4067- len = strlen (outcharset);
4068- tmp = (char *) alloca (len + 10 + 1);
4069- memcpy (tmp, outcharset, len);
4070- memcpy (tmp + len, "//TRANSLIT", 10 + 1);
4071- outcharset = tmp;
4072-
4073- convd->conv = iconv_open (outcharset, charset);
4074-
4075- freea (outcharset);
4076- }
4077- else
4078-# endif
4079- convd->conv = iconv_open (outcharset, charset);
4080-# endif
4081-# endif
4082-
4083- freea (charset);
4084- }
4085- }
4086- }
4087- convd->conv_tab = NULL;
4088- /* Here domain->conversions is still == new_conversions. */
4089- domain->nconversions++;
4090- }
4091-
4092- found_convd:
4093- gl_rwlock_unlock (domain->conversions_lock);
4094- }
4095-
4096- if (
4097-# ifdef _LIBC
4098- convd->conv != (__gconv_t) -1
4099-# else
4100-# if HAVE_ICONV
4101- convd->conv != (iconv_t) -1
4102-# endif
4103-# endif
4104- )
4105- {
4106- /* We are supposed to do a conversion. First allocate an
4107- appropriate table with the same structure as the table
4108- of translations in the file, where we can put the pointers
4109- to the converted strings in.
4110- There is a slight complication with plural entries. They
4111- are represented by consecutive NUL terminated strings. We
4112- handle this case by converting RESULTLEN bytes, including
4113- NULs. */
4114-
4115- if (convd->conv_tab == NULL
4116- && ((convd->conv_tab =
4117- (char **) calloc (nstrings + domain->n_sysdep_strings,
4118- sizeof (char *)))
4119- == NULL))
4120- /* Mark that we didn't succeed allocating a table. */
4121- convd->conv_tab = (char **) -1;
4122-
4123- if (__builtin_expect (convd->conv_tab == (char **) -1, 0))
4124- /* Nothing we can do, no more memory. We cannot use the
4125- translation because it might be encoded incorrectly. */
4126- return (char *) -1;
4127-
4128- if (convd->conv_tab[act] == NULL)
4129- {
4130- /* We haven't used this string so far, so it is not
4131- translated yet. Do this now. */
4132- /* We use a bit more efficient memory handling.
4133- We allocate always larger blocks which get used over
4134- time. This is faster than many small allocations. */
4135- __libc_lock_define_initialized (static, lock)
4136-# define INITIAL_BLOCK_SIZE 4080
4137- static unsigned char *freemem;
4138- static size_t freemem_size;
4139-
4140- const unsigned char *inbuf;
4141- unsigned char *outbuf;
4142- int malloc_count;
4143-# ifndef _LIBC
4144- transmem_block_t *transmem_list = NULL;
4145-# endif
4146-
4147- __libc_lock_lock (lock);
4148-
4149- inbuf = (const unsigned char *) result;
4150- outbuf = freemem + sizeof (size_t);
4151-
4152- malloc_count = 0;
4153- while (1)
4154- {
4155- transmem_block_t *newmem;
4156-# ifdef _LIBC
4157- size_t non_reversible;
4158- int res;
4159-
4160- if (freemem_size < sizeof (size_t))
4161- goto resize_freemem;
4162-
4163- res = __gconv (convd->conv,
4164- &inbuf, inbuf + resultlen,
4165- &outbuf,
4166- outbuf + freemem_size - sizeof (size_t),
4167- &non_reversible);
4168-
4169- if (res == __GCONV_OK || res == __GCONV_EMPTY_INPUT)
4170- break;
4171-
4172- if (res != __GCONV_FULL_OUTPUT)
4173- {
4174- /* We should not use the translation at all, it
4175- is incorrectly encoded. */
4176- __libc_lock_unlock (lock);
4177- return NULL;
4178- }
4179-
4180- inbuf = (const unsigned char *) result;
4181-# else
4182-# if HAVE_ICONV
4183- const char *inptr = (const char *) inbuf;
4184- size_t inleft = resultlen;
4185- char *outptr = (char *) outbuf;
4186- size_t outleft;
4187-
4188- if (freemem_size < sizeof (size_t))
4189- goto resize_freemem;
4190-
4191- outleft = freemem_size - sizeof (size_t);
4192- if (iconv (convd->conv,
4193- (ICONV_CONST char **) &inptr, &inleft,
4194- &outptr, &outleft)
4195- != (size_t) (-1))
4196- {
4197- outbuf = (unsigned char *) outptr;
4198- break;
4199- }
4200- if (errno != E2BIG)
4201- {
4202- __libc_lock_unlock (lock);
4203- return NULL;
4204- }
4205-# endif
4206-# endif
4207-
4208- resize_freemem:
4209- /* We must allocate a new buffer or resize the old one. */
4210- if (malloc_count > 0)
4211- {
4212- ++malloc_count;
4213- freemem_size = malloc_count * INITIAL_BLOCK_SIZE;
4214- newmem = (transmem_block_t *) realloc (transmem_list,
4215- freemem_size);
4216-# ifdef _LIBC
4217- if (newmem != NULL)
4218- transmem_list = transmem_list->next;
4219- else
4220- {
4221- struct transmem_list *old = transmem_list;
4222-
4223- transmem_list = transmem_list->next;
4224- free (old);
4225- }
4226-# endif
4227- }
4228- else
4229- {
4230- malloc_count = 1;
4231- freemem_size = INITIAL_BLOCK_SIZE;
4232- newmem = (transmem_block_t *) malloc (freemem_size);
4233- }
4234- if (__builtin_expect (newmem == NULL, 0))
4235- {
4236- freemem = NULL;
4237- freemem_size = 0;
4238- __libc_lock_unlock (lock);
4239- return (char *) -1;
4240- }
4241-
4242-# ifdef _LIBC
4243- /* Add the block to the list of blocks we have to free
4244- at some point. */
4245- newmem->next = transmem_list;
4246- transmem_list = newmem;
4247-
4248- freemem = (unsigned char *) newmem->data;
4249- freemem_size -= offsetof (struct transmem_list, data);
4250-# else
4251- transmem_list = newmem;
4252- freemem = newmem;
4253-# endif
4254-
4255- outbuf = freemem + sizeof (size_t);
4256- }
4257-
4258- /* We have now in our buffer a converted string. Put this
4259- into the table of conversions. */
4260- *(size_t *) freemem = outbuf - freemem - sizeof (size_t);
4261- convd->conv_tab[act] = (char *) freemem;
4262- /* Shrink freemem, but keep it aligned. */
4263- freemem_size -= outbuf - freemem;
4264- freemem = outbuf;
4265- freemem += freemem_size & (alignof (size_t) - 1);
4266- freemem_size = freemem_size & ~ (alignof (size_t) - 1);
4267-
4268- __libc_lock_unlock (lock);
4269- }
4270-
4271- /* Now convd->conv_tab[act] contains the translation of all
4272- the plural variants. */
4273- result = convd->conv_tab[act] + sizeof (size_t);
4274- resultlen = *(size_t *) convd->conv_tab[act];
4275- }
4276- }
4277-
4278- /* The result string is converted. */
4279-
4280-#endif /* _LIBC || HAVE_ICONV */
4281-
4282- *lengthp = resultlen;
4283- return result;
4284-}
4285-
4286-
4287-/* Look up a plural variant. */
4288-static char *
4289-internal_function
4290-plural_lookup (struct loaded_l10nfile *domain, unsigned long int n,
4291- const char *translation, size_t translation_len)
4292-{
4293- struct loaded_domain *domaindata = (struct loaded_domain *) domain->data;
4294- unsigned long int index;
4295- const char *p;
4296-
4297- index = plural_eval (domaindata->plural, n);
4298- if (index >= domaindata->nplurals)
4299- /* This should never happen. It means the plural expression and the
4300- given maximum value do not match. */
4301- index = 0;
4302-
4303- /* Skip INDEX strings at TRANSLATION. */
4304- p = translation;
4305- while (index-- > 0)
4306- {
4307-#ifdef _LIBC
4308- p = __rawmemchr (p, '\0');
4309-#else
4310- p = strchr (p, '\0');
4311-#endif
4312- /* And skip over the NUL byte. */
4313- p++;
4314-
4315- if (p >= translation + translation_len)
4316- /* This should never happen. It means the plural expression
4317- evaluated to a value larger than the number of variants
4318- available for MSGID1. */
4319- return (char *) translation;
4320- }
4321- return (char *) p;
4322-}
4323-
4324-#ifndef _LIBC
4325-/* Return string representation of locale CATEGORY. */
4326-static const char *
4327-internal_function
4328-category_to_name (int category)
4329-{
4330- const char *retval;
4331-
4332- switch (category)
4333- {
4334-#ifdef LC_COLLATE
4335- case LC_COLLATE:
4336- retval = "LC_COLLATE";
4337- break;
4338-#endif
4339-#ifdef LC_CTYPE
4340- case LC_CTYPE:
4341- retval = "LC_CTYPE";
4342- break;
4343-#endif
4344-#ifdef LC_MONETARY
4345- case LC_MONETARY:
4346- retval = "LC_MONETARY";
4347- break;
4348-#endif
4349-#ifdef LC_NUMERIC
4350- case LC_NUMERIC:
4351- retval = "LC_NUMERIC";
4352- break;
4353-#endif
4354-#ifdef LC_TIME
4355- case LC_TIME:
4356- retval = "LC_TIME";
4357- break;
4358-#endif
4359-#ifdef LC_MESSAGES
4360- case LC_MESSAGES:
4361- retval = "LC_MESSAGES";
4362- break;
4363-#endif
4364-#ifdef LC_RESPONSE
4365- case LC_RESPONSE:
4366- retval = "LC_RESPONSE";
4367- break;
4368-#endif
4369-#ifdef LC_ALL
4370- case LC_ALL:
4371- /* This might not make sense but is perhaps better than any other
4372- value. */
4373- retval = "LC_ALL";
4374- break;
4375-#endif
4376- default:
4377- /* If you have a better idea for a default value let me know. */
4378- retval = "LC_XXX";
4379- }
4380-
4381- return retval;
4382-}
4383-#endif
4384-
4385-/* Guess value of current locale from value of the environment variables
4386- or system-dependent defaults. */
4387-static const char *
4388-internal_function
4389-#ifdef IN_LIBGLOCALE
4390-guess_category_value (int category, const char *categoryname,
4391- const char *locale)
4392-
4393-#else
4394-guess_category_value (int category, const char *categoryname)
4395-#endif
4396-{
4397- const char *language;
4398-#ifndef IN_LIBGLOCALE
4399- const char *locale;
4400-# ifndef _LIBC
4401- const char *language_default;
4402- int locale_defaulted;
4403-# endif
4404-#endif
4405-
4406- /* We use the settings in the following order:
4407- 1. The value of the environment variable 'LANGUAGE'. This is a GNU
4408- extension. Its value can be a colon-separated list of locale names.
4409- 2. The value of the environment variable 'LC_ALL', 'LC_xxx', or 'LANG'.
4410- More precisely, the first among these that is set to a non-empty value.
4411- This is how POSIX specifies it. The value is a single locale name.
4412- 3. A system-dependent preference list of languages. Its value can be a
4413- colon-separated list of locale names.
4414- 4. A system-dependent default locale name.
4415- This way:
4416- - System-dependent settings can be overridden by environment variables.
4417- - If the system provides both a list of languages and a default locale,
4418- the former is used. */
4419-
4420-#ifndef IN_LIBGLOCALE
4421- /* Fetch the locale name, through the POSIX method of looking to `LC_ALL',
4422- `LC_xxx', and `LANG'. On some systems this can be done by the
4423- `setlocale' function itself. */
4424-# ifdef _LIBC
4425- locale = __current_locale_name (category);
4426-# else
4427-# if HAVE_STRUCT___LOCALE_STRUCT___NAMES && defined USE_IN_GETTEXT_TESTS
4428- /* The __names field is not public glibc API and must therefore not be used
4429- in code that is installed in public locations. */
4430- locale_t thread_locale = uselocale (NULL);
4431- if (thread_locale != LC_GLOBAL_LOCALE)
4432- {
4433- locale = thread_locale->__names[category];
4434- locale_defaulted = 0;
4435- }
4436- else
4437-# endif
4438- {
4439- locale = _nl_locale_name_posix (category, categoryname);
4440- locale_defaulted = 0;
4441- if (locale == NULL)
4442- {
4443- locale = _nl_locale_name_default ();
4444- locale_defaulted = 1;
4445- }
4446- }
4447-# endif
4448-#endif
4449-
4450- /* Ignore LANGUAGE and its system-dependent analogon if the locale is set
4451- to "C" because
4452- 1. "C" locale usually uses the ASCII encoding, and most international
4453- messages use non-ASCII characters. These characters get displayed
4454- as question marks (if using glibc's iconv()) or as invalid 8-bit
4455- characters (because other iconv()s refuse to convert most non-ASCII
4456- characters to ASCII). In any case, the output is ugly.
4457- 2. The precise output of some programs in the "C" locale is specified
4458- by POSIX and should not depend on environment variables like
4459- "LANGUAGE" or system-dependent information. We allow such programs
4460- to use gettext(). */
4461- if (strcmp (locale, "C") == 0)
4462- return locale;
4463-
4464- /* The highest priority value is the value of the 'LANGUAGE' environment
4465- variable. */
4466- language = getenv ("LANGUAGE");
4467- if (language != NULL && language[0] != '\0')
4468- return language;
4469-#if !defined IN_LIBGLOCALE && !defined _LIBC
4470- /* The next priority value is the locale name, if not defaulted. */
4471- if (locale_defaulted)
4472- {
4473- /* The next priority value is the default language preferences list. */
4474- language_default = _nl_language_preferences_default ();
4475- if (language_default != NULL)
4476- return language_default;
4477- }
4478- /* The least priority value is the locale name, if defaulted. */
4479-#endif
4480- return locale;
4481-}
4482-
4483-#if (defined _LIBC || HAVE_ICONV) && !defined IN_LIBGLOCALE
4484-/* Returns the output charset. */
4485-static const char *
4486-internal_function
4487-get_output_charset (struct binding *domainbinding)
4488-{
4489- /* The output charset should normally be determined by the locale. But
4490- sometimes the locale is not used or not correctly set up, so we provide
4491- a possibility for the user to override this: the OUTPUT_CHARSET
4492- environment variable. Moreover, the value specified through
4493- bind_textdomain_codeset overrides both. */
4494- if (domainbinding != NULL && domainbinding->codeset != NULL)
4495- return domainbinding->codeset;
4496- else
4497- {
4498- /* For speed reasons, we look at the value of OUTPUT_CHARSET only
4499- once. This is a user variable that is not supposed to change
4500- during a program run. */
4501- static char *output_charset_cache;
4502- static int output_charset_cached;
4503-
4504- if (!output_charset_cached)
4505- {
4506- const char *value = getenv ("OUTPUT_CHARSET");
4507-
4508- if (value != NULL && value[0] != '\0')
4509- {
4510- size_t len = strlen (value) + 1;
4511- char *value_copy = (char *) malloc (len);
4512-
4513- if (value_copy != NULL)
4514- memcpy (value_copy, value, len);
4515- output_charset_cache = value_copy;
4516- }
4517- output_charset_cached = 1;
4518- }
4519-
4520- if (output_charset_cache != NULL)
4521- return output_charset_cache;
4522- else
4523- {
4524-# ifdef _LIBC
4525- return _NL_CURRENT (LC_CTYPE, CODESET);
4526-# else
4527-# if HAVE_ICONV
4528- return locale_charset ();
4529-# endif
4530-# endif
4531- }
4532- }
4533-}
4534-#endif
4535-
4536-/* @@ begin of epilog @@ */
4537-
4538-/* We don't want libintl.a to depend on any other library. So we
4539- avoid the non-standard function stpcpy. In GNU C Library this
4540- function is available, though. Also allow the symbol HAVE_STPCPY
4541- to be defined. */
4542-#if !_LIBC && !HAVE_STPCPY
4543-static char *
4544-stpcpy (char *dest, const char *src)
4545-{
4546- while ((*dest++ = *src++) != '\0')
4547- /* Do nothing. */ ;
4548- return dest - 1;
4549-}
4550-#endif
4551-
4552-#if !_LIBC && !HAVE_MEMPCPY
4553-static void *
4554-mempcpy (void *dest, const void *src, size_t n)
4555-{
4556- return (void *) ((char *) memcpy (dest, src, n) + n);
4557-}
4558-#endif
4559-
4560-#if !_LIBC && !HAVE_TSEARCH
4561-# include "tsearch.c"
4562-#endif
4563-
4564-
4565-#ifdef _LIBC
4566-/* If we want to free all resources we have to do some work at
4567- program's end. */
4568-libc_freeres_fn (free_mem)
4569-{
4570- void *old;
4571-
4572- while (_nl_domain_bindings != NULL)
4573- {
4574- struct binding *oldp = _nl_domain_bindings;
4575- _nl_domain_bindings = _nl_domain_bindings->next;
4576- if (oldp->dirname != _nl_default_dirname)
4577- /* Yes, this is a pointer comparison. */
4578- free (oldp->dirname);
4579- free (oldp->codeset);
4580- free (oldp);
4581- }
4582-
4583- if (_nl_current_default_domain != _nl_default_default_domain)
4584- /* Yes, again a pointer comparison. */
4585- free ((char *) _nl_current_default_domain);
4586-
4587- /* Remove the search tree with the known translations. */
4588- __tdestroy (root, free);
4589- root = NULL;
4590-
4591- while (transmem_list != NULL)
4592- {
4593- old = transmem_list;
4594- transmem_list = transmem_list->next;
4595- free (old);
4596- }
4597-}
4598-#endif
4599--- a/intl/dcngettext.c
4600+++ /dev/null
4601@@ -1,57 +0,0 @@
4602-/* Implementation of the dcngettext(3) function.
4603- Copyright (C) 1995-1999, 2000-2003 Free Software Foundation, Inc.
4604-
4605- This program is free software; you can redistribute it and/or modify it
4606- under the terms of the GNU Library General Public License as published
4607- by the Free Software Foundation; either version 2, or (at your option)
4608- any later version.
4609-
4610- This program is distributed in the hope that it will be useful,
4611- but WITHOUT ANY WARRANTY; without even the implied warranty of
4612- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
4613- Library General Public License for more details.
4614-
4615- You should have received a copy of the GNU Library General Public
4616- License along with this program; if not, write to the Free Software
4617- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
4618- USA. */
4619-
4620-#ifdef HAVE_CONFIG_H
4621-# include <config.h>
4622-#endif
4623-
4624-#include "gettextP.h"
4625-#ifdef _LIBC
4626-# include <libintl.h>
4627-#else
4628-# include "libgnuintl.h"
4629-#endif
4630-
4631-/* @@ end of prolog @@ */
4632-
4633-/* Names for the libintl functions are a problem. They must not clash
4634- with existing names and they should follow ANSI C. But this source
4635- code is also used in GNU C Library where the names have a __
4636- prefix. So we have to make a difference here. */
4637-#ifdef _LIBC
4638-# define DCNGETTEXT __dcngettext
4639-# define DCIGETTEXT __dcigettext
4640-#else
4641-# define DCNGETTEXT libintl_dcngettext
4642-# define DCIGETTEXT libintl_dcigettext
4643-#endif
4644-
4645-/* Look up MSGID in the DOMAINNAME message catalog for the current CATEGORY
4646- locale. */
4647-char *
4648-DCNGETTEXT (const char *domainname,
4649- const char *msgid1, const char *msgid2, unsigned long int n,
4650- int category)
4651-{
4652- return DCIGETTEXT (domainname, msgid1, msgid2, 1, n, category);
4653-}
4654-
4655-#ifdef _LIBC
4656-/* Alias for function name in GNU C Library. */
4657-weak_alias (__dcngettext, dcngettext);
4658-#endif
4659--- a/intl/dgettext.c
4660+++ /dev/null
4661@@ -1,58 +0,0 @@
4662-/* Implementation of the dgettext(3) function.
4663- Copyright (C) 1995-1997, 2000-2003 Free Software Foundation, Inc.
4664-
4665- This program is free software; you can redistribute it and/or modify it
4666- under the terms of the GNU Library General Public License as published
4667- by the Free Software Foundation; either version 2, or (at your option)
4668- any later version.
4669-
4670- This program is distributed in the hope that it will be useful,
4671- but WITHOUT ANY WARRANTY; without even the implied warranty of
4672- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
4673- Library General Public License for more details.
4674-
4675- You should have received a copy of the GNU Library General Public
4676- License along with this program; if not, write to the Free Software
4677- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
4678- USA. */
4679-
4680-#ifdef HAVE_CONFIG_H
4681-# include <config.h>
4682-#endif
4683-
4684-#include "gettextP.h"
4685-
4686-#include <locale.h>
4687-
4688-#ifdef _LIBC
4689-# include <libintl.h>
4690-#else
4691-# include "libgnuintl.h"
4692-#endif
4693-
4694-/* @@ end of prolog @@ */
4695-
4696-/* Names for the libintl functions are a problem. They must not clash
4697- with existing names and they should follow ANSI C. But this source
4698- code is also used in GNU C Library where the names have a __
4699- prefix. So we have to make a difference here. */
4700-#ifdef _LIBC
4701-# define DGETTEXT __dgettext
4702-# define DCGETTEXT INTUSE(__dcgettext)
4703-#else
4704-# define DGETTEXT libintl_dgettext
4705-# define DCGETTEXT libintl_dcgettext
4706-#endif
4707-
4708-/* Look up MSGID in the DOMAINNAME message catalog of the current
4709- LC_MESSAGES locale. */
4710-char *
4711-DGETTEXT (const char *domainname, const char *msgid)
4712-{
4713- return DCGETTEXT (domainname, msgid, LC_MESSAGES);
4714-}
4715-
4716-#ifdef _LIBC
4717-/* Alias for function name in GNU C Library. */
4718-weak_alias (__dgettext, dgettext);
4719-#endif
4720--- a/intl/dngettext.c
4721+++ /dev/null
4722@@ -1,59 +0,0 @@
4723-/* Implementation of the dngettext(3) function.
4724- Copyright (C) 1995-1997, 2000-2003 Free Software Foundation, Inc.
4725-
4726- This program is free software; you can redistribute it and/or modify it
4727- under the terms of the GNU Library General Public License as published
4728- by the Free Software Foundation; either version 2, or (at your option)
4729- any later version.
4730-
4731- This program is distributed in the hope that it will be useful,
4732- but WITHOUT ANY WARRANTY; without even the implied warranty of
4733- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
4734- Library General Public License for more details.
4735-
4736- You should have received a copy of the GNU Library General Public
4737- License along with this program; if not, write to the Free Software
4738- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
4739- USA. */
4740-
4741-#ifdef HAVE_CONFIG_H
4742-# include <config.h>
4743-#endif
4744-
4745-#include "gettextP.h"
4746-
4747-#include <locale.h>
4748-
4749-#ifdef _LIBC
4750-# include <libintl.h>
4751-#else
4752-# include "libgnuintl.h"
4753-#endif
4754-
4755-/* @@ end of prolog @@ */
4756-
4757-/* Names for the libintl functions are a problem. They must not clash
4758- with existing names and they should follow ANSI C. But this source
4759- code is also used in GNU C Library where the names have a __
4760- prefix. So we have to make a difference here. */
4761-#ifdef _LIBC
4762-# define DNGETTEXT __dngettext
4763-# define DCNGETTEXT __dcngettext
4764-#else
4765-# define DNGETTEXT libintl_dngettext
4766-# define DCNGETTEXT libintl_dcngettext
4767-#endif
4768-
4769-/* Look up MSGID in the DOMAINNAME message catalog of the current
4770- LC_MESSAGES locale and skip message according to the plural form. */
4771-char *
4772-DNGETTEXT (const char *domainname,
4773- const char *msgid1, const char *msgid2, unsigned long int n)
4774-{
4775- return DCNGETTEXT (domainname, msgid1, msgid2, n, LC_MESSAGES);
4776-}
4777-
4778-#ifdef _LIBC
4779-/* Alias for function name in GNU C Library. */
4780-weak_alias (__dngettext, dngettext);
4781-#endif
4782--- a/intl/eval-plural.h
4783+++ /dev/null
4784@@ -1,108 +0,0 @@
4785-/* Plural expression evaluation.
4786- Copyright (C) 2000-2003, 2007 Free Software Foundation, Inc.
4787-
4788- This program is free software; you can redistribute it and/or modify it
4789- under the terms of the GNU Library General Public License as published
4790- by the Free Software Foundation; either version 2, or (at your option)
4791- any later version.
4792-
4793- This program is distributed in the hope that it will be useful,
4794- but WITHOUT ANY WARRANTY; without even the implied warranty of
4795- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
4796- Library General Public License for more details.
4797-
4798- You should have received a copy of the GNU Library General Public
4799- License along with this program; if not, write to the Free Software
4800- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
4801- USA. */
4802-
4803-#ifndef STATIC
4804-#define STATIC static
4805-#endif
4806-
4807-/* Evaluate the plural expression and return an index value. */
4808-STATIC
4809-unsigned long int
4810-internal_function
4811-plural_eval (const struct expression *pexp, unsigned long int n)
4812-{
4813- switch (pexp->nargs)
4814- {
4815- case 0:
4816- switch (pexp->operation)
4817- {
4818- case var:
4819- return n;
4820- case num:
4821- return pexp->val.num;
4822- default:
4823- break;
4824- }
4825- /* NOTREACHED */
4826- break;
4827- case 1:
4828- {
4829- /* pexp->operation must be lnot. */
4830- unsigned long int arg = plural_eval (pexp->val.args[0], n);
4831- return ! arg;
4832- }
4833- case 2:
4834- {
4835- unsigned long int leftarg = plural_eval (pexp->val.args[0], n);
4836- if (pexp->operation == lor)
4837- return leftarg || plural_eval (pexp->val.args[1], n);
4838- else if (pexp->operation == land)
4839- return leftarg && plural_eval (pexp->val.args[1], n);
4840- else
4841- {
4842- unsigned long int rightarg = plural_eval (pexp->val.args[1], n);
4843-
4844- switch (pexp->operation)
4845- {
4846- case mult:
4847- return leftarg * rightarg;
4848- case divide:
4849-#if !INTDIV0_RAISES_SIGFPE
4850- if (rightarg == 0)
4851- raise (SIGFPE);
4852-#endif
4853- return leftarg / rightarg;
4854- case module:
4855-#if !INTDIV0_RAISES_SIGFPE
4856- if (rightarg == 0)
4857- raise (SIGFPE);
4858-#endif
4859- return leftarg % rightarg;
4860- case plus:
4861- return leftarg + rightarg;
4862- case minus:
4863- return leftarg - rightarg;
4864- case less_than:
4865- return leftarg < rightarg;
4866- case greater_than:
4867- return leftarg > rightarg;
4868- case less_or_equal:
4869- return leftarg <= rightarg;
4870- case greater_or_equal:
4871- return leftarg >= rightarg;
4872- case equal:
4873- return leftarg == rightarg;
4874- case not_equal:
4875- return leftarg != rightarg;
4876- default:
4877- break;
4878- }
4879- }
4880- /* NOTREACHED */
4881- break;
4882- }
4883- case 3:
4884- {
4885- /* pexp->operation must be qmop. */
4886- unsigned long int boolarg = plural_eval (pexp->val.args[0], n);
4887- return plural_eval (pexp->val.args[boolarg ? 1 : 2], n);
4888- }
4889- }
4890- /* NOTREACHED */
4891- return 0;
4892-}
4893--- a/intl/explodename.c
4894+++ /dev/null
4895@@ -1,135 +0,0 @@
4896-/* Copyright (C) 1995-1998, 2000-2001, 2003, 2005, 2007 Free Software Foundation, Inc.
4897- Contributed by Ulrich Drepper <drepper@gnu.ai.mit.edu>, 1995.
4898-
4899- This program is free software; you can redistribute it and/or modify it
4900- under the terms of the GNU Library General Public License as published
4901- by the Free Software Foundation; either version 2, or (at your option)
4902- any later version.
4903-
4904- This program is distributed in the hope that it will be useful,
4905- but WITHOUT ANY WARRANTY; without even the implied warranty of
4906- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
4907- Library General Public License for more details.
4908-
4909- You should have received a copy of the GNU Library General Public
4910- License along with this program; if not, write to the Free Software
4911- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
4912- USA. */
4913-
4914-#ifdef HAVE_CONFIG_H
4915-# include <config.h>
4916-#endif
4917-
4918-#include <stdlib.h>
4919-#include <string.h>
4920-#include <sys/types.h>
4921-
4922-#include "loadinfo.h"
4923-
4924-/* On some strange systems still no definition of NULL is found. Sigh! */
4925-#ifndef NULL
4926-# if defined __STDC__ && __STDC__
4927-# define NULL ((void *) 0)
4928-# else
4929-# define NULL 0
4930-# endif
4931-#endif
4932-
4933-/* @@ end of prolog @@ */
4934-
4935-/* Split a locale name NAME into a leading language part and all the
4936- rest. Return a pointer to the first character after the language,
4937- i.e. to the first byte of the rest. */
4938-static char *_nl_find_language (const char *name);
4939-
4940-static char *
4941-_nl_find_language (const char *name)
4942-{
4943- while (name[0] != '\0' && name[0] != '_' && name[0] != '@' && name[0] != '.')
4944- ++name;
4945-
4946- return (char *) name;
4947-}
4948-
4949-
4950-int
4951-_nl_explode_name (char *name,
4952- const char **language, const char **modifier,
4953- const char **territory, const char **codeset,
4954- const char **normalized_codeset)
4955-{
4956- char *cp;
4957- int mask;
4958-
4959- *modifier = NULL;
4960- *territory = NULL;
4961- *codeset = NULL;
4962- *normalized_codeset = NULL;
4963-
4964- /* Now we determine the single parts of the locale name. First
4965- look for the language. Termination symbols are `_', '.', and `@'. */
4966- mask = 0;
4967- *language = cp = name;
4968- cp = _nl_find_language (*language);
4969-
4970- if (*language == cp)
4971- /* This does not make sense: language has to be specified. Use
4972- this entry as it is without exploding. Perhaps it is an alias. */
4973- cp = strchr (*language, '\0');
4974- else
4975- {
4976- if (cp[0] == '_')
4977- {
4978- /* Next is the territory. */
4979- cp[0] = '\0';
4980- *territory = ++cp;
4981-
4982- while (cp[0] != '\0' && cp[0] != '.' && cp[0] != '@')
4983- ++cp;
4984-
4985- mask |= XPG_TERRITORY;
4986- }
4987-
4988- if (cp[0] == '.')
4989- {
4990- /* Next is the codeset. */
4991- cp[0] = '\0';
4992- *codeset = ++cp;
4993-
4994- while (cp[0] != '\0' && cp[0] != '@')
4995- ++cp;
4996-
4997- mask |= XPG_CODESET;
4998-
4999- if (*codeset != cp && (*codeset)[0] != '\0')
5000- {
5001- *normalized_codeset = _nl_normalize_codeset (*codeset,
5002- cp - *codeset);
5003- if (*normalized_codeset == NULL)
5004- return -1;
5005- else if (strcmp (*codeset, *normalized_codeset) == 0)
5006- free ((char *) *normalized_codeset);
5007- else
5008- mask |= XPG_NORM_CODESET;
5009- }
5010- }
5011- }
5012-
5013- if (cp[0] == '@')
5014- {
5015- /* Next is the modifier. */
5016- cp[0] = '\0';
5017- *modifier = ++cp;
5018-
5019- if (cp[0] != '\0')
5020- mask |= XPG_MODIFIER;
5021- }
5022-
5023- if (*territory != NULL && (*territory)[0] == '\0')
5024- mask &= ~XPG_TERRITORY;
5025-
5026- if (*codeset != NULL && (*codeset)[0] == '\0')
5027- mask &= ~XPG_CODESET;
5028-
5029- return mask;
5030-}
5031--- a/intl/export.h
5032+++ /dev/null
5033@@ -1,6 +0,0 @@
5034-
5035-#if @HAVE_VISIBILITY@ && BUILDING_LIBINTL
5036-#define LIBINTL_DLL_EXPORTED __attribute__((__visibility__("default")))
5037-#else
5038-#define LIBINTL_DLL_EXPORTED
5039-#endif
5040--- a/intl/finddomain.c
5041+++ /dev/null
5042@@ -1,212 +0,0 @@
5043-/* Handle list of needed message catalogs
5044- Copyright (C) 1995-1999, 2000-2001, 2003-2007 Free Software Foundation, Inc.
5045- Written by Ulrich Drepper <drepper@gnu.org>, 1995.
5046-
5047- This program is free software; you can redistribute it and/or modify it
5048- under the terms of the GNU Library General Public License as published
5049- by the Free Software Foundation; either version 2, or (at your option)
5050- any later version.
5051-
5052- This program is distributed in the hope that it will be useful,
5053- but WITHOUT ANY WARRANTY; without even the implied warranty of
5054- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
5055- Library General Public License for more details.
5056-
5057- You should have received a copy of the GNU Library General Public
5058- License along with this program; if not, write to the Free Software
5059- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
5060- USA. */
5061-
5062-#ifdef HAVE_CONFIG_H
5063-# include <config.h>
5064-#endif
5065-
5066-#include <stdio.h>
5067-#include <sys/types.h>
5068-#include <stdlib.h>
5069-#include <string.h>
5070-
5071-#if defined HAVE_UNISTD_H || defined _LIBC
5072-# include <unistd.h>
5073-#endif
5074-
5075-#include "gettextP.h"
5076-#ifdef _LIBC
5077-# include <libintl.h>
5078-#else
5079-# include "libgnuintl.h"
5080-#endif
5081-
5082-/* Handle multi-threaded applications. */
5083-#ifdef _LIBC
5084-# include <bits/libc-lock.h>
5085-# define gl_rwlock_define_initialized __libc_rwlock_define_initialized
5086-# define gl_rwlock_rdlock __libc_rwlock_rdlock
5087-# define gl_rwlock_wrlock __libc_rwlock_wrlock
5088-# define gl_rwlock_unlock __libc_rwlock_unlock
5089-#else
5090-# include "lock.h"
5091-#endif
5092-
5093-/* @@ end of prolog @@ */
5094-/* List of already loaded domains. */
5095-static struct loaded_l10nfile *_nl_loaded_domains;
5096-
5097-
5098-/* Return a data structure describing the message catalog described by
5099- the DOMAINNAME and CATEGORY parameters with respect to the currently
5100- established bindings. */
5101-struct loaded_l10nfile *
5102-internal_function
5103-_nl_find_domain (const char *dirname, char *locale,
5104- const char *domainname, struct binding *domainbinding)
5105-{
5106- struct loaded_l10nfile *retval;
5107- const char *language;
5108- const char *modifier;
5109- const char *territory;
5110- const char *codeset;
5111- const char *normalized_codeset;
5112- const char *alias_value;
5113- int mask;
5114-
5115- /* LOCALE can consist of up to four recognized parts for the XPG syntax:
5116-
5117- language[_territory][.codeset][@modifier]
5118-
5119- Beside the first part all of them are allowed to be missing. If
5120- the full specified locale is not found, the less specific one are
5121- looked for. The various parts will be stripped off according to
5122- the following order:
5123- (1) codeset
5124- (2) normalized codeset
5125- (3) territory
5126- (4) modifier
5127- */
5128-
5129- /* We need to protect modifying the _NL_LOADED_DOMAINS data. */
5130- gl_rwlock_define_initialized (static, lock);
5131- gl_rwlock_rdlock (lock);
5132-
5133- /* If we have already tested for this locale entry there has to
5134- be one data set in the list of loaded domains. */
5135- retval = _nl_make_l10nflist (&_nl_loaded_domains, dirname,
5136- strlen (dirname) + 1, 0, locale, NULL, NULL,
5137- NULL, NULL, domainname, 0);
5138-
5139- gl_rwlock_unlock (lock);
5140-
5141- if (retval != NULL)
5142- {
5143- /* We know something about this locale. */
5144- int cnt;
5145-
5146- if (retval->decided <= 0)
5147- _nl_load_domain (retval, domainbinding);
5148-
5149- if (retval->data != NULL)
5150- return retval;
5151-
5152- for (cnt = 0; retval->successor[cnt] != NULL; ++cnt)
5153- {
5154- if (retval->successor[cnt]->decided <= 0)
5155- _nl_load_domain (retval->successor[cnt], domainbinding);
5156-
5157- if (retval->successor[cnt]->data != NULL)
5158- break;
5159- }
5160-
5161- return retval;
5162- /* NOTREACHED */
5163- }
5164-
5165- /* See whether the locale value is an alias. If yes its value
5166- *overwrites* the alias name. No test for the original value is
5167- done. */
5168- alias_value = _nl_expand_alias (locale);
5169- if (alias_value != NULL)
5170- {
5171-#if defined _LIBC || defined HAVE_STRDUP
5172- locale = strdup (alias_value);
5173- if (locale == NULL)
5174- return NULL;
5175-#else
5176- size_t len = strlen (alias_value) + 1;
5177- locale = (char *) malloc (len);
5178- if (locale == NULL)
5179- return NULL;
5180-
5181- memcpy (locale, alias_value, len);
5182-#endif
5183- }
5184-
5185- /* Now we determine the single parts of the locale name. First
5186- look for the language. Termination symbols are `_', '.', and `@'. */
5187- mask = _nl_explode_name (locale, &language, &modifier, &territory,
5188- &codeset, &normalized_codeset);
5189- if (mask == -1)
5190- /* This means we are out of core. */
5191- return NULL;
5192-
5193- /* We need to protect modifying the _NL_LOADED_DOMAINS data. */
5194- gl_rwlock_wrlock (lock);
5195-
5196- /* Create all possible locale entries which might be interested in
5197- generalization. */
5198- retval = _nl_make_l10nflist (&_nl_loaded_domains, dirname,
5199- strlen (dirname) + 1, mask, language, territory,
5200- codeset, normalized_codeset, modifier,
5201- domainname, 1);
5202-
5203- gl_rwlock_unlock (lock);
5204-
5205- if (retval == NULL)
5206- /* This means we are out of core. */
5207- goto out;
5208-
5209- if (retval->decided <= 0)
5210- _nl_load_domain (retval, domainbinding);
5211- if (retval->data == NULL)
5212- {
5213- int cnt;
5214- for (cnt = 0; retval->successor[cnt] != NULL; ++cnt)
5215- {
5216- if (retval->successor[cnt]->decided <= 0)
5217- _nl_load_domain (retval->successor[cnt], domainbinding);
5218- if (retval->successor[cnt]->data != NULL)
5219- break;
5220- }
5221- }
5222-
5223- /* The room for an alias was dynamically allocated. Free it now. */
5224- if (alias_value != NULL)
5225- free (locale);
5226-
5227-out:
5228- /* The space for normalized_codeset is dynamically allocated. Free it. */
5229- if (mask & XPG_NORM_CODESET)
5230- free ((void *) normalized_codeset);
5231-
5232- return retval;
5233-}
5234-
5235-
5236-#ifdef _LIBC
5237-/* This is called from iconv/gconv_db.c's free_mem, as locales must
5238- be freed before freeing gconv steps arrays. */
5239-void __libc_freeres_fn_section
5240-_nl_finddomain_subfreeres ()
5241-{
5242- struct loaded_l10nfile *runp = _nl_loaded_domains;
5243-
5244- while (runp != NULL)
5245- {
5246- struct loaded_l10nfile *here = runp;
5247- if (runp->data != NULL)
5248- _nl_unload_domain ((struct loaded_domain *) runp->data);
5249- runp = runp->next;
5250- free ((char *) here->filename);
5251- free (here);
5252- }
5253-}
5254-#endif
5255--- a/intl/gettext.c
5256+++ /dev/null
5257@@ -1,63 +0,0 @@
5258-/* Implementation of gettext(3) function.
5259- Copyright (C) 1995, 1997, 2000-2003 Free Software Foundation, Inc.
5260-
5261- This program is free software; you can redistribute it and/or modify it
5262- under the terms of the GNU Library General Public License as published
5263- by the Free Software Foundation; either version 2, or (at your option)
5264- any later version.
5265-
5266- This program is distributed in the hope that it will be useful,
5267- but WITHOUT ANY WARRANTY; without even the implied warranty of
5268- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
5269- Library General Public License for more details.
5270-
5271- You should have received a copy of the GNU Library General Public
5272- License along with this program; if not, write to the Free Software
5273- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
5274- USA. */
5275-
5276-#ifdef HAVE_CONFIG_H
5277-# include <config.h>
5278-#endif
5279-
5280-#ifdef _LIBC
5281-# define __need_NULL
5282-# include <stddef.h>
5283-#else
5284-# include <stdlib.h> /* Just for NULL. */
5285-#endif
5286-
5287-#include "gettextP.h"
5288-#ifdef _LIBC
5289-# include <libintl.h>
5290-#else
5291-# include "libgnuintl.h"
5292-#endif
5293-
5294-/* @@ end of prolog @@ */
5295-
5296-/* Names for the libintl functions are a problem. They must not clash
5297- with existing names and they should follow ANSI C. But this source
5298- code is also used in GNU C Library where the names have a __
5299- prefix. So we have to make a difference here. */
5300-#ifdef _LIBC
5301-# define GETTEXT __gettext
5302-# define DCGETTEXT INTUSE(__dcgettext)
5303-#else
5304-# define GETTEXT libintl_gettext
5305-# define DCGETTEXT libintl_dcgettext
5306-#endif
5307-
5308-/* Look up MSGID in the current default message catalog for the current
5309- LC_MESSAGES locale. If not found, returns MSGID itself (the default
5310- text). */
5311-char *
5312-GETTEXT (const char *msgid)
5313-{
5314- return DCGETTEXT (NULL, msgid, LC_MESSAGES);
5315-}
5316-
5317-#ifdef _LIBC
5318-/* Alias for function name in GNU C Library. */
5319-weak_alias (__gettext, gettext);
5320-#endif
5321--- a/intl/gettextP.h
5322+++ /dev/null
5323@@ -1,297 +0,0 @@
5324-/* Header describing internals of libintl library.
5325- Copyright (C) 1995-1999, 2000-2007 Free Software Foundation, Inc.
5326- Written by Ulrich Drepper <drepper@cygnus.com>, 1995.
5327-
5328- This program is free software; you can redistribute it and/or modify it
5329- under the terms of the GNU Library General Public License as published
5330- by the Free Software Foundation; either version 2, or (at your option)
5331- any later version.
5332-
5333- This program is distributed in the hope that it will be useful,
5334- but WITHOUT ANY WARRANTY; without even the implied warranty of
5335- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
5336- Library General Public License for more details.
5337-
5338- You should have received a copy of the GNU Library General Public
5339- License along with this program; if not, write to the Free Software
5340- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
5341- USA. */
5342-
5343-#ifndef _GETTEXTP_H
5344-#define _GETTEXTP_H
5345-
5346-#include <stddef.h> /* Get size_t. */
5347-
5348-#ifdef _LIBC
5349-# include "../iconv/gconv_int.h"
5350-#else
5351-# if HAVE_ICONV
5352-# include <iconv.h>
5353-# endif
5354-#endif
5355-
5356-/* Handle multi-threaded applications. */
5357-#ifdef _LIBC
5358-# include <bits/libc-lock.h>
5359-# define gl_rwlock_define __libc_rwlock_define
5360-#else
5361-# include "lock.h"
5362-#endif
5363-
5364-#ifdef _LIBC
5365-extern char *__gettext (const char *__msgid);
5366-extern char *__dgettext (const char *__domainname, const char *__msgid);
5367-extern char *__dcgettext (const char *__domainname, const char *__msgid,
5368- int __category);
5369-extern char *__ngettext (const char *__msgid1, const char *__msgid2,
5370- unsigned long int __n);
5371-extern char *__dngettext (const char *__domainname,
5372- const char *__msgid1, const char *__msgid2,
5373- unsigned long int n);
5374-extern char *__dcngettext (const char *__domainname,
5375- const char *__msgid1, const char *__msgid2,
5376- unsigned long int __n, int __category);
5377-extern char *__dcigettext (const char *__domainname,
5378- const char *__msgid1, const char *__msgid2,
5379- int __plural, unsigned long int __n,
5380- int __category);
5381-extern char *__textdomain (const char *__domainname);
5382-extern char *__bindtextdomain (const char *__domainname,
5383- const char *__dirname);
5384-extern char *__bind_textdomain_codeset (const char *__domainname,
5385- const char *__codeset);
5386-extern void _nl_finddomain_subfreeres (void) attribute_hidden;
5387-extern void _nl_unload_domain (struct loaded_domain *__domain)
5388- internal_function attribute_hidden;
5389-#else
5390-/* Declare the exported libintl_* functions, in a way that allows us to
5391- call them under their real name. */
5392-# undef _INTL_REDIRECT_INLINE
5393-# undef _INTL_REDIRECT_MACROS
5394-# define _INTL_REDIRECT_MACROS
5395-# include "libgnuintl.h"
5396-# ifdef IN_LIBGLOCALE
5397-extern char *gl_dcigettext (const char *__domainname,
5398- const char *__msgid1, const char *__msgid2,
5399- int __plural, unsigned long int __n,
5400- int __category,
5401- const char *__localename, const char *__encoding);
5402-# else
5403-extern char *libintl_dcigettext (const char *__domainname,
5404- const char *__msgid1, const char *__msgid2,
5405- int __plural, unsigned long int __n,
5406- int __category);
5407-# endif
5408-#endif
5409-
5410-#include "loadinfo.h"
5411-
5412-#include "gmo.h" /* Get nls_uint32. */
5413-
5414-/* @@ end of prolog @@ */
5415-
5416-#ifndef internal_function
5417-# define internal_function
5418-#endif
5419-
5420-#ifndef attribute_hidden
5421-# define attribute_hidden
5422-#endif
5423-
5424-/* Tell the compiler when a conditional or integer expression is
5425- almost always true or almost always false. */
5426-#ifndef HAVE_BUILTIN_EXPECT
5427-# define __builtin_expect(expr, val) (expr)
5428-#endif
5429-
5430-#ifndef W
5431-# define W(flag, data) ((flag) ? SWAP (data) : (data))
5432-#endif
5433-
5434-
5435-#ifdef _LIBC
5436-# include <byteswap.h>
5437-# define SWAP(i) bswap_32 (i)
5438-#else
5439-static inline nls_uint32
5440-# ifdef __cplusplus
5441-SWAP (nls_uint32 i)
5442-# else
5443-SWAP (i)
5444- nls_uint32 i;
5445-# endif
5446-{
5447- return (i << 24) | ((i & 0xff00) << 8) | ((i >> 8) & 0xff00) | (i >> 24);
5448-}
5449-#endif
5450-
5451-
5452-/* In-memory representation of system dependent string. */
5453-struct sysdep_string_desc
5454-{
5455- /* Length of addressed string, including the trailing NUL. */
5456- size_t length;
5457- /* Pointer to addressed string. */
5458- const char *pointer;
5459-};
5460-
5461-/* Cache of translated strings after charset conversion.
5462- Note: The strings are converted to the target encoding only on an as-needed
5463- basis. */
5464-struct converted_domain
5465-{
5466- /* The target encoding name. */
5467- const char *encoding;
5468- /* The descriptor for conversion from the message catalog's encoding to
5469- this target encoding. */
5470-#ifdef _LIBC
5471- __gconv_t conv;
5472-#else
5473-# if HAVE_ICONV
5474- iconv_t conv;
5475-# endif
5476-#endif
5477- /* The table of translated strings after charset conversion. */
5478- char **conv_tab;
5479-};
5480-
5481-/* The representation of an opened message catalog. */
5482-struct loaded_domain
5483-{
5484- /* Pointer to memory containing the .mo file. */
5485- const char *data;
5486- /* 1 if the memory is mmap()ed, 0 if the memory is malloc()ed. */
5487- int use_mmap;
5488- /* Size of mmap()ed memory. */
5489- size_t mmap_size;
5490- /* 1 if the .mo file uses a different endianness than this machine. */
5491- int must_swap;
5492- /* Pointer to additional malloc()ed memory. */
5493- void *malloced;
5494-
5495- /* Number of static strings pairs. */
5496- nls_uint32 nstrings;
5497- /* Pointer to descriptors of original strings in the file. */
5498- const struct string_desc *orig_tab;
5499- /* Pointer to descriptors of translated strings in the file. */
5500- const struct string_desc *trans_tab;
5501-
5502- /* Number of system dependent strings pairs. */
5503- nls_uint32 n_sysdep_strings;
5504- /* Pointer to descriptors of original sysdep strings. */
5505- const struct sysdep_string_desc *orig_sysdep_tab;
5506- /* Pointer to descriptors of translated sysdep strings. */
5507- const struct sysdep_string_desc *trans_sysdep_tab;
5508-
5509- /* Size of hash table. */
5510- nls_uint32 hash_size;
5511- /* Pointer to hash table. */
5512- const nls_uint32 *hash_tab;
5513- /* 1 if the hash table uses a different endianness than this machine. */
5514- int must_swap_hash_tab;
5515-
5516- /* Cache of charset conversions of the translated strings. */
5517- struct converted_domain *conversions;
5518- size_t nconversions;
5519- gl_rwlock_define (, conversions_lock)
5520-
5521- const struct expression *plural;
5522- unsigned long int nplurals;
5523-};
5524-
5525-/* We want to allocate a string at the end of the struct. But ISO C
5526- doesn't allow zero sized arrays. */
5527-#ifdef __GNUC__
5528-# define ZERO 0
5529-#else
5530-# define ZERO 1
5531-#endif
5532-
5533-/* A set of settings bound to a message domain. Used to store settings
5534- from bindtextdomain() and bind_textdomain_codeset(). */
5535-struct binding
5536-{
5537- struct binding *next;
5538- char *dirname;
5539- char *codeset;
5540- char domainname[ZERO];
5541-};
5542-
5543-/* A counter which is incremented each time some previous translations
5544- become invalid.
5545- This variable is part of the external ABI of the GNU libintl. */
5546-#ifdef IN_LIBGLOCALE
5547-# include <glocale/config.h>
5548-extern LIBGLOCALE_DLL_EXPORTED int _nl_msg_cat_cntr;
5549-#else
5550-extern LIBINTL_DLL_EXPORTED int _nl_msg_cat_cntr;
5551-#endif
5552-
5553-#ifndef _LIBC
5554-extern const char *_nl_language_preferences_default (void);
5555-# define gl_locale_name_canonicalize _nl_locale_name_canonicalize
5556-extern void _nl_locale_name_canonicalize (char *name);
5557-# define gl_locale_name_posix _nl_locale_name_posix
5558-extern const char *_nl_locale_name_posix (int category,
5559- const char *categoryname);
5560-# define gl_locale_name_default _nl_locale_name_default
5561-extern const char *_nl_locale_name_default (void);
5562-# define gl_locale_name _nl_locale_name
5563-extern const char *_nl_locale_name (int category, const char *categoryname);
5564-#endif
5565-
5566-struct loaded_l10nfile *_nl_find_domain (const char *__dirname, char *__locale,
5567- const char *__domainname,
5568- struct binding *__domainbinding)
5569- internal_function;
5570-void _nl_load_domain (struct loaded_l10nfile *__domain,
5571- struct binding *__domainbinding)
5572- internal_function;
5573-
5574-#ifdef IN_LIBGLOCALE
5575-char *_nl_find_msg (struct loaded_l10nfile *domain_file,
5576- struct binding *domainbinding, const char *encoding,
5577- const char *msgid,
5578- size_t *lengthp)
5579- internal_function;
5580-#else
5581-char *_nl_find_msg (struct loaded_l10nfile *domain_file,
5582- struct binding *domainbinding, const char *msgid,
5583- int convert, size_t *lengthp)
5584- internal_function;
5585-#endif
5586-
5587-/* The internal variables in the standalone libintl.a must have different
5588- names than the internal variables in GNU libc, otherwise programs
5589- using libintl.a cannot be linked statically. */
5590-#if !defined _LIBC
5591-# define _nl_default_dirname libintl_nl_default_dirname
5592-# define _nl_domain_bindings libintl_nl_domain_bindings
5593-#endif
5594-
5595-/* Contains the default location of the message catalogs. */
5596-extern const char _nl_default_dirname[];
5597-#ifdef _LIBC
5598-libc_hidden_proto (_nl_default_dirname)
5599-#endif
5600-
5601-/* List with bindings of specific domains. */
5602-extern struct binding *_nl_domain_bindings;
5603-
5604-/* The internal variables in the standalone libintl.a must have different
5605- names than the internal variables in GNU libc, otherwise programs
5606- using libintl.a cannot be linked statically. */
5607-#if !defined _LIBC
5608-# define _nl_default_default_domain libintl_nl_default_default_domain
5609-# define _nl_current_default_domain libintl_nl_current_default_domain
5610-#endif
5611-
5612-/* Name of the default text domain. */
5613-extern const char _nl_default_default_domain[] attribute_hidden;
5614-
5615-/* Default text domain in which entries for gettext(3) are to be found. */
5616-extern const char *_nl_current_default_domain attribute_hidden;
5617-
5618-/* @@ begin of epilog @@ */
5619-
5620-#endif /* gettextP.h */
5621--- a/intl/gmo.h
5622+++ /dev/null
5623@@ -1,152 +0,0 @@
5624-/* Description of GNU message catalog format: general file layout.
5625- Copyright (C) 1995, 1997, 2000-2002, 2004, 2006 Free Software Foundation, Inc.
5626-
5627- This program is free software; you can redistribute it and/or modify it
5628- under the terms of the GNU Library General Public License as published
5629- by the Free Software Foundation; either version 2, or (at your option)
5630- any later version.
5631-
5632- This program is distributed in the hope that it will be useful,
5633- but WITHOUT ANY WARRANTY; without even the implied warranty of
5634- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
5635- Library General Public License for more details.
5636-
5637- You should have received a copy of the GNU Library General Public
5638- License along with this program; if not, write to the Free Software
5639- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
5640- USA. */
5641-
5642-#ifndef _GETTEXT_H
5643-#define _GETTEXT_H 1
5644-
5645-#include <limits.h>
5646-
5647-/* @@ end of prolog @@ */
5648-
5649-/* The magic number of the GNU message catalog format. */
5650-#define _MAGIC 0x950412de
5651-#define _MAGIC_SWAPPED 0xde120495
5652-
5653-/* Revision number of the currently used .mo (binary) file format. */
5654-#define MO_REVISION_NUMBER 0
5655-#define MO_REVISION_NUMBER_WITH_SYSDEP_I 1
5656-
5657-/* The following contortions are an attempt to use the C preprocessor
5658- to determine an unsigned integral type that is 32 bits wide. An
5659- alternative approach is to use autoconf's AC_CHECK_SIZEOF macro, but
5660- as of version autoconf-2.13, the AC_CHECK_SIZEOF macro doesn't work
5661- when cross-compiling. */
5662-
5663-#if __STDC__
5664-# define UINT_MAX_32_BITS 4294967295U
5665-#else
5666-# define UINT_MAX_32_BITS 0xFFFFFFFF
5667-#endif
5668-
5669-/* If UINT_MAX isn't defined, assume it's a 32-bit type.
5670- This should be valid for all systems GNU cares about because
5671- that doesn't include 16-bit systems, and only modern systems
5672- (that certainly have <limits.h>) have 64+-bit integral types. */
5673-
5674-#ifndef UINT_MAX
5675-# define UINT_MAX UINT_MAX_32_BITS
5676-#endif
5677-
5678-#if UINT_MAX == UINT_MAX_32_BITS
5679-typedef unsigned nls_uint32;
5680-#else
5681-# if USHRT_MAX == UINT_MAX_32_BITS
5682-typedef unsigned short nls_uint32;
5683-# else
5684-# if ULONG_MAX == UINT_MAX_32_BITS
5685-typedef unsigned long nls_uint32;
5686-# else
5687- /* The following line is intended to throw an error. Using #error is
5688- not portable enough. */
5689- "Cannot determine unsigned 32-bit data type."
5690-# endif
5691-# endif
5692-#endif
5693-
5694-
5695-/* Header for binary .mo file format. */
5696-struct mo_file_header
5697-{
5698- /* The magic number. */
5699- nls_uint32 magic;
5700- /* The revision number of the file format. */
5701- nls_uint32 revision;
5702-
5703- /* The following are only used in .mo files with major revision 0 or 1. */
5704-
5705- /* The number of strings pairs. */
5706- nls_uint32 nstrings;
5707- /* Offset of table with start offsets of original strings. */
5708- nls_uint32 orig_tab_offset;
5709- /* Offset of table with start offsets of translated strings. */
5710- nls_uint32 trans_tab_offset;
5711- /* Size of hash table. */
5712- nls_uint32 hash_tab_size;
5713- /* Offset of first hash table entry. */
5714- nls_uint32 hash_tab_offset;
5715-
5716- /* The following are only used in .mo files with minor revision >= 1. */
5717-
5718- /* The number of system dependent segments. */
5719- nls_uint32 n_sysdep_segments;
5720- /* Offset of table describing system dependent segments. */
5721- nls_uint32 sysdep_segments_offset;
5722- /* The number of system dependent strings pairs. */
5723- nls_uint32 n_sysdep_strings;
5724- /* Offset of table with start offsets of original sysdep strings. */
5725- nls_uint32 orig_sysdep_tab_offset;
5726- /* Offset of table with start offsets of translated sysdep strings. */
5727- nls_uint32 trans_sysdep_tab_offset;
5728-};
5729-
5730-/* Descriptor for static string contained in the binary .mo file. */
5731-struct string_desc
5732-{
5733- /* Length of addressed string, not including the trailing NUL. */
5734- nls_uint32 length;
5735- /* Offset of string in file. */
5736- nls_uint32 offset;
5737-};
5738-
5739-/* The following are only used in .mo files with minor revision >= 1. */
5740-
5741-/* Descriptor for system dependent string segment. */
5742-struct sysdep_segment
5743-{
5744- /* Length of addressed string, including the trailing NUL. */
5745- nls_uint32 length;
5746- /* Offset of string in file. */
5747- nls_uint32 offset;
5748-};
5749-
5750-/* Pair of a static and a system dependent segment, in struct sysdep_string. */
5751-struct segment_pair
5752-{
5753- /* Size of static segment. */
5754- nls_uint32 segsize;
5755- /* Reference to system dependent string segment, or ~0 at the end. */
5756- nls_uint32 sysdepref;
5757-};
5758-
5759-/* Descriptor for system dependent string. */
5760-struct sysdep_string
5761-{
5762- /* Offset of static string segments in file. */
5763- nls_uint32 offset;
5764- /* Alternating sequence of static and system dependent segments.
5765- The last segment is a static segment, including the trailing NUL. */
5766- struct segment_pair segments[1];
5767-};
5768-
5769-/* Marker for the end of the segments[] array. This has the value 0xFFFFFFFF,
5770- regardless whether 'int' is 16 bit, 32 bit, or 64 bit. */
5771-#define SEGMENTS_END ((nls_uint32) ~0)
5772-
5773-/* @@ begin of epilog @@ */
5774-
5775-#endif /* gettext.h */
5776--- a/intl/hash-string.c
5777+++ /dev/null
5778@@ -1,51 +0,0 @@
5779-/* Implements a string hashing function.
5780- Copyright (C) 1995, 1997, 1998, 2000, 2003 Free Software Foundation, Inc.
5781- This file is part of the GNU C Library.
5782-
5783- The GNU C Library is free software; you can redistribute it and/or
5784- modify it under the terms of the GNU Lesser General Public
5785- License as published by the Free Software Foundation; either
5786- version 2.1 of the License, or (at your option) any later version.
5787-
5788- The GNU C Library is distributed in the hope that it will be useful,
5789- but WITHOUT ANY WARRANTY; without even the implied warranty of
5790- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
5791- Lesser General Public License for more details.
5792-
5793- You should have received a copy of the GNU Lesser General Public
5794- License along with the GNU C Library; if not, write to the Free
5795- Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
5796- Boston, MA 02110-1301, USA. */
5797-
5798-#ifdef HAVE_CONFIG_H
5799-# include <config.h>
5800-#endif
5801-
5802-/* Specification. */
5803-#include "hash-string.h"
5804-
5805-
5806-/* Defines the so called `hashpjw' function by P.J. Weinberger
5807- [see Aho/Sethi/Ullman, COMPILERS: Principles, Techniques and Tools,
5808- 1986, 1987 Bell Telephone Laboratories, Inc.] */
5809-unsigned long int
5810-__hash_string (const char *str_param)
5811-{
5812- unsigned long int hval, g;
5813- const char *str = str_param;
5814-
5815- /* Compute the hash value for the given string. */
5816- hval = 0;
5817- while (*str != '\0')
5818- {
5819- hval <<= 4;
5820- hval += (unsigned char) *str++;
5821- g = hval & ((unsigned long int) 0xf << (HASHWORDBITS - 4));
5822- if (g != 0)
5823- {
5824- hval ^= g >> (HASHWORDBITS - 8);
5825- hval ^= g;
5826- }
5827- }
5828- return hval;
5829-}
5830--- a/intl/hash-string.h
5831+++ /dev/null
5832@@ -1,36 +0,0 @@
5833-/* Description of GNU message catalog format: string hashing function.
5834- Copyright (C) 1995, 1997-1998, 2000-2003, 2005 Free Software Foundation, Inc.
5835-
5836- This program is free software; you can redistribute it and/or modify it
5837- under the terms of the GNU Library General Public License as published
5838- by the Free Software Foundation; either version 2, or (at your option)
5839- any later version.
5840-
5841- This program is distributed in the hope that it will be useful,
5842- but WITHOUT ANY WARRANTY; without even the implied warranty of
5843- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
5844- Library General Public License for more details.
5845-
5846- You should have received a copy of the GNU Library General Public
5847- License along with this program; if not, write to the Free Software
5848- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
5849- USA. */
5850-
5851-/* @@ end of prolog @@ */
5852-
5853-/* We assume to have `unsigned long int' value with at least 32 bits. */
5854-#define HASHWORDBITS 32
5855-
5856-
5857-#ifndef _LIBC
5858-# ifdef IN_LIBINTL
5859-# define __hash_string libintl_hash_string
5860-# else
5861-# define __hash_string hash_string
5862-# endif
5863-#endif
5864-
5865-/* Defines the so called `hashpjw' function by P.J. Weinberger
5866- [see Aho/Sethi/Ullman, COMPILERS: Principles, Techniques and Tools,
5867- 1986, 1987 Bell Telephone Laboratories, Inc.] */
5868-extern unsigned long int __hash_string (const char *str_param);
5869--- a/intl/intl-compat.c
5870+++ /dev/null
5871@@ -1,133 +0,0 @@
5872-/* intl-compat.c - Stub functions to call gettext functions from GNU gettext
5873- Library.
5874- Copyright (C) 1995, 2000-2003, 2005 Software Foundation, Inc.
5875-
5876- This program is free software; you can redistribute it and/or modify it
5877- under the terms of the GNU Library General Public License as published
5878- by the Free Software Foundation; either version 2, or (at your option)
5879- any later version.
5880-
5881- This program is distributed in the hope that it will be useful,
5882- but WITHOUT ANY WARRANTY; without even the implied warranty of
5883- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
5884- Library General Public License for more details.
5885-
5886- You should have received a copy of the GNU Library General Public
5887- License along with this program; if not, write to the Free Software
5888- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
5889- USA. */
5890-
5891-#ifdef HAVE_CONFIG_H
5892-# include <config.h>
5893-#endif
5894-
5895-#include "gettextP.h"
5896-
5897-/* @@ end of prolog @@ */
5898-
5899-/* This file redirects the gettext functions (without prefix) to those
5900- defined in the included GNU libintl library (with "libintl_" prefix).
5901- It is compiled into libintl in order to make the AM_GNU_GETTEXT test
5902- of gettext <= 0.11.2 work with the libintl library >= 0.11.3 which
5903- has the redirections primarily in the <libintl.h> include file.
5904- It is also compiled into libgnuintl so that libgnuintl.so can be used
5905- as LD_PRELOADable library on glibc systems, to provide the extra
5906- features that the functions in the libc don't have (namely, logging). */
5907-
5908-
5909-#undef gettext
5910-#undef dgettext
5911-#undef dcgettext
5912-#undef ngettext
5913-#undef dngettext
5914-#undef dcngettext
5915-#undef textdomain
5916-#undef bindtextdomain
5917-#undef bind_textdomain_codeset
5918-
5919-
5920-/* When building a DLL, we must export some functions. Note that because
5921- the functions are only defined for binary backward compatibility, we
5922- don't need to use __declspec(dllimport) in any case. */
5923-#if HAVE_VISIBILITY && BUILDING_DLL
5924-# define DLL_EXPORTED __attribute__((__visibility__("default")))
5925-#elif defined _MSC_VER && BUILDING_DLL
5926-# define DLL_EXPORTED __declspec(dllexport)
5927-#else
5928-# define DLL_EXPORTED
5929-#endif
5930-
5931-
5932-DLL_EXPORTED
5933-char *
5934-gettext (const char *msgid)
5935-{
5936- return libintl_gettext (msgid);
5937-}
5938-
5939-
5940-DLL_EXPORTED
5941-char *
5942-dgettext (const char *domainname, const char *msgid)
5943-{
5944- return libintl_dgettext (domainname, msgid);
5945-}
5946-
5947-
5948-DLL_EXPORTED
5949-char *
5950-dcgettext (const char *domainname, const char *msgid, int category)
5951-{
5952- return libintl_dcgettext (domainname, msgid, category);
5953-}
5954-
5955-
5956-DLL_EXPORTED
5957-char *
5958-ngettext (const char *msgid1, const char *msgid2, unsigned long int n)
5959-{
5960- return libintl_ngettext (msgid1, msgid2, n);
5961-}
5962-
5963-
5964-DLL_EXPORTED
5965-char *
5966-dngettext (const char *domainname,
5967- const char *msgid1, const char *msgid2, unsigned long int n)
5968-{
5969- return libintl_dngettext (domainname, msgid1, msgid2, n);
5970-}
5971-
5972-
5973-DLL_EXPORTED
5974-char *
5975-dcngettext (const char *domainname,
5976- const char *msgid1, const char *msgid2, unsigned long int n,
5977- int category)
5978-{
5979- return libintl_dcngettext (domainname, msgid1, msgid2, n, category);
5980-}
5981-
5982-
5983-DLL_EXPORTED
5984-char *
5985-textdomain (const char *domainname)
5986-{
5987- return libintl_textdomain (domainname);
5988-}
5989-
5990-
5991-DLL_EXPORTED
5992-char *
5993-bindtextdomain (const char *domainname, const char *dirname)
5994-{
5995- return libintl_bindtextdomain (domainname, dirname);
5996-}
5997-
5998-
5999-DLL_EXPORTED
6000-char *
6001-bind_textdomain_codeset (const char *domainname, const char *codeset)
6002-{
6003- return libintl_bind_textdomain_codeset (domainname, codeset);
6004-}
6005--- a/intl/intl-exports.c
6006+++ /dev/null
6007@@ -1,36 +0,0 @@
6008-/* List of exported symbols of libintl on Cygwin.
6009- Copyright (C) 2006 Free Software Foundation, Inc.
6010- Written by Bruno Haible <bruno@clisp.org>, 2006.
6011-
6012- This program is free software; you can redistribute it and/or modify it
6013- under the terms of the GNU Library General Public License as published
6014- by the Free Software Foundation; either version 2, or (at your option)
6015- any later version.
6016-
6017- This program is distributed in the hope that it will be useful,
6018- but WITHOUT ANY WARRANTY; without even the implied warranty of
6019- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
6020- Library General Public License for more details.
6021-
6022- You should have received a copy of the GNU Library General Public
6023- License along with this program; if not, write to the Free Software
6024- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
6025- USA. */
6026-
6027- /* IMP(x) is a symbol that contains the address of x. */
6028-#define IMP(x) _imp__##x
6029-
6030- /* Ensure that the variable x is exported from the library, and that a
6031- pseudo-variable IMP(x) is available. */
6032-#define VARIABLE(x) \
6033- /* Export x without redefining x. This code was found by compiling a \
6034- snippet: \
6035- extern __declspec(dllexport) int x; int x = 42; */ \
6036- asm (".section .drectve\n"); \
6037- asm (".ascii \" -export:" #x ",data\"\n"); \
6038- asm (".data\n"); \
6039- /* Allocate a pseudo-variable IMP(x). */ \
6040- extern int x; \
6041- void * IMP(x) = &x;
6042-
6043-VARIABLE(libintl_version)
6044--- a/intl/l10nflist.c
6045+++ /dev/null
6046@@ -1,400 +0,0 @@
6047-/* Copyright (C) 1995-1999, 2000-2006 Free Software Foundation, Inc.
6048- Contributed by Ulrich Drepper <drepper@gnu.ai.mit.edu>, 1995.
6049-
6050- This program is free software; you can redistribute it and/or modify it
6051- under the terms of the GNU Library General Public License as published
6052- by the Free Software Foundation; either version 2, or (at your option)
6053- any later version.
6054-
6055- This program is distributed in the hope that it will be useful,
6056- but WITHOUT ANY WARRANTY; without even the implied warranty of
6057- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
6058- Library General Public License for more details.
6059-
6060- You should have received a copy of the GNU Library General Public
6061- License along with this program; if not, write to the Free Software
6062- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
6063- USA. */
6064-
6065-/* Tell glibc's <string.h> to provide a prototype for stpcpy().
6066- This must come before <config.h> because <config.h> may include
6067- <features.h>, and once <features.h> has been included, it's too late. */
6068-#ifndef _GNU_SOURCE
6069-# define _GNU_SOURCE 1
6070-#endif
6071-
6072-#ifdef HAVE_CONFIG_H
6073-# include <config.h>
6074-#endif
6075-
6076-#include <string.h>
6077-
6078-#if defined _LIBC || defined HAVE_ARGZ_H
6079-# include <argz.h>
6080-#endif
6081-#include <ctype.h>
6082-#include <sys/types.h>
6083-#include <stdlib.h>
6084-
6085-#include "loadinfo.h"
6086-
6087-/* On some strange systems still no definition of NULL is found. Sigh! */
6088-#ifndef NULL
6089-# if defined __STDC__ && __STDC__
6090-# define NULL ((void *) 0)
6091-# else
6092-# define NULL 0
6093-# endif
6094-#endif
6095-
6096-/* @@ end of prolog @@ */
6097-
6098-#ifdef _LIBC
6099-/* Rename the non ANSI C functions. This is required by the standard
6100- because some ANSI C functions will require linking with this object
6101- file and the name space must not be polluted. */
6102-# ifndef stpcpy
6103-# define stpcpy(dest, src) __stpcpy(dest, src)
6104-# endif
6105-#else
6106-# ifndef HAVE_STPCPY
6107-static char *stpcpy (char *dest, const char *src);
6108-# endif
6109-#endif
6110-
6111-/* Pathname support.
6112- ISSLASH(C) tests whether C is a directory separator character.
6113- IS_ABSOLUTE_PATH(P) tests whether P is an absolute path. If it is not,
6114- it may be concatenated to a directory pathname.
6115- */
6116-#if defined _WIN32 || defined __WIN32__ || defined __CYGWIN__ || defined __EMX__ || defined __DJGPP__
6117- /* Win32, Cygwin, OS/2, DOS */
6118-# define ISSLASH(C) ((C) == '/' || (C) == '\\')
6119-# define HAS_DEVICE(P) \
6120- ((((P)[0] >= 'A' && (P)[0] <= 'Z') || ((P)[0] >= 'a' && (P)[0] <= 'z')) \
6121- && (P)[1] == ':')
6122-# define IS_ABSOLUTE_PATH(P) (ISSLASH ((P)[0]) || HAS_DEVICE (P))
6123-#else
6124- /* Unix */
6125-# define ISSLASH(C) ((C) == '/')
6126-# define IS_ABSOLUTE_PATH(P) ISSLASH ((P)[0])
6127-#endif
6128-
6129-/* Define function which are usually not available. */
6130-
6131-#ifdef _LIBC
6132-# define __argz_count(argz, len) INTUSE(__argz_count) (argz, len)
6133-#elif defined HAVE_ARGZ_COUNT
6134-# undef __argz_count
6135-# define __argz_count argz_count
6136-#else
6137-/* Returns the number of strings in ARGZ. */
6138-static size_t
6139-argz_count__ (const char *argz, size_t len)
6140-{
6141- size_t count = 0;
6142- while (len > 0)
6143- {
6144- size_t part_len = strlen (argz);
6145- argz += part_len + 1;
6146- len -= part_len + 1;
6147- count++;
6148- }
6149- return count;
6150-}
6151-# undef __argz_count
6152-# define __argz_count(argz, len) argz_count__ (argz, len)
6153-#endif /* !_LIBC && !HAVE_ARGZ_COUNT */
6154-
6155-#ifdef _LIBC
6156-# define __argz_stringify(argz, len, sep) \
6157- INTUSE(__argz_stringify) (argz, len, sep)
6158-#elif defined HAVE_ARGZ_STRINGIFY
6159-# undef __argz_stringify
6160-# define __argz_stringify argz_stringify
6161-#else
6162-/* Make '\0' separated arg vector ARGZ printable by converting all the '\0's
6163- except the last into the character SEP. */
6164-static void
6165-argz_stringify__ (char *argz, size_t len, int sep)
6166-{
6167- while (len > 0)
6168- {
6169- size_t part_len = strlen (argz);
6170- argz += part_len;
6171- len -= part_len + 1;
6172- if (len > 0)
6173- *argz++ = sep;
6174- }
6175-}
6176-# undef __argz_stringify
6177-# define __argz_stringify(argz, len, sep) argz_stringify__ (argz, len, sep)
6178-#endif /* !_LIBC && !HAVE_ARGZ_STRINGIFY */
6179-
6180-#ifdef _LIBC
6181-#elif defined HAVE_ARGZ_NEXT
6182-# undef __argz_next
6183-# define __argz_next argz_next
6184-#else
6185-static char *
6186-argz_next__ (char *argz, size_t argz_len, const char *entry)
6187-{
6188- if (entry)
6189- {
6190- if (entry < argz + argz_len)
6191- entry = strchr (entry, '\0') + 1;
6192-
6193- return entry >= argz + argz_len ? NULL : (char *) entry;
6194- }
6195- else
6196- if (argz_len > 0)
6197- return argz;
6198- else
6199- return 0;
6200-}
6201-# undef __argz_next
6202-# define __argz_next(argz, len, entry) argz_next__ (argz, len, entry)
6203-#endif /* !_LIBC && !HAVE_ARGZ_NEXT */
6204-
6205-
6206-/* Return number of bits set in X. */
6207-static inline int
6208-pop (int x)
6209-{
6210- /* We assume that no more than 16 bits are used. */
6211- x = ((x & ~0x5555) >> 1) + (x & 0x5555);
6212- x = ((x & ~0x3333) >> 2) + (x & 0x3333);
6213- x = ((x >> 4) + x) & 0x0f0f;
6214- x = ((x >> 8) + x) & 0xff;
6215-
6216- return x;
6217-}
6218-
6219-
6220-struct loaded_l10nfile *
6221-_nl_make_l10nflist (struct loaded_l10nfile **l10nfile_list,
6222- const char *dirlist, size_t dirlist_len,
6223- int mask, const char *language, const char *territory,
6224- const char *codeset, const char *normalized_codeset,
6225- const char *modifier,
6226- const char *filename, int do_allocate)
6227-{
6228- char *abs_filename;
6229- struct loaded_l10nfile **lastp;
6230- struct loaded_l10nfile *retval;
6231- char *cp;
6232- size_t dirlist_count;
6233- size_t entries;
6234- int cnt;
6235-
6236- /* If LANGUAGE contains an absolute directory specification, we ignore
6237- DIRLIST. */
6238- if (IS_ABSOLUTE_PATH (language))
6239- dirlist_len = 0;
6240-
6241- /* Allocate room for the full file name. */
6242- abs_filename = (char *) malloc (dirlist_len
6243- + strlen (language)
6244- + ((mask & XPG_TERRITORY) != 0
6245- ? strlen (territory) + 1 : 0)
6246- + ((mask & XPG_CODESET) != 0
6247- ? strlen (codeset) + 1 : 0)
6248- + ((mask & XPG_NORM_CODESET) != 0
6249- ? strlen (normalized_codeset) + 1 : 0)
6250- + ((mask & XPG_MODIFIER) != 0
6251- ? strlen (modifier) + 1 : 0)
6252- + 1 + strlen (filename) + 1);
6253-
6254- if (abs_filename == NULL)
6255- return NULL;
6256-
6257- /* Construct file name. */
6258- cp = abs_filename;
6259- if (dirlist_len > 0)
6260- {
6261- memcpy (cp, dirlist, dirlist_len);
6262- __argz_stringify (cp, dirlist_len, PATH_SEPARATOR);
6263- cp += dirlist_len;
6264- cp[-1] = '/';
6265- }
6266-
6267- cp = stpcpy (cp, language);
6268-
6269- if ((mask & XPG_TERRITORY) != 0)
6270- {
6271- *cp++ = '_';
6272- cp = stpcpy (cp, territory);
6273- }
6274- if ((mask & XPG_CODESET) != 0)
6275- {
6276- *cp++ = '.';
6277- cp = stpcpy (cp, codeset);
6278- }
6279- if ((mask & XPG_NORM_CODESET) != 0)
6280- {
6281- *cp++ = '.';
6282- cp = stpcpy (cp, normalized_codeset);
6283- }
6284- if ((mask & XPG_MODIFIER) != 0)
6285- {
6286- *cp++ = '@';
6287- cp = stpcpy (cp, modifier);
6288- }
6289-
6290- *cp++ = '/';
6291- stpcpy (cp, filename);
6292-
6293- /* Look in list of already loaded domains whether it is already
6294- available. */
6295- lastp = l10nfile_list;
6296- for (retval = *l10nfile_list; retval != NULL; retval = retval->next)
6297- if (retval->filename != NULL)
6298- {
6299- int compare = strcmp (retval->filename, abs_filename);
6300- if (compare == 0)
6301- /* We found it! */
6302- break;
6303- if (compare < 0)
6304- {
6305- /* It's not in the list. */
6306- retval = NULL;
6307- break;
6308- }
6309-
6310- lastp = &retval->next;
6311- }
6312-
6313- if (retval != NULL || do_allocate == 0)
6314- {
6315- free (abs_filename);
6316- return retval;
6317- }
6318-
6319- dirlist_count = (dirlist_len > 0 ? __argz_count (dirlist, dirlist_len) : 1);
6320-
6321- /* Allocate a new loaded_l10nfile. */
6322- retval =
6323- (struct loaded_l10nfile *)
6324- malloc (sizeof (*retval)
6325- + (((dirlist_count << pop (mask)) + (dirlist_count > 1 ? 1 : 0))
6326- * sizeof (struct loaded_l10nfile *)));
6327- if (retval == NULL)
6328- {
6329- free (abs_filename);
6330- return NULL;
6331- }
6332-
6333- retval->filename = abs_filename;
6334-
6335- /* We set retval->data to NULL here; it is filled in later.
6336- Setting retval->decided to 1 here means that retval does not
6337- correspond to a real file (dirlist_count > 1) or is not worth
6338- looking up (if an unnormalized codeset was specified). */
6339- retval->decided = (dirlist_count > 1
6340- || ((mask & XPG_CODESET) != 0
6341- && (mask & XPG_NORM_CODESET) != 0));
6342- retval->data = NULL;
6343-
6344- retval->next = *lastp;
6345- *lastp = retval;
6346-
6347- entries = 0;
6348- /* Recurse to fill the inheritance list of RETVAL.
6349- If the DIRLIST is a real list (i.e. DIRLIST_COUNT > 1), the RETVAL
6350- entry does not correspond to a real file; retval->filename contains
6351- colons. In this case we loop across all elements of DIRLIST and
6352- across all bit patterns dominated by MASK.
6353- If the DIRLIST is a single directory or entirely redundant (i.e.
6354- DIRLIST_COUNT == 1), we loop across all bit patterns dominated by
6355- MASK, excluding MASK itself.
6356- In either case, we loop down from MASK to 0. This has the effect
6357- that the extra bits in the locale name are dropped in this order:
6358- first the modifier, then the territory, then the codeset, then the
6359- normalized_codeset. */
6360- for (cnt = dirlist_count > 1 ? mask : mask - 1; cnt >= 0; --cnt)
6361- if ((cnt & ~mask) == 0
6362- && !((cnt & XPG_CODESET) != 0 && (cnt & XPG_NORM_CODESET) != 0))
6363- {
6364- if (dirlist_count > 1)
6365- {
6366- /* Iterate over all elements of the DIRLIST. */
6367- char *dir = NULL;
6368-
6369- while ((dir = __argz_next ((char *) dirlist, dirlist_len, dir))
6370- != NULL)
6371- retval->successor[entries++]
6372- = _nl_make_l10nflist (l10nfile_list, dir, strlen (dir) + 1,
6373- cnt, language, territory, codeset,
6374- normalized_codeset, modifier, filename,
6375- 1);
6376- }
6377- else
6378- retval->successor[entries++]
6379- = _nl_make_l10nflist (l10nfile_list, dirlist, dirlist_len,
6380- cnt, language, territory, codeset,
6381- normalized_codeset, modifier, filename, 1);
6382- }
6383- retval->successor[entries] = NULL;
6384-
6385- return retval;
6386-}
6387-
6388-/* Normalize codeset name. There is no standard for the codeset
6389- names. Normalization allows the user to use any of the common
6390- names. The return value is dynamically allocated and has to be
6391- freed by the caller. */
6392-const char *
6393-_nl_normalize_codeset (const char *codeset, size_t name_len)
6394-{
6395- int len = 0;
6396- int only_digit = 1;
6397- char *retval;
6398- char *wp;
6399- size_t cnt;
6400-
6401- for (cnt = 0; cnt < name_len; ++cnt)
6402- if (isalnum ((unsigned char) codeset[cnt]))
6403- {
6404- ++len;
6405-
6406- if (isalpha ((unsigned char) codeset[cnt]))
6407- only_digit = 0;
6408- }
6409-
6410- retval = (char *) malloc ((only_digit ? 3 : 0) + len + 1);
6411-
6412- if (retval != NULL)
6413- {
6414- if (only_digit)
6415- wp = stpcpy (retval, "iso");
6416- else
6417- wp = retval;
6418-
6419- for (cnt = 0; cnt < name_len; ++cnt)
6420- if (isalpha ((unsigned char) codeset[cnt]))
6421- *wp++ = tolower ((unsigned char) codeset[cnt]);
6422- else if (isdigit ((unsigned char) codeset[cnt]))
6423- *wp++ = codeset[cnt];
6424-
6425- *wp = '\0';
6426- }
6427-
6428- return (const char *) retval;
6429-}
6430-
6431-
6432-/* @@ begin of epilog @@ */
6433-
6434-/* We don't want libintl.a to depend on any other library. So we
6435- avoid the non-standard function stpcpy. In GNU C Library this
6436- function is available, though. Also allow the symbol HAVE_STPCPY
6437- to be defined. */
6438-#if !_LIBC && !HAVE_STPCPY
6439-static char *
6440-stpcpy (char *dest, const char *src)
6441-{
6442- while ((*dest++ = *src++) != '\0')
6443- /* Do nothing. */ ;
6444- return dest - 1;
6445-}
6446-#endif
6447--- a/intl/langprefs.c
6448+++ /dev/null
6449@@ -1,130 +0,0 @@
6450-/* Determine the user's language preferences.
6451- Copyright (C) 2004-2006 Free Software Foundation, Inc.
6452-
6453- This program is free software; you can redistribute it and/or modify it
6454- under the terms of the GNU Library General Public License as published
6455- by the Free Software Foundation; either version 2, or (at your option)
6456- any later version.
6457-
6458- This program is distributed in the hope that it will be useful,
6459- but WITHOUT ANY WARRANTY; without even the implied warranty of
6460- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
6461- Library General Public License for more details.
6462-
6463- You should have received a copy of the GNU Library General Public
6464- License along with this program; if not, write to the Free Software
6465- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
6466- USA. */
6467-
6468-/* Written by Bruno Haible <bruno@clisp.org>. */
6469-
6470-#ifdef HAVE_CONFIG_H
6471-# include <config.h>
6472-#endif
6473-
6474-#include <stdlib.h>
6475-
6476-#if HAVE_CFPREFERENCESCOPYAPPVALUE
6477-# include <string.h>
6478-# include <CoreFoundation/CFPreferences.h>
6479-# include <CoreFoundation/CFPropertyList.h>
6480-# include <CoreFoundation/CFArray.h>
6481-# include <CoreFoundation/CFString.h>
6482-extern void _nl_locale_name_canonicalize (char *name);
6483-#endif
6484-
6485-/* Determine the user's language preferences, as a colon separated list of
6486- locale names in XPG syntax
6487- language[_territory][.codeset][@modifier]
6488- The result must not be freed; it is statically allocated.
6489- The LANGUAGE environment variable does not need to be considered; it is
6490- already taken into account by the caller. */
6491-
6492-const char *
6493-_nl_language_preferences_default (void)
6494-{
6495-#if HAVE_CFPREFERENCESCOPYAPPVALUE /* MacOS X 10.2 or newer */
6496- {
6497- /* Cache the preferences list, since CoreFoundation calls are expensive. */
6498- static const char *cached_languages;
6499- static int cache_initialized;
6500-
6501- if (!cache_initialized)
6502- {
6503- CFTypeRef preferences =
6504- CFPreferencesCopyAppValue (CFSTR ("AppleLanguages"),
6505- kCFPreferencesCurrentApplication);
6506- if (preferences != NULL
6507- && CFGetTypeID (preferences) == CFArrayGetTypeID ())
6508- {
6509- CFArrayRef prefArray = (CFArrayRef)preferences;
6510- int n = CFArrayGetCount (prefArray);
6511- char buf[256];
6512- size_t size = 0;
6513- int i;
6514-
6515- for (i = 0; i < n; i++)
6516- {
6517- CFTypeRef element = CFArrayGetValueAtIndex (prefArray, i);
6518- if (element != NULL
6519- && CFGetTypeID (element) == CFStringGetTypeID ()
6520- && CFStringGetCString ((CFStringRef)element,
6521- buf, sizeof (buf),
6522- kCFStringEncodingASCII))
6523- {
6524- _nl_locale_name_canonicalize (buf);
6525- size += strlen (buf) + 1;
6526- /* Most GNU programs use msgids in English and don't ship
6527- an en.mo message catalog. Therefore when we see "en"
6528- in the preferences list, arrange for gettext() to
6529- return the msgid, and ignore all further elements of
6530- the preferences list. */
6531- if (strcmp (buf, "en") == 0)
6532- break;
6533- }
6534- else
6535- break;
6536- }
6537- if (size > 0)
6538- {
6539- char *languages = (char *) malloc (size);
6540-
6541- if (languages != NULL)
6542- {
6543- char *p = languages;
6544-
6545- for (i = 0; i < n; i++)
6546- {
6547- CFTypeRef element =
6548- CFArrayGetValueAtIndex (prefArray, i);
6549- if (element != NULL
6550- && CFGetTypeID (element) == CFStringGetTypeID ()
6551- && CFStringGetCString ((CFStringRef)element,
6552- buf, sizeof (buf),
6553- kCFStringEncodingASCII))
6554- {
6555- _nl_locale_name_canonicalize (buf);
6556- strcpy (p, buf);
6557- p += strlen (buf);
6558- *p++ = ':';
6559- if (strcmp (buf, "en") == 0)
6560- break;
6561- }
6562- else
6563- break;
6564- }
6565- *--p = '\0';
6566-
6567- cached_languages = languages;
6568- }
6569- }
6570- }
6571- cache_initialized = 1;
6572- }
6573- if (cached_languages != NULL)
6574- return cached_languages;
6575- }
6576-#endif
6577-
6578- return NULL;
6579-}
6580--- a/intl/libgnuintl.h.in
6581+++ /dev/null
6582@@ -1,419 +0,0 @@
6583-/* Message catalogs for internationalization.
6584- Copyright (C) 1995-1997, 2000-2007 Free Software Foundation, Inc.
6585-
6586- This program is free software; you can redistribute it and/or modify it
6587- under the terms of the GNU Library General Public License as published
6588- by the Free Software Foundation; either version 2, or (at your option)
6589- any later version.
6590-
6591- This program is distributed in the hope that it will be useful,
6592- but WITHOUT ANY WARRANTY; without even the implied warranty of
6593- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
6594- Library General Public License for more details.
6595-
6596- You should have received a copy of the GNU Library General Public
6597- License along with this program; if not, write to the Free Software
6598- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
6599- USA. */
6600-
6601-#ifndef _LIBINTL_H
6602-#define _LIBINTL_H 1
6603-
6604-#include <locale.h>
6605-
6606-/* The LC_MESSAGES locale category is the category used by the functions
6607- gettext() and dgettext(). It is specified in POSIX, but not in ANSI C.
6608- On systems that don't define it, use an arbitrary value instead.
6609- On Solaris, <locale.h> defines __LOCALE_H (or _LOCALE_H in Solaris 2.5)
6610- then includes <libintl.h> (i.e. this file!) and then only defines
6611- LC_MESSAGES. To avoid a redefinition warning, don't define LC_MESSAGES
6612- in this case. */
6613-#if !defined LC_MESSAGES && !(defined __LOCALE_H || (defined _LOCALE_H && defined __sun))
6614-# define LC_MESSAGES 1729
6615-#endif
6616-
6617-/* We define an additional symbol to signal that we use the GNU
6618- implementation of gettext. */
6619-#define __USE_GNU_GETTEXT 1
6620-
6621-/* Provide information about the supported file formats. Returns the
6622- maximum minor revision number supported for a given major revision. */
6623-#define __GNU_GETTEXT_SUPPORTED_REVISION(major) \
6624- ((major) == 0 || (major) == 1 ? 1 : -1)
6625-
6626-/* Resolve a platform specific conflict on DJGPP. GNU gettext takes
6627- precedence over _conio_gettext. */
6628-#ifdef __DJGPP__
6629-# undef gettext
6630-#endif
6631-
6632-#ifdef __cplusplus
6633-extern "C" {
6634-#endif
6635-
6636-
6637-/* Version number: (major<<16) + (minor<<8) + subminor */
6638-#define LIBINTL_VERSION 0x001100
6639-extern int libintl_version;
6640-
6641-
6642-/* We redirect the functions to those prefixed with "libintl_". This is
6643- necessary, because some systems define gettext/textdomain/... in the C
6644- library (namely, Solaris 2.4 and newer, and GNU libc 2.0 and newer).
6645- If we used the unprefixed names, there would be cases where the
6646- definition in the C library would override the one in the libintl.so
6647- shared library. Recall that on ELF systems, the symbols are looked
6648- up in the following order:
6649- 1. in the executable,
6650- 2. in the shared libraries specified on the link command line, in order,
6651- 3. in the dependencies of the shared libraries specified on the link
6652- command line,
6653- 4. in the dlopen()ed shared libraries, in the order in which they were
6654- dlopen()ed.
6655- The definition in the C library would override the one in libintl.so if
6656- either
6657- * -lc is given on the link command line and -lintl isn't, or
6658- * -lc is given on the link command line before -lintl, or
6659- * libintl.so is a dependency of a dlopen()ed shared library but not
6660- linked to the executable at link time.
6661- Since Solaris gettext() behaves differently than GNU gettext(), this
6662- would be unacceptable.
6663-
6664- The redirection happens by default through macros in C, so that &gettext
6665- is independent of the compilation unit, but through inline functions in
6666- C++, in order not to interfere with the name mangling of class fields or
6667- class methods called 'gettext'. */
6668-
6669-/* The user can define _INTL_REDIRECT_INLINE or _INTL_REDIRECT_MACROS.
6670- If he doesn't, we choose the method. A third possible method is
6671- _INTL_REDIRECT_ASM, supported only by GCC. */
6672-#if !(defined _INTL_REDIRECT_INLINE || defined _INTL_REDIRECT_MACROS)
6673-# if __GNUC__ >= 2 && !(__APPLE_CC__ > 1) && !defined __MINGW32__ && !(__GNUC__ == 2 && defined _AIX) && (defined __STDC__ || defined __cplusplus)
6674-# define _INTL_REDIRECT_ASM
6675-# else
6676-# ifdef __cplusplus
6677-# define _INTL_REDIRECT_INLINE
6678-# else
6679-# define _INTL_REDIRECT_MACROS
6680-# endif
6681-# endif
6682-#endif
6683-/* Auxiliary macros. */
6684-#ifdef _INTL_REDIRECT_ASM
6685-# define _INTL_ASM(cname) __asm__ (_INTL_ASMNAME (__USER_LABEL_PREFIX__, #cname))
6686-# define _INTL_ASMNAME(prefix,cnamestring) _INTL_STRINGIFY (prefix) cnamestring
6687-# define _INTL_STRINGIFY(prefix) #prefix
6688-#else
6689-# define _INTL_ASM(cname)
6690-#endif
6691-
6692-/* _INTL_MAY_RETURN_STRING_ARG(n) declares that the given function may return
6693- its n-th argument literally. This enables GCC to warn for example about
6694- printf (gettext ("foo %y")). */
6695-#if __GNUC__ >= 3 && !(__APPLE_CC__ > 1 && defined __cplusplus)
6696-# define _INTL_MAY_RETURN_STRING_ARG(n) __attribute__ ((__format_arg__ (n)))
6697-#else
6698-# define _INTL_MAY_RETURN_STRING_ARG(n)
6699-#endif
6700-
6701-/* Look up MSGID in the current default message catalog for the current
6702- LC_MESSAGES locale. If not found, returns MSGID itself (the default
6703- text). */
6704-#ifdef _INTL_REDIRECT_INLINE
6705-extern char *libintl_gettext (const char *__msgid)
6706- _INTL_MAY_RETURN_STRING_ARG (1);
6707-static inline char *gettext (const char *__msgid)
6708-{
6709- return libintl_gettext (__msgid);
6710-}
6711-#else
6712-#ifdef _INTL_REDIRECT_MACROS
6713-# define gettext libintl_gettext
6714-#endif
6715-extern char *gettext (const char *__msgid)
6716- _INTL_ASM (libintl_gettext)
6717- _INTL_MAY_RETURN_STRING_ARG (1);
6718-#endif
6719-
6720-/* Look up MSGID in the DOMAINNAME message catalog for the current
6721- LC_MESSAGES locale. */
6722-#ifdef _INTL_REDIRECT_INLINE
6723-extern char *libintl_dgettext (const char *__domainname, const char *__msgid)
6724- _INTL_MAY_RETURN_STRING_ARG (2);
6725-static inline char *dgettext (const char *__domainname, const char *__msgid)
6726-{
6727- return libintl_dgettext (__domainname, __msgid);
6728-}
6729-#else
6730-#ifdef _INTL_REDIRECT_MACROS
6731-# define dgettext libintl_dgettext
6732-#endif
6733-extern char *dgettext (const char *__domainname, const char *__msgid)
6734- _INTL_ASM (libintl_dgettext)
6735- _INTL_MAY_RETURN_STRING_ARG (2);
6736-#endif
6737-
6738-/* Look up MSGID in the DOMAINNAME message catalog for the current CATEGORY
6739- locale. */
6740-#ifdef _INTL_REDIRECT_INLINE
6741-extern char *libintl_dcgettext (const char *__domainname, const char *__msgid,
6742- int __category)
6743- _INTL_MAY_RETURN_STRING_ARG (2);
6744-static inline char *dcgettext (const char *__domainname, const char *__msgid,
6745- int __category)
6746-{
6747- return libintl_dcgettext (__domainname, __msgid, __category);
6748-}
6749-#else
6750-#ifdef _INTL_REDIRECT_MACROS
6751-# define dcgettext libintl_dcgettext
6752-#endif
6753-extern char *dcgettext (const char *__domainname, const char *__msgid,
6754- int __category)
6755- _INTL_ASM (libintl_dcgettext)
6756- _INTL_MAY_RETURN_STRING_ARG (2);
6757-#endif
6758-
6759-
6760-/* Similar to `gettext' but select the plural form corresponding to the
6761- number N. */
6762-#ifdef _INTL_REDIRECT_INLINE
6763-extern char *libintl_ngettext (const char *__msgid1, const char *__msgid2,
6764- unsigned long int __n)
6765- _INTL_MAY_RETURN_STRING_ARG (1) _INTL_MAY_RETURN_STRING_ARG (2);
6766-static inline char *ngettext (const char *__msgid1, const char *__msgid2,
6767- unsigned long int __n)
6768-{
6769- return libintl_ngettext (__msgid1, __msgid2, __n);
6770-}
6771-#else
6772-#ifdef _INTL_REDIRECT_MACROS
6773-# define ngettext libintl_ngettext
6774-#endif
6775-extern char *ngettext (const char *__msgid1, const char *__msgid2,
6776- unsigned long int __n)
6777- _INTL_ASM (libintl_ngettext)
6778- _INTL_MAY_RETURN_STRING_ARG (1) _INTL_MAY_RETURN_STRING_ARG (2);
6779-#endif
6780-
6781-/* Similar to `dgettext' but select the plural form corresponding to the
6782- number N. */
6783-#ifdef _INTL_REDIRECT_INLINE
6784-extern char *libintl_dngettext (const char *__domainname, const char *__msgid1,
6785- const char *__msgid2, unsigned long int __n)
6786- _INTL_MAY_RETURN_STRING_ARG (2) _INTL_MAY_RETURN_STRING_ARG (3);
6787-static inline char *dngettext (const char *__domainname, const char *__msgid1,
6788- const char *__msgid2, unsigned long int __n)
6789-{
6790- return libintl_dngettext (__domainname, __msgid1, __msgid2, __n);
6791-}
6792-#else
6793-#ifdef _INTL_REDIRECT_MACROS
6794-# define dngettext libintl_dngettext
6795-#endif
6796-extern char *dngettext (const char *__domainname,
6797- const char *__msgid1, const char *__msgid2,
6798- unsigned long int __n)
6799- _INTL_ASM (libintl_dngettext)
6800- _INTL_MAY_RETURN_STRING_ARG (2) _INTL_MAY_RETURN_STRING_ARG (3);
6801-#endif
6802-
6803-/* Similar to `dcgettext' but select the plural form corresponding to the
6804- number N. */
6805-#ifdef _INTL_REDIRECT_INLINE
6806-extern char *libintl_dcngettext (const char *__domainname,
6807- const char *__msgid1, const char *__msgid2,
6808- unsigned long int __n, int __category)
6809- _INTL_MAY_RETURN_STRING_ARG (2) _INTL_MAY_RETURN_STRING_ARG (3);
6810-static inline char *dcngettext (const char *__domainname,
6811- const char *__msgid1, const char *__msgid2,
6812- unsigned long int __n, int __category)
6813-{
6814- return libintl_dcngettext (__domainname, __msgid1, __msgid2, __n, __category);
6815-}
6816-#else
6817-#ifdef _INTL_REDIRECT_MACROS
6818-# define dcngettext libintl_dcngettext
6819-#endif
6820-extern char *dcngettext (const char *__domainname,
6821- const char *__msgid1, const char *__msgid2,
6822- unsigned long int __n, int __category)
6823- _INTL_ASM (libintl_dcngettext)
6824- _INTL_MAY_RETURN_STRING_ARG (2) _INTL_MAY_RETURN_STRING_ARG (3);
6825-#endif
6826-
6827-
6828-#ifndef IN_LIBGLOCALE
6829-
6830-/* Set the current default message catalog to DOMAINNAME.
6831- If DOMAINNAME is null, return the current default.
6832- If DOMAINNAME is "", reset to the default of "messages". */
6833-#ifdef _INTL_REDIRECT_INLINE
6834-extern char *libintl_textdomain (const char *__domainname);
6835-static inline char *textdomain (const char *__domainname)
6836-{
6837- return libintl_textdomain (__domainname);
6838-}
6839-#else
6840-#ifdef _INTL_REDIRECT_MACROS
6841-# define textdomain libintl_textdomain
6842-#endif
6843-extern char *textdomain (const char *__domainname)
6844- _INTL_ASM (libintl_textdomain);
6845-#endif
6846-
6847-/* Specify that the DOMAINNAME message catalog will be found
6848- in DIRNAME rather than in the system locale data base. */
6849-#ifdef _INTL_REDIRECT_INLINE
6850-extern char *libintl_bindtextdomain (const char *__domainname,
6851- const char *__dirname);
6852-static inline char *bindtextdomain (const char *__domainname,
6853- const char *__dirname)
6854-{
6855- return libintl_bindtextdomain (__domainname, __dirname);
6856-}
6857-#else
6858-#ifdef _INTL_REDIRECT_MACROS
6859-# define bindtextdomain libintl_bindtextdomain
6860-#endif
6861-extern char *bindtextdomain (const char *__domainname, const char *__dirname)
6862- _INTL_ASM (libintl_bindtextdomain);
6863-#endif
6864-
6865-/* Specify the character encoding in which the messages from the
6866- DOMAINNAME message catalog will be returned. */
6867-#ifdef _INTL_REDIRECT_INLINE
6868-extern char *libintl_bind_textdomain_codeset (const char *__domainname,
6869- const char *__codeset);
6870-static inline char *bind_textdomain_codeset (const char *__domainname,
6871- const char *__codeset)
6872-{
6873- return libintl_bind_textdomain_codeset (__domainname, __codeset);
6874-}
6875-#else
6876-#ifdef _INTL_REDIRECT_MACROS
6877-# define bind_textdomain_codeset libintl_bind_textdomain_codeset
6878-#endif
6879-extern char *bind_textdomain_codeset (const char *__domainname,
6880- const char *__codeset)
6881- _INTL_ASM (libintl_bind_textdomain_codeset);
6882-#endif
6883-
6884-#endif /* IN_LIBGLOCALE */
6885-
6886-
6887-/* Support for format strings with positions in *printf(), following the
6888- POSIX/XSI specification.
6889- Note: These replacements for the *printf() functions are visible only
6890- in source files that #include <libintl.h> or #include "gettext.h".
6891- Packages that use *printf() in source files that don't refer to _()
6892- or gettext() but for which the format string could be the return value
6893- of _() or gettext() need to add this #include. Oh well. */
6894-
6895-#if !@HAVE_POSIX_PRINTF@
6896-
6897-#include <stdio.h>
6898-#include <stddef.h>
6899-
6900-/* Get va_list. */
6901-#if __STDC__ || defined __cplusplus || defined _MSC_VER
6902-# include <stdarg.h>
6903-#else
6904-# include <varargs.h>
6905-#endif
6906-
6907-#undef fprintf
6908-#define fprintf libintl_fprintf
6909-extern int fprintf (FILE *, const char *, ...);
6910-#undef vfprintf
6911-#define vfprintf libintl_vfprintf
6912-extern int vfprintf (FILE *, const char *, va_list);
6913-
6914-#undef printf
6915-#if defined __NetBSD__ || defined __BEOS__ || defined __CYGWIN__ || defined __MINGW32__
6916-/* Don't break __attribute__((format(printf,M,N))).
6917- This redefinition is only possible because the libc in NetBSD, Cygwin,
6918- mingw does not have a function __printf__. */
6919-# define libintl_printf __printf__
6920-#endif
6921-#define printf libintl_printf
6922-extern int printf (const char *, ...);
6923-#undef vprintf
6924-#define vprintf libintl_vprintf
6925-extern int vprintf (const char *, va_list);
6926-
6927-#undef sprintf
6928-#define sprintf libintl_sprintf
6929-extern int sprintf (char *, const char *, ...);
6930-#undef vsprintf
6931-#define vsprintf libintl_vsprintf
6932-extern int vsprintf (char *, const char *, va_list);
6933-
6934-#if @HAVE_SNPRINTF@
6935-
6936-#undef snprintf
6937-#define snprintf libintl_snprintf
6938-extern int snprintf (char *, size_t, const char *, ...);
6939-#undef vsnprintf
6940-#define vsnprintf libintl_vsnprintf
6941-extern int vsnprintf (char *, size_t, const char *, va_list);
6942-
6943-#endif
6944-
6945-#if @HAVE_ASPRINTF@
6946-
6947-#undef asprintf
6948-#define asprintf libintl_asprintf
6949-extern int asprintf (char **, const char *, ...);
6950-#undef vasprintf
6951-#define vasprintf libintl_vasprintf
6952-extern int vasprintf (char **, const char *, va_list);
6953-
6954-#endif
6955-
6956-#if @HAVE_WPRINTF@
6957-
6958-#undef fwprintf
6959-#define fwprintf libintl_fwprintf
6960-extern int fwprintf (FILE *, const wchar_t *, ...);
6961-#undef vfwprintf
6962-#define vfwprintf libintl_vfwprintf
6963-extern int vfwprintf (FILE *, const wchar_t *, va_list);
6964-
6965-#undef wprintf
6966-#define wprintf libintl_wprintf
6967-extern int wprintf (const wchar_t *, ...);
6968-#undef vwprintf
6969-#define vwprintf libintl_vwprintf
6970-extern int vwprintf (const wchar_t *, va_list);
6971-
6972-#undef swprintf
6973-#define swprintf libintl_swprintf
6974-extern int swprintf (wchar_t *, size_t, const wchar_t *, ...);
6975-#undef vswprintf
6976-#define vswprintf libintl_vswprintf
6977-extern int vswprintf (wchar_t *, size_t, const wchar_t *, va_list);
6978-
6979-#endif
6980-
6981-#endif
6982-
6983-
6984-/* Support for relocatable packages. */
6985-
6986-/* Sets the original and the current installation prefix of the package.
6987- Relocation simply replaces a pathname starting with the original prefix
6988- by the corresponding pathname with the current prefix instead. Both
6989- prefixes should be directory names without trailing slash (i.e. use ""
6990- instead of "/"). */
6991-#define libintl_set_relocation_prefix libintl_set_relocation_prefix
6992-extern void
6993- libintl_set_relocation_prefix (const char *orig_prefix,
6994- const char *curr_prefix);
6995-
6996-
6997-#ifdef __cplusplus
6998-}
6999-#endif
7000-
7001-#endif /* libintl.h */
7002--- a/intl/libintl.rc
7003+++ /dev/null
7004@@ -1,38 +0,0 @@
7005-/* Resources for intl.dll */
7006-
7007-#include <winver.h>
7008-
7009-VS_VERSION_INFO VERSIONINFO
7010- FILEVERSION PACKAGE_VERSION_MAJOR,PACKAGE_VERSION_MINOR,PACKAGE_VERSION_SUBMINOR,0
7011- PRODUCTVERSION PACKAGE_VERSION_MAJOR,PACKAGE_VERSION_MINOR,PACKAGE_VERSION_SUBMINOR,0
7012- FILEFLAGSMASK 0x3fL /* VS_FFI_FILEFLAGSMASK */
7013-#ifdef _DEBUG
7014- FILEFLAGS 0x1L /* VS_FF_DEBUG */
7015-#else
7016- FILEFLAGS 0x0L
7017-#endif
7018- FILEOS 0x10004L /* VOS_DOS_WINDOWS32 */
7019- FILETYPE 0x2L /* VFT_DLL */
7020- FILESUBTYPE 0x0L /* VFT2_UNKNOWN */
7021-BEGIN
7022- BLOCK "StringFileInfo"
7023- BEGIN
7024- BLOCK "04090000" /* Lang = US English, Charset = ASCII */
7025- BEGIN
7026- VALUE "Comments", "This library is free software; you can redistribute it and/or modify it under the terms of the GNU Library General Public License. You should have received a copy of the GNU Library 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\0"
7027- VALUE "CompanyName", "Free Software Foundation\0"
7028- VALUE "FileDescription", "LGPLed libintl for Windows NT/2000/XP/Vista and Windows 95/98/ME\0"
7029- VALUE "FileVersion", PACKAGE_VERSION_STRING "\0"
7030- VALUE "InternalName", "intl.dll\0"
7031- VALUE "LegalCopyright", "Copyright (C) 1995-2007\0"
7032- VALUE "LegalTrademarks", "\0"
7033- VALUE "OriginalFilename", "intl.dll\0"
7034- VALUE "ProductName", "libintl: accessing NLS message catalogs\0"
7035- VALUE "ProductVersion", PACKAGE_VERSION_STRING "\0"
7036- END
7037- END
7038- BLOCK "VarFileInfo"
7039- BEGIN
7040- VALUE "Translation", 0x0409, 0 /* US English, ASCII */
7041- END
7042-END
7043--- a/intl/loadinfo.h
7044+++ /dev/null
7045@@ -1,132 +0,0 @@
7046-/* Copyright (C) 1996-1999, 2000-2003, 2005-2006 Free Software Foundation, Inc.
7047- This file is part of the GNU C Library.
7048- Contributed by Ulrich Drepper <drepper@cygnus.com>, 1996.
7049-
7050- This program is free software; you can redistribute it and/or modify it
7051- under the terms of the GNU Library General Public License as published
7052- by the Free Software Foundation; either version 2, or (at your option)
7053- any later version.
7054-
7055- This program is distributed in the hope that it will be useful,
7056- but WITHOUT ANY WARRANTY; without even the implied warranty of
7057- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
7058- Library General Public License for more details.
7059-
7060- You should have received a copy of the GNU Library General Public
7061- License along with this program; if not, write to the Free Software
7062- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
7063- USA. */
7064-
7065-#ifndef _LOADINFO_H
7066-#define _LOADINFO_H 1
7067-
7068-/* Declarations of locale dependent catalog lookup functions.
7069- Implemented in
7070-
7071- localealias.c Possibly replace a locale name by another.
7072- explodename.c Split a locale name into its various fields.
7073- l10nflist.c Generate a list of filenames of possible message catalogs.
7074- finddomain.c Find and open the relevant message catalogs.
7075-
7076- The main function _nl_find_domain() in finddomain.c is declared
7077- in gettextP.h.
7078- */
7079-
7080-#ifndef internal_function
7081-# define internal_function
7082-#endif
7083-
7084-#ifndef LIBINTL_DLL_EXPORTED
7085-# define LIBINTL_DLL_EXPORTED
7086-#endif
7087-
7088-/* Tell the compiler when a conditional or integer expression is
7089- almost always true or almost always false. */
7090-#ifndef HAVE_BUILTIN_EXPECT
7091-# define __builtin_expect(expr, val) (expr)
7092-#endif
7093-
7094-/* Separator in PATH like lists of pathnames. */
7095-#if ((defined _WIN32 || defined __WIN32__) && !defined __CYGWIN__) || defined __EMX__ || defined __DJGPP__
7096- /* Win32, OS/2, DOS */
7097-# define PATH_SEPARATOR ';'
7098-#else
7099- /* Unix */
7100-# define PATH_SEPARATOR ':'
7101-#endif
7102-
7103-/* Encoding of locale name parts. */
7104-#define XPG_NORM_CODESET 1
7105-#define XPG_CODESET 2
7106-#define XPG_TERRITORY 4
7107-#define XPG_MODIFIER 8
7108-
7109-
7110-struct loaded_l10nfile
7111-{
7112- const char *filename;
7113- int decided;
7114-
7115- const void *data;
7116-
7117- struct loaded_l10nfile *next;
7118- struct loaded_l10nfile *successor[1];
7119-};
7120-
7121-
7122-/* Normalize codeset name. There is no standard for the codeset
7123- names. Normalization allows the user to use any of the common
7124- names. The return value is dynamically allocated and has to be
7125- freed by the caller. */
7126-extern const char *_nl_normalize_codeset (const char *codeset,
7127- size_t name_len);
7128-
7129-/* Lookup a locale dependent file.
7130- *L10NFILE_LIST denotes a pool of lookup results of locale dependent
7131- files of the same kind, sorted in decreasing order of ->filename.
7132- DIRLIST and DIRLIST_LEN are an argz list of directories in which to
7133- look, containing at least one directory (i.e. DIRLIST_LEN > 0).
7134- MASK, LANGUAGE, TERRITORY, CODESET, NORMALIZED_CODESET, MODIFIER
7135- are the pieces of the locale name, as produced by _nl_explode_name().
7136- FILENAME is the filename suffix.
7137- The return value is the lookup result, either found in *L10NFILE_LIST,
7138- or - if DO_ALLOCATE is nonzero - freshly allocated, or possibly NULL.
7139- If the return value is non-NULL, it is added to *L10NFILE_LIST, and
7140- its ->next field denotes the chaining inside *L10NFILE_LIST, and
7141- furthermore its ->successor[] field contains a list of other lookup
7142- results from which this lookup result inherits. */
7143-extern struct loaded_l10nfile *
7144-_nl_make_l10nflist (struct loaded_l10nfile **l10nfile_list,
7145- const char *dirlist, size_t dirlist_len, int mask,
7146- const char *language, const char *territory,
7147- const char *codeset, const char *normalized_codeset,
7148- const char *modifier,
7149- const char *filename, int do_allocate);
7150-
7151-/* Lookup the real locale name for a locale alias NAME, or NULL if
7152- NAME is not a locale alias (but possibly a real locale name).
7153- The return value is statically allocated and must not be freed. */
7154-/* Part of the libintl ABI only for the sake of the gettext.m4 macro. */
7155-extern LIBINTL_DLL_EXPORTED const char *_nl_expand_alias (const char *name);
7156-
7157-/* Split a locale name NAME into its pieces: language, modifier,
7158- territory, codeset.
7159- NAME gets destructively modified: NUL bytes are inserted here and
7160- there. *LANGUAGE gets assigned NAME. Each of *MODIFIER, *TERRITORY,
7161- *CODESET gets assigned either a pointer into the old NAME string, or
7162- NULL. *NORMALIZED_CODESET gets assigned the expanded *CODESET, if it
7163- is different from *CODESET; this one is dynamically allocated and has
7164- to be freed by the caller.
7165- The return value is a bitmask, where each bit corresponds to one
7166- filled-in value:
7167- XPG_MODIFIER for *MODIFIER,
7168- XPG_TERRITORY for *TERRITORY,
7169- XPG_CODESET for *CODESET,
7170- XPG_NORM_CODESET for *NORMALIZED_CODESET.
7171- */
7172-extern int _nl_explode_name (char *name, const char **language,
7173- const char **modifier, const char **territory,
7174- const char **codeset,
7175- const char **normalized_codeset);
7176-
7177-#endif /* loadinfo.h */
7178--- a/intl/loadmsgcat.c
7179+++ /dev/null
7180@@ -1,1336 +0,0 @@
7181-/* Load needed message catalogs.
7182- Copyright (C) 1995-1999, 2000-2007 Free Software Foundation, Inc.
7183-
7184- This program is free software; you can redistribute it and/or modify it
7185- under the terms of the GNU Library General Public License as published
7186- by the Free Software Foundation; either version 2, or (at your option)
7187- any later version.
7188-
7189- This program is distributed in the hope that it will be useful,
7190- but WITHOUT ANY WARRANTY; without even the implied warranty of
7191- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
7192- Library General Public License for more details.
7193-
7194- You should have received a copy of the GNU Library General Public
7195- License along with this program; if not, write to the Free Software
7196- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
7197- USA. */
7198-
7199-/* Tell glibc's <string.h> to provide a prototype for mempcpy().
7200- This must come before <config.h> because <config.h> may include
7201- <features.h>, and once <features.h> has been included, it's too late. */
7202-#ifndef _GNU_SOURCE
7203-# define _GNU_SOURCE 1
7204-#endif
7205-
7206-#ifdef HAVE_CONFIG_H
7207-# include <config.h>
7208-#endif
7209-
7210-#include <ctype.h>
7211-#include <errno.h>
7212-#include <fcntl.h>
7213-#include <sys/types.h>
7214-#include <sys/stat.h>
7215-
7216-#ifdef __GNUC__
7217-# undef alloca
7218-# define alloca __builtin_alloca
7219-# define HAVE_ALLOCA 1
7220-#else
7221-# ifdef _MSC_VER
7222-# include <malloc.h>
7223-# define alloca _alloca
7224-# else
7225-# if defined HAVE_ALLOCA_H || defined _LIBC
7226-# include <alloca.h>
7227-# else
7228-# ifdef _AIX
7229- #pragma alloca
7230-# else
7231-# ifndef alloca
7232-char *alloca ();
7233-# endif
7234-# endif
7235-# endif
7236-# endif
7237-#endif
7238-
7239-#include <stdlib.h>
7240-#include <string.h>
7241-
7242-#if defined HAVE_UNISTD_H || defined _LIBC
7243-# include <unistd.h>
7244-#endif
7245-
7246-#ifdef _LIBC
7247-# include <langinfo.h>
7248-# include <locale.h>
7249-#endif
7250-
7251-#if (defined HAVE_MMAP && defined HAVE_MUNMAP && !defined DISALLOW_MMAP) \
7252- || (defined _LIBC && defined _POSIX_MAPPED_FILES)
7253-# include <sys/mman.h>
7254-# undef HAVE_MMAP
7255-# define HAVE_MMAP 1
7256-#else
7257-# undef HAVE_MMAP
7258-#endif
7259-
7260-#if defined HAVE_STDINT_H_WITH_UINTMAX || defined _LIBC
7261-# include <stdint.h>
7262-#endif
7263-#if defined HAVE_INTTYPES_H || defined _LIBC
7264-# include <inttypes.h>
7265-#endif
7266-
7267-#include "gmo.h"
7268-#include "gettextP.h"
7269-#include "hash-string.h"
7270-#include "plural-exp.h"
7271-
7272-#ifdef _LIBC
7273-# include "../locale/localeinfo.h"
7274-# include <not-cancel.h>
7275-#endif
7276-
7277-/* Handle multi-threaded applications. */
7278-#ifdef _LIBC
7279-# include <bits/libc-lock.h>
7280-#else
7281-# include "lock.h"
7282-#endif
7283-
7284-/* Provide fallback values for macros that ought to be defined in <inttypes.h>.
7285- Note that our fallback values need not be literal strings, because we don't
7286- use them with preprocessor string concatenation. */
7287-#if !defined PRId8 || PRI_MACROS_BROKEN
7288-# undef PRId8
7289-# define PRId8 "d"
7290-#endif
7291-#if !defined PRIi8 || PRI_MACROS_BROKEN
7292-# undef PRIi8
7293-# define PRIi8 "i"
7294-#endif
7295-#if !defined PRIo8 || PRI_MACROS_BROKEN
7296-# undef PRIo8
7297-# define PRIo8 "o"
7298-#endif
7299-#if !defined PRIu8 || PRI_MACROS_BROKEN
7300-# undef PRIu8
7301-# define PRIu8 "u"
7302-#endif
7303-#if !defined PRIx8 || PRI_MACROS_BROKEN
7304-# undef PRIx8
7305-# define PRIx8 "x"
7306-#endif
7307-#if !defined PRIX8 || PRI_MACROS_BROKEN
7308-# undef PRIX8
7309-# define PRIX8 "X"
7310-#endif
7311-#if !defined PRId16 || PRI_MACROS_BROKEN
7312-# undef PRId16
7313-# define PRId16 "d"
7314-#endif
7315-#if !defined PRIi16 || PRI_MACROS_BROKEN
7316-# undef PRIi16
7317-# define PRIi16 "i"
7318-#endif
7319-#if !defined PRIo16 || PRI_MACROS_BROKEN
7320-# undef PRIo16
7321-# define PRIo16 "o"
7322-#endif
7323-#if !defined PRIu16 || PRI_MACROS_BROKEN
7324-# undef PRIu16
7325-# define PRIu16 "u"
7326-#endif
7327-#if !defined PRIx16 || PRI_MACROS_BROKEN
7328-# undef PRIx16
7329-# define PRIx16 "x"
7330-#endif
7331-#if !defined PRIX16 || PRI_MACROS_BROKEN
7332-# undef PRIX16
7333-# define PRIX16 "X"
7334-#endif
7335-#if !defined PRId32 || PRI_MACROS_BROKEN
7336-# undef PRId32
7337-# define PRId32 "d"
7338-#endif
7339-#if !defined PRIi32 || PRI_MACROS_BROKEN
7340-# undef PRIi32
7341-# define PRIi32 "i"
7342-#endif
7343-#if !defined PRIo32 || PRI_MACROS_BROKEN
7344-# undef PRIo32
7345-# define PRIo32 "o"
7346-#endif
7347-#if !defined PRIu32 || PRI_MACROS_BROKEN
7348-# undef PRIu32
7349-# define PRIu32 "u"
7350-#endif
7351-#if !defined PRIx32 || PRI_MACROS_BROKEN
7352-# undef PRIx32
7353-# define PRIx32 "x"
7354-#endif
7355-#if !defined PRIX32 || PRI_MACROS_BROKEN
7356-# undef PRIX32
7357-# define PRIX32 "X"
7358-#endif
7359-#if !defined PRId64 || PRI_MACROS_BROKEN
7360-# undef PRId64
7361-# define PRId64 (sizeof (long) == 8 ? "ld" : "lld")
7362-#endif
7363-#if !defined PRIi64 || PRI_MACROS_BROKEN
7364-# undef PRIi64
7365-# define PRIi64 (sizeof (long) == 8 ? "li" : "lli")
7366-#endif
7367-#if !defined PRIo64 || PRI_MACROS_BROKEN
7368-# undef PRIo64
7369-# define PRIo64 (sizeof (long) == 8 ? "lo" : "llo")
7370-#endif
7371-#if !defined PRIu64 || PRI_MACROS_BROKEN
7372-# undef PRIu64
7373-# define PRIu64 (sizeof (long) == 8 ? "lu" : "llu")
7374-#endif
7375-#if !defined PRIx64 || PRI_MACROS_BROKEN
7376-# undef PRIx64
7377-# define PRIx64 (sizeof (long) == 8 ? "lx" : "llx")
7378-#endif
7379-#if !defined PRIX64 || PRI_MACROS_BROKEN
7380-# undef PRIX64
7381-# define PRIX64 (sizeof (long) == 8 ? "lX" : "llX")
7382-#endif
7383-#if !defined PRIdLEAST8 || PRI_MACROS_BROKEN
7384-# undef PRIdLEAST8
7385-# define PRIdLEAST8 "d"
7386-#endif
7387-#if !defined PRIiLEAST8 || PRI_MACROS_BROKEN
7388-# undef PRIiLEAST8
7389-# define PRIiLEAST8 "i"
7390-#endif
7391-#if !defined PRIoLEAST8 || PRI_MACROS_BROKEN
7392-# undef PRIoLEAST8
7393-# define PRIoLEAST8 "o"
7394-#endif
7395-#if !defined PRIuLEAST8 || PRI_MACROS_BROKEN
7396-# undef PRIuLEAST8
7397-# define PRIuLEAST8 "u"
7398-#endif
7399-#if !defined PRIxLEAST8 || PRI_MACROS_BROKEN
7400-# undef PRIxLEAST8
7401-# define PRIxLEAST8 "x"
7402-#endif
7403-#if !defined PRIXLEAST8 || PRI_MACROS_BROKEN
7404-# undef PRIXLEAST8
7405-# define PRIXLEAST8 "X"
7406-#endif
7407-#if !defined PRIdLEAST16 || PRI_MACROS_BROKEN
7408-# undef PRIdLEAST16
7409-# define PRIdLEAST16 "d"
7410-#endif
7411-#if !defined PRIiLEAST16 || PRI_MACROS_BROKEN
7412-# undef PRIiLEAST16
7413-# define PRIiLEAST16 "i"
7414-#endif
7415-#if !defined PRIoLEAST16 || PRI_MACROS_BROKEN
7416-# undef PRIoLEAST16
7417-# define PRIoLEAST16 "o"
7418-#endif
7419-#if !defined PRIuLEAST16 || PRI_MACROS_BROKEN
7420-# undef PRIuLEAST16
7421-# define PRIuLEAST16 "u"
7422-#endif
7423-#if !defined PRIxLEAST16 || PRI_MACROS_BROKEN
7424-# undef PRIxLEAST16
7425-# define PRIxLEAST16 "x"
7426-#endif
7427-#if !defined PRIXLEAST16 || PRI_MACROS_BROKEN
7428-# undef PRIXLEAST16
7429-# define PRIXLEAST16 "X"
7430-#endif
7431-#if !defined PRIdLEAST32 || PRI_MACROS_BROKEN
7432-# undef PRIdLEAST32
7433-# define PRIdLEAST32 "d"
7434-#endif
7435-#if !defined PRIiLEAST32 || PRI_MACROS_BROKEN
7436-# undef PRIiLEAST32
7437-# define PRIiLEAST32 "i"
7438-#endif
7439-#if !defined PRIoLEAST32 || PRI_MACROS_BROKEN
7440-# undef PRIoLEAST32
7441-# define PRIoLEAST32 "o"
7442-#endif
7443-#if !defined PRIuLEAST32 || PRI_MACROS_BROKEN
7444-# undef PRIuLEAST32
7445-# define PRIuLEAST32 "u"
7446-#endif
7447-#if !defined PRIxLEAST32 || PRI_MACROS_BROKEN
7448-# undef PRIxLEAST32
7449-# define PRIxLEAST32 "x"
7450-#endif
7451-#if !defined PRIXLEAST32 || PRI_MACROS_BROKEN
7452-# undef PRIXLEAST32
7453-# define PRIXLEAST32 "X"
7454-#endif
7455-#if !defined PRIdLEAST64 || PRI_MACROS_BROKEN
7456-# undef PRIdLEAST64
7457-# define PRIdLEAST64 PRId64
7458-#endif
7459-#if !defined PRIiLEAST64 || PRI_MACROS_BROKEN
7460-# undef PRIiLEAST64
7461-# define PRIiLEAST64 PRIi64
7462-#endif
7463-#if !defined PRIoLEAST64 || PRI_MACROS_BROKEN
7464-# undef PRIoLEAST64
7465-# define PRIoLEAST64 PRIo64
7466-#endif
7467-#if !defined PRIuLEAST64 || PRI_MACROS_BROKEN
7468-# undef PRIuLEAST64
7469-# define PRIuLEAST64 PRIu64
7470-#endif
7471-#if !defined PRIxLEAST64 || PRI_MACROS_BROKEN
7472-# undef PRIxLEAST64
7473-# define PRIxLEAST64 PRIx64
7474-#endif
7475-#if !defined PRIXLEAST64 || PRI_MACROS_BROKEN
7476-# undef PRIXLEAST64
7477-# define PRIXLEAST64 PRIX64
7478-#endif
7479-#if !defined PRIdFAST8 || PRI_MACROS_BROKEN
7480-# undef PRIdFAST8
7481-# define PRIdFAST8 "d"
7482-#endif
7483-#if !defined PRIiFAST8 || PRI_MACROS_BROKEN
7484-# undef PRIiFAST8
7485-# define PRIiFAST8 "i"
7486-#endif
7487-#if !defined PRIoFAST8 || PRI_MACROS_BROKEN
7488-# undef PRIoFAST8
7489-# define PRIoFAST8 "o"
7490-#endif
7491-#if !defined PRIuFAST8 || PRI_MACROS_BROKEN
7492-# undef PRIuFAST8
7493-# define PRIuFAST8 "u"
7494-#endif
7495-#if !defined PRIxFAST8 || PRI_MACROS_BROKEN
7496-# undef PRIxFAST8
7497-# define PRIxFAST8 "x"
7498-#endif
7499-#if !defined PRIXFAST8 || PRI_MACROS_BROKEN
7500-# undef PRIXFAST8
7501-# define PRIXFAST8 "X"
7502-#endif
7503-#if !defined PRIdFAST16 || PRI_MACROS_BROKEN
7504-# undef PRIdFAST16
7505-# define PRIdFAST16 "d"
7506-#endif
7507-#if !defined PRIiFAST16 || PRI_MACROS_BROKEN
7508-# undef PRIiFAST16
7509-# define PRIiFAST16 "i"
7510-#endif
7511-#if !defined PRIoFAST16 || PRI_MACROS_BROKEN
7512-# undef PRIoFAST16
7513-# define PRIoFAST16 "o"
7514-#endif
7515-#if !defined PRIuFAST16 || PRI_MACROS_BROKEN
7516-# undef PRIuFAST16
7517-# define PRIuFAST16 "u"
7518-#endif
7519-#if !defined PRIxFAST16 || PRI_MACROS_BROKEN
7520-# undef PRIxFAST16
7521-# define PRIxFAST16 "x"
7522-#endif
7523-#if !defined PRIXFAST16 || PRI_MACROS_BROKEN
7524-# undef PRIXFAST16
7525-# define PRIXFAST16 "X"
7526-#endif
7527-#if !defined PRIdFAST32 || PRI_MACROS_BROKEN
7528-# undef PRIdFAST32
7529-# define PRIdFAST32 "d"
7530-#endif
7531-#if !defined PRIiFAST32 || PRI_MACROS_BROKEN
7532-# undef PRIiFAST32
7533-# define PRIiFAST32 "i"
7534-#endif
7535-#if !defined PRIoFAST32 || PRI_MACROS_BROKEN
7536-# undef PRIoFAST32
7537-# define PRIoFAST32 "o"
7538-#endif
7539-#if !defined PRIuFAST32 || PRI_MACROS_BROKEN
7540-# undef PRIuFAST32
7541-# define PRIuFAST32 "u"
7542-#endif
7543-#if !defined PRIxFAST32 || PRI_MACROS_BROKEN
7544-# undef PRIxFAST32
7545-# define PRIxFAST32 "x"
7546-#endif
7547-#if !defined PRIXFAST32 || PRI_MACROS_BROKEN
7548-# undef PRIXFAST32
7549-# define PRIXFAST32 "X"
7550-#endif
7551-#if !defined PRIdFAST64 || PRI_MACROS_BROKEN
7552-# undef PRIdFAST64
7553-# define PRIdFAST64 PRId64
7554-#endif
7555-#if !defined PRIiFAST64 || PRI_MACROS_BROKEN
7556-# undef PRIiFAST64
7557-# define PRIiFAST64 PRIi64
7558-#endif
7559-#if !defined PRIoFAST64 || PRI_MACROS_BROKEN
7560-# undef PRIoFAST64
7561-# define PRIoFAST64 PRIo64
7562-#endif
7563-#if !defined PRIuFAST64 || PRI_MACROS_BROKEN
7564-# undef PRIuFAST64
7565-# define PRIuFAST64 PRIu64
7566-#endif
7567-#if !defined PRIxFAST64 || PRI_MACROS_BROKEN
7568-# undef PRIxFAST64
7569-# define PRIxFAST64 PRIx64
7570-#endif
7571-#if !defined PRIXFAST64 || PRI_MACROS_BROKEN
7572-# undef PRIXFAST64
7573-# define PRIXFAST64 PRIX64
7574-#endif
7575-#if !defined PRIdMAX || PRI_MACROS_BROKEN
7576-# undef PRIdMAX
7577-# define PRIdMAX (sizeof (uintmax_t) == sizeof (long) ? "ld" : "lld")
7578-#endif
7579-#if !defined PRIiMAX || PRI_MACROS_BROKEN
7580-# undef PRIiMAX
7581-# define PRIiMAX (sizeof (uintmax_t) == sizeof (long) ? "li" : "lli")
7582-#endif
7583-#if !defined PRIoMAX || PRI_MACROS_BROKEN
7584-# undef PRIoMAX
7585-# define PRIoMAX (sizeof (uintmax_t) == sizeof (long) ? "lo" : "llo")
7586-#endif
7587-#if !defined PRIuMAX || PRI_MACROS_BROKEN
7588-# undef PRIuMAX
7589-# define PRIuMAX (sizeof (uintmax_t) == sizeof (long) ? "lu" : "llu")
7590-#endif
7591-#if !defined PRIxMAX || PRI_MACROS_BROKEN
7592-# undef PRIxMAX
7593-# define PRIxMAX (sizeof (uintmax_t) == sizeof (long) ? "lx" : "llx")
7594-#endif
7595-#if !defined PRIXMAX || PRI_MACROS_BROKEN
7596-# undef PRIXMAX
7597-# define PRIXMAX (sizeof (uintmax_t) == sizeof (long) ? "lX" : "llX")
7598-#endif
7599-#if !defined PRIdPTR || PRI_MACROS_BROKEN
7600-# undef PRIdPTR
7601-# define PRIdPTR \
7602- (sizeof (void *) == sizeof (long) ? "ld" : \
7603- sizeof (void *) == sizeof (int) ? "d" : \
7604- "lld")
7605-#endif
7606-#if !defined PRIiPTR || PRI_MACROS_BROKEN
7607-# undef PRIiPTR
7608-# define PRIiPTR \
7609- (sizeof (void *) == sizeof (long) ? "li" : \
7610- sizeof (void *) == sizeof (int) ? "i" : \
7611- "lli")
7612-#endif
7613-#if !defined PRIoPTR || PRI_MACROS_BROKEN
7614-# undef PRIoPTR
7615-# define PRIoPTR \
7616- (sizeof (void *) == sizeof (long) ? "lo" : \
7617- sizeof (void *) == sizeof (int) ? "o" : \
7618- "llo")
7619-#endif
7620-#if !defined PRIuPTR || PRI_MACROS_BROKEN
7621-# undef PRIuPTR
7622-# define PRIuPTR \
7623- (sizeof (void *) == sizeof (long) ? "lu" : \
7624- sizeof (void *) == sizeof (int) ? "u" : \
7625- "llu")
7626-#endif
7627-#if !defined PRIxPTR || PRI_MACROS_BROKEN
7628-# undef PRIxPTR
7629-# define PRIxPTR \
7630- (sizeof (void *) == sizeof (long) ? "lx" : \
7631- sizeof (void *) == sizeof (int) ? "x" : \
7632- "llx")
7633-#endif
7634-#if !defined PRIXPTR || PRI_MACROS_BROKEN
7635-# undef PRIXPTR
7636-# define PRIXPTR \
7637- (sizeof (void *) == sizeof (long) ? "lX" : \
7638- sizeof (void *) == sizeof (int) ? "X" : \
7639- "llX")
7640-#endif
7641-
7642-/* @@ end of prolog @@ */
7643-
7644-#ifdef _LIBC
7645-/* Rename the non ISO C functions. This is required by the standard
7646- because some ISO C functions will require linking with this object
7647- file and the name space must not be polluted. */
7648-# define open(name, flags) open_not_cancel_2 (name, flags)
7649-# define close(fd) close_not_cancel_no_status (fd)
7650-# define read(fd, buf, n) read_not_cancel (fd, buf, n)
7651-# define mmap(addr, len, prot, flags, fd, offset) \
7652- __mmap (addr, len, prot, flags, fd, offset)
7653-# define munmap(addr, len) __munmap (addr, len)
7654-#endif
7655-
7656-/* For those losing systems which don't have `alloca' we have to add
7657- some additional code emulating it. */
7658-#ifdef HAVE_ALLOCA
7659-# define freea(p) /* nothing */
7660-#else
7661-# define alloca(n) malloc (n)
7662-# define freea(p) free (p)
7663-#endif
7664-
7665-/* For systems that distinguish between text and binary I/O.
7666- O_BINARY is usually declared in <fcntl.h>. */
7667-#if !defined O_BINARY && defined _O_BINARY
7668- /* For MSC-compatible compilers. */
7669-# define O_BINARY _O_BINARY
7670-# define O_TEXT _O_TEXT
7671-#endif
7672-#ifdef __BEOS__
7673- /* BeOS 5 has O_BINARY and O_TEXT, but they have no effect. */
7674-# undef O_BINARY
7675-# undef O_TEXT
7676-#endif
7677-/* On reasonable systems, binary I/O is the default. */
7678-#ifndef O_BINARY
7679-# define O_BINARY 0
7680-#endif
7681-
7682-
7683-/* We need a sign, whether a new catalog was loaded, which can be associated
7684- with all translations. This is important if the translations are
7685- cached by one of GCC's features. */
7686-int _nl_msg_cat_cntr;
7687-
7688-
7689-/* Expand a system dependent string segment. Return NULL if unsupported. */
7690-static const char *
7691-get_sysdep_segment_value (const char *name)
7692-{
7693- /* Test for an ISO C 99 section 7.8.1 format string directive.
7694- Syntax:
7695- P R I { d | i | o | u | x | X }
7696- { { | LEAST | FAST } { 8 | 16 | 32 | 64 } | MAX | PTR } */
7697- /* We don't use a table of 14 times 6 'const char *' strings here, because
7698- data relocations cost startup time. */
7699- if (name[0] == 'P' && name[1] == 'R' && name[2] == 'I')
7700- {
7701- if (name[3] == 'd' || name[3] == 'i' || name[3] == 'o' || name[3] == 'u'
7702- || name[3] == 'x' || name[3] == 'X')
7703- {
7704- if (name[4] == '8' && name[5] == '\0')
7705- {
7706- if (name[3] == 'd')
7707- return PRId8;
7708- if (name[3] == 'i')
7709- return PRIi8;
7710- if (name[3] == 'o')
7711- return PRIo8;
7712- if (name[3] == 'u')
7713- return PRIu8;
7714- if (name[3] == 'x')
7715- return PRIx8;
7716- if (name[3] == 'X')
7717- return PRIX8;
7718- abort ();
7719- }
7720- if (name[4] == '1' && name[5] == '6' && name[6] == '\0')
7721- {
7722- if (name[3] == 'd')
7723- return PRId16;
7724- if (name[3] == 'i')
7725- return PRIi16;
7726- if (name[3] == 'o')
7727- return PRIo16;
7728- if (name[3] == 'u')
7729- return PRIu16;
7730- if (name[3] == 'x')
7731- return PRIx16;
7732- if (name[3] == 'X')
7733- return PRIX16;
7734- abort ();
7735- }
7736- if (name[4] == '3' && name[5] == '2' && name[6] == '\0')
7737- {
7738- if (name[3] == 'd')
7739- return PRId32;
7740- if (name[3] == 'i')
7741- return PRIi32;
7742- if (name[3] == 'o')
7743- return PRIo32;
7744- if (name[3] == 'u')
7745- return PRIu32;
7746- if (name[3] == 'x')
7747- return PRIx32;
7748- if (name[3] == 'X')
7749- return PRIX32;
7750- abort ();
7751- }
7752- if (name[4] == '6' && name[5] == '4' && name[6] == '\0')
7753- {
7754- if (name[3] == 'd')
7755- return PRId64;
7756- if (name[3] == 'i')
7757- return PRIi64;
7758- if (name[3] == 'o')
7759- return PRIo64;
7760- if (name[3] == 'u')
7761- return PRIu64;
7762- if (name[3] == 'x')
7763- return PRIx64;
7764- if (name[3] == 'X')
7765- return PRIX64;
7766- abort ();
7767- }
7768- if (name[4] == 'L' && name[5] == 'E' && name[6] == 'A'
7769- && name[7] == 'S' && name[8] == 'T')
7770- {
7771- if (name[9] == '8' && name[10] == '\0')
7772- {
7773- if (name[3] == 'd')
7774- return PRIdLEAST8;
7775- if (name[3] == 'i')
7776- return PRIiLEAST8;
7777- if (name[3] == 'o')
7778- return PRIoLEAST8;
7779- if (name[3] == 'u')
7780- return PRIuLEAST8;
7781- if (name[3] == 'x')
7782- return PRIxLEAST8;
7783- if (name[3] == 'X')
7784- return PRIXLEAST8;
7785- abort ();
7786- }
7787- if (name[9] == '1' && name[10] == '6' && name[11] == '\0')
7788- {
7789- if (name[3] == 'd')
7790- return PRIdLEAST16;
7791- if (name[3] == 'i')
7792- return PRIiLEAST16;
7793- if (name[3] == 'o')
7794- return PRIoLEAST16;
7795- if (name[3] == 'u')
7796- return PRIuLEAST16;
7797- if (name[3] == 'x')
7798- return PRIxLEAST16;
7799- if (name[3] == 'X')
7800- return PRIXLEAST16;
7801- abort ();
7802- }
7803- if (name[9] == '3' && name[10] == '2' && name[11] == '\0')
7804- {
7805- if (name[3] == 'd')
7806- return PRIdLEAST32;
7807- if (name[3] == 'i')
7808- return PRIiLEAST32;
7809- if (name[3] == 'o')
7810- return PRIoLEAST32;
7811- if (name[3] == 'u')
7812- return PRIuLEAST32;
7813- if (name[3] == 'x')
7814- return PRIxLEAST32;
7815- if (name[3] == 'X')
7816- return PRIXLEAST32;
7817- abort ();
7818- }
7819- if (name[9] == '6' && name[10] == '4' && name[11] == '\0')
7820- {
7821- if (name[3] == 'd')
7822- return PRIdLEAST64;
7823- if (name[3] == 'i')
7824- return PRIiLEAST64;
7825- if (name[3] == 'o')
7826- return PRIoLEAST64;
7827- if (name[3] == 'u')
7828- return PRIuLEAST64;
7829- if (name[3] == 'x')
7830- return PRIxLEAST64;
7831- if (name[3] == 'X')
7832- return PRIXLEAST64;
7833- abort ();
7834- }
7835- }
7836- if (name[4] == 'F' && name[5] == 'A' && name[6] == 'S'
7837- && name[7] == 'T')
7838- {
7839- if (name[8] == '8' && name[9] == '\0')
7840- {
7841- if (name[3] == 'd')
7842- return PRIdFAST8;
7843- if (name[3] == 'i')
7844- return PRIiFAST8;
7845- if (name[3] == 'o')
7846- return PRIoFAST8;
7847- if (name[3] == 'u')
7848- return PRIuFAST8;
7849- if (name[3] == 'x')
7850- return PRIxFAST8;
7851- if (name[3] == 'X')
7852- return PRIXFAST8;
7853- abort ();
7854- }
7855- if (name[8] == '1' && name[9] == '6' && name[10] == '\0')
7856- {
7857- if (name[3] == 'd')
7858- return PRIdFAST16;
7859- if (name[3] == 'i')
7860- return PRIiFAST16;
7861- if (name[3] == 'o')
7862- return PRIoFAST16;
7863- if (name[3] == 'u')
7864- return PRIuFAST16;
7865- if (name[3] == 'x')
7866- return PRIxFAST16;
7867- if (name[3] == 'X')
7868- return PRIXFAST16;
7869- abort ();
7870- }
7871- if (name[8] == '3' && name[9] == '2' && name[10] == '\0')
7872- {
7873- if (name[3] == 'd')
7874- return PRIdFAST32;
7875- if (name[3] == 'i')
7876- return PRIiFAST32;
7877- if (name[3] == 'o')
7878- return PRIoFAST32;
7879- if (name[3] == 'u')
7880- return PRIuFAST32;
7881- if (name[3] == 'x')
7882- return PRIxFAST32;
7883- if (name[3] == 'X')
7884- return PRIXFAST32;
7885- abort ();
7886- }
7887- if (name[8] == '6' && name[9] == '4' && name[10] == '\0')
7888- {
7889- if (name[3] == 'd')
7890- return PRIdFAST64;
7891- if (name[3] == 'i')
7892- return PRIiFAST64;
7893- if (name[3] == 'o')
7894- return PRIoFAST64;
7895- if (name[3] == 'u')
7896- return PRIuFAST64;
7897- if (name[3] == 'x')
7898- return PRIxFAST64;
7899- if (name[3] == 'X')
7900- return PRIXFAST64;
7901- abort ();
7902- }
7903- }
7904- if (name[4] == 'M' && name[5] == 'A' && name[6] == 'X'
7905- && name[7] == '\0')
7906- {
7907- if (name[3] == 'd')
7908- return PRIdMAX;
7909- if (name[3] == 'i')
7910- return PRIiMAX;
7911- if (name[3] == 'o')
7912- return PRIoMAX;
7913- if (name[3] == 'u')
7914- return PRIuMAX;
7915- if (name[3] == 'x')
7916- return PRIxMAX;
7917- if (name[3] == 'X')
7918- return PRIXMAX;
7919- abort ();
7920- }
7921- if (name[4] == 'P' && name[5] == 'T' && name[6] == 'R'
7922- && name[7] == '\0')
7923- {
7924- if (name[3] == 'd')
7925- return PRIdPTR;
7926- if (name[3] == 'i')
7927- return PRIiPTR;
7928- if (name[3] == 'o')
7929- return PRIoPTR;
7930- if (name[3] == 'u')
7931- return PRIuPTR;
7932- if (name[3] == 'x')
7933- return PRIxPTR;
7934- if (name[3] == 'X')
7935- return PRIXPTR;
7936- abort ();
7937- }
7938- }
7939- }
7940- /* Test for a glibc specific printf() format directive flag. */
7941- if (name[0] == 'I' && name[1] == '\0')
7942- {
7943-#if defined _LIBC || __GLIBC__ > 2 || (__GLIBC__ == 2 && __GLIBC_MINOR__ >= 2)
7944- /* The 'I' flag, in numeric format directives, replaces ASCII digits
7945- with the 'outdigits' defined in the LC_CTYPE locale facet. This is
7946- used for Farsi (Persian) and maybe Arabic. */
7947- return "I";
7948-#else
7949- return "";
7950-#endif
7951- }
7952- /* Other system dependent strings are not valid. */
7953- return NULL;
7954-}
7955-
7956-/* Load the message catalogs specified by FILENAME. If it is no valid
7957- message catalog do nothing. */
7958-void
7959-internal_function
7960-_nl_load_domain (struct loaded_l10nfile *domain_file,
7961- struct binding *domainbinding)
7962-{
7963- __libc_lock_define_initialized_recursive (static, lock)
7964- int fd = -1;
7965- size_t size;
7966-#ifdef _LIBC
7967- struct stat64 st;
7968-#else
7969- struct stat st;
7970-#endif
7971- struct mo_file_header *data = (struct mo_file_header *) -1;
7972- int use_mmap = 0;
7973- struct loaded_domain *domain;
7974- int revision;
7975- const char *nullentry;
7976- size_t nullentrylen;
7977-
7978- __libc_lock_lock_recursive (lock);
7979- if (domain_file->decided != 0)
7980- {
7981- /* There are two possibilities:
7982-
7983- + this is the same thread calling again during this initialization
7984- via _nl_find_msg. We have initialized everything this call needs.
7985-
7986- + this is another thread which tried to initialize this object.
7987- Not necessary anymore since if the lock is available this
7988- is finished.
7989- */
7990- goto done;
7991- }
7992-
7993- domain_file->decided = -1;
7994- domain_file->data = NULL;
7995-
7996- /* Note that it would be useless to store domainbinding in domain_file
7997- because domainbinding might be == NULL now but != NULL later (after
7998- a call to bind_textdomain_codeset). */
7999-
8000- /* If the record does not represent a valid locale the FILENAME
8001- might be NULL. This can happen when according to the given
8002- specification the locale file name is different for XPG and CEN
8003- syntax. */
8004- if (domain_file->filename == NULL)
8005- goto out;
8006-
8007- /* Try to open the addressed file. */
8008- fd = open (domain_file->filename, O_RDONLY | O_BINARY);
8009- if (fd == -1)
8010- goto out;
8011-
8012- /* We must know about the size of the file. */
8013- if (
8014-#ifdef _LIBC
8015- __builtin_expect (fstat64 (fd, &st) != 0, 0)
8016-#else
8017- __builtin_expect (fstat (fd, &st) != 0, 0)
8018-#endif
8019- || __builtin_expect ((size = (size_t) st.st_size) != st.st_size, 0)
8020- || __builtin_expect (size < sizeof (struct mo_file_header), 0))
8021- /* Something went wrong. */
8022- goto out;
8023-
8024-#ifdef HAVE_MMAP
8025- /* Now we are ready to load the file. If mmap() is available we try
8026- this first. If not available or it failed we try to load it. */
8027- data = (struct mo_file_header *) mmap (NULL, size, PROT_READ,
8028- MAP_PRIVATE, fd, 0);
8029-
8030- if (__builtin_expect (data != (struct mo_file_header *) -1, 1))
8031- {
8032- /* mmap() call was successful. */
8033- close (fd);
8034- fd = -1;
8035- use_mmap = 1;
8036- }
8037-#endif
8038-
8039- /* If the data is not yet available (i.e. mmap'ed) we try to load
8040- it manually. */
8041- if (data == (struct mo_file_header *) -1)
8042- {
8043- size_t to_read;
8044- char *read_ptr;
8045-
8046- data = (struct mo_file_header *) malloc (size);
8047- if (data == NULL)
8048- goto out;
8049-
8050- to_read = size;
8051- read_ptr = (char *) data;
8052- do
8053- {
8054- long int nb = (long int) read (fd, read_ptr, to_read);
8055- if (nb <= 0)
8056- {
8057-#ifdef EINTR
8058- if (nb == -1 && errno == EINTR)
8059- continue;
8060-#endif
8061- goto out;
8062- }
8063- read_ptr += nb;
8064- to_read -= nb;
8065- }
8066- while (to_read > 0);
8067-
8068- close (fd);
8069- fd = -1;
8070- }
8071-
8072- /* Using the magic number we can test whether it really is a message
8073- catalog file. */
8074- if (__builtin_expect (data->magic != _MAGIC && data->magic != _MAGIC_SWAPPED,
8075- 0))
8076- {
8077- /* The magic number is wrong: not a message catalog file. */
8078-#ifdef HAVE_MMAP
8079- if (use_mmap)
8080- munmap ((caddr_t) data, size);
8081- else
8082-#endif
8083- free (data);
8084- goto out;
8085- }
8086-
8087- domain = (struct loaded_domain *) malloc (sizeof (struct loaded_domain));
8088- if (domain == NULL)
8089- goto out;
8090- domain_file->data = domain;
8091-
8092- domain->data = (char *) data;
8093- domain->use_mmap = use_mmap;
8094- domain->mmap_size = size;
8095- domain->must_swap = data->magic != _MAGIC;
8096- domain->malloced = NULL;
8097-
8098- /* Fill in the information about the available tables. */
8099- revision = W (domain->must_swap, data->revision);
8100- /* We support only the major revisions 0 and 1. */
8101- switch (revision >> 16)
8102- {
8103- case 0:
8104- case 1:
8105- domain->nstrings = W (domain->must_swap, data->nstrings);
8106- domain->orig_tab = (const struct string_desc *)
8107- ((char *) data + W (domain->must_swap, data->orig_tab_offset));
8108- domain->trans_tab = (const struct string_desc *)
8109- ((char *) data + W (domain->must_swap, data->trans_tab_offset));
8110- domain->hash_size = W (domain->must_swap, data->hash_tab_size);
8111- domain->hash_tab =
8112- (domain->hash_size > 2
8113- ? (const nls_uint32 *)
8114- ((char *) data + W (domain->must_swap, data->hash_tab_offset))
8115- : NULL);
8116- domain->must_swap_hash_tab = domain->must_swap;
8117-
8118- /* Now dispatch on the minor revision. */
8119- switch (revision & 0xffff)
8120- {
8121- case 0:
8122- domain->n_sysdep_strings = 0;
8123- domain->orig_sysdep_tab = NULL;
8124- domain->trans_sysdep_tab = NULL;
8125- break;
8126- case 1:
8127- default:
8128- {
8129- nls_uint32 n_sysdep_strings;
8130-
8131- if (domain->hash_tab == NULL)
8132- /* This is invalid. These minor revisions need a hash table. */
8133- goto invalid;
8134-
8135- n_sysdep_strings =
8136- W (domain->must_swap, data->n_sysdep_strings);
8137- if (n_sysdep_strings > 0)
8138- {
8139- nls_uint32 n_sysdep_segments;
8140- const struct sysdep_segment *sysdep_segments;
8141- const char **sysdep_segment_values;
8142- const nls_uint32 *orig_sysdep_tab;
8143- const nls_uint32 *trans_sysdep_tab;
8144- nls_uint32 n_inmem_sysdep_strings;
8145- size_t memneed;
8146- char *mem;
8147- struct sysdep_string_desc *inmem_orig_sysdep_tab;
8148- struct sysdep_string_desc *inmem_trans_sysdep_tab;
8149- nls_uint32 *inmem_hash_tab;
8150- unsigned int i, j;
8151-
8152- /* Get the values of the system dependent segments. */
8153- n_sysdep_segments =
8154- W (domain->must_swap, data->n_sysdep_segments);
8155- sysdep_segments = (const struct sysdep_segment *)
8156- ((char *) data
8157- + W (domain->must_swap, data->sysdep_segments_offset));
8158- sysdep_segment_values =
8159- (const char **)
8160- alloca (n_sysdep_segments * sizeof (const char *));
8161- for (i = 0; i < n_sysdep_segments; i++)
8162- {
8163- const char *name =
8164- (char *) data
8165- + W (domain->must_swap, sysdep_segments[i].offset);
8166- nls_uint32 namelen =
8167- W (domain->must_swap, sysdep_segments[i].length);
8168-
8169- if (!(namelen > 0 && name[namelen - 1] == '\0'))
8170- {
8171- freea (sysdep_segment_values);
8172- goto invalid;
8173- }
8174-
8175- sysdep_segment_values[i] = get_sysdep_segment_value (name);
8176- }
8177-
8178- orig_sysdep_tab = (const nls_uint32 *)
8179- ((char *) data
8180- + W (domain->must_swap, data->orig_sysdep_tab_offset));
8181- trans_sysdep_tab = (const nls_uint32 *)
8182- ((char *) data
8183- + W (domain->must_swap, data->trans_sysdep_tab_offset));
8184-
8185- /* Compute the amount of additional memory needed for the
8186- system dependent strings and the augmented hash table.
8187- At the same time, also drop string pairs which refer to
8188- an undefined system dependent segment. */
8189- n_inmem_sysdep_strings = 0;
8190- memneed = domain->hash_size * sizeof (nls_uint32);
8191- for (i = 0; i < n_sysdep_strings; i++)
8192- {
8193- int valid = 1;
8194- size_t needs[2];
8195-
8196- for (j = 0; j < 2; j++)
8197- {
8198- const struct sysdep_string *sysdep_string =
8199- (const struct sysdep_string *)
8200- ((char *) data
8201- + W (domain->must_swap,
8202- j == 0
8203- ? orig_sysdep_tab[i]
8204- : trans_sysdep_tab[i]));
8205- size_t need = 0;
8206- const struct segment_pair *p = sysdep_string->segments;
8207-
8208- if (W (domain->must_swap, p->sysdepref) != SEGMENTS_END)
8209- for (p = sysdep_string->segments;; p++)
8210- {
8211- nls_uint32 sysdepref;
8212-
8213- need += W (domain->must_swap, p->segsize);
8214-
8215- sysdepref = W (domain->must_swap, p->sysdepref);
8216- if (sysdepref == SEGMENTS_END)
8217- break;
8218-
8219- if (sysdepref >= n_sysdep_segments)
8220- {
8221- /* Invalid. */
8222- freea (sysdep_segment_values);
8223- goto invalid;
8224- }
8225-
8226- if (sysdep_segment_values[sysdepref] == NULL)
8227- {
8228- /* This particular string pair is invalid. */
8229- valid = 0;
8230- break;
8231- }
8232-
8233- need += strlen (sysdep_segment_values[sysdepref]);
8234- }
8235-
8236- needs[j] = need;
8237- if (!valid)
8238- break;
8239- }
8240-
8241- if (valid)
8242- {
8243- n_inmem_sysdep_strings++;
8244- memneed += needs[0] + needs[1];
8245- }
8246- }
8247- memneed += 2 * n_inmem_sysdep_strings
8248- * sizeof (struct sysdep_string_desc);
8249-
8250- if (n_inmem_sysdep_strings > 0)
8251- {
8252- unsigned int k;
8253-
8254- /* Allocate additional memory. */
8255- mem = (char *) malloc (memneed);
8256- if (mem == NULL)
8257- goto invalid;
8258-
8259- domain->malloced = mem;
8260- inmem_orig_sysdep_tab = (struct sysdep_string_desc *) mem;
8261- mem += n_inmem_sysdep_strings
8262- * sizeof (struct sysdep_string_desc);
8263- inmem_trans_sysdep_tab = (struct sysdep_string_desc *) mem;
8264- mem += n_inmem_sysdep_strings
8265- * sizeof (struct sysdep_string_desc);
8266- inmem_hash_tab = (nls_uint32 *) mem;
8267- mem += domain->hash_size * sizeof (nls_uint32);
8268-
8269- /* Compute the system dependent strings. */
8270- k = 0;
8271- for (i = 0; i < n_sysdep_strings; i++)
8272- {
8273- int valid = 1;
8274-
8275- for (j = 0; j < 2; j++)
8276- {
8277- const struct sysdep_string *sysdep_string =
8278- (const struct sysdep_string *)
8279- ((char *) data
8280- + W (domain->must_swap,
8281- j == 0
8282- ? orig_sysdep_tab[i]
8283- : trans_sysdep_tab[i]));
8284- const struct segment_pair *p =
8285- sysdep_string->segments;
8286-
8287- if (W (domain->must_swap, p->sysdepref)
8288- != SEGMENTS_END)
8289- for (p = sysdep_string->segments;; p++)
8290- {
8291- nls_uint32 sysdepref;
8292-
8293- sysdepref =
8294- W (domain->must_swap, p->sysdepref);
8295- if (sysdepref == SEGMENTS_END)
8296- break;
8297-
8298- if (sysdep_segment_values[sysdepref] == NULL)
8299- {
8300- /* This particular string pair is
8301- invalid. */
8302- valid = 0;
8303- break;
8304- }
8305- }
8306-
8307- if (!valid)
8308- break;
8309- }
8310-
8311- if (valid)
8312- {
8313- for (j = 0; j < 2; j++)
8314- {
8315- const struct sysdep_string *sysdep_string =
8316- (const struct sysdep_string *)
8317- ((char *) data
8318- + W (domain->must_swap,
8319- j == 0
8320- ? orig_sysdep_tab[i]
8321- : trans_sysdep_tab[i]));
8322- const char *static_segments =
8323- (char *) data
8324- + W (domain->must_swap, sysdep_string->offset);
8325- const struct segment_pair *p =
8326- sysdep_string->segments;
8327-
8328- /* Concatenate the segments, and fill
8329- inmem_orig_sysdep_tab[k] (for j == 0) and
8330- inmem_trans_sysdep_tab[k] (for j == 1). */
8331-
8332- struct sysdep_string_desc *inmem_tab_entry =
8333- (j == 0
8334- ? inmem_orig_sysdep_tab
8335- : inmem_trans_sysdep_tab)
8336- + k;
8337-
8338- if (W (domain->must_swap, p->sysdepref)
8339- == SEGMENTS_END)
8340- {
8341- /* Only one static segment. */
8342- inmem_tab_entry->length =
8343- W (domain->must_swap, p->segsize);
8344- inmem_tab_entry->pointer = static_segments;
8345- }
8346- else
8347- {
8348- inmem_tab_entry->pointer = mem;
8349-
8350- for (p = sysdep_string->segments;; p++)
8351- {
8352- nls_uint32 segsize =
8353- W (domain->must_swap, p->segsize);
8354- nls_uint32 sysdepref =
8355- W (domain->must_swap, p->sysdepref);
8356- size_t n;
8357-
8358- if (segsize > 0)
8359- {
8360- memcpy (mem, static_segments, segsize);
8361- mem += segsize;
8362- static_segments += segsize;
8363- }
8364-
8365- if (sysdepref == SEGMENTS_END)
8366- break;
8367-
8368- n = strlen (sysdep_segment_values[sysdepref]);
8369- memcpy (mem, sysdep_segment_values[sysdepref], n);
8370- mem += n;
8371- }
8372-
8373- inmem_tab_entry->length =
8374- mem - inmem_tab_entry->pointer;
8375- }
8376- }
8377-
8378- k++;
8379- }
8380- }
8381- if (k != n_inmem_sysdep_strings)
8382- abort ();
8383-
8384- /* Compute the augmented hash table. */
8385- for (i = 0; i < domain->hash_size; i++)
8386- inmem_hash_tab[i] =
8387- W (domain->must_swap_hash_tab, domain->hash_tab[i]);
8388- for (i = 0; i < n_inmem_sysdep_strings; i++)
8389- {
8390- const char *msgid = inmem_orig_sysdep_tab[i].pointer;
8391- nls_uint32 hash_val = __hash_string (msgid);
8392- nls_uint32 idx = hash_val % domain->hash_size;
8393- nls_uint32 incr =
8394- 1 + (hash_val % (domain->hash_size - 2));
8395-
8396- for (;;)
8397- {
8398- if (inmem_hash_tab[idx] == 0)
8399- {
8400- /* Hash table entry is empty. Use it. */
8401- inmem_hash_tab[idx] = 1 + domain->nstrings + i;
8402- break;
8403- }
8404-
8405- if (idx >= domain->hash_size - incr)
8406- idx -= domain->hash_size - incr;
8407- else
8408- idx += incr;
8409- }
8410- }
8411-
8412- domain->n_sysdep_strings = n_inmem_sysdep_strings;
8413- domain->orig_sysdep_tab = inmem_orig_sysdep_tab;
8414- domain->trans_sysdep_tab = inmem_trans_sysdep_tab;
8415-
8416- domain->hash_tab = inmem_hash_tab;
8417- domain->must_swap_hash_tab = 0;
8418- }
8419- else
8420- {
8421- domain->n_sysdep_strings = 0;
8422- domain->orig_sysdep_tab = NULL;
8423- domain->trans_sysdep_tab = NULL;
8424- }
8425-
8426- freea (sysdep_segment_values);
8427- }
8428- else
8429- {
8430- domain->n_sysdep_strings = 0;
8431- domain->orig_sysdep_tab = NULL;
8432- domain->trans_sysdep_tab = NULL;
8433- }
8434- }
8435- break;
8436- }
8437- break;
8438- default:
8439- /* This is an invalid revision. */
8440- invalid:
8441- /* This is an invalid .mo file. */
8442- if (domain->malloced)
8443- free (domain->malloced);
8444-#ifdef HAVE_MMAP
8445- if (use_mmap)
8446- munmap ((caddr_t) data, size);
8447- else
8448-#endif
8449- free (data);
8450- free (domain);
8451- domain_file->data = NULL;
8452- goto out;
8453- }
8454-
8455- /* No caches of converted translations so far. */
8456- domain->conversions = NULL;
8457- domain->nconversions = 0;
8458- gl_rwlock_init (domain->conversions_lock);
8459-
8460- /* Get the header entry and look for a plural specification. */
8461-#ifdef IN_LIBGLOCALE
8462- nullentry =
8463- _nl_find_msg (domain_file, domainbinding, NULL, "", &nullentrylen);
8464-#else
8465- nullentry = _nl_find_msg (domain_file, domainbinding, "", 0, &nullentrylen);
8466-#endif
8467- EXTRACT_PLURAL_EXPRESSION (nullentry, &domain->plural, &domain->nplurals);
8468-
8469- out:
8470- if (fd != -1)
8471- close (fd);
8472-
8473- domain_file->decided = 1;
8474-
8475- done:
8476- __libc_lock_unlock_recursive (lock);
8477-}
8478-
8479-
8480-#ifdef _LIBC
8481-void
8482-internal_function __libc_freeres_fn_section
8483-_nl_unload_domain (struct loaded_domain *domain)
8484-{
8485- size_t i;
8486-
8487- if (domain->plural != &__gettext_germanic_plural)
8488- __gettext_free_exp ((struct expression *) domain->plural);
8489-
8490- for (i = 0; i < domain->nconversions; i++)
8491- {
8492- struct converted_domain *convd = &domain->conversions[i];
8493-
8494- free (convd->encoding);
8495- if (convd->conv_tab != NULL && convd->conv_tab != (char **) -1)
8496- free (convd->conv_tab);
8497- if (convd->conv != (__gconv_t) -1)
8498- __gconv_close (convd->conv);
8499- }
8500- if (domain->conversions != NULL)
8501- free (domain->conversions);
8502- __libc_rwlock_fini (domain->conversions_lock);
8503-
8504- if (domain->malloced)
8505- free (domain->malloced);
8506-
8507-# ifdef _POSIX_MAPPED_FILES
8508- if (domain->use_mmap)
8509- munmap ((caddr_t) domain->data, domain->mmap_size);
8510- else
8511-# endif /* _POSIX_MAPPED_FILES */
8512- free ((void *) domain->data);
8513-
8514- free (domain);
8515-}
8516-#endif
8517--- a/intl/localcharset.c
8518+++ /dev/null
8519@@ -1,461 +0,0 @@
8520-/* Determine a canonical name for the current locale's character encoding.
8521-
8522- Copyright (C) 2000-2006 Free Software Foundation, Inc.
8523-
8524- This program is free software; you can redistribute it and/or modify it
8525- under the terms of the GNU Library General Public License as published
8526- by the Free Software Foundation; either version 2, or (at your option)
8527- any later version.
8528-
8529- This program is distributed in the hope that it will be useful,
8530- but WITHOUT ANY WARRANTY; without even the implied warranty of
8531- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
8532- Library General Public License for more details.
8533-
8534- You should have received a copy of the GNU Library General Public
8535- License along with this program; if not, write to the Free Software
8536- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
8537- USA. */
8538-
8539-/* Written by Bruno Haible <bruno@clisp.org>. */
8540-
8541-#include <config.h>
8542-
8543-/* Specification. */
8544-#include "localcharset.h"
8545-
8546-#include <stddef.h>
8547-#include <stdio.h>
8548-#include <string.h>
8549-#include <stdlib.h>
8550-
8551-#if defined _WIN32 || defined __WIN32__
8552-# define WIN32_NATIVE
8553-#endif
8554-
8555-#if defined __EMX__
8556-/* Assume EMX program runs on OS/2, even if compiled under DOS. */
8557-# define OS2
8558-#endif
8559-
8560-#if !defined WIN32_NATIVE
8561-# if HAVE_LANGINFO_CODESET
8562-# include <langinfo.h>
8563-# else
8564-# if 0 /* see comment below */
8565-# include <locale.h>
8566-# endif
8567-# endif
8568-# ifdef __CYGWIN__
8569-# define WIN32_LEAN_AND_MEAN
8570-# include <windows.h>
8571-# endif
8572-#elif defined WIN32_NATIVE
8573-# define WIN32_LEAN_AND_MEAN
8574-# include <windows.h>
8575-#endif
8576-#if defined OS2
8577-# define INCL_DOS
8578-# include <os2.h>
8579-#endif
8580-
8581-#if ENABLE_RELOCATABLE
8582-# include "relocatable.h"
8583-#else
8584-# define relocate(pathname) (pathname)
8585-#endif
8586-
8587-/* Get LIBDIR. */
8588-#ifndef LIBDIR
8589-# include "configmake.h"
8590-#endif
8591-
8592-#if defined _WIN32 || defined __WIN32__ || defined __CYGWIN__ || defined __EMX__ || defined __DJGPP__
8593- /* Win32, Cygwin, OS/2, DOS */
8594-# define ISSLASH(C) ((C) == '/' || (C) == '\\')
8595-#endif
8596-
8597-#ifndef DIRECTORY_SEPARATOR
8598-# define DIRECTORY_SEPARATOR '/'
8599-#endif
8600-
8601-#ifndef ISSLASH
8602-# define ISSLASH(C) ((C) == DIRECTORY_SEPARATOR)
8603-#endif
8604-
8605-#if HAVE_DECL_GETC_UNLOCKED
8606-# undef getc
8607-# define getc getc_unlocked
8608-#endif
8609-
8610-/* The following static variable is declared 'volatile' to avoid a
8611- possible multithread problem in the function get_charset_aliases. If we
8612- are running in a threaded environment, and if two threads initialize
8613- 'charset_aliases' simultaneously, both will produce the same value,
8614- and everything will be ok if the two assignments to 'charset_aliases'
8615- are atomic. But I don't know what will happen if the two assignments mix. */
8616-#if __STDC__ != 1
8617-# define volatile /* empty */
8618-#endif
8619-/* Pointer to the contents of the charset.alias file, if it has already been
8620- read, else NULL. Its format is:
8621- ALIAS_1 '\0' CANONICAL_1 '\0' ... ALIAS_n '\0' CANONICAL_n '\0' '\0' */
8622-static const char * volatile charset_aliases;
8623-
8624-/* Return a pointer to the contents of the charset.alias file. */
8625-static const char *
8626-get_charset_aliases (void)
8627-{
8628- const char *cp;
8629-
8630- cp = charset_aliases;
8631- if (cp == NULL)
8632- {
8633-#if !(defined VMS || defined WIN32_NATIVE || defined __CYGWIN__)
8634- FILE *fp;
8635- const char *dir;
8636- const char *base = "charset.alias";
8637- char *file_name;
8638-
8639- /* Make it possible to override the charset.alias location. This is
8640- necessary for running the testsuite before "make install". */
8641- dir = getenv ("CHARSETALIASDIR");
8642- if (dir == NULL || dir[0] == '\0')
8643- dir = relocate (LIBDIR);
8644-
8645- /* Concatenate dir and base into freshly allocated file_name. */
8646- {
8647- size_t dir_len = strlen (dir);
8648- size_t base_len = strlen (base);
8649- int add_slash = (dir_len > 0 && !ISSLASH (dir[dir_len - 1]));
8650- file_name = (char *) malloc (dir_len + add_slash + base_len + 1);
8651- if (file_name != NULL)
8652- {
8653- memcpy (file_name, dir, dir_len);
8654- if (add_slash)
8655- file_name[dir_len] = DIRECTORY_SEPARATOR;
8656- memcpy (file_name + dir_len + add_slash, base, base_len + 1);
8657- }
8658- }
8659-
8660- if (file_name == NULL || (fp = fopen (file_name, "r")) == NULL)
8661- /* Out of memory or file not found, treat it as empty. */
8662- cp = "";
8663- else
8664- {
8665- /* Parse the file's contents. */
8666- char *res_ptr = NULL;
8667- size_t res_size = 0;
8668-
8669- for (;;)
8670- {
8671- int c;
8672- char buf1[50+1];
8673- char buf2[50+1];
8674- size_t l1, l2;
8675- char *old_res_ptr;
8676-
8677- c = getc (fp);
8678- if (c == EOF)
8679- break;
8680- if (c == '\n' || c == ' ' || c == '\t')
8681- continue;
8682- if (c == '#')
8683- {
8684- /* Skip comment, to end of line. */
8685- do
8686- c = getc (fp);
8687- while (!(c == EOF || c == '\n'));
8688- if (c == EOF)
8689- break;
8690- continue;
8691- }
8692- ungetc (c, fp);
8693- if (fscanf (fp, "%50s %50s", buf1, buf2) < 2)
8694- break;
8695- l1 = strlen (buf1);
8696- l2 = strlen (buf2);
8697- old_res_ptr = res_ptr;
8698- if (res_size == 0)
8699- {
8700- res_size = l1 + 1 + l2 + 1;
8701- res_ptr = (char *) malloc (res_size + 1);
8702- }
8703- else
8704- {
8705- res_size += l1 + 1 + l2 + 1;
8706- res_ptr = (char *) realloc (res_ptr, res_size + 1);
8707- }
8708- if (res_ptr == NULL)
8709- {
8710- /* Out of memory. */
8711- res_size = 0;
8712- if (old_res_ptr != NULL)
8713- free (old_res_ptr);
8714- break;
8715- }
8716- strcpy (res_ptr + res_size - (l2 + 1) - (l1 + 1), buf1);
8717- strcpy (res_ptr + res_size - (l2 + 1), buf2);
8718- }
8719- fclose (fp);
8720- if (res_size == 0)
8721- cp = "";
8722- else
8723- {
8724- *(res_ptr + res_size) = '\0';
8725- cp = res_ptr;
8726- }
8727- }
8728-
8729- if (file_name != NULL)
8730- free (file_name);
8731-
8732-#else
8733-
8734-# if defined VMS
8735- /* To avoid the troubles of an extra file charset.alias_vms in the
8736- sources of many GNU packages, simply inline the aliases here. */
8737- /* The list of encodings is taken from the OpenVMS 7.3-1 documentation
8738- "Compaq C Run-Time Library Reference Manual for OpenVMS systems"
8739- section 10.7 "Handling Different Character Sets". */
8740- cp = "ISO8859-1" "\0" "ISO-8859-1" "\0"
8741- "ISO8859-2" "\0" "ISO-8859-2" "\0"
8742- "ISO8859-5" "\0" "ISO-8859-5" "\0"
8743- "ISO8859-7" "\0" "ISO-8859-7" "\0"
8744- "ISO8859-8" "\0" "ISO-8859-8" "\0"
8745- "ISO8859-9" "\0" "ISO-8859-9" "\0"
8746- /* Japanese */
8747- "eucJP" "\0" "EUC-JP" "\0"
8748- "SJIS" "\0" "SHIFT_JIS" "\0"
8749- "DECKANJI" "\0" "DEC-KANJI" "\0"
8750- "SDECKANJI" "\0" "EUC-JP" "\0"
8751- /* Chinese */
8752- "eucTW" "\0" "EUC-TW" "\0"
8753- "DECHANYU" "\0" "DEC-HANYU" "\0"
8754- "DECHANZI" "\0" "GB2312" "\0"
8755- /* Korean */
8756- "DECKOREAN" "\0" "EUC-KR" "\0";
8757-# endif
8758-
8759-# if defined WIN32_NATIVE || defined __CYGWIN__
8760- /* To avoid the troubles of installing a separate file in the same
8761- directory as the DLL and of retrieving the DLL's directory at
8762- runtime, simply inline the aliases here. */
8763-
8764- cp = "CP936" "\0" "GBK" "\0"
8765- "CP1361" "\0" "JOHAB" "\0"
8766- "CP20127" "\0" "ASCII" "\0"
8767- "CP20866" "\0" "KOI8-R" "\0"
8768- "CP20936" "\0" "GB2312" "\0"
8769- "CP21866" "\0" "KOI8-RU" "\0"
8770- "CP28591" "\0" "ISO-8859-1" "\0"
8771- "CP28592" "\0" "ISO-8859-2" "\0"
8772- "CP28593" "\0" "ISO-8859-3" "\0"
8773- "CP28594" "\0" "ISO-8859-4" "\0"
8774- "CP28595" "\0" "ISO-8859-5" "\0"
8775- "CP28596" "\0" "ISO-8859-6" "\0"
8776- "CP28597" "\0" "ISO-8859-7" "\0"
8777- "CP28598" "\0" "ISO-8859-8" "\0"
8778- "CP28599" "\0" "ISO-8859-9" "\0"
8779- "CP28605" "\0" "ISO-8859-15" "\0"
8780- "CP38598" "\0" "ISO-8859-8" "\0"
8781- "CP51932" "\0" "EUC-JP" "\0"
8782- "CP51936" "\0" "GB2312" "\0"
8783- "CP51949" "\0" "EUC-KR" "\0"
8784- "CP51950" "\0" "EUC-TW" "\0"
8785- "CP54936" "\0" "GB18030" "\0"
8786- "CP65001" "\0" "UTF-8" "\0";
8787-# endif
8788-#endif
8789-
8790- charset_aliases = cp;
8791- }
8792-
8793- return cp;
8794-}
8795-
8796-/* Determine the current locale's character encoding, and canonicalize it
8797- into one of the canonical names listed in config.charset.
8798- The result must not be freed; it is statically allocated.
8799- If the canonical name cannot be determined, the result is a non-canonical
8800- name. */
8801-
8802-#ifdef STATIC
8803-STATIC
8804-#endif
8805-const char *
8806-locale_charset (void)
8807-{
8808- const char *codeset;
8809- const char *aliases;
8810-
8811-#if !(defined WIN32_NATIVE || defined OS2)
8812-
8813-# if HAVE_LANGINFO_CODESET
8814-
8815- /* Most systems support nl_langinfo (CODESET) nowadays. */
8816- codeset = nl_langinfo (CODESET);
8817-
8818-# ifdef __CYGWIN__
8819- /* Cygwin 2006 does not have locales. nl_langinfo (CODESET) always
8820- returns "US-ASCII". As long as this is not fixed, return the suffix
8821- of the locale name from the environment variables (if present) or
8822- the codepage as a number. */
8823- if (codeset != NULL && strcmp (codeset, "US-ASCII") == 0)
8824- {
8825- const char *locale;
8826- static char buf[2 + 10 + 1];
8827-
8828- locale = getenv ("LC_ALL");
8829- if (locale == NULL || locale[0] == '\0')
8830- {
8831- locale = getenv ("LC_CTYPE");
8832- if (locale == NULL || locale[0] == '\0')
8833- locale = getenv ("LANG");
8834- }
8835- if (locale != NULL && locale[0] != '\0')
8836- {
8837- /* If the locale name contains an encoding after the dot, return
8838- it. */
8839- const char *dot = strchr (locale, '.');
8840-
8841- if (dot != NULL)
8842- {
8843- const char *modifier;
8844-
8845- dot++;
8846- /* Look for the possible @... trailer and remove it, if any. */
8847- modifier = strchr (dot, '@');
8848- if (modifier == NULL)
8849- return dot;
8850- if (modifier - dot < sizeof (buf))
8851- {
8852- memcpy (buf, dot, modifier - dot);
8853- buf [modifier - dot] = '\0';
8854- return buf;
8855- }
8856- }
8857- }
8858-
8859- /* Woe32 has a function returning the locale's codepage as a number. */
8860- sprintf (buf, "CP%u", GetACP ());
8861- codeset = buf;
8862- }
8863-# endif
8864-
8865-# else
8866-
8867- /* On old systems which lack it, use setlocale or getenv. */
8868- const char *locale = NULL;
8869-
8870- /* But most old systems don't have a complete set of locales. Some
8871- (like SunOS 4 or DJGPP) have only the C locale. Therefore we don't
8872- use setlocale here; it would return "C" when it doesn't support the
8873- locale name the user has set. */
8874-# if 0
8875- locale = setlocale (LC_CTYPE, NULL);
8876-# endif
8877- if (locale == NULL || locale[0] == '\0')
8878- {
8879- locale = getenv ("LC_ALL");
8880- if (locale == NULL || locale[0] == '\0')
8881- {
8882- locale = getenv ("LC_CTYPE");
8883- if (locale == NULL || locale[0] == '\0')
8884- locale = getenv ("LANG");
8885- }
8886- }
8887-
8888- /* On some old systems, one used to set locale = "iso8859_1". On others,
8889- you set it to "language_COUNTRY.charset". In any case, we resolve it
8890- through the charset.alias file. */
8891- codeset = locale;
8892-
8893-# endif
8894-
8895-#elif defined WIN32_NATIVE
8896-
8897- static char buf[2 + 10 + 1];
8898-
8899- /* Woe32 has a function returning the locale's codepage as a number. */
8900- sprintf (buf, "CP%u", GetACP ());
8901- codeset = buf;
8902-
8903-#elif defined OS2
8904-
8905- const char *locale;
8906- static char buf[2 + 10 + 1];
8907- ULONG cp[3];
8908- ULONG cplen;
8909-
8910- /* Allow user to override the codeset, as set in the operating system,
8911- with standard language environment variables. */
8912- locale = getenv ("LC_ALL");
8913- if (locale == NULL || locale[0] == '\0')
8914- {
8915- locale = getenv ("LC_CTYPE");
8916- if (locale == NULL || locale[0] == '\0')
8917- locale = getenv ("LANG");
8918- }
8919- if (locale != NULL && locale[0] != '\0')
8920- {
8921- /* If the locale name contains an encoding after the dot, return it. */
8922- const char *dot = strchr (locale, '.');
8923-
8924- if (dot != NULL)
8925- {
8926- const char *modifier;
8927-
8928- dot++;
8929- /* Look for the possible @... trailer and remove it, if any. */
8930- modifier = strchr (dot, '@');
8931- if (modifier == NULL)
8932- return dot;
8933- if (modifier - dot < sizeof (buf))
8934- {
8935- memcpy (buf, dot, modifier - dot);
8936- buf [modifier - dot] = '\0';
8937- return buf;
8938- }
8939- }
8940-
8941- /* Resolve through the charset.alias file. */
8942- codeset = locale;
8943- }
8944- else
8945- {
8946- /* OS/2 has a function returning the locale's codepage as a number. */
8947- if (DosQueryCp (sizeof (cp), cp, &cplen))
8948- codeset = "";
8949- else
8950- {
8951- sprintf (buf, "CP%u", cp[0]);
8952- codeset = buf;
8953- }
8954- }
8955-
8956-#endif
8957-
8958- if (codeset == NULL)
8959- /* The canonical name cannot be determined. */
8960- codeset = "";
8961-
8962- /* Resolve alias. */
8963- for (aliases = get_charset_aliases ();
8964- *aliases != '\0';
8965- aliases += strlen (aliases) + 1, aliases += strlen (aliases) + 1)
8966- if (strcmp (codeset, aliases) == 0
8967- || (aliases[0] == '*' && aliases[1] == '\0'))
8968- {
8969- codeset = aliases + strlen (aliases) + 1;
8970- break;
8971- }
8972-
8973- /* Don't return an empty string. GNU libc and GNU libiconv interpret
8974- the empty string as denoting "the locale's character encoding",
8975- thus GNU libiconv would call this function a second time. */
8976- if (codeset[0] == '\0')
8977- codeset = "ASCII";
8978-
8979- return codeset;
8980-}
8981--- a/intl/localcharset.h
8982+++ /dev/null
8983@@ -1,42 +0,0 @@
8984-/* Determine a canonical name for the current locale's character encoding.
8985- Copyright (C) 2000-2003 Free Software Foundation, Inc.
8986- This file is part of the GNU CHARSET Library.
8987-
8988- This program is free software; you can redistribute it and/or modify it
8989- under the terms of the GNU Library General Public License as published
8990- by the Free Software Foundation; either version 2, or (at your option)
8991- any later version.
8992-
8993- This program is distributed in the hope that it will be useful,
8994- but WITHOUT ANY WARRANTY; without even the implied warranty of
8995- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
8996- Library General Public License for more details.
8997-
8998- You should have received a copy of the GNU Library General Public
8999- License along with this program; if not, write to the Free Software
9000- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
9001- USA. */
9002-
9003-#ifndef _LOCALCHARSET_H
9004-#define _LOCALCHARSET_H
9005-
9006-
9007-#ifdef __cplusplus
9008-extern "C" {
9009-#endif
9010-
9011-
9012-/* Determine the current locale's character encoding, and canonicalize it
9013- into one of the canonical names listed in config.charset.
9014- The result must not be freed; it is statically allocated.
9015- If the canonical name cannot be determined, the result is a non-canonical
9016- name. */
9017-extern const char * locale_charset (void);
9018-
9019-
9020-#ifdef __cplusplus
9021-}
9022-#endif
9023-
9024-
9025-#endif /* _LOCALCHARSET_H */
9026--- a/intl/locale.alias
9027+++ /dev/null
9028@@ -1,77 +0,0 @@
9029-# Locale name alias data base.
9030-# Copyright (C) 1996-2001,2003,2007 Free Software Foundation, Inc.
9031-#
9032-# This program is free software; you can redistribute it and/or modify it
9033-# under the terms of the GNU Library General Public License as published
9034-# by the Free Software Foundation; either version 2, or (at your option)
9035-# any later version.
9036-#
9037-# This program is distributed in the hope that it will be useful,
9038-# but WITHOUT ANY WARRANTY; without even the implied warranty of
9039-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
9040-# Library General Public License for more details.
9041-#
9042-# You should have received a copy of the GNU Library General Public
9043-# License along with this program; if not, write to the Free Software
9044-# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
9045-# USA.
9046-
9047-# The format of this file is the same as for the corresponding file of
9048-# the X Window System, which normally can be found in
9049-# /usr/lib/X11/locale/locale.alias
9050-# A single line contains two fields: an alias and a substitution value.
9051-# All entries are case independent.
9052-
9053-# Note: This file is obsolete and is kept around for the time being for
9054-# backward compatibility. Nobody should rely on the names defined here.
9055-# Locales should always be specified by their full name.
9056-
9057-# Packages using this file:
9058-
9059-bokmal nb_NO.ISO-8859-1
9060-bokmål nb_NO.ISO-8859-1
9061-catalan ca_ES.ISO-8859-1
9062-croatian hr_HR.ISO-8859-2
9063-czech cs_CZ.ISO-8859-2
9064-danish da_DK.ISO-8859-1
9065-dansk da_DK.ISO-8859-1
9066-deutsch de_DE.ISO-8859-1
9067-dutch nl_NL.ISO-8859-1
9068-eesti et_EE.ISO-8859-1
9069-estonian et_EE.ISO-8859-1
9070-finnish fi_FI.ISO-8859-1
9071-français fr_FR.ISO-8859-1
9072-french fr_FR.ISO-8859-1
9073-galego gl_ES.ISO-8859-1
9074-galician gl_ES.ISO-8859-1
9075-german de_DE.ISO-8859-1
9076-greek el_GR.ISO-8859-7
9077-hebrew he_IL.ISO-8859-8
9078-hrvatski hr_HR.ISO-8859-2
9079-hungarian hu_HU.ISO-8859-2
9080-icelandic is_IS.ISO-8859-1
9081-italian it_IT.ISO-8859-1
9082-japanese ja_JP.eucJP
9083-japanese.euc ja_JP.eucJP
9084-ja_JP ja_JP.eucJP
9085-ja_JP.ujis ja_JP.eucJP
9086-japanese.sjis ja_JP.SJIS
9087-korean ko_KR.eucKR
9088-korean.euc ko_KR.eucKR
9089-ko_KR ko_KR.eucKR
9090-lithuanian lt_LT.ISO-8859-13
9091-no_NO nb_NO.ISO-8859-1
9092-no_NO.ISO-8859-1 nb_NO.ISO-8859-1
9093-norwegian nb_NO.ISO-8859-1
9094-nynorsk nn_NO.ISO-8859-1
9095-polish pl_PL.ISO-8859-2
9096-portuguese pt_PT.ISO-8859-1
9097-romanian ro_RO.ISO-8859-2
9098-russian ru_RU.ISO-8859-5
9099-slovak sk_SK.ISO-8859-2
9100-slovene sl_SI.ISO-8859-2
9101-slovenian sl_SI.ISO-8859-2
9102-spanish es_ES.ISO-8859-1
9103-swedish sv_SE.ISO-8859-1
9104-thai th_TH.TIS-620
9105-turkish tr_TR.ISO-8859-9
9106--- a/intl/localealias.c
9107+++ /dev/null
9108@@ -1,439 +0,0 @@
9109-/* Handle aliases for locale names.
9110- Copyright (C) 1995-1999, 2000-2001, 2003, 2005-2006 Free Software Foundation, Inc.
9111-
9112- This program is free software; you can redistribute it and/or modify it
9113- under the terms of the GNU Library General Public License as published
9114- by the Free Software Foundation; either version 2, or (at your option)
9115- any later version.
9116-
9117- This program is distributed in the hope that it will be useful,
9118- but WITHOUT ANY WARRANTY; without even the implied warranty of
9119- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
9120- Library General Public License for more details.
9121-
9122- You should have received a copy of the GNU Library General Public
9123- License along with this program; if not, write to the Free Software
9124- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
9125- USA. */
9126-
9127-/* Tell glibc's <string.h> to provide a prototype for mempcpy().
9128- This must come before <config.h> because <config.h> may include
9129- <features.h>, and once <features.h> has been included, it's too late. */
9130-#ifndef _GNU_SOURCE
9131-# define _GNU_SOURCE 1
9132-#endif
9133-
9134-#ifdef HAVE_CONFIG_H
9135-# include <config.h>
9136-#endif
9137-
9138-#include <ctype.h>
9139-#include <stdio.h>
9140-#if defined _LIBC || defined HAVE___FSETLOCKING
9141-# include <stdio_ext.h>
9142-#endif
9143-#include <sys/types.h>
9144-
9145-#ifdef __GNUC__
9146-# undef alloca
9147-# define alloca __builtin_alloca
9148-# define HAVE_ALLOCA 1
9149-#else
9150-# ifdef _MSC_VER
9151-# include <malloc.h>
9152-# define alloca _alloca
9153-# else
9154-# if defined HAVE_ALLOCA_H || defined _LIBC
9155-# include <alloca.h>
9156-# else
9157-# ifdef _AIX
9158- #pragma alloca
9159-# else
9160-# ifndef alloca
9161-char *alloca ();
9162-# endif
9163-# endif
9164-# endif
9165-# endif
9166-#endif
9167-
9168-#include <stdlib.h>
9169-#include <string.h>
9170-
9171-#include "gettextP.h"
9172-
9173-#if ENABLE_RELOCATABLE
9174-# include "relocatable.h"
9175-#else
9176-# define relocate(pathname) (pathname)
9177-#endif
9178-
9179-/* @@ end of prolog @@ */
9180-
9181-#ifdef _LIBC
9182-/* Rename the non ANSI C functions. This is required by the standard
9183- because some ANSI C functions will require linking with this object
9184- file and the name space must not be polluted. */
9185-# define strcasecmp __strcasecmp
9186-
9187-# ifndef mempcpy
9188-# define mempcpy __mempcpy
9189-# endif
9190-# define HAVE_MEMPCPY 1
9191-# define HAVE___FSETLOCKING 1
9192-#endif
9193-
9194-/* Handle multi-threaded applications. */
9195-#ifdef _LIBC
9196-# include <bits/libc-lock.h>
9197-#else
9198-# include "lock.h"
9199-#endif
9200-
9201-#ifndef internal_function
9202-# define internal_function
9203-#endif
9204-
9205-/* Some optimizations for glibc. */
9206-#ifdef _LIBC
9207-# define FEOF(fp) feof_unlocked (fp)
9208-# define FGETS(buf, n, fp) fgets_unlocked (buf, n, fp)
9209-#else
9210-# define FEOF(fp) feof (fp)
9211-# define FGETS(buf, n, fp) fgets (buf, n, fp)
9212-#endif
9213-
9214-/* For those losing systems which don't have `alloca' we have to add
9215- some additional code emulating it. */
9216-#ifdef HAVE_ALLOCA
9217-# define freea(p) /* nothing */
9218-#else
9219-# define alloca(n) malloc (n)
9220-# define freea(p) free (p)
9221-#endif
9222-
9223-#if defined _LIBC_REENTRANT || HAVE_DECL_FGETS_UNLOCKED
9224-# undef fgets
9225-# define fgets(buf, len, s) fgets_unlocked (buf, len, s)
9226-#endif
9227-#if defined _LIBC_REENTRANT || HAVE_DECL_FEOF_UNLOCKED
9228-# undef feof
9229-# define feof(s) feof_unlocked (s)
9230-#endif
9231-
9232-
9233-__libc_lock_define_initialized (static, lock)
9234-
9235-
9236-struct alias_map
9237-{
9238- const char *alias;
9239- const char *value;
9240-};
9241-
9242-
9243-#ifndef _LIBC
9244-# define libc_freeres_ptr(decl) decl
9245-#endif
9246-
9247-libc_freeres_ptr (static char *string_space);
9248-static size_t string_space_act;
9249-static size_t string_space_max;
9250-libc_freeres_ptr (static struct alias_map *map);
9251-static size_t nmap;
9252-static size_t maxmap;
9253-
9254-
9255-/* Prototypes for local functions. */
9256-static size_t read_alias_file (const char *fname, int fname_len)
9257- internal_function;
9258-static int extend_alias_table (void);
9259-static int alias_compare (const struct alias_map *map1,
9260- const struct alias_map *map2);
9261-
9262-
9263-const char *
9264-_nl_expand_alias (const char *name)
9265-{
9266- static const char *locale_alias_path;
9267- struct alias_map *retval;
9268- const char *result = NULL;
9269- size_t added;
9270-
9271- __libc_lock_lock (lock);
9272-
9273- if (locale_alias_path == NULL)
9274- locale_alias_path = LOCALE_ALIAS_PATH;
9275-
9276- do
9277- {
9278- struct alias_map item;
9279-
9280- item.alias = name;
9281-
9282- if (nmap > 0)
9283- retval = (struct alias_map *) bsearch (&item, map, nmap,
9284- sizeof (struct alias_map),
9285- (int (*) (const void *,
9286- const void *)
9287- ) alias_compare);
9288- else
9289- retval = NULL;
9290-
9291- /* We really found an alias. Return the value. */
9292- if (retval != NULL)
9293- {
9294- result = retval->value;
9295- break;
9296- }
9297-
9298- /* Perhaps we can find another alias file. */
9299- added = 0;
9300- while (added == 0 && locale_alias_path[0] != '\0')
9301- {
9302- const char *start;
9303-
9304- while (locale_alias_path[0] == PATH_SEPARATOR)
9305- ++locale_alias_path;
9306- start = locale_alias_path;
9307-
9308- while (locale_alias_path[0] != '\0'
9309- && locale_alias_path[0] != PATH_SEPARATOR)
9310- ++locale_alias_path;
9311-
9312- if (start < locale_alias_path)
9313- added = read_alias_file (start, locale_alias_path - start);
9314- }
9315- }
9316- while (added != 0);
9317-
9318- __libc_lock_unlock (lock);
9319-
9320- return result;
9321-}
9322-
9323-
9324-static size_t
9325-internal_function
9326-read_alias_file (const char *fname, int fname_len)
9327-{
9328- FILE *fp;
9329- char *full_fname;
9330- size_t added;
9331- static const char aliasfile[] = "/locale.alias";
9332-
9333- full_fname = (char *) alloca (fname_len + sizeof aliasfile);
9334-#ifdef HAVE_MEMPCPY
9335- mempcpy (mempcpy (full_fname, fname, fname_len),
9336- aliasfile, sizeof aliasfile);
9337-#else
9338- memcpy (full_fname, fname, fname_len);
9339- memcpy (&full_fname[fname_len], aliasfile, sizeof aliasfile);
9340-#endif
9341-
9342-#ifdef _LIBC
9343- /* Note the file is opened with cancellation in the I/O functions
9344- disabled. */
9345- fp = fopen (relocate (full_fname), "rc");
9346-#else
9347- fp = fopen (relocate (full_fname), "r");
9348-#endif
9349- freea (full_fname);
9350- if (fp == NULL)
9351- return 0;
9352-
9353-#ifdef HAVE___FSETLOCKING
9354- /* No threads present. */
9355- __fsetlocking (fp, FSETLOCKING_BYCALLER);
9356-#endif
9357-
9358- added = 0;
9359- while (!FEOF (fp))
9360- {
9361- /* It is a reasonable approach to use a fix buffer here because
9362- a) we are only interested in the first two fields
9363- b) these fields must be usable as file names and so must not
9364- be that long
9365- We avoid a multi-kilobyte buffer here since this would use up
9366- stack space which we might not have if the program ran out of
9367- memory. */
9368- char buf[400];
9369- char *alias;
9370- char *value;
9371- char *cp;
9372- int complete_line;
9373-
9374- if (FGETS (buf, sizeof buf, fp) == NULL)
9375- /* EOF reached. */
9376- break;
9377-
9378- /* Determine whether the line is complete. */
9379- complete_line = strchr (buf, '\n') != NULL;
9380-
9381- cp = buf;
9382- /* Ignore leading white space. */
9383- while (isspace ((unsigned char) cp[0]))
9384- ++cp;
9385-
9386- /* A leading '#' signals a comment line. */
9387- if (cp[0] != '\0' && cp[0] != '#')
9388- {
9389- alias = cp++;
9390- while (cp[0] != '\0' && !isspace ((unsigned char) cp[0]))
9391- ++cp;
9392- /* Terminate alias name. */
9393- if (cp[0] != '\0')
9394- *cp++ = '\0';
9395-
9396- /* Now look for the beginning of the value. */
9397- while (isspace ((unsigned char) cp[0]))
9398- ++cp;
9399-
9400- if (cp[0] != '\0')
9401- {
9402- value = cp++;
9403- while (cp[0] != '\0' && !isspace ((unsigned char) cp[0]))
9404- ++cp;
9405- /* Terminate value. */
9406- if (cp[0] == '\n')
9407- {
9408- /* This has to be done to make the following test
9409- for the end of line possible. We are looking for
9410- the terminating '\n' which do not overwrite here. */
9411- *cp++ = '\0';
9412- *cp = '\n';
9413- }
9414- else if (cp[0] != '\0')
9415- *cp++ = '\0';
9416-
9417-#ifdef IN_LIBGLOCALE
9418- /* glibc's locale.alias contains entries for ja_JP and ko_KR
9419- that make it impossible to use a Japanese or Korean UTF-8
9420- locale under the name "ja_JP" or "ko_KR". Ignore these
9421- entries. */
9422- if (strchr (alias, '_') == NULL)
9423-#endif
9424- {
9425- size_t alias_len;
9426- size_t value_len;
9427-
9428- if (nmap >= maxmap)
9429- if (__builtin_expect (extend_alias_table (), 0))
9430- goto out;
9431-
9432- alias_len = strlen (alias) + 1;
9433- value_len = strlen (value) + 1;
9434-
9435- if (string_space_act + alias_len + value_len > string_space_max)
9436- {
9437- /* Increase size of memory pool. */
9438- size_t new_size = (string_space_max
9439- + (alias_len + value_len > 1024
9440- ? alias_len + value_len : 1024));
9441- char *new_pool = (char *) realloc (string_space, new_size);
9442- if (new_pool == NULL)
9443- goto out;
9444-
9445- if (__builtin_expect (string_space != new_pool, 0))
9446- {
9447- size_t i;
9448-
9449- for (i = 0; i < nmap; i++)
9450- {
9451- map[i].alias += new_pool - string_space;
9452- map[i].value += new_pool - string_space;
9453- }
9454- }
9455-
9456- string_space = new_pool;
9457- string_space_max = new_size;
9458- }
9459-
9460- map[nmap].alias =
9461- (const char *) memcpy (&string_space[string_space_act],
9462- alias, alias_len);
9463- string_space_act += alias_len;
9464-
9465- map[nmap].value =
9466- (const char *) memcpy (&string_space[string_space_act],
9467- value, value_len);
9468- string_space_act += value_len;
9469-
9470- ++nmap;
9471- ++added;
9472- }
9473- }
9474- }
9475-
9476- /* Possibly not the whole line fits into the buffer. Ignore
9477- the rest of the line. */
9478- if (! complete_line)
9479- do
9480- if (FGETS (buf, sizeof buf, fp) == NULL)
9481- /* Make sure the inner loop will be left. The outer loop
9482- will exit at the `feof' test. */
9483- break;
9484- while (strchr (buf, '\n') == NULL);
9485- }
9486-
9487- out:
9488- /* Should we test for ferror()? I think we have to silently ignore
9489- errors. --drepper */
9490- fclose (fp);
9491-
9492- if (added > 0)
9493- qsort (map, nmap, sizeof (struct alias_map),
9494- (int (*) (const void *, const void *)) alias_compare);
9495-
9496- return added;
9497-}
9498-
9499-
9500-static int
9501-extend_alias_table ()
9502-{
9503- size_t new_size;
9504- struct alias_map *new_map;
9505-
9506- new_size = maxmap == 0 ? 100 : 2 * maxmap;
9507- new_map = (struct alias_map *) realloc (map, (new_size
9508- * sizeof (struct alias_map)));
9509- if (new_map == NULL)
9510- /* Simply don't extend: we don't have any more core. */
9511- return -1;
9512-
9513- map = new_map;
9514- maxmap = new_size;
9515- return 0;
9516-}
9517-
9518-
9519-static int
9520-alias_compare (const struct alias_map *map1, const struct alias_map *map2)
9521-{
9522-#if defined _LIBC || defined HAVE_STRCASECMP
9523- return strcasecmp (map1->alias, map2->alias);
9524-#else
9525- const unsigned char *p1 = (const unsigned char *) map1->alias;
9526- const unsigned char *p2 = (const unsigned char *) map2->alias;
9527- unsigned char c1, c2;
9528-
9529- if (p1 == p2)
9530- return 0;
9531-
9532- do
9533- {
9534- /* I know this seems to be odd but the tolower() function in
9535- some systems libc cannot handle nonalpha characters. */
9536- c1 = isupper (*p1) ? tolower (*p1) : *p1;
9537- c2 = isupper (*p2) ? tolower (*p2) : *p2;
9538- if (c1 == '\0')
9539- break;
9540- ++p1;
9541- ++p2;
9542- }
9543- while (c1 == c2);
9544-
9545- return c1 - c2;
9546-#endif
9547-}
9548--- a/intl/localename.c
9549+++ /dev/null
9550@@ -1,1507 +0,0 @@
9551-/* Determine name of the currently selected locale.
9552- Copyright (C) 1995-1999, 2000-2007 Free Software Foundation, Inc.
9553-
9554- This program is free software; you can redistribute it and/or modify it
9555- under the terms of the GNU Library General Public License as published
9556- by the Free Software Foundation; either version 2, or (at your option)
9557- any later version.
9558-
9559- This program is distributed in the hope that it will be useful,
9560- but WITHOUT ANY WARRANTY; without even the implied warranty of
9561- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
9562- Library General Public License for more details.
9563-
9564- You should have received a copy of the GNU Library General Public
9565- License along with this program; if not, write to the Free Software
9566- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
9567- USA. */
9568-
9569-/* Written by Ulrich Drepper <drepper@gnu.org>, 1995. */
9570-/* Win32 code written by Tor Lillqvist <tml@iki.fi>. */
9571-/* MacOS X code written by Bruno Haible <bruno@clisp.org>. */
9572-
9573-#include <config.h>
9574-
9575-/* Specification. */
9576-#ifdef IN_LIBINTL
9577-# include "gettextP.h"
9578-#else
9579-# include "localename.h"
9580-#endif
9581-
9582-#include <stdlib.h>
9583-#include <locale.h>
9584-
9585-#if HAVE_CFLOCALECOPYCURRENT || HAVE_CFPREFERENCESCOPYAPPVALUE
9586-# include <string.h>
9587-# include <CoreFoundation/CFString.h>
9588-# if HAVE_CFLOCALECOPYCURRENT
9589-# include <CoreFoundation/CFLocale.h>
9590-# elif HAVE_CFPREFERENCESCOPYAPPVALUE
9591-# include <CoreFoundation/CFPreferences.h>
9592-# endif
9593-#endif
9594-
9595-#if defined _WIN32 || defined __WIN32__
9596-# define WIN32_NATIVE
9597-#endif
9598-
9599-#ifdef WIN32_NATIVE
9600-# define WIN32_LEAN_AND_MEAN
9601-# include <windows.h>
9602-/* List of language codes, sorted by value:
9603- 0x01 LANG_ARABIC
9604- 0x02 LANG_BULGARIAN
9605- 0x03 LANG_CATALAN
9606- 0x04 LANG_CHINESE
9607- 0x05 LANG_CZECH
9608- 0x06 LANG_DANISH
9609- 0x07 LANG_GERMAN
9610- 0x08 LANG_GREEK
9611- 0x09 LANG_ENGLISH
9612- 0x0a LANG_SPANISH
9613- 0x0b LANG_FINNISH
9614- 0x0c LANG_FRENCH
9615- 0x0d LANG_HEBREW
9616- 0x0e LANG_HUNGARIAN
9617- 0x0f LANG_ICELANDIC
9618- 0x10 LANG_ITALIAN
9619- 0x11 LANG_JAPANESE
9620- 0x12 LANG_KOREAN
9621- 0x13 LANG_DUTCH
9622- 0x14 LANG_NORWEGIAN
9623- 0x15 LANG_POLISH
9624- 0x16 LANG_PORTUGUESE
9625- 0x17 LANG_RHAETO_ROMANCE
9626- 0x18 LANG_ROMANIAN
9627- 0x19 LANG_RUSSIAN
9628- 0x1a LANG_CROATIAN == LANG_SERBIAN
9629- 0x1b LANG_SLOVAK
9630- 0x1c LANG_ALBANIAN
9631- 0x1d LANG_SWEDISH
9632- 0x1e LANG_THAI
9633- 0x1f LANG_TURKISH
9634- 0x20 LANG_URDU
9635- 0x21 LANG_INDONESIAN
9636- 0x22 LANG_UKRAINIAN
9637- 0x23 LANG_BELARUSIAN
9638- 0x24 LANG_SLOVENIAN
9639- 0x25 LANG_ESTONIAN
9640- 0x26 LANG_LATVIAN
9641- 0x27 LANG_LITHUANIAN
9642- 0x28 LANG_TAJIK
9643- 0x29 LANG_FARSI
9644- 0x2a LANG_VIETNAMESE
9645- 0x2b LANG_ARMENIAN
9646- 0x2c LANG_AZERI
9647- 0x2d LANG_BASQUE
9648- 0x2e LANG_SORBIAN
9649- 0x2f LANG_MACEDONIAN
9650- 0x30 LANG_SUTU
9651- 0x31 LANG_TSONGA
9652- 0x32 LANG_TSWANA
9653- 0x33 LANG_VENDA
9654- 0x34 LANG_XHOSA
9655- 0x35 LANG_ZULU
9656- 0x36 LANG_AFRIKAANS
9657- 0x37 LANG_GEORGIAN
9658- 0x38 LANG_FAEROESE
9659- 0x39 LANG_HINDI
9660- 0x3a LANG_MALTESE
9661- 0x3b LANG_SAAMI
9662- 0x3c LANG_GAELIC
9663- 0x3d LANG_YIDDISH
9664- 0x3e LANG_MALAY
9665- 0x3f LANG_KAZAK
9666- 0x40 LANG_KYRGYZ
9667- 0x41 LANG_SWAHILI
9668- 0x42 LANG_TURKMEN
9669- 0x43 LANG_UZBEK
9670- 0x44 LANG_TATAR
9671- 0x45 LANG_BENGALI
9672- 0x46 LANG_PUNJABI
9673- 0x47 LANG_GUJARATI
9674- 0x48 LANG_ORIYA
9675- 0x49 LANG_TAMIL
9676- 0x4a LANG_TELUGU
9677- 0x4b LANG_KANNADA
9678- 0x4c LANG_MALAYALAM
9679- 0x4d LANG_ASSAMESE
9680- 0x4e LANG_MARATHI
9681- 0x4f LANG_SANSKRIT
9682- 0x50 LANG_MONGOLIAN
9683- 0x51 LANG_TIBETAN
9684- 0x52 LANG_WELSH
9685- 0x53 LANG_CAMBODIAN
9686- 0x54 LANG_LAO
9687- 0x55 LANG_BURMESE
9688- 0x56 LANG_GALICIAN
9689- 0x57 LANG_KONKANI
9690- 0x58 LANG_MANIPURI
9691- 0x59 LANG_SINDHI
9692- 0x5a LANG_SYRIAC
9693- 0x5b LANG_SINHALESE
9694- 0x5c LANG_CHEROKEE
9695- 0x5d LANG_INUKTITUT
9696- 0x5e LANG_AMHARIC
9697- 0x5f LANG_TAMAZIGHT
9698- 0x60 LANG_KASHMIRI
9699- 0x61 LANG_NEPALI
9700- 0x62 LANG_FRISIAN
9701- 0x63 LANG_PASHTO
9702- 0x64 LANG_TAGALOG
9703- 0x65 LANG_DIVEHI
9704- 0x66 LANG_EDO
9705- 0x67 LANG_FULFULDE
9706- 0x68 LANG_HAUSA
9707- 0x69 LANG_IBIBIO
9708- 0x6a LANG_YORUBA
9709- 0x70 LANG_IGBO
9710- 0x71 LANG_KANURI
9711- 0x72 LANG_OROMO
9712- 0x73 LANG_TIGRINYA
9713- 0x74 LANG_GUARANI
9714- 0x75 LANG_HAWAIIAN
9715- 0x76 LANG_LATIN
9716- 0x77 LANG_SOMALI
9717- 0x78 LANG_YI
9718- 0x79 LANG_PAPIAMENTU
9719-*/
9720-/* Mingw headers don't have latest language and sublanguage codes. */
9721-# ifndef LANG_AFRIKAANS
9722-# define LANG_AFRIKAANS 0x36
9723-# endif
9724-# ifndef LANG_ALBANIAN
9725-# define LANG_ALBANIAN 0x1c
9726-# endif
9727-# ifndef LANG_AMHARIC
9728-# define LANG_AMHARIC 0x5e
9729-# endif
9730-# ifndef LANG_ARABIC
9731-# define LANG_ARABIC 0x01
9732-# endif
9733-# ifndef LANG_ARMENIAN
9734-# define LANG_ARMENIAN 0x2b
9735-# endif
9736-# ifndef LANG_ASSAMESE
9737-# define LANG_ASSAMESE 0x4d
9738-# endif
9739-# ifndef LANG_AZERI
9740-# define LANG_AZERI 0x2c
9741-# endif
9742-# ifndef LANG_BASQUE
9743-# define LANG_BASQUE 0x2d
9744-# endif
9745-# ifndef LANG_BELARUSIAN
9746-# define LANG_BELARUSIAN 0x23
9747-# endif
9748-# ifndef LANG_BENGALI
9749-# define LANG_BENGALI 0x45
9750-# endif
9751-# ifndef LANG_BURMESE
9752-# define LANG_BURMESE 0x55
9753-# endif
9754-# ifndef LANG_CAMBODIAN
9755-# define LANG_CAMBODIAN 0x53
9756-# endif
9757-# ifndef LANG_CATALAN
9758-# define LANG_CATALAN 0x03
9759-# endif
9760-# ifndef LANG_CHEROKEE
9761-# define LANG_CHEROKEE 0x5c
9762-# endif
9763-# ifndef LANG_DIVEHI
9764-# define LANG_DIVEHI 0x65
9765-# endif
9766-# ifndef LANG_EDO
9767-# define LANG_EDO 0x66
9768-# endif
9769-# ifndef LANG_ESTONIAN
9770-# define LANG_ESTONIAN 0x25
9771-# endif
9772-# ifndef LANG_FAEROESE
9773-# define LANG_FAEROESE 0x38
9774-# endif
9775-# ifndef LANG_FARSI
9776-# define LANG_FARSI 0x29
9777-# endif
9778-# ifndef LANG_FRISIAN
9779-# define LANG_FRISIAN 0x62
9780-# endif
9781-# ifndef LANG_FULFULDE
9782-# define LANG_FULFULDE 0x67
9783-# endif
9784-# ifndef LANG_GAELIC
9785-# define LANG_GAELIC 0x3c
9786-# endif
9787-# ifndef LANG_GALICIAN
9788-# define LANG_GALICIAN 0x56
9789-# endif
9790-# ifndef LANG_GEORGIAN
9791-# define LANG_GEORGIAN 0x37
9792-# endif
9793-# ifndef LANG_GUARANI
9794-# define LANG_GUARANI 0x74
9795-# endif
9796-# ifndef LANG_GUJARATI
9797-# define LANG_GUJARATI 0x47
9798-# endif
9799-# ifndef LANG_HAUSA
9800-# define LANG_HAUSA 0x68
9801-# endif
9802-# ifndef LANG_HAWAIIAN
9803-# define LANG_HAWAIIAN 0x75
9804-# endif
9805-# ifndef LANG_HEBREW
9806-# define LANG_HEBREW 0x0d
9807-# endif
9808-# ifndef LANG_HINDI
9809-# define LANG_HINDI 0x39
9810-# endif
9811-# ifndef LANG_IBIBIO
9812-# define LANG_IBIBIO 0x69
9813-# endif
9814-# ifndef LANG_IGBO
9815-# define LANG_IGBO 0x70
9816-# endif
9817-# ifndef LANG_INDONESIAN
9818-# define LANG_INDONESIAN 0x21
9819-# endif
9820-# ifndef LANG_INUKTITUT
9821-# define LANG_INUKTITUT 0x5d
9822-# endif
9823-# ifndef LANG_KANNADA
9824-# define LANG_KANNADA 0x4b
9825-# endif
9826-# ifndef LANG_KANURI
9827-# define LANG_KANURI 0x71
9828-# endif
9829-# ifndef LANG_KASHMIRI
9830-# define LANG_KASHMIRI 0x60
9831-# endif
9832-# ifndef LANG_KAZAK
9833-# define LANG_KAZAK 0x3f
9834-# endif
9835-# ifndef LANG_KONKANI
9836-# define LANG_KONKANI 0x57
9837-# endif
9838-# ifndef LANG_KYRGYZ
9839-# define LANG_KYRGYZ 0x40
9840-# endif
9841-# ifndef LANG_LAO
9842-# define LANG_LAO 0x54
9843-# endif
9844-# ifndef LANG_LATIN
9845-# define LANG_LATIN 0x76
9846-# endif
9847-# ifndef LANG_LATVIAN
9848-# define LANG_LATVIAN 0x26
9849-# endif
9850-# ifndef LANG_LITHUANIAN
9851-# define LANG_LITHUANIAN 0x27
9852-# endif
9853-# ifndef LANG_MACEDONIAN
9854-# define LANG_MACEDONIAN 0x2f
9855-# endif
9856-# ifndef LANG_MALAY
9857-# define LANG_MALAY 0x3e
9858-# endif
9859-# ifndef LANG_MALAYALAM
9860-# define LANG_MALAYALAM 0x4c
9861-# endif
9862-# ifndef LANG_MALTESE
9863-# define LANG_MALTESE 0x3a
9864-# endif
9865-# ifndef LANG_MANIPURI
9866-# define LANG_MANIPURI 0x58
9867-# endif
9868-# ifndef LANG_MARATHI
9869-# define LANG_MARATHI 0x4e
9870-# endif
9871-# ifndef LANG_MONGOLIAN
9872-# define LANG_MONGOLIAN 0x50
9873-# endif
9874-# ifndef LANG_NEPALI
9875-# define LANG_NEPALI 0x61
9876-# endif
9877-# ifndef LANG_ORIYA
9878-# define LANG_ORIYA 0x48
9879-# endif
9880-# ifndef LANG_OROMO
9881-# define LANG_OROMO 0x72
9882-# endif
9883-# ifndef LANG_PAPIAMENTU
9884-# define LANG_PAPIAMENTU 0x79
9885-# endif
9886-# ifndef LANG_PASHTO
9887-# define LANG_PASHTO 0x63
9888-# endif
9889-# ifndef LANG_PUNJABI
9890-# define LANG_PUNJABI 0x46
9891-# endif
9892-# ifndef LANG_RHAETO_ROMANCE
9893-# define LANG_RHAETO_ROMANCE 0x17
9894-# endif
9895-# ifndef LANG_SAAMI
9896-# define LANG_SAAMI 0x3b
9897-# endif
9898-# ifndef LANG_SANSKRIT
9899-# define LANG_SANSKRIT 0x4f
9900-# endif
9901-# ifndef LANG_SERBIAN
9902-# define LANG_SERBIAN 0x1a
9903-# endif
9904-# ifndef LANG_SINDHI
9905-# define LANG_SINDHI 0x59
9906-# endif
9907-# ifndef LANG_SINHALESE
9908-# define LANG_SINHALESE 0x5b
9909-# endif
9910-# ifndef LANG_SLOVAK
9911-# define LANG_SLOVAK 0x1b
9912-# endif
9913-# ifndef LANG_SOMALI
9914-# define LANG_SOMALI 0x77
9915-# endif
9916-# ifndef LANG_SORBIAN
9917-# define LANG_SORBIAN 0x2e
9918-# endif
9919-# ifndef LANG_SUTU
9920-# define LANG_SUTU 0x30
9921-# endif
9922-# ifndef LANG_SWAHILI
9923-# define LANG_SWAHILI 0x41
9924-# endif
9925-# ifndef LANG_SYRIAC
9926-# define LANG_SYRIAC 0x5a
9927-# endif
9928-# ifndef LANG_TAGALOG
9929-# define LANG_TAGALOG 0x64
9930-# endif
9931-# ifndef LANG_TAJIK
9932-# define LANG_TAJIK 0x28
9933-# endif
9934-# ifndef LANG_TAMAZIGHT
9935-# define LANG_TAMAZIGHT 0x5f
9936-# endif
9937-# ifndef LANG_TAMIL
9938-# define LANG_TAMIL 0x49
9939-# endif
9940-# ifndef LANG_TATAR
9941-# define LANG_TATAR 0x44
9942-# endif
9943-# ifndef LANG_TELUGU
9944-# define LANG_TELUGU 0x4a
9945-# endif
9946-# ifndef LANG_THAI
9947-# define LANG_THAI 0x1e
9948-# endif
9949-# ifndef LANG_TIBETAN
9950-# define LANG_TIBETAN 0x51
9951-# endif
9952-# ifndef LANG_TIGRINYA
9953-# define LANG_TIGRINYA 0x73
9954-# endif
9955-# ifndef LANG_TSONGA
9956-# define LANG_TSONGA 0x31
9957-# endif
9958-# ifndef LANG_TSWANA
9959-# define LANG_TSWANA 0x32
9960-# endif
9961-# ifndef LANG_TURKMEN
9962-# define LANG_TURKMEN 0x42
9963-# endif
9964-# ifndef LANG_UKRAINIAN
9965-# define LANG_UKRAINIAN 0x22
9966-# endif
9967-# ifndef LANG_URDU
9968-# define LANG_URDU 0x20
9969-# endif
9970-# ifndef LANG_UZBEK
9971-# define LANG_UZBEK 0x43
9972-# endif
9973-# ifndef LANG_VENDA
9974-# define LANG_VENDA 0x33
9975-# endif
9976-# ifndef LANG_VIETNAMESE
9977-# define LANG_VIETNAMESE 0x2a
9978-# endif
9979-# ifndef LANG_WELSH
9980-# define LANG_WELSH 0x52
9981-# endif
9982-# ifndef LANG_XHOSA
9983-# define LANG_XHOSA 0x34
9984-# endif
9985-# ifndef LANG_YI
9986-# define LANG_YI 0x78
9987-# endif
9988-# ifndef LANG_YIDDISH
9989-# define LANG_YIDDISH 0x3d
9990-# endif
9991-# ifndef LANG_YORUBA
9992-# define LANG_YORUBA 0x6a
9993-# endif
9994-# ifndef LANG_ZULU
9995-# define LANG_ZULU 0x35
9996-# endif
9997-# ifndef SUBLANG_ARABIC_SAUDI_ARABIA
9998-# define SUBLANG_ARABIC_SAUDI_ARABIA 0x01
9999-# endif
10000-# ifndef SUBLANG_ARABIC_IRAQ
10001-# define SUBLANG_ARABIC_IRAQ 0x02
10002-# endif
10003-# ifndef SUBLANG_ARABIC_EGYPT
10004-# define SUBLANG_ARABIC_EGYPT 0x03
10005-# endif
10006-# ifndef SUBLANG_ARABIC_LIBYA
10007-# define SUBLANG_ARABIC_LIBYA 0x04
10008-# endif
10009-# ifndef SUBLANG_ARABIC_ALGERIA
10010-# define SUBLANG_ARABIC_ALGERIA 0x05
10011-# endif
10012-# ifndef SUBLANG_ARABIC_MOROCCO
10013-# define SUBLANG_ARABIC_MOROCCO 0x06
10014-# endif
10015-# ifndef SUBLANG_ARABIC_TUNISIA
10016-# define SUBLANG_ARABIC_TUNISIA 0x07
10017-# endif
10018-# ifndef SUBLANG_ARABIC_OMAN
10019-# define SUBLANG_ARABIC_OMAN 0x08
10020-# endif
10021-# ifndef SUBLANG_ARABIC_YEMEN
10022-# define SUBLANG_ARABIC_YEMEN 0x09
10023-# endif
10024-# ifndef SUBLANG_ARABIC_SYRIA
10025-# define SUBLANG_ARABIC_SYRIA 0x0a
10026-# endif
10027-# ifndef SUBLANG_ARABIC_JORDAN
10028-# define SUBLANG_ARABIC_JORDAN 0x0b
10029-# endif
10030-# ifndef SUBLANG_ARABIC_LEBANON
10031-# define SUBLANG_ARABIC_LEBANON 0x0c
10032-# endif
10033-# ifndef SUBLANG_ARABIC_KUWAIT
10034-# define SUBLANG_ARABIC_KUWAIT 0x0d
10035-# endif
10036-# ifndef SUBLANG_ARABIC_UAE
10037-# define SUBLANG_ARABIC_UAE 0x0e
10038-# endif
10039-# ifndef SUBLANG_ARABIC_BAHRAIN
10040-# define SUBLANG_ARABIC_BAHRAIN 0x0f
10041-# endif
10042-# ifndef SUBLANG_ARABIC_QATAR
10043-# define SUBLANG_ARABIC_QATAR 0x10
10044-# endif
10045-# ifndef SUBLANG_AZERI_LATIN
10046-# define SUBLANG_AZERI_LATIN 0x01
10047-# endif
10048-# ifndef SUBLANG_AZERI_CYRILLIC
10049-# define SUBLANG_AZERI_CYRILLIC 0x02
10050-# endif
10051-# ifndef SUBLANG_BENGALI_INDIA
10052-# define SUBLANG_BENGALI_INDIA 0x01
10053-# endif
10054-# ifndef SUBLANG_BENGALI_BANGLADESH
10055-# define SUBLANG_BENGALI_BANGLADESH 0x02
10056-# endif
10057-# ifndef SUBLANG_CHINESE_MACAU
10058-# define SUBLANG_CHINESE_MACAU 0x05
10059-# endif
10060-# ifndef SUBLANG_ENGLISH_SOUTH_AFRICA
10061-# define SUBLANG_ENGLISH_SOUTH_AFRICA 0x07
10062-# endif
10063-# ifndef SUBLANG_ENGLISH_JAMAICA
10064-# define SUBLANG_ENGLISH_JAMAICA 0x08
10065-# endif
10066-# ifndef SUBLANG_ENGLISH_CARIBBEAN
10067-# define SUBLANG_ENGLISH_CARIBBEAN 0x09
10068-# endif
10069-# ifndef SUBLANG_ENGLISH_BELIZE
10070-# define SUBLANG_ENGLISH_BELIZE 0x0a
10071-# endif
10072-# ifndef SUBLANG_ENGLISH_TRINIDAD
10073-# define SUBLANG_ENGLISH_TRINIDAD 0x0b
10074-# endif
10075-# ifndef SUBLANG_ENGLISH_ZIMBABWE
10076-# define SUBLANG_ENGLISH_ZIMBABWE 0x0c
10077-# endif
10078-# ifndef SUBLANG_ENGLISH_PHILIPPINES
10079-# define SUBLANG_ENGLISH_PHILIPPINES 0x0d
10080-# endif
10081-# ifndef SUBLANG_ENGLISH_INDONESIA
10082-# define SUBLANG_ENGLISH_INDONESIA 0x0e
10083-# endif
10084-# ifndef SUBLANG_ENGLISH_HONGKONG
10085-# define SUBLANG_ENGLISH_HONGKONG 0x0f
10086-# endif
10087-# ifndef SUBLANG_ENGLISH_INDIA
10088-# define SUBLANG_ENGLISH_INDIA 0x10
10089-# endif
10090-# ifndef SUBLANG_ENGLISH_MALAYSIA
10091-# define SUBLANG_ENGLISH_MALAYSIA 0x11
10092-# endif
10093-# ifndef SUBLANG_ENGLISH_SINGAPORE
10094-# define SUBLANG_ENGLISH_SINGAPORE 0x12
10095-# endif
10096-# ifndef SUBLANG_FRENCH_LUXEMBOURG
10097-# define SUBLANG_FRENCH_LUXEMBOURG 0x05
10098-# endif
10099-# ifndef SUBLANG_FRENCH_MONACO
10100-# define SUBLANG_FRENCH_MONACO 0x06
10101-# endif
10102-# ifndef SUBLANG_FRENCH_WESTINDIES
10103-# define SUBLANG_FRENCH_WESTINDIES 0x07
10104-# endif
10105-# ifndef SUBLANG_FRENCH_REUNION
10106-# define SUBLANG_FRENCH_REUNION 0x08
10107-# endif
10108-# ifndef SUBLANG_FRENCH_CONGO
10109-# define SUBLANG_FRENCH_CONGO 0x09
10110-# endif
10111-# ifndef SUBLANG_FRENCH_SENEGAL
10112-# define SUBLANG_FRENCH_SENEGAL 0x0a
10113-# endif
10114-# ifndef SUBLANG_FRENCH_CAMEROON
10115-# define SUBLANG_FRENCH_CAMEROON 0x0b
10116-# endif
10117-# ifndef SUBLANG_FRENCH_COTEDIVOIRE
10118-# define SUBLANG_FRENCH_COTEDIVOIRE 0x0c
10119-# endif
10120-# ifndef SUBLANG_FRENCH_MALI
10121-# define SUBLANG_FRENCH_MALI 0x0d
10122-# endif
10123-# ifndef SUBLANG_FRENCH_MOROCCO
10124-# define SUBLANG_FRENCH_MOROCCO 0x0e
10125-# endif
10126-# ifndef SUBLANG_FRENCH_HAITI
10127-# define SUBLANG_FRENCH_HAITI 0x0f
10128-# endif
10129-# ifndef SUBLANG_GERMAN_LUXEMBOURG
10130-# define SUBLANG_GERMAN_LUXEMBOURG 0x04
10131-# endif
10132-# ifndef SUBLANG_GERMAN_LIECHTENSTEIN
10133-# define SUBLANG_GERMAN_LIECHTENSTEIN 0x05
10134-# endif
10135-# ifndef SUBLANG_KASHMIRI_INDIA
10136-# define SUBLANG_KASHMIRI_INDIA 0x02
10137-# endif
10138-# ifndef SUBLANG_MALAY_MALAYSIA
10139-# define SUBLANG_MALAY_MALAYSIA 0x01
10140-# endif
10141-# ifndef SUBLANG_MALAY_BRUNEI_DARUSSALAM
10142-# define SUBLANG_MALAY_BRUNEI_DARUSSALAM 0x02
10143-# endif
10144-# ifndef SUBLANG_NEPALI_INDIA
10145-# define SUBLANG_NEPALI_INDIA 0x02
10146-# endif
10147-# ifndef SUBLANG_PUNJABI_INDIA
10148-# define SUBLANG_PUNJABI_INDIA 0x01
10149-# endif
10150-# ifndef SUBLANG_PUNJABI_PAKISTAN
10151-# define SUBLANG_PUNJABI_PAKISTAN 0x02
10152-# endif
10153-# ifndef SUBLANG_ROMANIAN_ROMANIA
10154-# define SUBLANG_ROMANIAN_ROMANIA 0x01
10155-# endif
10156-# ifndef SUBLANG_ROMANIAN_MOLDOVA
10157-# define SUBLANG_ROMANIAN_MOLDOVA 0x02
10158-# endif
10159-# ifndef SUBLANG_SERBIAN_LATIN
10160-# define SUBLANG_SERBIAN_LATIN 0x02
10161-# endif
10162-# ifndef SUBLANG_SERBIAN_CYRILLIC
10163-# define SUBLANG_SERBIAN_CYRILLIC 0x03
10164-# endif
10165-# ifndef SUBLANG_SINDHI_PAKISTAN
10166-# define SUBLANG_SINDHI_PAKISTAN 0x01
10167-# endif
10168-# ifndef SUBLANG_SINDHI_AFGHANISTAN
10169-# define SUBLANG_SINDHI_AFGHANISTAN 0x02
10170-# endif
10171-# ifndef SUBLANG_SPANISH_GUATEMALA
10172-# define SUBLANG_SPANISH_GUATEMALA 0x04
10173-# endif
10174-# ifndef SUBLANG_SPANISH_COSTA_RICA
10175-# define SUBLANG_SPANISH_COSTA_RICA 0x05
10176-# endif
10177-# ifndef SUBLANG_SPANISH_PANAMA
10178-# define SUBLANG_SPANISH_PANAMA 0x06
10179-# endif
10180-# ifndef SUBLANG_SPANISH_DOMINICAN_REPUBLIC
10181-# define SUBLANG_SPANISH_DOMINICAN_REPUBLIC 0x07
10182-# endif
10183-# ifndef SUBLANG_SPANISH_VENEZUELA
10184-# define SUBLANG_SPANISH_VENEZUELA 0x08
10185-# endif
10186-# ifndef SUBLANG_SPANISH_COLOMBIA
10187-# define SUBLANG_SPANISH_COLOMBIA 0x09
10188-# endif
10189-# ifndef SUBLANG_SPANISH_PERU
10190-# define SUBLANG_SPANISH_PERU 0x0a
10191-# endif
10192-# ifndef SUBLANG_SPANISH_ARGENTINA
10193-# define SUBLANG_SPANISH_ARGENTINA 0x0b
10194-# endif
10195-# ifndef SUBLANG_SPANISH_ECUADOR
10196-# define SUBLANG_SPANISH_ECUADOR 0x0c
10197-# endif
10198-# ifndef SUBLANG_SPANISH_CHILE
10199-# define SUBLANG_SPANISH_CHILE 0x0d
10200-# endif
10201-# ifndef SUBLANG_SPANISH_URUGUAY
10202-# define SUBLANG_SPANISH_URUGUAY 0x0e
10203-# endif
10204-# ifndef SUBLANG_SPANISH_PARAGUAY
10205-# define SUBLANG_SPANISH_PARAGUAY 0x0f
10206-# endif
10207-# ifndef SUBLANG_SPANISH_BOLIVIA
10208-# define SUBLANG_SPANISH_BOLIVIA 0x10
10209-# endif
10210-# ifndef SUBLANG_SPANISH_EL_SALVADOR
10211-# define SUBLANG_SPANISH_EL_SALVADOR 0x11
10212-# endif
10213-# ifndef SUBLANG_SPANISH_HONDURAS
10214-# define SUBLANG_SPANISH_HONDURAS 0x12
10215-# endif
10216-# ifndef SUBLANG_SPANISH_NICARAGUA
10217-# define SUBLANG_SPANISH_NICARAGUA 0x13
10218-# endif
10219-# ifndef SUBLANG_SPANISH_PUERTO_RICO
10220-# define SUBLANG_SPANISH_PUERTO_RICO 0x14
10221-# endif
10222-# ifndef SUBLANG_SWEDISH_FINLAND
10223-# define SUBLANG_SWEDISH_FINLAND 0x02
10224-# endif
10225-# ifndef SUBLANG_TAMAZIGHT_ARABIC
10226-# define SUBLANG_TAMAZIGHT_ARABIC 0x01
10227-# endif
10228-# ifndef SUBLANG_TAMAZIGHT_ALGERIA_LATIN
10229-# define SUBLANG_TAMAZIGHT_ALGERIA_LATIN 0x02
10230-# endif
10231-# ifndef SUBLANG_TIGRINYA_ETHIOPIA
10232-# define SUBLANG_TIGRINYA_ETHIOPIA 0x01
10233-# endif
10234-# ifndef SUBLANG_TIGRINYA_ERITREA
10235-# define SUBLANG_TIGRINYA_ERITREA 0x02
10236-# endif
10237-# ifndef SUBLANG_URDU_PAKISTAN
10238-# define SUBLANG_URDU_PAKISTAN 0x01
10239-# endif
10240-# ifndef SUBLANG_URDU_INDIA
10241-# define SUBLANG_URDU_INDIA 0x02
10242-# endif
10243-# ifndef SUBLANG_UZBEK_LATIN
10244-# define SUBLANG_UZBEK_LATIN 0x01
10245-# endif
10246-# ifndef SUBLANG_UZBEK_CYRILLIC
10247-# define SUBLANG_UZBEK_CYRILLIC 0x02
10248-# endif
10249-#endif
10250-
10251-# if HAVE_CFLOCALECOPYCURRENT || HAVE_CFPREFERENCESCOPYAPPVALUE
10252-/* MacOS X 10.2 or newer */
10253-
10254-/* Canonicalize a MacOS X locale name to a Unix locale name.
10255- NAME is a sufficiently large buffer.
10256- On input, it contains the MacOS X locale name.
10257- On output, it contains the Unix locale name. */
10258-# if !defined IN_LIBINTL
10259-static
10260-# endif
10261-void
10262-gl_locale_name_canonicalize (char *name)
10263-{
10264- /* This conversion is based on a posting by
10265- Deborah GoldSmith <goldsmit@apple.com> on 2005-03-08,
10266- http://lists.apple.com/archives/carbon-dev/2005/Mar/msg00293.html */
10267-
10268- /* Convert legacy (NeXTstep inherited) English names to Unix (ISO 639 and
10269- ISO 3166) names. Prior to MacOS X 10.3, there is no API for doing this.
10270- Therefore we do it ourselves, using a table based on the results of the
10271- MacOS X 10.3.8 function
10272- CFLocaleCreateCanonicalLocaleIdentifierFromString(). */
10273- typedef struct { const char legacy[21+1]; const char unixy[5+1]; }
10274- legacy_entry;
10275- static const legacy_entry legacy_table[] = {
10276- { "Afrikaans", "af" },
10277- { "Albanian", "sq" },
10278- { "Amharic", "am" },
10279- { "Arabic", "ar" },
10280- { "Armenian", "hy" },
10281- { "Assamese", "as" },
10282- { "Aymara", "ay" },
10283- { "Azerbaijani", "az" },
10284- { "Basque", "eu" },
10285- { "Belarusian", "be" },
10286- { "Belorussian", "be" },
10287- { "Bengali", "bn" },
10288- { "Brazilian Portugese", "pt_BR" },
10289- { "Brazilian Portuguese", "pt_BR" },
10290- { "Breton", "br" },
10291- { "Bulgarian", "bg" },
10292- { "Burmese", "my" },
10293- { "Byelorussian", "be" },
10294- { "Catalan", "ca" },
10295- { "Chewa", "ny" },
10296- { "Chichewa", "ny" },
10297- { "Chinese", "zh" },
10298- { "Chinese, Simplified", "zh_CN" },
10299- { "Chinese, Traditional", "zh_TW" },
10300- { "Chinese, Tradtional", "zh_TW" },
10301- { "Croatian", "hr" },
10302- { "Czech", "cs" },
10303- { "Danish", "da" },
10304- { "Dutch", "nl" },
10305- { "Dzongkha", "dz" },
10306- { "English", "en" },
10307- { "Esperanto", "eo" },
10308- { "Estonian", "et" },
10309- { "Faroese", "fo" },
10310- { "Farsi", "fa" },
10311- { "Finnish", "fi" },
10312- { "Flemish", "nl_BE" },
10313- { "French", "fr" },
10314- { "Galician", "gl" },
10315- { "Gallegan", "gl" },
10316- { "Georgian", "ka" },
10317- { "German", "de" },
10318- { "Greek", "el" },
10319- { "Greenlandic", "kl" },
10320- { "Guarani", "gn" },
10321- { "Gujarati", "gu" },
10322- { "Hawaiian", "haw" }, /* Yes, "haw", not "cpe". */
10323- { "Hebrew", "he" },
10324- { "Hindi", "hi" },
10325- { "Hungarian", "hu" },
10326- { "Icelandic", "is" },
10327- { "Indonesian", "id" },
10328- { "Inuktitut", "iu" },
10329- { "Irish", "ga" },
10330- { "Italian", "it" },
10331- { "Japanese", "ja" },
10332- { "Javanese", "jv" },
10333- { "Kalaallisut", "kl" },
10334- { "Kannada", "kn" },
10335- { "Kashmiri", "ks" },
10336- { "Kazakh", "kk" },
10337- { "Khmer", "km" },
10338- { "Kinyarwanda", "rw" },
10339- { "Kirghiz", "ky" },
10340- { "Korean", "ko" },
10341- { "Kurdish", "ku" },
10342- { "Latin", "la" },
10343- { "Latvian", "lv" },
10344- { "Lithuanian", "lt" },
10345- { "Macedonian", "mk" },
10346- { "Malagasy", "mg" },
10347- { "Malay", "ms" },
10348- { "Malayalam", "ml" },
10349- { "Maltese", "mt" },
10350- { "Manx", "gv" },
10351- { "Marathi", "mr" },
10352- { "Moldavian", "mo" },
10353- { "Mongolian", "mn" },
10354- { "Nepali", "ne" },
10355- { "Norwegian", "nb" }, /* Yes, "nb", not the obsolete "no". */
10356- { "Nyanja", "ny" },
10357- { "Nynorsk", "nn" },
10358- { "Oriya", "or" },
10359- { "Oromo", "om" },
10360- { "Panjabi", "pa" },
10361- { "Pashto", "ps" },
10362- { "Persian", "fa" },
10363- { "Polish", "pl" },
10364- { "Portuguese", "pt" },
10365- { "Portuguese, Brazilian", "pt_BR" },
10366- { "Punjabi", "pa" },
10367- { "Pushto", "ps" },
10368- { "Quechua", "qu" },
10369- { "Romanian", "ro" },
10370- { "Ruanda", "rw" },
10371- { "Rundi", "rn" },
10372- { "Russian", "ru" },
10373- { "Sami", "se_NO" }, /* Not just "se". */
10374- { "Sanskrit", "sa" },
10375- { "Scottish", "gd" },
10376- { "Serbian", "sr" },
10377- { "Simplified Chinese", "zh_CN" },
10378- { "Sindhi", "sd" },
10379- { "Sinhalese", "si" },
10380- { "Slovak", "sk" },
10381- { "Slovenian", "sl" },
10382- { "Somali", "so" },
10383- { "Spanish", "es" },
10384- { "Sundanese", "su" },
10385- { "Swahili", "sw" },
10386- { "Swedish", "sv" },
10387- { "Tagalog", "tl" },
10388- { "Tajik", "tg" },
10389- { "Tajiki", "tg" },
10390- { "Tamil", "ta" },
10391- { "Tatar", "tt" },
10392- { "Telugu", "te" },
10393- { "Thai", "th" },
10394- { "Tibetan", "bo" },
10395- { "Tigrinya", "ti" },
10396- { "Tongan", "to" },
10397- { "Traditional Chinese", "zh_TW" },
10398- { "Turkish", "tr" },
10399- { "Turkmen", "tk" },
10400- { "Uighur", "ug" },
10401- { "Ukrainian", "uk" },
10402- { "Urdu", "ur" },
10403- { "Uzbek", "uz" },
10404- { "Vietnamese", "vi" },
10405- { "Welsh", "cy" },
10406- { "Yiddish", "yi" }
10407- };
10408-
10409- /* Convert new-style locale names with language tags (ISO 639 and ISO 15924)
10410- to Unix (ISO 639 and ISO 3166) names. */
10411- typedef struct { const char langtag[7+1]; const char unixy[12+1]; }
10412- langtag_entry;
10413- static const langtag_entry langtag_table[] = {
10414- /* MacOS X has "az-Arab", "az-Cyrl", "az-Latn".
10415- The default script for az on Unix is Latin. */
10416- { "az-Latn", "az" },
10417- /* MacOS X has "ga-dots". Does not yet exist on Unix. */
10418- { "ga-dots", "ga" },
10419- /* MacOS X has "kk-Cyrl". Does not yet exist on Unix. */
10420- /* MacOS X has "mn-Cyrl", "mn-Mong".
10421- The default script for mn on Unix is Cyrillic. */
10422- { "mn-Cyrl", "mn" },
10423- /* MacOS X has "ms-Arab", "ms-Latn".
10424- The default script for ms on Unix is Latin. */
10425- { "ms-Latn", "ms" },
10426- /* MacOS X has "tg-Cyrl".
10427- The default script for tg on Unix is Cyrillic. */
10428- { "tg-Cyrl", "tg" },
10429- /* MacOS X has "tk-Cyrl". Does not yet exist on Unix. */
10430- /* MacOS X has "tt-Cyrl".
10431- The default script for tt on Unix is Cyrillic. */
10432- { "tt-Cyrl", "tt" },
10433- /* MacOS X has "zh-Hans", "zh-Hant".
10434- Country codes are used to distinguish these on Unix. */
10435- { "zh-Hans", "zh_CN" },
10436- { "zh-Hant", "zh_TW" }
10437- };
10438-
10439- /* Convert script names (ISO 15924) to Unix conventions.
10440- See http://www.unicode.org/iso15924/iso15924-codes.html */
10441- typedef struct { const char script[4+1]; const char unixy[9+1]; }
10442- script_entry;
10443- static const script_entry script_table[] = {
10444- { "Arab", "arabic" },
10445- { "Cyrl", "cyrillic" },
10446- { "Mong", "mongolian" }
10447- };
10448-
10449- /* Step 1: Convert using legacy_table. */
10450- if (name[0] >= 'A' && name[0] <= 'Z')
10451- {
10452- unsigned int i1, i2;
10453- i1 = 0;
10454- i2 = sizeof (legacy_table) / sizeof (legacy_entry);
10455- while (i2 - i1 > 1)
10456- {
10457- /* At this point we know that if name occurs in legacy_table,
10458- its index must be >= i1 and < i2. */
10459- unsigned int i = (i1 + i2) >> 1;
10460- const legacy_entry *p = &legacy_table[i];
10461- if (strcmp (name, p->legacy) < 0)
10462- i2 = i;
10463- else
10464- i1 = i;
10465- }
10466- if (strcmp (name, legacy_table[i1].legacy) == 0)
10467- {
10468- strcpy (name, legacy_table[i1].unixy);
10469- return;
10470- }
10471- }
10472-
10473- /* Step 2: Convert using langtag_table and script_table. */
10474- if (strlen (name) == 7 && name[2] == '-')
10475- {
10476- unsigned int i1, i2;
10477- i1 = 0;
10478- i2 = sizeof (langtag_table) / sizeof (langtag_entry);
10479- while (i2 - i1 > 1)
10480- {
10481- /* At this point we know that if name occurs in langtag_table,
10482- its index must be >= i1 and < i2. */
10483- unsigned int i = (i1 + i2) >> 1;
10484- const langtag_entry *p = &langtag_table[i];
10485- if (strcmp (name, p->langtag) < 0)
10486- i2 = i;
10487- else
10488- i1 = i;
10489- }
10490- if (strcmp (name, langtag_table[i1].langtag) == 0)
10491- {
10492- strcpy (name, langtag_table[i1].unixy);
10493- return;
10494- }
10495-
10496- i1 = 0;
10497- i2 = sizeof (script_table) / sizeof (script_entry);
10498- while (i2 - i1 > 1)
10499- {
10500- /* At this point we know that if (name + 3) occurs in script_table,
10501- its index must be >= i1 and < i2. */
10502- unsigned int i = (i1 + i2) >> 1;
10503- const script_entry *p = &script_table[i];
10504- if (strcmp (name + 3, p->script) < 0)
10505- i2 = i;
10506- else
10507- i1 = i;
10508- }
10509- if (strcmp (name + 3, script_table[i1].script) == 0)
10510- {
10511- name[2] = '@';
10512- strcpy (name + 3, script_table[i1].unixy);
10513- return;
10514- }
10515- }
10516-
10517- /* Step 3: Convert new-style dash to Unix underscore. */
10518- {
10519- char *p;
10520- for (p = name; *p != '\0'; p++)
10521- if (*p == '-')
10522- *p = '_';
10523- }
10524-}
10525-
10526-#endif
10527-
10528-/* XPG3 defines the result of 'setlocale (category, NULL)' as:
10529- "Directs 'setlocale()' to query 'category' and return the current
10530- setting of 'local'."
10531- However it does not specify the exact format. Neither do SUSV2 and
10532- ISO C 99. So we can use this feature only on selected systems (e.g.
10533- those using GNU C Library). */
10534-#if defined _LIBC || (defined __GLIBC__ && __GLIBC__ >= 2)
10535-# define HAVE_LOCALE_NULL
10536-#endif
10537-
10538-/* Determine the current locale's name, and canonicalize it into XPG syntax
10539- language[_territory][.codeset][@modifier]
10540- The codeset part in the result is not reliable; the locale_charset()
10541- should be used for codeset information instead.
10542- The result must not be freed; it is statically allocated. */
10543-
10544-const char *
10545-gl_locale_name_posix (int category, const char *categoryname)
10546-{
10547- /* Use the POSIX methods of looking to 'LC_ALL', 'LC_xxx', and 'LANG'.
10548- On some systems this can be done by the 'setlocale' function itself. */
10549-#if defined HAVE_SETLOCALE && defined HAVE_LC_MESSAGES && defined HAVE_LOCALE_NULL
10550- return setlocale (category, NULL);
10551-#else
10552- const char *retval;
10553-
10554- /* Setting of LC_ALL overrides all other. */
10555- retval = getenv ("LC_ALL");
10556- if (retval != NULL && retval[0] != '\0')
10557- return retval;
10558- /* Next comes the name of the desired category. */
10559- retval = getenv (categoryname);
10560- if (retval != NULL && retval[0] != '\0')
10561- return retval;
10562- /* Last possibility is the LANG environment variable. */
10563- retval = getenv ("LANG");
10564- if (retval != NULL && retval[0] != '\0')
10565- return retval;
10566-
10567- return NULL;
10568-#endif
10569-}
10570-
10571-const char *
10572-gl_locale_name_default (void)
10573-{
10574- /* POSIX:2001 says:
10575- "All implementations shall define a locale as the default locale, to be
10576- invoked when no environment variables are set, or set to the empty
10577- string. This default locale can be the POSIX locale or any other
10578- implementation-defined locale. Some implementations may provide
10579- facilities for local installation administrators to set the default
10580- locale, customizing it for each location. POSIX:2001 does not require
10581- such a facility. */
10582-
10583-#if !(HAVE_CFLOCALECOPYCURRENT || HAVE_CFPREFERENCESCOPYAPPVALUE || defined(WIN32_NATIVE))
10584-
10585- /* The system does not have a way of setting the locale, other than the
10586- POSIX specified environment variables. We use C as default locale. */
10587- return "C";
10588-
10589-#else
10590-
10591- /* Return an XPG style locale name language[_territory][@modifier].
10592- Don't even bother determining the codeset; it's not useful in this
10593- context, because message catalogs are not specific to a single
10594- codeset. */
10595-
10596-# if HAVE_CFLOCALECOPYCURRENT || HAVE_CFPREFERENCESCOPYAPPVALUE
10597- /* MacOS X 10.2 or newer */
10598- {
10599- /* Cache the locale name, since CoreFoundation calls are expensive. */
10600- static const char *cached_localename;
10601-
10602- if (cached_localename == NULL)
10603- {
10604- char namebuf[256];
10605-# if HAVE_CFLOCALECOPYCURRENT /* MacOS X 10.3 or newer */
10606- CFLocaleRef locale = CFLocaleCopyCurrent ();
10607- CFStringRef name = CFLocaleGetIdentifier (locale);
10608-
10609- if (CFStringGetCString (name, namebuf, sizeof(namebuf),
10610- kCFStringEncodingASCII))
10611- {
10612- gl_locale_name_canonicalize (namebuf);
10613- cached_localename = strdup (namebuf);
10614- }
10615- CFRelease (locale);
10616-# elif HAVE_CFPREFERENCESCOPYAPPVALUE /* MacOS X 10.2 or newer */
10617- CFTypeRef value =
10618- CFPreferencesCopyAppValue (CFSTR ("AppleLocale"),
10619- kCFPreferencesCurrentApplication);
10620- if (value != NULL
10621- && CFGetTypeID (value) == CFStringGetTypeID ()
10622- && CFStringGetCString ((CFStringRef)value, namebuf, sizeof(namebuf),
10623- kCFStringEncodingASCII))
10624- {
10625- gl_locale_name_canonicalize (namebuf);
10626- cached_localename = strdup (namebuf);
10627- }
10628-# endif
10629- if (cached_localename == NULL)
10630- cached_localename = "C";
10631- }
10632- return cached_localename;
10633- }
10634-
10635-# endif
10636-
10637-# if defined(WIN32_NATIVE) /* WIN32, not Cygwin */
10638- {
10639- LCID lcid;
10640- LANGID langid;
10641- int primary, sub;
10642-
10643- /* Use native Win32 API locale ID. */
10644- lcid = GetThreadLocale ();
10645-
10646- /* Strip off the sorting rules, keep only the language part. */
10647- langid = LANGIDFROMLCID (lcid);
10648-
10649- /* Split into language and territory part. */
10650- primary = PRIMARYLANGID (langid);
10651- sub = SUBLANGID (langid);
10652-
10653- /* Dispatch on language.
10654- See also http://www.unicode.org/unicode/onlinedat/languages.html .
10655- For details about languages, see http://www.ethnologue.com/ . */
10656- switch (primary)
10657- {
10658- case LANG_AFRIKAANS: return "af_ZA";
10659- case LANG_ALBANIAN: return "sq_AL";
10660- case LANG_AMHARIC: return "am_ET";
10661- case LANG_ARABIC:
10662- switch (sub)
10663- {
10664- case SUBLANG_ARABIC_SAUDI_ARABIA: return "ar_SA";
10665- case SUBLANG_ARABIC_IRAQ: return "ar_IQ";
10666- case SUBLANG_ARABIC_EGYPT: return "ar_EG";
10667- case SUBLANG_ARABIC_LIBYA: return "ar_LY";
10668- case SUBLANG_ARABIC_ALGERIA: return "ar_DZ";
10669- case SUBLANG_ARABIC_MOROCCO: return "ar_MA";
10670- case SUBLANG_ARABIC_TUNISIA: return "ar_TN";
10671- case SUBLANG_ARABIC_OMAN: return "ar_OM";
10672- case SUBLANG_ARABIC_YEMEN: return "ar_YE";
10673- case SUBLANG_ARABIC_SYRIA: return "ar_SY";
10674- case SUBLANG_ARABIC_JORDAN: return "ar_JO";
10675- case SUBLANG_ARABIC_LEBANON: return "ar_LB";
10676- case SUBLANG_ARABIC_KUWAIT: return "ar_KW";
10677- case SUBLANG_ARABIC_UAE: return "ar_AE";
10678- case SUBLANG_ARABIC_BAHRAIN: return "ar_BH";
10679- case SUBLANG_ARABIC_QATAR: return "ar_QA";
10680- }
10681- return "ar";
10682- case LANG_ARMENIAN: return "hy_AM";
10683- case LANG_ASSAMESE: return "as_IN";
10684- case LANG_AZERI:
10685- switch (sub)
10686- {
10687- /* FIXME: Adjust this when Azerbaijani locales appear on Unix. */
10688- case SUBLANG_AZERI_LATIN: return "az_AZ@latin";
10689- case SUBLANG_AZERI_CYRILLIC: return "az_AZ@cyrillic";
10690- }
10691- return "az";
10692- case LANG_BASQUE:
10693- switch (sub)
10694- {
10695- case SUBLANG_DEFAULT: return "eu_ES";
10696- }
10697- return "eu"; /* Ambiguous: could be "eu_ES" or "eu_FR". */
10698- case LANG_BELARUSIAN: return "be_BY";
10699- case LANG_BENGALI:
10700- switch (sub)
10701- {
10702- case SUBLANG_BENGALI_INDIA: return "bn_IN";
10703- case SUBLANG_BENGALI_BANGLADESH: return "bn_BD";
10704- }
10705- return "bn";
10706- case LANG_BULGARIAN: return "bg_BG";
10707- case LANG_BURMESE: return "my_MM";
10708- case LANG_CAMBODIAN: return "km_KH";
10709- case LANG_CATALAN: return "ca_ES";
10710- case LANG_CHEROKEE: return "chr_US";
10711- case LANG_CHINESE:
10712- switch (sub)
10713- {
10714- case SUBLANG_CHINESE_TRADITIONAL: return "zh_TW";
10715- case SUBLANG_CHINESE_SIMPLIFIED: return "zh_CN";
10716- case SUBLANG_CHINESE_HONGKONG: return "zh_HK";
10717- case SUBLANG_CHINESE_SINGAPORE: return "zh_SG";
10718- case SUBLANG_CHINESE_MACAU: return "zh_MO";
10719- }
10720- return "zh";
10721- case LANG_CROATIAN: /* LANG_CROATIAN == LANG_SERBIAN
10722- * What used to be called Serbo-Croatian
10723- * should really now be two separate
10724- * languages because of political reasons.
10725- * (Says tml, who knows nothing about Serbian
10726- * or Croatian.)
10727- * (I can feel those flames coming already.)
10728- */
10729- switch (sub)
10730- {
10731- case SUBLANG_DEFAULT: return "hr_HR";
10732- case SUBLANG_SERBIAN_LATIN: return "sr_CS";
10733- case SUBLANG_SERBIAN_CYRILLIC: return "sr_CS@cyrillic";
10734- }
10735- return "hr";
10736- case LANG_CZECH: return "cs_CZ";
10737- case LANG_DANISH: return "da_DK";
10738- case LANG_DIVEHI: return "dv_MV";
10739- case LANG_DUTCH:
10740- switch (sub)
10741- {
10742- case SUBLANG_DUTCH: return "nl_NL";
10743- case SUBLANG_DUTCH_BELGIAN: /* FLEMISH, VLAAMS */ return "nl_BE";
10744- }
10745- return "nl";
10746- case LANG_EDO: return "bin_NG";
10747- case LANG_ENGLISH:
10748- switch (sub)
10749- {
10750- /* SUBLANG_ENGLISH_US == SUBLANG_DEFAULT. Heh. I thought
10751- * English was the language spoken in England.
10752- * Oh well.
10753- */
10754- case SUBLANG_ENGLISH_US: return "en_US";
10755- case SUBLANG_ENGLISH_UK: return "en_GB";
10756- case SUBLANG_ENGLISH_AUS: return "en_AU";
10757- case SUBLANG_ENGLISH_CAN: return "en_CA";
10758- case SUBLANG_ENGLISH_NZ: return "en_NZ";
10759- case SUBLANG_ENGLISH_EIRE: return "en_IE";
10760- case SUBLANG_ENGLISH_SOUTH_AFRICA: return "en_ZA";
10761- case SUBLANG_ENGLISH_JAMAICA: return "en_JM";
10762- case SUBLANG_ENGLISH_CARIBBEAN: return "en_GD"; /* Grenada? */
10763- case SUBLANG_ENGLISH_BELIZE: return "en_BZ";
10764- case SUBLANG_ENGLISH_TRINIDAD: return "en_TT";
10765- case SUBLANG_ENGLISH_ZIMBABWE: return "en_ZW";
10766- case SUBLANG_ENGLISH_PHILIPPINES: return "en_PH";
10767- case SUBLANG_ENGLISH_INDONESIA: return "en_ID";
10768- case SUBLANG_ENGLISH_HONGKONG: return "en_HK";
10769- case SUBLANG_ENGLISH_INDIA: return "en_IN";
10770- case SUBLANG_ENGLISH_MALAYSIA: return "en_MY";
10771- case SUBLANG_ENGLISH_SINGAPORE: return "en_SG";
10772- }
10773- return "en";
10774- case LANG_ESTONIAN: return "et_EE";
10775- case LANG_FAEROESE: return "fo_FO";
10776- case LANG_FARSI: return "fa_IR";
10777- case LANG_FINNISH: return "fi_FI";
10778- case LANG_FRENCH:
10779- switch (sub)
10780- {
10781- case SUBLANG_FRENCH: return "fr_FR";
10782- case SUBLANG_FRENCH_BELGIAN: /* WALLOON */ return "fr_BE";
10783- case SUBLANG_FRENCH_CANADIAN: return "fr_CA";
10784- case SUBLANG_FRENCH_SWISS: return "fr_CH";
10785- case SUBLANG_FRENCH_LUXEMBOURG: return "fr_LU";
10786- case SUBLANG_FRENCH_MONACO: return "fr_MC";
10787- case SUBLANG_FRENCH_WESTINDIES: return "fr"; /* Caribbean? */
10788- case SUBLANG_FRENCH_REUNION: return "fr_RE";
10789- case SUBLANG_FRENCH_CONGO: return "fr_CG";
10790- case SUBLANG_FRENCH_SENEGAL: return "fr_SN";
10791- case SUBLANG_FRENCH_CAMEROON: return "fr_CM";
10792- case SUBLANG_FRENCH_COTEDIVOIRE: return "fr_CI";
10793- case SUBLANG_FRENCH_MALI: return "fr_ML";
10794- case SUBLANG_FRENCH_MOROCCO: return "fr_MA";
10795- case SUBLANG_FRENCH_HAITI: return "fr_HT";
10796- }
10797- return "fr";
10798- case LANG_FRISIAN: return "fy_NL";
10799- case LANG_FULFULDE:
10800- /* Spoken in Nigeria, Guinea, Senegal, Mali, Niger, Cameroon, Benin. */
10801- return "ff_NG";
10802- case LANG_GAELIC:
10803- switch (sub)
10804- {
10805- case 0x01: /* SCOTTISH */ return "gd_GB";
10806- case 0x02: /* IRISH */ return "ga_IE";
10807- }
10808- return "C";
10809- case LANG_GALICIAN: return "gl_ES";
10810- case LANG_GEORGIAN: return "ka_GE";
10811- case LANG_GERMAN:
10812- switch (sub)
10813- {
10814- case SUBLANG_GERMAN: return "de_DE";
10815- case SUBLANG_GERMAN_SWISS: return "de_CH";
10816- case SUBLANG_GERMAN_AUSTRIAN: return "de_AT";
10817- case SUBLANG_GERMAN_LUXEMBOURG: return "de_LU";
10818- case SUBLANG_GERMAN_LIECHTENSTEIN: return "de_LI";
10819- }
10820- return "de";
10821- case LANG_GREEK: return "el_GR";
10822- case LANG_GUARANI: return "gn_PY";
10823- case LANG_GUJARATI: return "gu_IN";
10824- case LANG_HAUSA: return "ha_NG";
10825- case LANG_HAWAIIAN:
10826- /* FIXME: Do they mean Hawaiian ("haw_US", 1000 speakers)
10827- or Hawaii Creole English ("cpe_US", 600000 speakers)? */
10828- return "cpe_US";
10829- case LANG_HEBREW: return "he_IL";
10830- case LANG_HINDI: return "hi_IN";
10831- case LANG_HUNGARIAN: return "hu_HU";
10832- case LANG_IBIBIO: return "nic_NG";
10833- case LANG_ICELANDIC: return "is_IS";
10834- case LANG_IGBO: return "ig_NG";
10835- case LANG_INDONESIAN: return "id_ID";
10836- case LANG_INUKTITUT: return "iu_CA";
10837- case LANG_ITALIAN:
10838- switch (sub)
10839- {
10840- case SUBLANG_ITALIAN: return "it_IT";
10841- case SUBLANG_ITALIAN_SWISS: return "it_CH";
10842- }
10843- return "it";
10844- case LANG_JAPANESE: return "ja_JP";
10845- case LANG_KANNADA: return "kn_IN";
10846- case LANG_KANURI: return "kr_NG";
10847- case LANG_KASHMIRI:
10848- switch (sub)
10849- {
10850- case SUBLANG_DEFAULT: return "ks_PK";
10851- case SUBLANG_KASHMIRI_INDIA: return "ks_IN";
10852- }
10853- return "ks";
10854- case LANG_KAZAK: return "kk_KZ";
10855- case LANG_KONKANI:
10856- /* FIXME: Adjust this when such locales appear on Unix. */
10857- return "kok_IN";
10858- case LANG_KOREAN: return "ko_KR";
10859- case LANG_KYRGYZ: return "ky_KG";
10860- case LANG_LAO: return "lo_LA";
10861- case LANG_LATIN: return "la_VA";
10862- case LANG_LATVIAN: return "lv_LV";
10863- case LANG_LITHUANIAN: return "lt_LT";
10864- case LANG_MACEDONIAN: return "mk_MK";
10865- case LANG_MALAY:
10866- switch (sub)
10867- {
10868- case SUBLANG_MALAY_MALAYSIA: return "ms_MY";
10869- case SUBLANG_MALAY_BRUNEI_DARUSSALAM: return "ms_BN";
10870- }
10871- return "ms";
10872- case LANG_MALAYALAM: return "ml_IN";
10873- case LANG_MALTESE: return "mt_MT";
10874- case LANG_MANIPURI:
10875- /* FIXME: Adjust this when such locales appear on Unix. */
10876- return "mni_IN";
10877- case LANG_MARATHI: return "mr_IN";
10878- case LANG_MONGOLIAN:
10879- switch (sub)
10880- {
10881- case SUBLANG_DEFAULT: return "mn_MN";
10882- }
10883- return "mn"; /* Ambiguous: could be "mn_CN" or "mn_MN". */
10884- case LANG_NEPALI:
10885- switch (sub)
10886- {
10887- case SUBLANG_DEFAULT: return "ne_NP";
10888- case SUBLANG_NEPALI_INDIA: return "ne_IN";
10889- }
10890- return "ne";
10891- case LANG_NORWEGIAN:
10892- switch (sub)
10893- {
10894- case SUBLANG_NORWEGIAN_BOKMAL: return "nb_NO";
10895- case SUBLANG_NORWEGIAN_NYNORSK: return "nn_NO";
10896- }
10897- return "no";
10898- case LANG_ORIYA: return "or_IN";
10899- case LANG_OROMO: return "om_ET";
10900- case LANG_PAPIAMENTU: return "pap_AN";
10901- case LANG_PASHTO:
10902- return "ps"; /* Ambiguous: could be "ps_PK" or "ps_AF". */
10903- case LANG_POLISH: return "pl_PL";
10904- case LANG_PORTUGUESE:
10905- switch (sub)
10906- {
10907- case SUBLANG_PORTUGUESE: return "pt_PT";
10908- /* Hmm. SUBLANG_PORTUGUESE_BRAZILIAN == SUBLANG_DEFAULT.
10909- Same phenomenon as SUBLANG_ENGLISH_US == SUBLANG_DEFAULT. */
10910- case SUBLANG_PORTUGUESE_BRAZILIAN: return "pt_BR";
10911- }
10912- return "pt";
10913- case LANG_PUNJABI:
10914- switch (sub)
10915- {
10916- case SUBLANG_PUNJABI_INDIA: return "pa_IN"; /* Gurmukhi script */
10917- case SUBLANG_PUNJABI_PAKISTAN: return "pa_PK"; /* Arabic script */
10918- }
10919- return "pa";
10920- case LANG_RHAETO_ROMANCE: return "rm_CH";
10921- case LANG_ROMANIAN:
10922- switch (sub)
10923- {
10924- case SUBLANG_ROMANIAN_ROMANIA: return "ro_RO";
10925- case SUBLANG_ROMANIAN_MOLDOVA: return "ro_MD";
10926- }
10927- return "ro";
10928- case LANG_RUSSIAN:
10929- switch (sub)
10930- {
10931- case SUBLANG_DEFAULT: return "ru_RU";
10932- }
10933- return "ru"; /* Ambiguous: could be "ru_RU" or "ru_UA" or "ru_MD". */
10934- case LANG_SAAMI: /* actually Northern Sami */ return "se_NO";
10935- case LANG_SANSKRIT: return "sa_IN";
10936- case LANG_SINDHI:
10937- switch (sub)
10938- {
10939- case SUBLANG_SINDHI_PAKISTAN: return "sd_PK";
10940- case SUBLANG_SINDHI_AFGHANISTAN: return "sd_AF";
10941- }
10942- return "sd";
10943- case LANG_SINHALESE: return "si_LK";
10944- case LANG_SLOVAK: return "sk_SK";
10945- case LANG_SLOVENIAN: return "sl_SI";
10946- case LANG_SOMALI: return "so_SO";
10947- case LANG_SORBIAN:
10948- /* FIXME: Adjust this when such locales appear on Unix. */
10949- return "wen_DE";
10950- case LANG_SPANISH:
10951- switch (sub)
10952- {
10953- case SUBLANG_SPANISH: return "es_ES";
10954- case SUBLANG_SPANISH_MEXICAN: return "es_MX";
10955- case SUBLANG_SPANISH_MODERN:
10956- return "es_ES@modern"; /* not seen on Unix */
10957- case SUBLANG_SPANISH_GUATEMALA: return "es_GT";
10958- case SUBLANG_SPANISH_COSTA_RICA: return "es_CR";
10959- case SUBLANG_SPANISH_PANAMA: return "es_PA";
10960- case SUBLANG_SPANISH_DOMINICAN_REPUBLIC: return "es_DO";
10961- case SUBLANG_SPANISH_VENEZUELA: return "es_VE";
10962- case SUBLANG_SPANISH_COLOMBIA: return "es_CO";
10963- case SUBLANG_SPANISH_PERU: return "es_PE";
10964- case SUBLANG_SPANISH_ARGENTINA: return "es_AR";
10965- case SUBLANG_SPANISH_ECUADOR: return "es_EC";
10966- case SUBLANG_SPANISH_CHILE: return "es_CL";
10967- case SUBLANG_SPANISH_URUGUAY: return "es_UY";
10968- case SUBLANG_SPANISH_PARAGUAY: return "es_PY";
10969- case SUBLANG_SPANISH_BOLIVIA: return "es_BO";
10970- case SUBLANG_SPANISH_EL_SALVADOR: return "es_SV";
10971- case SUBLANG_SPANISH_HONDURAS: return "es_HN";
10972- case SUBLANG_SPANISH_NICARAGUA: return "es_NI";
10973- case SUBLANG_SPANISH_PUERTO_RICO: return "es_PR";
10974- }
10975- return "es";
10976- case LANG_SUTU: return "bnt_TZ"; /* or "st_LS" or "nso_ZA"? */
10977- case LANG_SWAHILI: return "sw_KE";
10978- case LANG_SWEDISH:
10979- switch (sub)
10980- {
10981- case SUBLANG_DEFAULT: return "sv_SE";
10982- case SUBLANG_SWEDISH_FINLAND: return "sv_FI";
10983- }
10984- return "sv";
10985- case LANG_SYRIAC: return "syr_TR"; /* An extinct language. */
10986- case LANG_TAGALOG: return "tl_PH";
10987- case LANG_TAJIK: return "tg_TJ";
10988- case LANG_TAMAZIGHT:
10989- switch (sub)
10990- {
10991- /* FIXME: Adjust this when Tamazight locales appear on Unix. */
10992- case SUBLANG_TAMAZIGHT_ARABIC: return "ber_MA@arabic";
10993- case SUBLANG_TAMAZIGHT_ALGERIA_LATIN: return "ber_DZ@latin";
10994- }
10995- return "ber_MA";
10996- case LANG_TAMIL:
10997- switch (sub)
10998- {
10999- case SUBLANG_DEFAULT: return "ta_IN";
11000- }
11001- return "ta"; /* Ambiguous: could be "ta_IN" or "ta_LK" or "ta_SG". */
11002- case LANG_TATAR: return "tt_RU";
11003- case LANG_TELUGU: return "te_IN";
11004- case LANG_THAI: return "th_TH";
11005- case LANG_TIBETAN: return "bo_CN";
11006- case LANG_TIGRINYA:
11007- switch (sub)
11008- {
11009- case SUBLANG_TIGRINYA_ETHIOPIA: return "ti_ET";
11010- case SUBLANG_TIGRINYA_ERITREA: return "ti_ER";
11011- }
11012- return "ti";
11013- case LANG_TSONGA: return "ts_ZA";
11014- case LANG_TSWANA: return "tn_BW";
11015- case LANG_TURKISH: return "tr_TR";
11016- case LANG_TURKMEN: return "tk_TM";
11017- case LANG_UKRAINIAN: return "uk_UA";
11018- case LANG_URDU:
11019- switch (sub)
11020- {
11021- case SUBLANG_URDU_PAKISTAN: return "ur_PK";
11022- case SUBLANG_URDU_INDIA: return "ur_IN";
11023- }
11024- return "ur";
11025- case LANG_UZBEK:
11026- switch (sub)
11027- {
11028- case SUBLANG_UZBEK_LATIN: return "uz_UZ";
11029- case SUBLANG_UZBEK_CYRILLIC: return "uz_UZ@cyrillic";
11030- }
11031- return "uz";
11032- case LANG_VENDA: return "ve_ZA";
11033- case LANG_VIETNAMESE: return "vi_VN";
11034- case LANG_WELSH: return "cy_GB";
11035- case LANG_XHOSA: return "xh_ZA";
11036- case LANG_YI: return "sit_CN";
11037- case LANG_YIDDISH: return "yi_IL";
11038- case LANG_YORUBA: return "yo_NG";
11039- case LANG_ZULU: return "zu_ZA";
11040- default: return "C";
11041- }
11042- }
11043-# endif
11044-#endif
11045-}
11046-
11047-const char *
11048-gl_locale_name (int category, const char *categoryname)
11049-{
11050- const char *retval;
11051-
11052- retval = gl_locale_name_posix (category, categoryname);
11053- if (retval != NULL)
11054- return retval;
11055-
11056- return gl_locale_name_default ();
11057-}
11058--- a/intl/lock.c
11059+++ /dev/null
11060@@ -1,922 +0,0 @@
11061-/* Locking in multithreaded situations.
11062- Copyright (C) 2005-2006 Free Software Foundation, Inc.
11063-
11064- This program is free software; you can redistribute it and/or modify it
11065- under the terms of the GNU Library General Public License as published
11066- by the Free Software Foundation; either version 2, or (at your option)
11067- any later version.
11068-
11069- This program is distributed in the hope that it will be useful,
11070- but WITHOUT ANY WARRANTY; without even the implied warranty of
11071- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11072- Library General Public License for more details.
11073-
11074- You should have received a copy of the GNU Library General Public
11075- License along with this program; if not, write to the Free Software
11076- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
11077- USA. */
11078-
11079-/* Written by Bruno Haible <bruno@clisp.org>, 2005.
11080- Based on GCC's gthr-posix.h, gthr-posix95.h, gthr-solaris.h,
11081- gthr-win32.h. */
11082-
11083-#include <config.h>
11084-
11085-#include "lock.h"
11086-
11087-/* ========================================================================= */
11088-
11089-#if USE_POSIX_THREADS
11090-
11091-/* Use the POSIX threads library. */
11092-
11093-# if PTHREAD_IN_USE_DETECTION_HARD
11094-
11095-/* The function to be executed by a dummy thread. */
11096-static void *
11097-dummy_thread_func (void *arg)
11098-{
11099- return arg;
11100-}
11101-
11102-int
11103-glthread_in_use (void)
11104-{
11105- static int tested;
11106- static int result; /* 1: linked with -lpthread, 0: only with libc */
11107-
11108- if (!tested)
11109- {
11110- pthread_t thread;
11111-
11112- if (pthread_create (&thread, NULL, dummy_thread_func, NULL) != 0)
11113- /* Thread creation failed. */
11114- result = 0;
11115- else
11116- {
11117- /* Thread creation works. */
11118- void *retval;
11119- if (pthread_join (thread, &retval) != 0)
11120- abort ();
11121- result = 1;
11122- }
11123- tested = 1;
11124- }
11125- return result;
11126-}
11127-
11128-# endif
11129-
11130-/* -------------------------- gl_lock_t datatype -------------------------- */
11131-
11132-/* ------------------------- gl_rwlock_t datatype ------------------------- */
11133-
11134-# if HAVE_PTHREAD_RWLOCK
11135-
11136-# if !defined PTHREAD_RWLOCK_INITIALIZER
11137-
11138-void
11139-glthread_rwlock_init (gl_rwlock_t *lock)
11140-{
11141- if (pthread_rwlock_init (&lock->rwlock, NULL) != 0)
11142- abort ();
11143- lock->initialized = 1;
11144-}
11145-
11146-void
11147-glthread_rwlock_rdlock (gl_rwlock_t *lock)
11148-{
11149- if (!lock->initialized)
11150- {
11151- if (pthread_mutex_lock (&lock->guard) != 0)
11152- abort ();
11153- if (!lock->initialized)
11154- glthread_rwlock_init (lock);
11155- if (pthread_mutex_unlock (&lock->guard) != 0)
11156- abort ();
11157- }
11158- if (pthread_rwlock_rdlock (&lock->rwlock) != 0)
11159- abort ();
11160-}
11161-
11162-void
11163-glthread_rwlock_wrlock (gl_rwlock_t *lock)
11164-{
11165- if (!lock->initialized)
11166- {
11167- if (pthread_mutex_lock (&lock->guard) != 0)
11168- abort ();
11169- if (!lock->initialized)
11170- glthread_rwlock_init (lock);
11171- if (pthread_mutex_unlock (&lock->guard) != 0)
11172- abort ();
11173- }
11174- if (pthread_rwlock_wrlock (&lock->rwlock) != 0)
11175- abort ();
11176-}
11177-
11178-void
11179-glthread_rwlock_unlock (gl_rwlock_t *lock)
11180-{
11181- if (!lock->initialized)
11182- abort ();
11183- if (pthread_rwlock_unlock (&lock->rwlock) != 0)
11184- abort ();
11185-}
11186-
11187-void
11188-glthread_rwlock_destroy (gl_rwlock_t *lock)
11189-{
11190- if (!lock->initialized)
11191- abort ();
11192- if (pthread_rwlock_destroy (&lock->rwlock) != 0)
11193- abort ();
11194- lock->initialized = 0;
11195-}
11196-
11197-# endif
11198-
11199-# else
11200-
11201-void
11202-glthread_rwlock_init (gl_rwlock_t *lock)
11203-{
11204- if (pthread_mutex_init (&lock->lock, NULL) != 0)
11205- abort ();
11206- if (pthread_cond_init (&lock->waiting_readers, NULL) != 0)
11207- abort ();
11208- if (pthread_cond_init (&lock->waiting_writers, NULL) != 0)
11209- abort ();
11210- lock->waiting_writers_count = 0;
11211- lock->runcount = 0;
11212-}
11213-
11214-void
11215-glthread_rwlock_rdlock (gl_rwlock_t *lock)
11216-{
11217- if (pthread_mutex_lock (&lock->lock) != 0)
11218- abort ();
11219- /* Test whether only readers are currently running, and whether the runcount
11220- field will not overflow. */
11221- /* POSIX says: "It is implementation-defined whether the calling thread
11222- acquires the lock when a writer does not hold the lock and there are
11223- writers blocked on the lock." Let's say, no: give the writers a higher
11224- priority. */
11225- while (!(lock->runcount + 1 > 0 && lock->waiting_writers_count == 0))
11226- {
11227- /* This thread has to wait for a while. Enqueue it among the
11228- waiting_readers. */
11229- if (pthread_cond_wait (&lock->waiting_readers, &lock->lock) != 0)
11230- abort ();
11231- }
11232- lock->runcount++;
11233- if (pthread_mutex_unlock (&lock->lock) != 0)
11234- abort ();
11235-}
11236-
11237-void
11238-glthread_rwlock_wrlock (gl_rwlock_t *lock)
11239-{
11240- if (pthread_mutex_lock (&lock->lock) != 0)
11241- abort ();
11242- /* Test whether no readers or writers are currently running. */
11243- while (!(lock->runcount == 0))
11244- {
11245- /* This thread has to wait for a while. Enqueue it among the
11246- waiting_writers. */
11247- lock->waiting_writers_count++;
11248- if (pthread_cond_wait (&lock->waiting_writers, &lock->lock) != 0)
11249- abort ();
11250- lock->waiting_writers_count--;
11251- }
11252- lock->runcount--; /* runcount becomes -1 */
11253- if (pthread_mutex_unlock (&lock->lock) != 0)
11254- abort ();
11255-}
11256-
11257-void
11258-glthread_rwlock_unlock (gl_rwlock_t *lock)
11259-{
11260- if (pthread_mutex_lock (&lock->lock) != 0)
11261- abort ();
11262- if (lock->runcount < 0)
11263- {
11264- /* Drop a writer lock. */
11265- if (!(lock->runcount == -1))
11266- abort ();
11267- lock->runcount = 0;
11268- }
11269- else
11270- {
11271- /* Drop a reader lock. */
11272- if (!(lock->runcount > 0))
11273- abort ();
11274- lock->runcount--;
11275- }
11276- if (lock->runcount == 0)
11277- {
11278- /* POSIX recommends that "write locks shall take precedence over read
11279- locks", to avoid "writer starvation". */
11280- if (lock->waiting_writers_count > 0)
11281- {
11282- /* Wake up one of the waiting writers. */
11283- if (pthread_cond_signal (&lock->waiting_writers) != 0)
11284- abort ();
11285- }
11286- else
11287- {
11288- /* Wake up all waiting readers. */
11289- if (pthread_cond_broadcast (&lock->waiting_readers) != 0)
11290- abort ();
11291- }
11292- }
11293- if (pthread_mutex_unlock (&lock->lock) != 0)
11294- abort ();
11295-}
11296-
11297-void
11298-glthread_rwlock_destroy (gl_rwlock_t *lock)
11299-{
11300- if (pthread_mutex_destroy (&lock->lock) != 0)
11301- abort ();
11302- if (pthread_cond_destroy (&lock->waiting_readers) != 0)
11303- abort ();
11304- if (pthread_cond_destroy (&lock->waiting_writers) != 0)
11305- abort ();
11306-}
11307-
11308-# endif
11309-
11310-/* --------------------- gl_recursive_lock_t datatype --------------------- */
11311-
11312-# if HAVE_PTHREAD_MUTEX_RECURSIVE
11313-
11314-# if !(defined PTHREAD_RECURSIVE_MUTEX_INITIALIZER || defined PTHREAD_RECURSIVE_MUTEX_INITIALIZER_NP)
11315-
11316-void
11317-glthread_recursive_lock_init (gl_recursive_lock_t *lock)
11318-{
11319- pthread_mutexattr_t attributes;
11320-
11321- if (pthread_mutexattr_init (&attributes) != 0)
11322- abort ();
11323- if (pthread_mutexattr_settype (&attributes, PTHREAD_MUTEX_RECURSIVE) != 0)
11324- abort ();
11325- if (pthread_mutex_init (&lock->recmutex, &attributes) != 0)
11326- abort ();
11327- if (pthread_mutexattr_destroy (&attributes) != 0)
11328- abort ();
11329- lock->initialized = 1;
11330-}
11331-
11332-void
11333-glthread_recursive_lock_lock (gl_recursive_lock_t *lock)
11334-{
11335- if (!lock->initialized)
11336- {
11337- if (pthread_mutex_lock (&lock->guard) != 0)
11338- abort ();
11339- if (!lock->initialized)
11340- glthread_recursive_lock_init (lock);
11341- if (pthread_mutex_unlock (&lock->guard) != 0)
11342- abort ();
11343- }
11344- if (pthread_mutex_lock (&lock->recmutex) != 0)
11345- abort ();
11346-}
11347-
11348-void
11349-glthread_recursive_lock_unlock (gl_recursive_lock_t *lock)
11350-{
11351- if (!lock->initialized)
11352- abort ();
11353- if (pthread_mutex_unlock (&lock->recmutex) != 0)
11354- abort ();
11355-}
11356-
11357-void
11358-glthread_recursive_lock_destroy (gl_recursive_lock_t *lock)
11359-{
11360- if (!lock->initialized)
11361- abort ();
11362- if (pthread_mutex_destroy (&lock->recmutex) != 0)
11363- abort ();
11364- lock->initialized = 0;
11365-}
11366-
11367-# endif
11368-
11369-# else
11370-
11371-void
11372-glthread_recursive_lock_init (gl_recursive_lock_t *lock)
11373-{
11374- if (pthread_mutex_init (&lock->mutex, NULL) != 0)
11375- abort ();
11376- lock->owner = (pthread_t) 0;
11377- lock->depth = 0;
11378-}
11379-
11380-void
11381-glthread_recursive_lock_lock (gl_recursive_lock_t *lock)
11382-{
11383- pthread_t self = pthread_self ();
11384- if (lock->owner != self)
11385- {
11386- if (pthread_mutex_lock (&lock->mutex) != 0)
11387- abort ();
11388- lock->owner = self;
11389- }
11390- if (++(lock->depth) == 0) /* wraparound? */
11391- abort ();
11392-}
11393-
11394-void
11395-glthread_recursive_lock_unlock (gl_recursive_lock_t *lock)
11396-{
11397- if (lock->owner != pthread_self ())
11398- abort ();
11399- if (lock->depth == 0)
11400- abort ();
11401- if (--(lock->depth) == 0)
11402- {
11403- lock->owner = (pthread_t) 0;
11404- if (pthread_mutex_unlock (&lock->mutex) != 0)
11405- abort ();
11406- }
11407-}
11408-
11409-void
11410-glthread_recursive_lock_destroy (gl_recursive_lock_t *lock)
11411-{
11412- if (lock->owner != (pthread_t) 0)
11413- abort ();
11414- if (pthread_mutex_destroy (&lock->mutex) != 0)
11415- abort ();
11416-}
11417-
11418-# endif
11419-
11420-/* -------------------------- gl_once_t datatype -------------------------- */
11421-
11422-static const pthread_once_t fresh_once = PTHREAD_ONCE_INIT;
11423-
11424-int
11425-glthread_once_singlethreaded (pthread_once_t *once_control)
11426-{
11427- /* We don't know whether pthread_once_t is an integer type, a floating-point
11428- type, a pointer type, or a structure type. */
11429- char *firstbyte = (char *)once_control;
11430- if (*firstbyte == *(const char *)&fresh_once)
11431- {
11432- /* First time use of once_control. Invert the first byte. */
11433- *firstbyte = ~ *(const char *)&fresh_once;
11434- return 1;
11435- }
11436- else
11437- return 0;
11438-}
11439-
11440-#endif
11441-
11442-/* ========================================================================= */
11443-
11444-#if USE_PTH_THREADS
11445-
11446-/* Use the GNU Pth threads library. */
11447-
11448-/* -------------------------- gl_lock_t datatype -------------------------- */
11449-
11450-/* ------------------------- gl_rwlock_t datatype ------------------------- */
11451-
11452-/* --------------------- gl_recursive_lock_t datatype --------------------- */
11453-
11454-/* -------------------------- gl_once_t datatype -------------------------- */
11455-
11456-void
11457-glthread_once_call (void *arg)
11458-{
11459- void (**gl_once_temp_addr) (void) = (void (**) (void)) arg;
11460- void (*initfunction) (void) = *gl_once_temp_addr;
11461- initfunction ();
11462-}
11463-
11464-int
11465-glthread_once_singlethreaded (pth_once_t *once_control)
11466-{
11467- /* We know that pth_once_t is an integer type. */
11468- if (*once_control == PTH_ONCE_INIT)
11469- {
11470- /* First time use of once_control. Invert the marker. */
11471- *once_control = ~ PTH_ONCE_INIT;
11472- return 1;
11473- }
11474- else
11475- return 0;
11476-}
11477-
11478-#endif
11479-
11480-/* ========================================================================= */
11481-
11482-#if USE_SOLARIS_THREADS
11483-
11484-/* Use the old Solaris threads library. */
11485-
11486-/* -------------------------- gl_lock_t datatype -------------------------- */
11487-
11488-/* ------------------------- gl_rwlock_t datatype ------------------------- */
11489-
11490-/* --------------------- gl_recursive_lock_t datatype --------------------- */
11491-
11492-void
11493-glthread_recursive_lock_init (gl_recursive_lock_t *lock)
11494-{
11495- if (mutex_init (&lock->mutex, USYNC_THREAD, NULL) != 0)
11496- abort ();
11497- lock->owner = (thread_t) 0;
11498- lock->depth = 0;
11499-}
11500-
11501-void
11502-glthread_recursive_lock_lock (gl_recursive_lock_t *lock)
11503-{
11504- thread_t self = thr_self ();
11505- if (lock->owner != self)
11506- {
11507- if (mutex_lock (&lock->mutex) != 0)
11508- abort ();
11509- lock->owner = self;
11510- }
11511- if (++(lock->depth) == 0) /* wraparound? */
11512- abort ();
11513-}
11514-
11515-void
11516-glthread_recursive_lock_unlock (gl_recursive_lock_t *lock)
11517-{
11518- if (lock->owner != thr_self ())
11519- abort ();
11520- if (lock->depth == 0)
11521- abort ();
11522- if (--(lock->depth) == 0)
11523- {
11524- lock->owner = (thread_t) 0;
11525- if (mutex_unlock (&lock->mutex) != 0)
11526- abort ();
11527- }
11528-}
11529-
11530-void
11531-glthread_recursive_lock_destroy (gl_recursive_lock_t *lock)
11532-{
11533- if (lock->owner != (thread_t) 0)
11534- abort ();
11535- if (mutex_destroy (&lock->mutex) != 0)
11536- abort ();
11537-}
11538-
11539-/* -------------------------- gl_once_t datatype -------------------------- */
11540-
11541-void
11542-glthread_once (gl_once_t *once_control, void (*initfunction) (void))
11543-{
11544- if (!once_control->inited)
11545- {
11546- /* Use the mutex to guarantee that if another thread is already calling
11547- the initfunction, this thread waits until it's finished. */
11548- if (mutex_lock (&once_control->mutex) != 0)
11549- abort ();
11550- if (!once_control->inited)
11551- {
11552- once_control->inited = 1;
11553- initfunction ();
11554- }
11555- if (mutex_unlock (&once_control->mutex) != 0)
11556- abort ();
11557- }
11558-}
11559-
11560-int
11561-glthread_once_singlethreaded (gl_once_t *once_control)
11562-{
11563- /* We know that gl_once_t contains an integer type. */
11564- if (!once_control->inited)
11565- {
11566- /* First time use of once_control. Invert the marker. */
11567- once_control->inited = ~ 0;
11568- return 1;
11569- }
11570- else
11571- return 0;
11572-}
11573-
11574-#endif
11575-
11576-/* ========================================================================= */
11577-
11578-#if USE_WIN32_THREADS
11579-
11580-/* -------------------------- gl_lock_t datatype -------------------------- */
11581-
11582-void
11583-glthread_lock_init (gl_lock_t *lock)
11584-{
11585- InitializeCriticalSection (&lock->lock);
11586- lock->guard.done = 1;
11587-}
11588-
11589-void
11590-glthread_lock_lock (gl_lock_t *lock)
11591-{
11592- if (!lock->guard.done)
11593- {
11594- if (InterlockedIncrement (&lock->guard.started) == 0)
11595- /* This thread is the first one to need this lock. Initialize it. */
11596- glthread_lock_init (lock);
11597- else
11598- /* Yield the CPU while waiting for another thread to finish
11599- initializing this lock. */
11600- while (!lock->guard.done)
11601- Sleep (0);
11602- }
11603- EnterCriticalSection (&lock->lock);
11604-}
11605-
11606-void
11607-glthread_lock_unlock (gl_lock_t *lock)
11608-{
11609- if (!lock->guard.done)
11610- abort ();
11611- LeaveCriticalSection (&lock->lock);
11612-}
11613-
11614-void
11615-glthread_lock_destroy (gl_lock_t *lock)
11616-{
11617- if (!lock->guard.done)
11618- abort ();
11619- DeleteCriticalSection (&lock->lock);
11620- lock->guard.done = 0;
11621-}
11622-
11623-/* ------------------------- gl_rwlock_t datatype ------------------------- */
11624-
11625-static inline void
11626-gl_waitqueue_init (gl_waitqueue_t *wq)
11627-{
11628- wq->array = NULL;
11629- wq->count = 0;
11630- wq->alloc = 0;
11631- wq->offset = 0;
11632-}
11633-
11634-/* Enqueues the current thread, represented by an event, in a wait queue.
11635- Returns INVALID_HANDLE_VALUE if an allocation failure occurs. */
11636-static HANDLE
11637-gl_waitqueue_add (gl_waitqueue_t *wq)
11638-{
11639- HANDLE event;
11640- unsigned int index;
11641-
11642- if (wq->count == wq->alloc)
11643- {
11644- unsigned int new_alloc = 2 * wq->alloc + 1;
11645- HANDLE *new_array =
11646- (HANDLE *) realloc (wq->array, new_alloc * sizeof (HANDLE));
11647- if (new_array == NULL)
11648- /* No more memory. */
11649- return INVALID_HANDLE_VALUE;
11650- /* Now is a good opportunity to rotate the array so that its contents
11651- starts at offset 0. */
11652- if (wq->offset > 0)
11653- {
11654- unsigned int old_count = wq->count;
11655- unsigned int old_alloc = wq->alloc;
11656- unsigned int old_offset = wq->offset;
11657- unsigned int i;
11658- if (old_offset + old_count > old_alloc)
11659- {
11660- unsigned int limit = old_offset + old_count - old_alloc;
11661- for (i = 0; i < limit; i++)
11662- new_array[old_alloc + i] = new_array[i];
11663- }
11664- for (i = 0; i < old_count; i++)
11665- new_array[i] = new_array[old_offset + i];
11666- wq->offset = 0;
11667- }
11668- wq->array = new_array;
11669- wq->alloc = new_alloc;
11670- }
11671- event = CreateEvent (NULL, TRUE, FALSE, NULL);
11672- if (event == INVALID_HANDLE_VALUE)
11673- /* No way to allocate an event. */
11674- return INVALID_HANDLE_VALUE;
11675- index = wq->offset + wq->count;
11676- if (index >= wq->alloc)
11677- index -= wq->alloc;
11678- wq->array[index] = event;
11679- wq->count++;
11680- return event;
11681-}
11682-
11683-/* Notifies the first thread from a wait queue and dequeues it. */
11684-static inline void
11685-gl_waitqueue_notify_first (gl_waitqueue_t *wq)
11686-{
11687- SetEvent (wq->array[wq->offset + 0]);
11688- wq->offset++;
11689- wq->count--;
11690- if (wq->count == 0 || wq->offset == wq->alloc)
11691- wq->offset = 0;
11692-}
11693-
11694-/* Notifies all threads from a wait queue and dequeues them all. */
11695-static inline void
11696-gl_waitqueue_notify_all (gl_waitqueue_t *wq)
11697-{
11698- unsigned int i;
11699-
11700- for (i = 0; i < wq->count; i++)
11701- {
11702- unsigned int index = wq->offset + i;
11703- if (index >= wq->alloc)
11704- index -= wq->alloc;
11705- SetEvent (wq->array[index]);
11706- }
11707- wq->count = 0;
11708- wq->offset = 0;
11709-}
11710-
11711-void
11712-glthread_rwlock_init (gl_rwlock_t *lock)
11713-{
11714- InitializeCriticalSection (&lock->lock);
11715- gl_waitqueue_init (&lock->waiting_readers);
11716- gl_waitqueue_init (&lock->waiting_writers);
11717- lock->runcount = 0;
11718- lock->guard.done = 1;
11719-}
11720-
11721-void
11722-glthread_rwlock_rdlock (gl_rwlock_t *lock)
11723-{
11724- if (!lock->guard.done)
11725- {
11726- if (InterlockedIncrement (&lock->guard.started) == 0)
11727- /* This thread is the first one to need this lock. Initialize it. */
11728- glthread_rwlock_init (lock);
11729- else
11730- /* Yield the CPU while waiting for another thread to finish
11731- initializing this lock. */
11732- while (!lock->guard.done)
11733- Sleep (0);
11734- }
11735- EnterCriticalSection (&lock->lock);
11736- /* Test whether only readers are currently running, and whether the runcount
11737- field will not overflow. */
11738- if (!(lock->runcount + 1 > 0))
11739- {
11740- /* This thread has to wait for a while. Enqueue it among the
11741- waiting_readers. */
11742- HANDLE event = gl_waitqueue_add (&lock->waiting_readers);
11743- if (event != INVALID_HANDLE_VALUE)
11744- {
11745- DWORD result;
11746- LeaveCriticalSection (&lock->lock);
11747- /* Wait until another thread signals this event. */
11748- result = WaitForSingleObject (event, INFINITE);
11749- if (result == WAIT_FAILED || result == WAIT_TIMEOUT)
11750- abort ();
11751- CloseHandle (event);
11752- /* The thread which signalled the event already did the bookkeeping:
11753- removed us from the waiting_readers, incremented lock->runcount. */
11754- if (!(lock->runcount > 0))
11755- abort ();
11756- return;
11757- }
11758- else
11759- {
11760- /* Allocation failure. Weird. */
11761- do
11762- {
11763- LeaveCriticalSection (&lock->lock);
11764- Sleep (1);
11765- EnterCriticalSection (&lock->lock);
11766- }
11767- while (!(lock->runcount + 1 > 0));
11768- }
11769- }
11770- lock->runcount++;
11771- LeaveCriticalSection (&lock->lock);
11772-}
11773-
11774-void
11775-glthread_rwlock_wrlock (gl_rwlock_t *lock)
11776-{
11777- if (!lock->guard.done)
11778- {
11779- if (InterlockedIncrement (&lock->guard.started) == 0)
11780- /* This thread is the first one to need this lock. Initialize it. */
11781- glthread_rwlock_init (lock);
11782- else
11783- /* Yield the CPU while waiting for another thread to finish
11784- initializing this lock. */
11785- while (!lock->guard.done)
11786- Sleep (0);
11787- }
11788- EnterCriticalSection (&lock->lock);
11789- /* Test whether no readers or writers are currently running. */
11790- if (!(lock->runcount == 0))
11791- {
11792- /* This thread has to wait for a while. Enqueue it among the
11793- waiting_writers. */
11794- HANDLE event = gl_waitqueue_add (&lock->waiting_writers);
11795- if (event != INVALID_HANDLE_VALUE)
11796- {
11797- DWORD result;
11798- LeaveCriticalSection (&lock->lock);
11799- /* Wait until another thread signals this event. */
11800- result = WaitForSingleObject (event, INFINITE);
11801- if (result == WAIT_FAILED || result == WAIT_TIMEOUT)
11802- abort ();
11803- CloseHandle (event);
11804- /* The thread which signalled the event already did the bookkeeping:
11805- removed us from the waiting_writers, set lock->runcount = -1. */
11806- if (!(lock->runcount == -1))
11807- abort ();
11808- return;
11809- }
11810- else
11811- {
11812- /* Allocation failure. Weird. */
11813- do
11814- {
11815- LeaveCriticalSection (&lock->lock);
11816- Sleep (1);
11817- EnterCriticalSection (&lock->lock);
11818- }
11819- while (!(lock->runcount == 0));
11820- }
11821- }
11822- lock->runcount--; /* runcount becomes -1 */
11823- LeaveCriticalSection (&lock->lock);
11824-}
11825-
11826-void
11827-glthread_rwlock_unlock (gl_rwlock_t *lock)
11828-{
11829- if (!lock->guard.done)
11830- abort ();
11831- EnterCriticalSection (&lock->lock);
11832- if (lock->runcount < 0)
11833- {
11834- /* Drop a writer lock. */
11835- if (!(lock->runcount == -1))
11836- abort ();
11837- lock->runcount = 0;
11838- }
11839- else
11840- {
11841- /* Drop a reader lock. */
11842- if (!(lock->runcount > 0))
11843- abort ();
11844- lock->runcount--;
11845- }
11846- if (lock->runcount == 0)
11847- {
11848- /* POSIX recommends that "write locks shall take precedence over read
11849- locks", to avoid "writer starvation". */
11850- if (lock->waiting_writers.count > 0)
11851- {
11852- /* Wake up one of the waiting writers. */
11853- lock->runcount--;
11854- gl_waitqueue_notify_first (&lock->waiting_writers);
11855- }
11856- else
11857- {
11858- /* Wake up all waiting readers. */
11859- lock->runcount += lock->waiting_readers.count;
11860- gl_waitqueue_notify_all (&lock->waiting_readers);
11861- }
11862- }
11863- LeaveCriticalSection (&lock->lock);
11864-}
11865-
11866-void
11867-glthread_rwlock_destroy (gl_rwlock_t *lock)
11868-{
11869- if (!lock->guard.done)
11870- abort ();
11871- if (lock->runcount != 0)
11872- abort ();
11873- DeleteCriticalSection (&lock->lock);
11874- if (lock->waiting_readers.array != NULL)
11875- free (lock->waiting_readers.array);
11876- if (lock->waiting_writers.array != NULL)
11877- free (lock->waiting_writers.array);
11878- lock->guard.done = 0;
11879-}
11880-
11881-/* --------------------- gl_recursive_lock_t datatype --------------------- */
11882-
11883-void
11884-glthread_recursive_lock_init (gl_recursive_lock_t *lock)
11885-{
11886- lock->owner = 0;
11887- lock->depth = 0;
11888- InitializeCriticalSection (&lock->lock);
11889- lock->guard.done = 1;
11890-}
11891-
11892-void
11893-glthread_recursive_lock_lock (gl_recursive_lock_t *lock)
11894-{
11895- if (!lock->guard.done)
11896- {
11897- if (InterlockedIncrement (&lock->guard.started) == 0)
11898- /* This thread is the first one to need this lock. Initialize it. */
11899- glthread_recursive_lock_init (lock);
11900- else
11901- /* Yield the CPU while waiting for another thread to finish
11902- initializing this lock. */
11903- while (!lock->guard.done)
11904- Sleep (0);
11905- }
11906- {
11907- DWORD self = GetCurrentThreadId ();
11908- if (lock->owner != self)
11909- {
11910- EnterCriticalSection (&lock->lock);
11911- lock->owner = self;
11912- }
11913- if (++(lock->depth) == 0) /* wraparound? */
11914- abort ();
11915- }
11916-}
11917-
11918-void
11919-glthread_recursive_lock_unlock (gl_recursive_lock_t *lock)
11920-{
11921- if (lock->owner != GetCurrentThreadId ())
11922- abort ();
11923- if (lock->depth == 0)
11924- abort ();
11925- if (--(lock->depth) == 0)
11926- {
11927- lock->owner = 0;
11928- LeaveCriticalSection (&lock->lock);
11929- }
11930-}
11931-
11932-void
11933-glthread_recursive_lock_destroy (gl_recursive_lock_t *lock)
11934-{
11935- if (lock->owner != 0)
11936- abort ();
11937- DeleteCriticalSection (&lock->lock);
11938- lock->guard.done = 0;
11939-}
11940-
11941-/* -------------------------- gl_once_t datatype -------------------------- */
11942-
11943-void
11944-glthread_once (gl_once_t *once_control, void (*initfunction) (void))
11945-{
11946- if (once_control->inited <= 0)
11947- {
11948- if (InterlockedIncrement (&once_control->started) == 0)
11949- {
11950- /* This thread is the first one to come to this once_control. */
11951- InitializeCriticalSection (&once_control->lock);
11952- EnterCriticalSection (&once_control->lock);
11953- once_control->inited = 0;
11954- initfunction ();
11955- once_control->inited = 1;
11956- LeaveCriticalSection (&once_control->lock);
11957- }
11958- else
11959- {
11960- /* Undo last operation. */
11961- InterlockedDecrement (&once_control->started);
11962- /* Some other thread has already started the initialization.
11963- Yield the CPU while waiting for the other thread to finish
11964- initializing and taking the lock. */
11965- while (once_control->inited < 0)
11966- Sleep (0);
11967- if (once_control->inited <= 0)
11968- {
11969- /* Take the lock. This blocks until the other thread has
11970- finished calling the initfunction. */
11971- EnterCriticalSection (&once_control->lock);
11972- LeaveCriticalSection (&once_control->lock);
11973- if (!(once_control->inited > 0))
11974- abort ();
11975- }
11976- }
11977- }
11978-}
11979-
11980-#endif
11981-
11982-/* ========================================================================= */
11983--- a/intl/lock.h
11984+++ /dev/null
11985@@ -1,1105 +0,0 @@
11986-/* Locking in multithreaded situations.
11987- Copyright (C) 2005-2007 Free Software Foundation, Inc.
11988-
11989- This program is free software; you can redistribute it and/or modify it
11990- under the terms of the GNU Library General Public License as published
11991- by the Free Software Foundation; either version 2, or (at your option)
11992- any later version.
11993-
11994- This program is distributed in the hope that it will be useful,
11995- but WITHOUT ANY WARRANTY; without even the implied warranty of
11996- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11997- Library General Public License for more details.
11998-
11999- You should have received a copy of the GNU Library General Public
12000- License along with this program; if not, write to the Free Software
12001- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
12002- USA. */
12003-
12004-/* Written by Bruno Haible <bruno@clisp.org>, 2005.
12005- Based on GCC's gthr-posix.h, gthr-posix95.h, gthr-solaris.h,
12006- gthr-win32.h. */
12007-
12008-/* This file contains locking primitives for use with a given thread library.
12009- It does not contain primitives for creating threads or for other
12010- synchronization primitives.
12011-
12012- Normal (non-recursive) locks:
12013- Type: gl_lock_t
12014- Declaration: gl_lock_define(extern, name)
12015- Initializer: gl_lock_define_initialized(, name)
12016- Initialization: gl_lock_init (name);
12017- Taking the lock: gl_lock_lock (name);
12018- Releasing the lock: gl_lock_unlock (name);
12019- De-initialization: gl_lock_destroy (name);
12020-
12021- Read-Write (non-recursive) locks:
12022- Type: gl_rwlock_t
12023- Declaration: gl_rwlock_define(extern, name)
12024- Initializer: gl_rwlock_define_initialized(, name)
12025- Initialization: gl_rwlock_init (name);
12026- Taking the lock: gl_rwlock_rdlock (name);
12027- gl_rwlock_wrlock (name);
12028- Releasing the lock: gl_rwlock_unlock (name);
12029- De-initialization: gl_rwlock_destroy (name);
12030-
12031- Recursive locks:
12032- Type: gl_recursive_lock_t
12033- Declaration: gl_recursive_lock_define(extern, name)
12034- Initializer: gl_recursive_lock_define_initialized(, name)
12035- Initialization: gl_recursive_lock_init (name);
12036- Taking the lock: gl_recursive_lock_lock (name);
12037- Releasing the lock: gl_recursive_lock_unlock (name);
12038- De-initialization: gl_recursive_lock_destroy (name);
12039-
12040- Once-only execution:
12041- Type: gl_once_t
12042- Initializer: gl_once_define(extern, name)
12043- Execution: gl_once (name, initfunction);
12044-*/
12045-
12046-
12047-#ifndef _LOCK_H
12048-#define _LOCK_H
12049-
12050-/* ========================================================================= */
12051-
12052-#if USE_POSIX_THREADS
12053-
12054-/* Use the POSIX threads library. */
12055-
12056-# include <pthread.h>
12057-# include <stdlib.h>
12058-
12059-# ifdef __cplusplus
12060-extern "C" {
12061-# endif
12062-
12063-# if PTHREAD_IN_USE_DETECTION_HARD
12064-
12065-/* The pthread_in_use() detection needs to be done at runtime. */
12066-# define pthread_in_use() \
12067- glthread_in_use ()
12068-extern int glthread_in_use (void);
12069-
12070-# endif
12071-
12072-# if USE_POSIX_THREADS_WEAK
12073-
12074-/* Use weak references to the POSIX threads library. */
12075-
12076-/* Weak references avoid dragging in external libraries if the other parts
12077- of the program don't use them. Here we use them, because we don't want
12078- every program that uses libintl to depend on libpthread. This assumes
12079- that libpthread would not be loaded after libintl; i.e. if libintl is
12080- loaded first, by an executable that does not depend on libpthread, and
12081- then a module is dynamically loaded that depends on libpthread, libintl
12082- will not be multithread-safe. */
12083-
12084-/* The way to test at runtime whether libpthread is present is to test
12085- whether a function pointer's value, such as &pthread_mutex_init, is
12086- non-NULL. However, some versions of GCC have a bug through which, in
12087- PIC mode, &foo != NULL always evaluates to true if there is a direct
12088- call to foo(...) in the same function. To avoid this, we test the
12089- address of a function in libpthread that we don't use. */
12090-
12091-# pragma weak pthread_mutex_init
12092-# pragma weak pthread_mutex_lock
12093-# pragma weak pthread_mutex_unlock
12094-# pragma weak pthread_mutex_destroy
12095-# pragma weak pthread_rwlock_init
12096-# pragma weak pthread_rwlock_rdlock
12097-# pragma weak pthread_rwlock_wrlock
12098-# pragma weak pthread_rwlock_unlock
12099-# pragma weak pthread_rwlock_destroy
12100-# pragma weak pthread_once
12101-# pragma weak pthread_cond_init
12102-# pragma weak pthread_cond_wait
12103-# pragma weak pthread_cond_signal
12104-# pragma weak pthread_cond_broadcast
12105-# pragma weak pthread_cond_destroy
12106-# pragma weak pthread_mutexattr_init
12107-# pragma weak pthread_mutexattr_settype
12108-# pragma weak pthread_mutexattr_destroy
12109-# ifndef pthread_self
12110-# pragma weak pthread_self
12111-# endif
12112-
12113-# if !PTHREAD_IN_USE_DETECTION_HARD
12114-# pragma weak pthread_cancel
12115-# define pthread_in_use() (pthread_cancel != NULL)
12116-# endif
12117-
12118-# else
12119-
12120-# if !PTHREAD_IN_USE_DETECTION_HARD
12121-# define pthread_in_use() 1
12122-# endif
12123-
12124-# endif
12125-
12126-/* -------------------------- gl_lock_t datatype -------------------------- */
12127-
12128-typedef pthread_mutex_t gl_lock_t;
12129-# define gl_lock_define(STORAGECLASS, NAME) \
12130- STORAGECLASS pthread_mutex_t NAME;
12131-# define gl_lock_define_initialized(STORAGECLASS, NAME) \
12132- STORAGECLASS pthread_mutex_t NAME = gl_lock_initializer;
12133-# define gl_lock_initializer \
12134- PTHREAD_MUTEX_INITIALIZER
12135-# define gl_lock_init(NAME) \
12136- do \
12137- { \
12138- if (pthread_in_use () && pthread_mutex_init (&NAME, NULL) != 0) \
12139- abort (); \
12140- } \
12141- while (0)
12142-# define gl_lock_lock(NAME) \
12143- do \
12144- { \
12145- if (pthread_in_use () && pthread_mutex_lock (&NAME) != 0) \
12146- abort (); \
12147- } \
12148- while (0)
12149-# define gl_lock_unlock(NAME) \
12150- do \
12151- { \
12152- if (pthread_in_use () && pthread_mutex_unlock (&NAME) != 0) \
12153- abort (); \
12154- } \
12155- while (0)
12156-# define gl_lock_destroy(NAME) \
12157- do \
12158- { \
12159- if (pthread_in_use () && pthread_mutex_destroy (&NAME) != 0) \
12160- abort (); \
12161- } \
12162- while (0)
12163-
12164-/* ------------------------- gl_rwlock_t datatype ------------------------- */
12165-
12166-# if HAVE_PTHREAD_RWLOCK
12167-
12168-# ifdef PTHREAD_RWLOCK_INITIALIZER
12169-
12170-typedef pthread_rwlock_t gl_rwlock_t;
12171-# define gl_rwlock_define(STORAGECLASS, NAME) \
12172- STORAGECLASS pthread_rwlock_t NAME;
12173-# define gl_rwlock_define_initialized(STORAGECLASS, NAME) \
12174- STORAGECLASS pthread_rwlock_t NAME = gl_rwlock_initializer;
12175-# define gl_rwlock_initializer \
12176- PTHREAD_RWLOCK_INITIALIZER
12177-# define gl_rwlock_init(NAME) \
12178- do \
12179- { \
12180- if (pthread_in_use () && pthread_rwlock_init (&NAME, NULL) != 0) \
12181- abort (); \
12182- } \
12183- while (0)
12184-# define gl_rwlock_rdlock(NAME) \
12185- do \
12186- { \
12187- if (pthread_in_use () && pthread_rwlock_rdlock (&NAME) != 0) \
12188- abort (); \
12189- } \
12190- while (0)
12191-# define gl_rwlock_wrlock(NAME) \
12192- do \
12193- { \
12194- if (pthread_in_use () && pthread_rwlock_wrlock (&NAME) != 0) \
12195- abort (); \
12196- } \
12197- while (0)
12198-# define gl_rwlock_unlock(NAME) \
12199- do \
12200- { \
12201- if (pthread_in_use () && pthread_rwlock_unlock (&NAME) != 0) \
12202- abort (); \
12203- } \
12204- while (0)
12205-# define gl_rwlock_destroy(NAME) \
12206- do \
12207- { \
12208- if (pthread_in_use () && pthread_rwlock_destroy (&NAME) != 0) \
12209- abort (); \
12210- } \
12211- while (0)
12212-
12213-# else
12214-
12215-typedef struct
12216- {
12217- int initialized;
12218- pthread_mutex_t guard; /* protects the initialization */
12219- pthread_rwlock_t rwlock; /* read-write lock */
12220- }
12221- gl_rwlock_t;
12222-# define gl_rwlock_define(STORAGECLASS, NAME) \
12223- STORAGECLASS gl_rwlock_t NAME;
12224-# define gl_rwlock_define_initialized(STORAGECLASS, NAME) \
12225- STORAGECLASS gl_rwlock_t NAME = gl_rwlock_initializer;
12226-# define gl_rwlock_initializer \
12227- { 0, PTHREAD_MUTEX_INITIALIZER }
12228-# define gl_rwlock_init(NAME) \
12229- do \
12230- { \
12231- if (pthread_in_use ()) \
12232- glthread_rwlock_init (&NAME); \
12233- } \
12234- while (0)
12235-# define gl_rwlock_rdlock(NAME) \
12236- do \
12237- { \
12238- if (pthread_in_use ()) \
12239- glthread_rwlock_rdlock (&NAME); \
12240- } \
12241- while (0)
12242-# define gl_rwlock_wrlock(NAME) \
12243- do \
12244- { \
12245- if (pthread_in_use ()) \
12246- glthread_rwlock_wrlock (&NAME); \
12247- } \
12248- while (0)
12249-# define gl_rwlock_unlock(NAME) \
12250- do \
12251- { \
12252- if (pthread_in_use ()) \
12253- glthread_rwlock_unlock (&NAME); \
12254- } \
12255- while (0)
12256-# define gl_rwlock_destroy(NAME) \
12257- do \
12258- { \
12259- if (pthread_in_use ()) \
12260- glthread_rwlock_destroy (&NAME); \
12261- } \
12262- while (0)
12263-extern void glthread_rwlock_init (gl_rwlock_t *lock);
12264-extern void glthread_rwlock_rdlock (gl_rwlock_t *lock);
12265-extern void glthread_rwlock_wrlock (gl_rwlock_t *lock);
12266-extern void glthread_rwlock_unlock (gl_rwlock_t *lock);
12267-extern void glthread_rwlock_destroy (gl_rwlock_t *lock);
12268-
12269-# endif
12270-
12271-# else
12272-
12273-typedef struct
12274- {
12275- pthread_mutex_t lock; /* protects the remaining fields */
12276- pthread_cond_t waiting_readers; /* waiting readers */
12277- pthread_cond_t waiting_writers; /* waiting writers */
12278- unsigned int waiting_writers_count; /* number of waiting writers */
12279- int runcount; /* number of readers running, or -1 when a writer runs */
12280- }
12281- gl_rwlock_t;
12282-# define gl_rwlock_define(STORAGECLASS, NAME) \
12283- STORAGECLASS gl_rwlock_t NAME;
12284-# define gl_rwlock_define_initialized(STORAGECLASS, NAME) \
12285- STORAGECLASS gl_rwlock_t NAME = gl_rwlock_initializer;
12286-# define gl_rwlock_initializer \
12287- { PTHREAD_MUTEX_INITIALIZER, PTHREAD_COND_INITIALIZER, PTHREAD_COND_INITIALIZER, 0, 0 }
12288-# define gl_rwlock_init(NAME) \
12289- do \
12290- { \
12291- if (pthread_in_use ()) \
12292- glthread_rwlock_init (&NAME); \
12293- } \
12294- while (0)
12295-# define gl_rwlock_rdlock(NAME) \
12296- do \
12297- { \
12298- if (pthread_in_use ()) \
12299- glthread_rwlock_rdlock (&NAME); \
12300- } \
12301- while (0)
12302-# define gl_rwlock_wrlock(NAME) \
12303- do \
12304- { \
12305- if (pthread_in_use ()) \
12306- glthread_rwlock_wrlock (&NAME); \
12307- } \
12308- while (0)
12309-# define gl_rwlock_unlock(NAME) \
12310- do \
12311- { \
12312- if (pthread_in_use ()) \
12313- glthread_rwlock_unlock (&NAME); \
12314- } \
12315- while (0)
12316-# define gl_rwlock_destroy(NAME) \
12317- do \
12318- { \
12319- if (pthread_in_use ()) \
12320- glthread_rwlock_destroy (&NAME); \
12321- } \
12322- while (0)
12323-extern void glthread_rwlock_init (gl_rwlock_t *lock);
12324-extern void glthread_rwlock_rdlock (gl_rwlock_t *lock);
12325-extern void glthread_rwlock_wrlock (gl_rwlock_t *lock);
12326-extern void glthread_rwlock_unlock (gl_rwlock_t *lock);
12327-extern void glthread_rwlock_destroy (gl_rwlock_t *lock);
12328-
12329-# endif
12330-
12331-/* --------------------- gl_recursive_lock_t datatype --------------------- */
12332-
12333-# if HAVE_PTHREAD_MUTEX_RECURSIVE
12334-
12335-# if defined PTHREAD_RECURSIVE_MUTEX_INITIALIZER || defined PTHREAD_RECURSIVE_MUTEX_INITIALIZER_NP
12336-
12337-typedef pthread_mutex_t gl_recursive_lock_t;
12338-# define gl_recursive_lock_define(STORAGECLASS, NAME) \
12339- STORAGECLASS pthread_mutex_t NAME;
12340-# define gl_recursive_lock_define_initialized(STORAGECLASS, NAME) \
12341- STORAGECLASS pthread_mutex_t NAME = gl_recursive_lock_initializer;
12342-# ifdef PTHREAD_RECURSIVE_MUTEX_INITIALIZER
12343-# define gl_recursive_lock_initializer \
12344- PTHREAD_RECURSIVE_MUTEX_INITIALIZER
12345-# else
12346-# define gl_recursive_lock_initializer \
12347- PTHREAD_RECURSIVE_MUTEX_INITIALIZER_NP
12348-# endif
12349-# define gl_recursive_lock_init(NAME) \
12350- do \
12351- { \
12352- if (pthread_in_use () && pthread_mutex_init (&NAME, NULL) != 0) \
12353- abort (); \
12354- } \
12355- while (0)
12356-# define gl_recursive_lock_lock(NAME) \
12357- do \
12358- { \
12359- if (pthread_in_use () && pthread_mutex_lock (&NAME) != 0) \
12360- abort (); \
12361- } \
12362- while (0)
12363-# define gl_recursive_lock_unlock(NAME) \
12364- do \
12365- { \
12366- if (pthread_in_use () && pthread_mutex_unlock (&NAME) != 0) \
12367- abort (); \
12368- } \
12369- while (0)
12370-# define gl_recursive_lock_destroy(NAME) \
12371- do \
12372- { \
12373- if (pthread_in_use () && pthread_mutex_destroy (&NAME) != 0) \
12374- abort (); \
12375- } \
12376- while (0)
12377-
12378-# else
12379-
12380-typedef struct
12381- {
12382- pthread_mutex_t recmutex; /* recursive mutex */
12383- pthread_mutex_t guard; /* protects the initialization */
12384- int initialized;
12385- }
12386- gl_recursive_lock_t;
12387-# define gl_recursive_lock_define(STORAGECLASS, NAME) \
12388- STORAGECLASS gl_recursive_lock_t NAME;
12389-# define gl_recursive_lock_define_initialized(STORAGECLASS, NAME) \
12390- STORAGECLASS gl_recursive_lock_t NAME = gl_recursive_lock_initializer;
12391-# define gl_recursive_lock_initializer \
12392- { PTHREAD_MUTEX_INITIALIZER, PTHREAD_MUTEX_INITIALIZER, 0 }
12393-# define gl_recursive_lock_init(NAME) \
12394- do \
12395- { \
12396- if (pthread_in_use ()) \
12397- glthread_recursive_lock_init (&NAME); \
12398- } \
12399- while (0)
12400-# define gl_recursive_lock_lock(NAME) \
12401- do \
12402- { \
12403- if (pthread_in_use ()) \
12404- glthread_recursive_lock_lock (&NAME); \
12405- } \
12406- while (0)
12407-# define gl_recursive_lock_unlock(NAME) \
12408- do \
12409- { \
12410- if (pthread_in_use ()) \
12411- glthread_recursive_lock_unlock (&NAME); \
12412- } \
12413- while (0)
12414-# define gl_recursive_lock_destroy(NAME) \
12415- do \
12416- { \
12417- if (pthread_in_use ()) \
12418- glthread_recursive_lock_destroy (&NAME); \
12419- } \
12420- while (0)
12421-extern void glthread_recursive_lock_init (gl_recursive_lock_t *lock);
12422-extern void glthread_recursive_lock_lock (gl_recursive_lock_t *lock);
12423-extern void glthread_recursive_lock_unlock (gl_recursive_lock_t *lock);
12424-extern void glthread_recursive_lock_destroy (gl_recursive_lock_t *lock);
12425-
12426-# endif
12427-
12428-# else
12429-
12430-/* Old versions of POSIX threads on Solaris did not have recursive locks.
12431- We have to implement them ourselves. */
12432-
12433-typedef struct
12434- {
12435- pthread_mutex_t mutex;
12436- pthread_t owner;
12437- unsigned long depth;
12438- }
12439- gl_recursive_lock_t;
12440-# define gl_recursive_lock_define(STORAGECLASS, NAME) \
12441- STORAGECLASS gl_recursive_lock_t NAME;
12442-# define gl_recursive_lock_define_initialized(STORAGECLASS, NAME) \
12443- STORAGECLASS gl_recursive_lock_t NAME = gl_recursive_lock_initializer;
12444-# define gl_recursive_lock_initializer \
12445- { PTHREAD_MUTEX_INITIALIZER, (pthread_t) 0, 0 }
12446-# define gl_recursive_lock_init(NAME) \
12447- do \
12448- { \
12449- if (pthread_in_use ()) \
12450- glthread_recursive_lock_init (&NAME); \
12451- } \
12452- while (0)
12453-# define gl_recursive_lock_lock(NAME) \
12454- do \
12455- { \
12456- if (pthread_in_use ()) \
12457- glthread_recursive_lock_lock (&NAME); \
12458- } \
12459- while (0)
12460-# define gl_recursive_lock_unlock(NAME) \
12461- do \
12462- { \
12463- if (pthread_in_use ()) \
12464- glthread_recursive_lock_unlock (&NAME); \
12465- } \
12466- while (0)
12467-# define gl_recursive_lock_destroy(NAME) \
12468- do \
12469- { \
12470- if (pthread_in_use ()) \
12471- glthread_recursive_lock_destroy (&NAME); \
12472- } \
12473- while (0)
12474-extern void glthread_recursive_lock_init (gl_recursive_lock_t *lock);
12475-extern void glthread_recursive_lock_lock (gl_recursive_lock_t *lock);
12476-extern void glthread_recursive_lock_unlock (gl_recursive_lock_t *lock);
12477-extern void glthread_recursive_lock_destroy (gl_recursive_lock_t *lock);
12478-
12479-# endif
12480-
12481-/* -------------------------- gl_once_t datatype -------------------------- */
12482-
12483-typedef pthread_once_t gl_once_t;
12484-# define gl_once_define(STORAGECLASS, NAME) \
12485- STORAGECLASS pthread_once_t NAME = PTHREAD_ONCE_INIT;
12486-# define gl_once(NAME, INITFUNCTION) \
12487- do \
12488- { \
12489- if (pthread_in_use ()) \
12490- { \
12491- if (pthread_once (&NAME, INITFUNCTION) != 0) \
12492- abort (); \
12493- } \
12494- else \
12495- { \
12496- if (glthread_once_singlethreaded (&NAME)) \
12497- INITFUNCTION (); \
12498- } \
12499- } \
12500- while (0)
12501-extern int glthread_once_singlethreaded (pthread_once_t *once_control);
12502-
12503-# ifdef __cplusplus
12504-}
12505-# endif
12506-
12507-#endif
12508-
12509-/* ========================================================================= */
12510-
12511-#if USE_PTH_THREADS
12512-
12513-/* Use the GNU Pth threads library. */
12514-
12515-# include <pth.h>
12516-# include <stdlib.h>
12517-
12518-# ifdef __cplusplus
12519-extern "C" {
12520-# endif
12521-
12522-# if USE_PTH_THREADS_WEAK
12523-
12524-/* Use weak references to the GNU Pth threads library. */
12525-
12526-# pragma weak pth_mutex_init
12527-# pragma weak pth_mutex_acquire
12528-# pragma weak pth_mutex_release
12529-# pragma weak pth_rwlock_init
12530-# pragma weak pth_rwlock_acquire
12531-# pragma weak pth_rwlock_release
12532-# pragma weak pth_once
12533-
12534-# pragma weak pth_cancel
12535-# define pth_in_use() (pth_cancel != NULL)
12536-
12537-# else
12538-
12539-# define pth_in_use() 1
12540-
12541-# endif
12542-
12543-/* -------------------------- gl_lock_t datatype -------------------------- */
12544-
12545-typedef pth_mutex_t gl_lock_t;
12546-# define gl_lock_define(STORAGECLASS, NAME) \
12547- STORAGECLASS pth_mutex_t NAME;
12548-# define gl_lock_define_initialized(STORAGECLASS, NAME) \
12549- STORAGECLASS pth_mutex_t NAME = gl_lock_initializer;
12550-# define gl_lock_initializer \
12551- PTH_MUTEX_INIT
12552-# define gl_lock_init(NAME) \
12553- do \
12554- { \
12555- if (pth_in_use() && !pth_mutex_init (&NAME)) \
12556- abort (); \
12557- } \
12558- while (0)
12559-# define gl_lock_lock(NAME) \
12560- do \
12561- { \
12562- if (pth_in_use() && !pth_mutex_acquire (&NAME, 0, NULL)) \
12563- abort (); \
12564- } \
12565- while (0)
12566-# define gl_lock_unlock(NAME) \
12567- do \
12568- { \
12569- if (pth_in_use() && !pth_mutex_release (&NAME)) \
12570- abort (); \
12571- } \
12572- while (0)
12573-# define gl_lock_destroy(NAME) \
12574- (void)(&NAME)
12575-
12576-/* ------------------------- gl_rwlock_t datatype ------------------------- */
12577-
12578-typedef pth_rwlock_t gl_rwlock_t;
12579-# define gl_rwlock_define(STORAGECLASS, NAME) \
12580- STORAGECLASS pth_rwlock_t NAME;
12581-# define gl_rwlock_define_initialized(STORAGECLASS, NAME) \
12582- STORAGECLASS pth_rwlock_t NAME = gl_rwlock_initializer;
12583-# define gl_rwlock_initializer \
12584- PTH_RWLOCK_INIT
12585-# define gl_rwlock_init(NAME) \
12586- do \
12587- { \
12588- if (pth_in_use() && !pth_rwlock_init (&NAME)) \
12589- abort (); \
12590- } \
12591- while (0)
12592-# define gl_rwlock_rdlock(NAME) \
12593- do \
12594- { \
12595- if (pth_in_use() \
12596- && !pth_rwlock_acquire (&NAME, PTH_RWLOCK_RD, 0, NULL)) \
12597- abort (); \
12598- } \
12599- while (0)
12600-# define gl_rwlock_wrlock(NAME) \
12601- do \
12602- { \
12603- if (pth_in_use() \
12604- && !pth_rwlock_acquire (&NAME, PTH_RWLOCK_RW, 0, NULL)) \
12605- abort (); \
12606- } \
12607- while (0)
12608-# define gl_rwlock_unlock(NAME) \
12609- do \
12610- { \
12611- if (pth_in_use() && !pth_rwlock_release (&NAME)) \
12612- abort (); \
12613- } \
12614- while (0)
12615-# define gl_rwlock_destroy(NAME) \
12616- (void)(&NAME)
12617-
12618-/* --------------------- gl_recursive_lock_t datatype --------------------- */
12619-
12620-/* In Pth, mutexes are recursive by default. */
12621-typedef pth_mutex_t gl_recursive_lock_t;
12622-# define gl_recursive_lock_define(STORAGECLASS, NAME) \
12623- STORAGECLASS pth_mutex_t NAME;
12624-# define gl_recursive_lock_define_initialized(STORAGECLASS, NAME) \
12625- STORAGECLASS pth_mutex_t NAME = gl_recursive_lock_initializer;
12626-# define gl_recursive_lock_initializer \
12627- PTH_MUTEX_INIT
12628-# define gl_recursive_lock_init(NAME) \
12629- do \
12630- { \
12631- if (pth_in_use() && !pth_mutex_init (&NAME)) \
12632- abort (); \
12633- } \
12634- while (0)
12635-# define gl_recursive_lock_lock(NAME) \
12636- do \
12637- { \
12638- if (pth_in_use() && !pth_mutex_acquire (&NAME, 0, NULL)) \
12639- abort (); \
12640- } \
12641- while (0)
12642-# define gl_recursive_lock_unlock(NAME) \
12643- do \
12644- { \
12645- if (pth_in_use() && !pth_mutex_release (&NAME)) \
12646- abort (); \
12647- } \
12648- while (0)
12649-# define gl_recursive_lock_destroy(NAME) \
12650- (void)(&NAME)
12651-
12652-/* -------------------------- gl_once_t datatype -------------------------- */
12653-
12654-typedef pth_once_t gl_once_t;
12655-# define gl_once_define(STORAGECLASS, NAME) \
12656- STORAGECLASS pth_once_t NAME = PTH_ONCE_INIT;
12657-# define gl_once(NAME, INITFUNCTION) \
12658- do \
12659- { \
12660- if (pth_in_use ()) \
12661- { \
12662- void (*gl_once_temp) (void) = INITFUNCTION; \
12663- if (!pth_once (&NAME, glthread_once_call, &gl_once_temp)) \
12664- abort (); \
12665- } \
12666- else \
12667- { \
12668- if (glthread_once_singlethreaded (&NAME)) \
12669- INITFUNCTION (); \
12670- } \
12671- } \
12672- while (0)
12673-extern void glthread_once_call (void *arg);
12674-extern int glthread_once_singlethreaded (pth_once_t *once_control);
12675-
12676-# ifdef __cplusplus
12677-}
12678-# endif
12679-
12680-#endif
12681-
12682-/* ========================================================================= */
12683-
12684-#if USE_SOLARIS_THREADS
12685-
12686-/* Use the old Solaris threads library. */
12687-
12688-# include <thread.h>
12689-# include <synch.h>
12690-# include <stdlib.h>
12691-
12692-# ifdef __cplusplus
12693-extern "C" {
12694-# endif
12695-
12696-# if USE_SOLARIS_THREADS_WEAK
12697-
12698-/* Use weak references to the old Solaris threads library. */
12699-
12700-# pragma weak mutex_init
12701-# pragma weak mutex_lock
12702-# pragma weak mutex_unlock
12703-# pragma weak mutex_destroy
12704-# pragma weak rwlock_init
12705-# pragma weak rw_rdlock
12706-# pragma weak rw_wrlock
12707-# pragma weak rw_unlock
12708-# pragma weak rwlock_destroy
12709-# pragma weak thr_self
12710-
12711-# pragma weak thr_suspend
12712-# define thread_in_use() (thr_suspend != NULL)
12713-
12714-# else
12715-
12716-# define thread_in_use() 1
12717-
12718-# endif
12719-
12720-/* -------------------------- gl_lock_t datatype -------------------------- */
12721-
12722-typedef mutex_t gl_lock_t;
12723-# define gl_lock_define(STORAGECLASS, NAME) \
12724- STORAGECLASS mutex_t NAME;
12725-# define gl_lock_define_initialized(STORAGECLASS, NAME) \
12726- STORAGECLASS mutex_t NAME = gl_lock_initializer;
12727-# define gl_lock_initializer \
12728- DEFAULTMUTEX
12729-# define gl_lock_init(NAME) \
12730- do \
12731- { \
12732- if (thread_in_use () && mutex_init (&NAME, USYNC_THREAD, NULL) != 0) \
12733- abort (); \
12734- } \
12735- while (0)
12736-# define gl_lock_lock(NAME) \
12737- do \
12738- { \
12739- if (thread_in_use () && mutex_lock (&NAME) != 0) \
12740- abort (); \
12741- } \
12742- while (0)
12743-# define gl_lock_unlock(NAME) \
12744- do \
12745- { \
12746- if (thread_in_use () && mutex_unlock (&NAME) != 0) \
12747- abort (); \
12748- } \
12749- while (0)
12750-# define gl_lock_destroy(NAME) \
12751- do \
12752- { \
12753- if (thread_in_use () && mutex_destroy (&NAME) != 0) \
12754- abort (); \
12755- } \
12756- while (0)
12757-
12758-/* ------------------------- gl_rwlock_t datatype ------------------------- */
12759-
12760-typedef rwlock_t gl_rwlock_t;
12761-# define gl_rwlock_define(STORAGECLASS, NAME) \
12762- STORAGECLASS rwlock_t NAME;
12763-# define gl_rwlock_define_initialized(STORAGECLASS, NAME) \
12764- STORAGECLASS rwlock_t NAME = gl_rwlock_initializer;
12765-# define gl_rwlock_initializer \
12766- DEFAULTRWLOCK
12767-# define gl_rwlock_init(NAME) \
12768- do \
12769- { \
12770- if (thread_in_use () && rwlock_init (&NAME, USYNC_THREAD, NULL) != 0) \
12771- abort (); \
12772- } \
12773- while (0)
12774-# define gl_rwlock_rdlock(NAME) \
12775- do \
12776- { \
12777- if (thread_in_use () && rw_rdlock (&NAME) != 0) \
12778- abort (); \
12779- } \
12780- while (0)
12781-# define gl_rwlock_wrlock(NAME) \
12782- do \
12783- { \
12784- if (thread_in_use () && rw_wrlock (&NAME) != 0) \
12785- abort (); \
12786- } \
12787- while (0)
12788-# define gl_rwlock_unlock(NAME) \
12789- do \
12790- { \
12791- if (thread_in_use () && rw_unlock (&NAME) != 0) \
12792- abort (); \
12793- } \
12794- while (0)
12795-# define gl_rwlock_destroy(NAME) \
12796- do \
12797- { \
12798- if (thread_in_use () && rwlock_destroy (&NAME) != 0) \
12799- abort (); \
12800- } \
12801- while (0)
12802-
12803-/* --------------------- gl_recursive_lock_t datatype --------------------- */
12804-
12805-/* Old Solaris threads did not have recursive locks.
12806- We have to implement them ourselves. */
12807-
12808-typedef struct
12809- {
12810- mutex_t mutex;
12811- thread_t owner;
12812- unsigned long depth;
12813- }
12814- gl_recursive_lock_t;
12815-# define gl_recursive_lock_define(STORAGECLASS, NAME) \
12816- STORAGECLASS gl_recursive_lock_t NAME;
12817-# define gl_recursive_lock_define_initialized(STORAGECLASS, NAME) \
12818- STORAGECLASS gl_recursive_lock_t NAME = gl_recursive_lock_initializer;
12819-# define gl_recursive_lock_initializer \
12820- { DEFAULTMUTEX, (thread_t) 0, 0 }
12821-# define gl_recursive_lock_init(NAME) \
12822- do \
12823- { \
12824- if (thread_in_use ()) \
12825- glthread_recursive_lock_init (&NAME); \
12826- } \
12827- while (0)
12828-# define gl_recursive_lock_lock(NAME) \
12829- do \
12830- { \
12831- if (thread_in_use ()) \
12832- glthread_recursive_lock_lock (&NAME); \
12833- } \
12834- while (0)
12835-# define gl_recursive_lock_unlock(NAME) \
12836- do \
12837- { \
12838- if (thread_in_use ()) \
12839- glthread_recursive_lock_unlock (&NAME); \
12840- } \
12841- while (0)
12842-# define gl_recursive_lock_destroy(NAME) \
12843- do \
12844- { \
12845- if (thread_in_use ()) \
12846- glthread_recursive_lock_destroy (&NAME); \
12847- } \
12848- while (0)
12849-extern void glthread_recursive_lock_init (gl_recursive_lock_t *lock);
12850-extern void glthread_recursive_lock_lock (gl_recursive_lock_t *lock);
12851-extern void glthread_recursive_lock_unlock (gl_recursive_lock_t *lock);
12852-extern void glthread_recursive_lock_destroy (gl_recursive_lock_t *lock);
12853-
12854-/* -------------------------- gl_once_t datatype -------------------------- */
12855-
12856-typedef struct
12857- {
12858- volatile int inited;
12859- mutex_t mutex;
12860- }
12861- gl_once_t;
12862-# define gl_once_define(STORAGECLASS, NAME) \
12863- STORAGECLASS gl_once_t NAME = { 0, DEFAULTMUTEX };
12864-# define gl_once(NAME, INITFUNCTION) \
12865- do \
12866- { \
12867- if (thread_in_use ()) \
12868- { \
12869- glthread_once (&NAME, INITFUNCTION); \
12870- } \
12871- else \
12872- { \
12873- if (glthread_once_singlethreaded (&NAME)) \
12874- INITFUNCTION (); \
12875- } \
12876- } \
12877- while (0)
12878-extern void glthread_once (gl_once_t *once_control, void (*initfunction) (void));
12879-extern int glthread_once_singlethreaded (gl_once_t *once_control);
12880-
12881-# ifdef __cplusplus
12882-}
12883-# endif
12884-
12885-#endif
12886-
12887-/* ========================================================================= */
12888-
12889-#if USE_WIN32_THREADS
12890-
12891-# include <windows.h>
12892-
12893-# ifdef __cplusplus
12894-extern "C" {
12895-# endif
12896-
12897-/* We can use CRITICAL_SECTION directly, rather than the Win32 Event, Mutex,
12898- Semaphore types, because
12899- - we need only to synchronize inside a single process (address space),
12900- not inter-process locking,
12901- - we don't need to support trylock operations. (TryEnterCriticalSection
12902- does not work on Windows 95/98/ME. Packages that need trylock usually
12903- define their own mutex type.) */
12904-
12905-/* There is no way to statically initialize a CRITICAL_SECTION. It needs
12906- to be done lazily, once only. For this we need spinlocks. */
12907-
12908-typedef struct { volatile int done; volatile long started; } gl_spinlock_t;
12909-
12910-/* -------------------------- gl_lock_t datatype -------------------------- */
12911-
12912-typedef struct
12913- {
12914- gl_spinlock_t guard; /* protects the initialization */
12915- CRITICAL_SECTION lock;
12916- }
12917- gl_lock_t;
12918-# define gl_lock_define(STORAGECLASS, NAME) \
12919- STORAGECLASS gl_lock_t NAME;
12920-# define gl_lock_define_initialized(STORAGECLASS, NAME) \
12921- STORAGECLASS gl_lock_t NAME = gl_lock_initializer;
12922-# define gl_lock_initializer \
12923- { { 0, -1 } }
12924-# define gl_lock_init(NAME) \
12925- glthread_lock_init (&NAME)
12926-# define gl_lock_lock(NAME) \
12927- glthread_lock_lock (&NAME)
12928-# define gl_lock_unlock(NAME) \
12929- glthread_lock_unlock (&NAME)
12930-# define gl_lock_destroy(NAME) \
12931- glthread_lock_destroy (&NAME)
12932-extern void glthread_lock_init (gl_lock_t *lock);
12933-extern void glthread_lock_lock (gl_lock_t *lock);
12934-extern void glthread_lock_unlock (gl_lock_t *lock);
12935-extern void glthread_lock_destroy (gl_lock_t *lock);
12936-
12937-/* ------------------------- gl_rwlock_t datatype ------------------------- */
12938-
12939-/* It is impossible to implement read-write locks using plain locks, without
12940- introducing an extra thread dedicated to managing read-write locks.
12941- Therefore here we need to use the low-level Event type. */
12942-
12943-typedef struct
12944- {
12945- HANDLE *array; /* array of waiting threads, each represented by an event */
12946- unsigned int count; /* number of waiting threads */
12947- unsigned int alloc; /* length of allocated array */
12948- unsigned int offset; /* index of first waiting thread in array */
12949- }
12950- gl_waitqueue_t;
12951-typedef struct
12952- {
12953- gl_spinlock_t guard; /* protects the initialization */
12954- CRITICAL_SECTION lock; /* protects the remaining fields */
12955- gl_waitqueue_t waiting_readers; /* waiting readers */
12956- gl_waitqueue_t waiting_writers; /* waiting writers */
12957- int runcount; /* number of readers running, or -1 when a writer runs */
12958- }
12959- gl_rwlock_t;
12960-# define gl_rwlock_define(STORAGECLASS, NAME) \
12961- STORAGECLASS gl_rwlock_t NAME;
12962-# define gl_rwlock_define_initialized(STORAGECLASS, NAME) \
12963- STORAGECLASS gl_rwlock_t NAME = gl_rwlock_initializer;
12964-# define gl_rwlock_initializer \
12965- { { 0, -1 } }
12966-# define gl_rwlock_init(NAME) \
12967- glthread_rwlock_init (&NAME)
12968-# define gl_rwlock_rdlock(NAME) \
12969- glthread_rwlock_rdlock (&NAME)
12970-# define gl_rwlock_wrlock(NAME) \
12971- glthread_rwlock_wrlock (&NAME)
12972-# define gl_rwlock_unlock(NAME) \
12973- glthread_rwlock_unlock (&NAME)
12974-# define gl_rwlock_destroy(NAME) \
12975- glthread_rwlock_destroy (&NAME)
12976-extern void glthread_rwlock_init (gl_rwlock_t *lock);
12977-extern void glthread_rwlock_rdlock (gl_rwlock_t *lock);
12978-extern void glthread_rwlock_wrlock (gl_rwlock_t *lock);
12979-extern void glthread_rwlock_unlock (gl_rwlock_t *lock);
12980-extern void glthread_rwlock_destroy (gl_rwlock_t *lock);
12981-
12982-/* --------------------- gl_recursive_lock_t datatype --------------------- */
12983-
12984-/* The Win32 documentation says that CRITICAL_SECTION already implements a
12985- recursive lock. But we need not rely on it: It's easy to implement a
12986- recursive lock without this assumption. */
12987-
12988-typedef struct
12989- {
12990- gl_spinlock_t guard; /* protects the initialization */
12991- DWORD owner;
12992- unsigned long depth;
12993- CRITICAL_SECTION lock;
12994- }
12995- gl_recursive_lock_t;
12996-# define gl_recursive_lock_define(STORAGECLASS, NAME) \
12997- STORAGECLASS gl_recursive_lock_t NAME;
12998-# define gl_recursive_lock_define_initialized(STORAGECLASS, NAME) \
12999- STORAGECLASS gl_recursive_lock_t NAME = gl_recursive_lock_initializer;
13000-# define gl_recursive_lock_initializer \
13001- { { 0, -1 }, 0, 0 }
13002-# define gl_recursive_lock_init(NAME) \
13003- glthread_recursive_lock_init (&NAME)
13004-# define gl_recursive_lock_lock(NAME) \
13005- glthread_recursive_lock_lock (&NAME)
13006-# define gl_recursive_lock_unlock(NAME) \
13007- glthread_recursive_lock_unlock (&NAME)
13008-# define gl_recursive_lock_destroy(NAME) \
13009- glthread_recursive_lock_destroy (&NAME)
13010-extern void glthread_recursive_lock_init (gl_recursive_lock_t *lock);
13011-extern void glthread_recursive_lock_lock (gl_recursive_lock_t *lock);
13012-extern void glthread_recursive_lock_unlock (gl_recursive_lock_t *lock);
13013-extern void glthread_recursive_lock_destroy (gl_recursive_lock_t *lock);
13014-
13015-/* -------------------------- gl_once_t datatype -------------------------- */
13016-
13017-typedef struct
13018- {
13019- volatile int inited;
13020- volatile long started;
13021- CRITICAL_SECTION lock;
13022- }
13023- gl_once_t;
13024-# define gl_once_define(STORAGECLASS, NAME) \
13025- STORAGECLASS gl_once_t NAME = { -1, -1 };
13026-# define gl_once(NAME, INITFUNCTION) \
13027- glthread_once (&NAME, INITFUNCTION)
13028-extern void glthread_once (gl_once_t *once_control, void (*initfunction) (void));
13029-
13030-# ifdef __cplusplus
13031-}
13032-# endif
13033-
13034-#endif
13035-
13036-/* ========================================================================= */
13037-
13038-#if !(USE_POSIX_THREADS || USE_PTH_THREADS || USE_SOLARIS_THREADS || USE_WIN32_THREADS)
13039-
13040-/* Provide dummy implementation if threads are not supported. */
13041-
13042-/* -------------------------- gl_lock_t datatype -------------------------- */
13043-
13044-typedef int gl_lock_t;
13045-# define gl_lock_define(STORAGECLASS, NAME)
13046-# define gl_lock_define_initialized(STORAGECLASS, NAME)
13047-# define gl_lock_init(NAME)
13048-# define gl_lock_lock(NAME)
13049-# define gl_lock_unlock(NAME)
13050-
13051-/* ------------------------- gl_rwlock_t datatype ------------------------- */
13052-
13053-typedef int gl_rwlock_t;
13054-# define gl_rwlock_define(STORAGECLASS, NAME)
13055-# define gl_rwlock_define_initialized(STORAGECLASS, NAME)
13056-# define gl_rwlock_init(NAME)
13057-# define gl_rwlock_rdlock(NAME)
13058-# define gl_rwlock_wrlock(NAME)
13059-# define gl_rwlock_unlock(NAME)
13060-
13061-/* --------------------- gl_recursive_lock_t datatype --------------------- */
13062-
13063-typedef int gl_recursive_lock_t;
13064-# define gl_recursive_lock_define(STORAGECLASS, NAME)
13065-# define gl_recursive_lock_define_initialized(STORAGECLASS, NAME)
13066-# define gl_recursive_lock_init(NAME)
13067-# define gl_recursive_lock_lock(NAME)
13068-# define gl_recursive_lock_unlock(NAME)
13069-
13070-/* -------------------------- gl_once_t datatype -------------------------- */
13071-
13072-typedef int gl_once_t;
13073-# define gl_once_define(STORAGECLASS, NAME) \
13074- STORAGECLASS gl_once_t NAME = 0;
13075-# define gl_once(NAME, INITFUNCTION) \
13076- do \
13077- { \
13078- if (NAME == 0) \
13079- { \
13080- NAME = ~ 0; \
13081- INITFUNCTION (); \
13082- } \
13083- } \
13084- while (0)
13085-
13086-#endif
13087-
13088-/* ========================================================================= */
13089-
13090-#endif /* _LOCK_H */
13091--- a/intl/log.c
13092+++ /dev/null
13093@@ -1,116 +0,0 @@
13094-/* Log file output.
13095- Copyright (C) 2003, 2005 Free Software Foundation, Inc.
13096-
13097- This program is free software; you can redistribute it and/or modify it
13098- under the terms of the GNU Library General Public License as published
13099- by the Free Software Foundation; either version 2, or (at your option)
13100- any later version.
13101-
13102- This program is distributed in the hope that it will be useful,
13103- but WITHOUT ANY WARRANTY; without even the implied warranty of
13104- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13105- Library General Public License for more details.
13106-
13107- You should have received a copy of the GNU Library General Public
13108- License along with this program; if not, write to the Free Software
13109- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
13110- USA. */
13111-
13112-/* Written by Bruno Haible <bruno@clisp.org>. */
13113-
13114-#ifdef HAVE_CONFIG_H
13115-# include <config.h>
13116-#endif
13117-
13118-#include <stdio.h>
13119-#include <stdlib.h>
13120-#include <string.h>
13121-
13122-/* Handle multi-threaded applications. */
13123-#ifdef _LIBC
13124-# include <bits/libc-lock.h>
13125-#else
13126-# include "lock.h"
13127-#endif
13128-
13129-/* Print an ASCII string with quotes and escape sequences where needed. */
13130-static void
13131-print_escaped (FILE *stream, const char *str)
13132-{
13133- putc ('"', stream);
13134- for (; *str != '\0'; str++)
13135- if (*str == '\n')
13136- {
13137- fputs ("\\n\"", stream);
13138- if (str[1] == '\0')
13139- return;
13140- fputs ("\n\"", stream);
13141- }
13142- else
13143- {
13144- if (*str == '"' || *str == '\\')
13145- putc ('\\', stream);
13146- putc (*str, stream);
13147- }
13148- putc ('"', stream);
13149-}
13150-
13151-static char *last_logfilename = NULL;
13152-static FILE *last_logfile = NULL;
13153-__libc_lock_define_initialized (static, lock)
13154-
13155-static inline void
13156-_nl_log_untranslated_locked (const char *logfilename, const char *domainname,
13157- const char *msgid1, const char *msgid2, int plural)
13158-{
13159- FILE *logfile;
13160-
13161- /* Can we reuse the last opened logfile? */
13162- if (last_logfilename == NULL || strcmp (logfilename, last_logfilename) != 0)
13163- {
13164- /* Close the last used logfile. */
13165- if (last_logfilename != NULL)
13166- {
13167- if (last_logfile != NULL)
13168- {
13169- fclose (last_logfile);
13170- last_logfile = NULL;
13171- }
13172- free (last_logfilename);
13173- last_logfilename = NULL;
13174- }
13175- /* Open the logfile. */
13176- last_logfilename = (char *) malloc (strlen (logfilename) + 1);
13177- if (last_logfilename == NULL)
13178- return;
13179- strcpy (last_logfilename, logfilename);
13180- last_logfile = fopen (logfilename, "a");
13181- if (last_logfile == NULL)
13182- return;
13183- }
13184- logfile = last_logfile;
13185-
13186- fprintf (logfile, "domain ");
13187- print_escaped (logfile, domainname);
13188- fprintf (logfile, "\nmsgid ");
13189- print_escaped (logfile, msgid1);
13190- if (plural)
13191- {
13192- fprintf (logfile, "\nmsgid_plural ");
13193- print_escaped (logfile, msgid2);
13194- fprintf (logfile, "\nmsgstr[0] \"\"\n");
13195- }
13196- else
13197- fprintf (logfile, "\nmsgstr \"\"\n");
13198- putc ('\n', logfile);
13199-}
13200-
13201-/* Add to the log file an entry denoting a failed translation. */
13202-void
13203-_nl_log_untranslated (const char *logfilename, const char *domainname,
13204- const char *msgid1, const char *msgid2, int plural)
13205-{
13206- __libc_lock_lock (lock);
13207- _nl_log_untranslated_locked (logfilename, domainname, msgid1, msgid2, plural);
13208- __libc_lock_unlock (lock);
13209-}
13210--- a/intl/ngettext.c
13211+++ /dev/null
13212@@ -1,65 +0,0 @@
13213-/* Implementation of ngettext(3) function.
13214- Copyright (C) 1995, 1997, 2000-2003 Free Software Foundation, Inc.
13215-
13216- This program is free software; you can redistribute it and/or modify it
13217- under the terms of the GNU Library General Public License as published
13218- by the Free Software Foundation; either version 2, or (at your option)
13219- any later version.
13220-
13221- This program is distributed in the hope that it will be useful,
13222- but WITHOUT ANY WARRANTY; without even the implied warranty of
13223- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13224- Library General Public License for more details.
13225-
13226- You should have received a copy of the GNU Library General Public
13227- License along with this program; if not, write to the Free Software
13228- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
13229- USA. */
13230-
13231-#ifdef HAVE_CONFIG_H
13232-# include <config.h>
13233-#endif
13234-
13235-#ifdef _LIBC
13236-# define __need_NULL
13237-# include <stddef.h>
13238-#else
13239-# include <stdlib.h> /* Just for NULL. */
13240-#endif
13241-
13242-#include "gettextP.h"
13243-#ifdef _LIBC
13244-# include <libintl.h>
13245-#else
13246-# include "libgnuintl.h"
13247-#endif
13248-
13249-#include <locale.h>
13250-
13251-/* @@ end of prolog @@ */
13252-
13253-/* Names for the libintl functions are a problem. They must not clash
13254- with existing names and they should follow ANSI C. But this source
13255- code is also used in GNU C Library where the names have a __
13256- prefix. So we have to make a difference here. */
13257-#ifdef _LIBC
13258-# define NGETTEXT __ngettext
13259-# define DCNGETTEXT __dcngettext
13260-#else
13261-# define NGETTEXT libintl_ngettext
13262-# define DCNGETTEXT libintl_dcngettext
13263-#endif
13264-
13265-/* Look up MSGID in the current default message catalog for the current
13266- LC_MESSAGES locale. If not found, returns MSGID itself (the default
13267- text). */
13268-char *
13269-NGETTEXT (const char *msgid1, const char *msgid2, unsigned long int n)
13270-{
13271- return DCNGETTEXT (NULL, msgid1, msgid2, n, LC_MESSAGES);
13272-}
13273-
13274-#ifdef _LIBC
13275-/* Alias for function name in GNU C Library. */
13276-weak_alias (__ngettext, ngettext);
13277-#endif
13278--- a/intl/os2compat.c
13279+++ /dev/null
13280@@ -1,98 +0,0 @@
13281-/* OS/2 compatibility functions.
13282- Copyright (C) 2001-2002 Free Software Foundation, Inc.
13283-
13284- This program is free software; you can redistribute it and/or modify it
13285- under the terms of the GNU Library General Public License as published
13286- by the Free Software Foundation; either version 2, or (at your option)
13287- any later version.
13288-
13289- This program is distributed in the hope that it will be useful,
13290- but WITHOUT ANY WARRANTY; without even the implied warranty of
13291- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13292- Library General Public License for more details.
13293-
13294- You should have received a copy of the GNU Library General Public
13295- License along with this program; if not, write to the Free Software
13296- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
13297- USA. */
13298-
13299-#define OS2_AWARE
13300-#ifdef HAVE_CONFIG_H
13301-#include <config.h>
13302-#endif
13303-
13304-#include <stdlib.h>
13305-#include <string.h>
13306-#include <sys/param.h>
13307-
13308-/* A version of getenv() that works from DLLs */
13309-extern unsigned long DosScanEnv (const unsigned char *pszName, unsigned char **ppszValue);
13310-
13311-char *
13312-_nl_getenv (const char *name)
13313-{
13314- unsigned char *value;
13315- if (DosScanEnv (name, &value))
13316- return NULL;
13317- else
13318- return value;
13319-}
13320-
13321-/* A fixed size buffer. */
13322-char libintl_nl_default_dirname[MAXPATHLEN+1];
13323-
13324-char *_nlos2_libdir = NULL;
13325-char *_nlos2_localealiaspath = NULL;
13326-char *_nlos2_localedir = NULL;
13327-
13328-static __attribute__((constructor)) void
13329-nlos2_initialize ()
13330-{
13331- char *root = getenv ("UNIXROOT");
13332- char *gnulocaledir = getenv ("GNULOCALEDIR");
13333-
13334- _nlos2_libdir = gnulocaledir;
13335- if (!_nlos2_libdir)
13336- {
13337- if (root)
13338- {
13339- size_t sl = strlen (root);
13340- _nlos2_libdir = (char *) malloc (sl + strlen (LIBDIR) + 1);
13341- memcpy (_nlos2_libdir, root, sl);
13342- memcpy (_nlos2_libdir + sl, LIBDIR, strlen (LIBDIR) + 1);
13343- }
13344- else
13345- _nlos2_libdir = LIBDIR;
13346- }
13347-
13348- _nlos2_localealiaspath = gnulocaledir;
13349- if (!_nlos2_localealiaspath)
13350- {
13351- if (root)
13352- {
13353- size_t sl = strlen (root);
13354- _nlos2_localealiaspath = (char *) malloc (sl + strlen (LOCALE_ALIAS_PATH) + 1);
13355- memcpy (_nlos2_localealiaspath, root, sl);
13356- memcpy (_nlos2_localealiaspath + sl, LOCALE_ALIAS_PATH, strlen (LOCALE_ALIAS_PATH) + 1);
13357- }
13358- else
13359- _nlos2_localealiaspath = LOCALE_ALIAS_PATH;
13360- }
13361-
13362- _nlos2_localedir = gnulocaledir;
13363- if (!_nlos2_localedir)
13364- {
13365- if (root)
13366- {
13367- size_t sl = strlen (root);
13368- _nlos2_localedir = (char *) malloc (sl + strlen (LOCALEDIR) + 1);
13369- memcpy (_nlos2_localedir, root, sl);
13370- memcpy (_nlos2_localedir + sl, LOCALEDIR, strlen (LOCALEDIR) + 1);
13371- }
13372- else
13373- _nlos2_localedir = LOCALEDIR;
13374- }
13375-
13376- if (strlen (_nlos2_localedir) <= MAXPATHLEN)
13377- strcpy (libintl_nl_default_dirname, _nlos2_localedir);
13378-}
13379--- a/intl/os2compat.h
13380+++ /dev/null
13381@@ -1,46 +0,0 @@
13382-/* OS/2 compatibility defines.
13383- This file is intended to be included from config.h
13384- Copyright (C) 2001-2002 Free Software Foundation, Inc.
13385-
13386- This program is free software; you can redistribute it and/or modify it
13387- under the terms of the GNU Library General Public License as published
13388- by the Free Software Foundation; either version 2, or (at your option)
13389- any later version.
13390-
13391- This program is distributed in the hope that it will be useful,
13392- but WITHOUT ANY WARRANTY; without even the implied warranty of
13393- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13394- Library General Public License for more details.
13395-
13396- You should have received a copy of the GNU Library General Public
13397- License along with this program; if not, write to the Free Software
13398- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
13399- USA. */
13400-
13401-/* When included from os2compat.h we need all the original definitions */
13402-#ifndef OS2_AWARE
13403-
13404-#undef LIBDIR
13405-#define LIBDIR _nlos2_libdir
13406-extern char *_nlos2_libdir;
13407-
13408-#undef LOCALEDIR
13409-#define LOCALEDIR _nlos2_localedir
13410-extern char *_nlos2_localedir;
13411-
13412-#undef LOCALE_ALIAS_PATH
13413-#define LOCALE_ALIAS_PATH _nlos2_localealiaspath
13414-extern char *_nlos2_localealiaspath;
13415-
13416-#endif
13417-
13418-#undef HAVE_STRCASECMP
13419-#define HAVE_STRCASECMP 1
13420-#define strcasecmp stricmp
13421-#define strncasecmp strnicmp
13422-
13423-/* We have our own getenv() which works even if library is compiled as DLL */
13424-#define getenv _nl_getenv
13425-
13426-/* Older versions of gettext used -1 as the value of LC_MESSAGES */
13427-#define LC_MESSAGES_COMPAT (-1)
13428--- a/intl/osdep.c
13429+++ /dev/null
13430@@ -1,26 +0,0 @@
13431-/* OS dependent parts of libintl.
13432- Copyright (C) 2001-2002, 2006 Free Software Foundation, Inc.
13433-
13434- This program is free software; you can redistribute it and/or modify it
13435- under the terms of the GNU Library General Public License as published
13436- by the Free Software Foundation; either version 2, or (at your option)
13437- any later version.
13438-
13439- This program is distributed in the hope that it will be useful,
13440- but WITHOUT ANY WARRANTY; without even the implied warranty of
13441- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13442- Library General Public License for more details.
13443-
13444- You should have received a copy of the GNU Library General Public
13445- License along with this program; if not, write to the Free Software
13446- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
13447- USA. */
13448-
13449-#if defined __CYGWIN__
13450-# include "intl-exports.c"
13451-#elif defined __EMX__
13452-# include "os2compat.c"
13453-#else
13454-/* Avoid AIX compiler warning. */
13455-typedef int dummy;
13456-#endif
13457--- a/intl/plural-exp.c
13458+++ /dev/null
13459@@ -1,155 +0,0 @@
13460-/* Expression parsing for plural form selection.
13461- Copyright (C) 2000-2001, 2003, 2005-2007 Free Software Foundation, Inc.
13462- Written by Ulrich Drepper <drepper@cygnus.com>, 2000.
13463-
13464- This program is free software; you can redistribute it and/or modify it
13465- under the terms of the GNU Library General Public License as published
13466- by the Free Software Foundation; either version 2, or (at your option)
13467- any later version.
13468-
13469- This program is distributed in the hope that it will be useful,
13470- but WITHOUT ANY WARRANTY; without even the implied warranty of
13471- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13472- Library General Public License for more details.
13473-
13474- You should have received a copy of the GNU Library General Public
13475- License along with this program; if not, write to the Free Software
13476- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
13477- USA. */
13478-
13479-#ifdef HAVE_CONFIG_H
13480-# include <config.h>
13481-#endif
13482-
13483-#include <ctype.h>
13484-#include <stdlib.h>
13485-#include <string.h>
13486-
13487-#include "plural-exp.h"
13488-
13489-#if (defined __GNUC__ && !(__APPLE_CC__ > 1) && !defined __cplusplus) \
13490- || (defined __STDC_VERSION__ && __STDC_VERSION__ >= 199901L)
13491-
13492-/* These structs are the constant expression for the germanic plural
13493- form determination. It represents the expression "n != 1". */
13494-static const struct expression plvar =
13495-{
13496- .nargs = 0,
13497- .operation = var,
13498-};
13499-static const struct expression plone =
13500-{
13501- .nargs = 0,
13502- .operation = num,
13503- .val =
13504- {
13505- .num = 1
13506- }
13507-};
13508-struct expression GERMANIC_PLURAL =
13509-{
13510- .nargs = 2,
13511- .operation = not_equal,
13512- .val =
13513- {
13514- .args =
13515- {
13516- [0] = (struct expression *) &plvar,
13517- [1] = (struct expression *) &plone
13518- }
13519- }
13520-};
13521-
13522-# define INIT_GERMANIC_PLURAL()
13523-
13524-#else
13525-
13526-/* For compilers without support for ISO C 99 struct/union initializers:
13527- Initialization at run-time. */
13528-
13529-static struct expression plvar;
13530-static struct expression plone;
13531-struct expression GERMANIC_PLURAL;
13532-
13533-static void
13534-init_germanic_plural ()
13535-{
13536- if (plone.val.num == 0)
13537- {
13538- plvar.nargs = 0;
13539- plvar.operation = var;
13540-
13541- plone.nargs = 0;
13542- plone.operation = num;
13543- plone.val.num = 1;
13544-
13545- GERMANIC_PLURAL.nargs = 2;
13546- GERMANIC_PLURAL.operation = not_equal;
13547- GERMANIC_PLURAL.val.args[0] = &plvar;
13548- GERMANIC_PLURAL.val.args[1] = &plone;
13549- }
13550-}
13551-
13552-# define INIT_GERMANIC_PLURAL() init_germanic_plural ()
13553-
13554-#endif
13555-
13556-void
13557-internal_function
13558-EXTRACT_PLURAL_EXPRESSION (const char *nullentry,
13559- const struct expression **pluralp,
13560- unsigned long int *npluralsp)
13561-{
13562- if (nullentry != NULL)
13563- {
13564- const char *plural;
13565- const char *nplurals;
13566-
13567- plural = strstr (nullentry, "plural=");
13568- nplurals = strstr (nullentry, "nplurals=");
13569- if (plural == NULL || nplurals == NULL)
13570- goto no_plural;
13571- else
13572- {
13573- char *endp;
13574- unsigned long int n;
13575- struct parse_args args;
13576-
13577- /* First get the number. */
13578- nplurals += 9;
13579- while (*nplurals != '\0' && isspace ((unsigned char) *nplurals))
13580- ++nplurals;
13581- if (!(*nplurals >= '0' && *nplurals <= '9'))
13582- goto no_plural;
13583-#if defined HAVE_STRTOUL || defined _LIBC
13584- n = strtoul (nplurals, &endp, 10);
13585-#else
13586- for (endp = nplurals, n = 0; *endp >= '0' && *endp <= '9'; endp++)
13587- n = n * 10 + (*endp - '0');
13588-#endif
13589- if (nplurals == endp)
13590- goto no_plural;
13591- *npluralsp = n;
13592-
13593- /* Due to the restrictions bison imposes onto the interface of the
13594- scanner function we have to put the input string and the result
13595- passed up from the parser into the same structure which address
13596- is passed down to the parser. */
13597- plural += 7;
13598- args.cp = plural;
13599- if (PLURAL_PARSE (&args) != 0)
13600- goto no_plural;
13601- *pluralp = args.res;
13602- }
13603- }
13604- else
13605- {
13606- /* By default we are using the Germanic form: singular form only
13607- for `one', the plural form otherwise. Yes, this is also what
13608- English is using since English is a Germanic language. */
13609- no_plural:
13610- INIT_GERMANIC_PLURAL ();
13611- *pluralp = &GERMANIC_PLURAL;
13612- *npluralsp = 2;
13613- }
13614-}
13615--- a/intl/plural-exp.h
13616+++ /dev/null
13617@@ -1,129 +0,0 @@
13618-/* Expression parsing and evaluation for plural form selection.
13619- Copyright (C) 2000-2003, 2005-2007 Free Software Foundation, Inc.
13620- Written by Ulrich Drepper <drepper@cygnus.com>, 2000.
13621-
13622- This program is free software; you can redistribute it and/or modify it
13623- under the terms of the GNU Library General Public License as published
13624- by the Free Software Foundation; either version 2, or (at your option)
13625- any later version.
13626-
13627- This program is distributed in the hope that it will be useful,
13628- but WITHOUT ANY WARRANTY; without even the implied warranty of
13629- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13630- Library General Public License for more details.
13631-
13632- You should have received a copy of the GNU Library General Public
13633- License along with this program; if not, write to the Free Software
13634- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
13635- USA. */
13636-
13637-#ifndef _PLURAL_EXP_H
13638-#define _PLURAL_EXP_H
13639-
13640-#ifndef internal_function
13641-# define internal_function
13642-#endif
13643-
13644-#ifndef attribute_hidden
13645-# define attribute_hidden
13646-#endif
13647-
13648-#ifdef __cplusplus
13649-extern "C" {
13650-#endif
13651-
13652-
13653-enum expression_operator
13654-{
13655- /* Without arguments: */
13656- var, /* The variable "n". */
13657- num, /* Decimal number. */
13658- /* Unary operators: */
13659- lnot, /* Logical NOT. */
13660- /* Binary operators: */
13661- mult, /* Multiplication. */
13662- divide, /* Division. */
13663- module, /* Modulo operation. */
13664- plus, /* Addition. */
13665- minus, /* Subtraction. */
13666- less_than, /* Comparison. */
13667- greater_than, /* Comparison. */
13668- less_or_equal, /* Comparison. */
13669- greater_or_equal, /* Comparison. */
13670- equal, /* Comparison for equality. */
13671- not_equal, /* Comparison for inequality. */
13672- land, /* Logical AND. */
13673- lor, /* Logical OR. */
13674- /* Ternary operators: */
13675- qmop /* Question mark operator. */
13676-};
13677-
13678-/* This is the representation of the expressions to determine the
13679- plural form. */
13680-struct expression
13681-{
13682- int nargs; /* Number of arguments. */
13683- enum expression_operator operation;
13684- union
13685- {
13686- unsigned long int num; /* Number value for `num'. */
13687- struct expression *args[3]; /* Up to three arguments. */
13688- } val;
13689-};
13690-
13691-/* This is the data structure to pass information to the parser and get
13692- the result in a thread-safe way. */
13693-struct parse_args
13694-{
13695- const char *cp;
13696- struct expression *res;
13697-};
13698-
13699-
13700-/* Names for the libintl functions are a problem. This source code is used
13701- 1. in the GNU C Library library,
13702- 2. in the GNU libintl library,
13703- 3. in the GNU gettext tools.
13704- The function names in each situation must be different, to allow for
13705- binary incompatible changes in 'struct expression'. Furthermore,
13706- 1. in the GNU C Library library, the names have a __ prefix,
13707- 2.+3. in the GNU libintl library and in the GNU gettext tools, the names
13708- must follow ANSI C and not start with __.
13709- So we have to distinguish the three cases. */
13710-#ifdef _LIBC
13711-# define FREE_EXPRESSION __gettext_free_exp
13712-# define PLURAL_PARSE __gettextparse
13713-# define GERMANIC_PLURAL __gettext_germanic_plural
13714-# define EXTRACT_PLURAL_EXPRESSION __gettext_extract_plural
13715-#elif defined (IN_LIBINTL)
13716-# define FREE_EXPRESSION libintl_gettext_free_exp
13717-# define PLURAL_PARSE libintl_gettextparse
13718-# define GERMANIC_PLURAL libintl_gettext_germanic_plural
13719-# define EXTRACT_PLURAL_EXPRESSION libintl_gettext_extract_plural
13720-#else
13721-# define FREE_EXPRESSION free_plural_expression
13722-# define PLURAL_PARSE parse_plural_expression
13723-# define GERMANIC_PLURAL germanic_plural
13724-# define EXTRACT_PLURAL_EXPRESSION extract_plural_expression
13725-#endif
13726-
13727-extern void FREE_EXPRESSION (struct expression *exp)
13728- internal_function;
13729-extern int PLURAL_PARSE (void *arg);
13730-extern struct expression GERMANIC_PLURAL attribute_hidden;
13731-extern void EXTRACT_PLURAL_EXPRESSION (const char *nullentry,
13732- const struct expression **pluralp,
13733- unsigned long int *npluralsp)
13734- internal_function;
13735-
13736-#if !defined (_LIBC) && !defined (IN_LIBINTL) && !defined (IN_LIBGLOCALE)
13737-extern unsigned long int plural_eval (const struct expression *pexp,
13738- unsigned long int n);
13739-#endif
13740-
13741-
13742-#ifdef __cplusplus
13743-}
13744-#endif
13745-
13746-#endif /* _PLURAL_EXP_H */
13747--- a/intl/plural.c
13748+++ /dev/null
13749@@ -1,1981 +0,0 @@
13750-
13751-/* A Bison parser, made by GNU Bison 2.4.1. */
13752-
13753-/* Skeleton implementation for Bison's Yacc-like parsers in C
13754-
13755- Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004, 2005, 2006
13756- Free Software Foundation, Inc.
13757-
13758- This program is free software: you can redistribute it and/or modify
13759- it under the terms of the GNU General Public License as published by
13760- the Free Software Foundation, either version 3 of the License, or
13761- (at your option) any later version.
13762-
13763- This program is distributed in the hope that it will be useful,
13764- but WITHOUT ANY WARRANTY; without even the implied warranty of
13765- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13766- GNU General Public License for more details.
13767-
13768- You should have received a copy of the GNU General Public License
13769- along with this program. If not, see <http://www.gnu.org/licenses/>. */
13770-
13771-/* As a special exception, you may create a larger work that contains
13772- part or all of the Bison parser skeleton and distribute that work
13773- under terms of your choice, so long as that work isn't itself a
13774- parser generator using the skeleton or a modified version thereof
13775- as a parser skeleton. Alternatively, if you modify or redistribute
13776- the parser skeleton itself, you may (at your option) remove this
13777- special exception, which will cause the skeleton and the resulting
13778- Bison output files to be licensed under the GNU General Public
13779- License without this special exception.
13780-
13781- This special exception was added by the Free Software Foundation in
13782- version 2.2 of Bison. */
13783-
13784-/* C LALR(1) parser skeleton written by Richard Stallman, by
13785- simplifying the original so-called "semantic" parser. */
13786-
13787-/* All symbols defined below should begin with yy or YY, to avoid
13788- infringing on user name space. This should be done even for local
13789- variables, as they might otherwise be expanded by user macros.
13790- There are some unavoidable exceptions within include files to
13791- define necessary library symbols; they are noted "INFRINGES ON
13792- USER NAME SPACE" below. */
13793-
13794-/* Identify Bison output. */
13795-#define YYBISON 1
13796-
13797-/* Bison version. */
13798-#define YYBISON_VERSION "2.4.1"
13799-
13800-/* Skeleton name. */
13801-#define YYSKELETON_NAME "yacc.c"
13802-
13803-/* Pure parsers. */
13804-#define YYPURE 1
13805-
13806-/* Push parsers. */
13807-#define YYPUSH 0
13808-
13809-/* Pull parsers. */
13810-#define YYPULL 1
13811-
13812-/* Using locations. */
13813-#define YYLSP_NEEDED 0
13814-
13815-/* Substitute the variable and function names. */
13816-#define yyparse __gettextparse
13817-#define yylex __gettextlex
13818-#define yyerror __gettexterror
13819-#define yylval __gettextlval
13820-#define yychar __gettextchar
13821-#define yydebug __gettextdebug
13822-#define yynerrs __gettextnerrs
13823-
13824-
13825-/* Copy the first part of user declarations. */
13826-
13827-/* Line 189 of yacc.c */
13828-#line 1 "plural.y"
13829-
13830-/* Expression parsing for plural form selection.
13831- Copyright (C) 2000-2001, 2003, 2005-2006 Free Software Foundation, Inc.
13832- Written by Ulrich Drepper <drepper@cygnus.com>, 2000.
13833-
13834- This program is free software; you can redistribute it and/or modify it
13835- under the terms of the GNU Library General Public License as published
13836- by the Free Software Foundation; either version 2, or (at your option)
13837- any later version.
13838-
13839- This program is distributed in the hope that it will be useful,
13840- but WITHOUT ANY WARRANTY; without even the implied warranty of
13841- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13842- Library General Public License for more details.
13843-
13844- You should have received a copy of the GNU Library General Public
13845- License along with this program; if not, write to the Free Software
13846- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
13847- USA. */
13848-
13849-/* For bison < 2.0, the bison generated parser uses alloca. AIX 3 forces us
13850- to put this declaration at the beginning of the file. The declaration in
13851- bison's skeleton file comes too late. This must come before <config.h>
13852- because <config.h> may include arbitrary system headers.
13853- This can go away once the AM_INTL_SUBDIR macro requires bison >= 2.0. */
13854-#if defined _AIX && !defined __GNUC__
13855- #pragma alloca
13856-#endif
13857-
13858-#ifdef HAVE_CONFIG_H
13859-# include <config.h>
13860-#endif
13861-
13862-#include <stddef.h>
13863-#include <stdlib.h>
13864-#include <string.h>
13865-#include "plural-exp.h"
13866-
13867-/* The main function generated by the parser is called __gettextparse,
13868- but we want it to be called PLURAL_PARSE. */
13869-#ifndef _LIBC
13870-# define __gettextparse PLURAL_PARSE
13871-#endif
13872-
13873-#define YYLEX_PARAM &((struct parse_args *) arg)->cp
13874-#define YYPARSE_PARAM arg
13875-
13876-
13877-/* Line 189 of yacc.c */
13878-#line 130 "plural.c"
13879-
13880-/* Enabling traces. */
13881-#ifndef YYDEBUG
13882-# define YYDEBUG 0
13883-#endif
13884-
13885-/* Enabling verbose error messages. */
13886-#ifdef YYERROR_VERBOSE
13887-# undef YYERROR_VERBOSE
13888-# define YYERROR_VERBOSE 1
13889-#else
13890-# define YYERROR_VERBOSE 0
13891-#endif
13892-
13893-/* Enabling the token table. */
13894-#ifndef YYTOKEN_TABLE
13895-# define YYTOKEN_TABLE 0
13896-#endif
13897-
13898-
13899-/* Tokens. */
13900-#ifndef YYTOKENTYPE
13901-# define YYTOKENTYPE
13902- /* Put the tokens into the symbol table, so that GDB and other debuggers
13903- know about them. */
13904- enum yytokentype {
13905- EQUOP2 = 258,
13906- CMPOP2 = 259,
13907- ADDOP2 = 260,
13908- MULOP2 = 261,
13909- NUMBER = 262
13910- };
13911-#endif
13912-/* Tokens. */
13913-#define EQUOP2 258
13914-#define CMPOP2 259
13915-#define ADDOP2 260
13916-#define MULOP2 261
13917-#define NUMBER 262
13918-
13919-
13920-
13921-
13922-#if ! defined YYSTYPE && ! defined YYSTYPE_IS_DECLARED
13923-typedef union YYSTYPE
13924-{
13925-
13926-/* Line 214 of yacc.c */
13927-#line 51 "plural.y"
13928-
13929- unsigned long int num;
13930- enum expression_operator op;
13931- struct expression *exp;
13932-
13933-
13934-
13935-/* Line 214 of yacc.c */
13936-#line 188 "plural.c"
13937-} YYSTYPE;
13938-# define YYSTYPE_IS_TRIVIAL 1
13939-# define yystype YYSTYPE /* obsolescent; will be withdrawn */
13940-# define YYSTYPE_IS_DECLARED 1
13941-#endif
13942-
13943-
13944-/* Copy the second part of user declarations. */
13945-
13946-/* Line 264 of yacc.c */
13947-#line 57 "plural.y"
13948-
13949-/* Prototypes for local functions. */
13950-static int yylex (YYSTYPE *lval, const char **pexp);
13951-static void yyerror (const char *str);
13952-
13953-/* Allocation of expressions. */
13954-
13955-static struct expression *
13956-new_exp (int nargs, enum expression_operator op,
13957- struct expression * const *args)
13958-{
13959- int i;
13960- struct expression *newp;
13961-
13962- /* If any of the argument could not be malloc'ed, just return NULL. */
13963- for (i = nargs - 1; i >= 0; i--)
13964- if (args[i] == NULL)
13965- goto fail;
13966-
13967- /* Allocate a new expression. */
13968- newp = (struct expression *) malloc (sizeof (*newp));
13969- if (newp != NULL)
13970- {
13971- newp->nargs = nargs;
13972- newp->operation = op;
13973- for (i = nargs - 1; i >= 0; i--)
13974- newp->val.args[i] = args[i];
13975- return newp;
13976- }
13977-
13978- fail:
13979- for (i = nargs - 1; i >= 0; i--)
13980- FREE_EXPRESSION (args[i]);
13981-
13982- return NULL;
13983-}
13984-
13985-static inline struct expression *
13986-new_exp_0 (enum expression_operator op)
13987-{
13988- return new_exp (0, op, NULL);
13989-}
13990-
13991-static inline struct expression *
13992-new_exp_1 (enum expression_operator op, struct expression *right)
13993-{
13994- struct expression *args[1];
13995-
13996- args[0] = right;
13997- return new_exp (1, op, args);
13998-}
13999-
14000-static struct expression *
14001-new_exp_2 (enum expression_operator op, struct expression *left,
14002- struct expression *right)
14003-{
14004- struct expression *args[2];
14005-
14006- args[0] = left;
14007- args[1] = right;
14008- return new_exp (2, op, args);
14009-}
14010-
14011-static inline struct expression *
14012-new_exp_3 (enum expression_operator op, struct expression *bexp,
14013- struct expression *tbranch, struct expression *fbranch)
14014-{
14015- struct expression *args[3];
14016-
14017- args[0] = bexp;
14018- args[1] = tbranch;
14019- args[2] = fbranch;
14020- return new_exp (3, op, args);
14021-}
14022-
14023-
14024-
14025-/* Line 264 of yacc.c */
14026-#line 278 "plural.c"
14027-
14028-#ifdef short
14029-# undef short
14030-#endif
14031-
14032-#ifdef YYTYPE_UINT8
14033-typedef YYTYPE_UINT8 yytype_uint8;
14034-#else
14035-typedef unsigned char yytype_uint8;
14036-#endif
14037-
14038-#ifdef YYTYPE_INT8
14039-typedef YYTYPE_INT8 yytype_int8;
14040-#elif (defined __STDC__ || defined __C99__FUNC__ \
14041- || defined __cplusplus || defined _MSC_VER)
14042-typedef signed char yytype_int8;
14043-#else
14044-typedef short int yytype_int8;
14045-#endif
14046-
14047-#ifdef YYTYPE_UINT16
14048-typedef YYTYPE_UINT16 yytype_uint16;
14049-#else
14050-typedef unsigned short int yytype_uint16;
14051-#endif
14052-
14053-#ifdef YYTYPE_INT16
14054-typedef YYTYPE_INT16 yytype_int16;
14055-#else
14056-typedef short int yytype_int16;
14057-#endif
14058-
14059-#ifndef YYSIZE_T
14060-# ifdef __SIZE_TYPE__
14061-# define YYSIZE_T __SIZE_TYPE__
14062-# elif defined size_t
14063-# define YYSIZE_T size_t
14064-# elif ! defined YYSIZE_T && (defined __STDC__ || defined __C99__FUNC__ \
14065- || defined __cplusplus || defined _MSC_VER)
14066-# include <stddef.h> /* INFRINGES ON USER NAME SPACE */
14067-# define YYSIZE_T size_t
14068-# else
14069-# define YYSIZE_T unsigned int
14070-# endif
14071-#endif
14072-
14073-#define YYSIZE_MAXIMUM ((YYSIZE_T) -1)
14074-
14075-#ifndef YY_
14076-# if YYENABLE_NLS
14077-# if ENABLE_NLS
14078-# include <libintl.h> /* INFRINGES ON USER NAME SPACE */
14079-# define YY_(msgid) dgettext ("bison-runtime", msgid)
14080-# endif
14081-# endif
14082-# ifndef YY_
14083-# define YY_(msgid) msgid
14084-# endif
14085-#endif
14086-
14087-/* Suppress unused-variable warnings by "using" E. */
14088-#if ! defined lint || defined __GNUC__
14089-# define YYUSE(e) ((void) (e))
14090-#else
14091-# define YYUSE(e) /* empty */
14092-#endif
14093-
14094-/* Identity function, used to suppress warnings about constant conditions. */
14095-#ifndef lint
14096-# define YYID(n) (n)
14097-#else
14098-#if (defined __STDC__ || defined __C99__FUNC__ \
14099- || defined __cplusplus || defined _MSC_VER)
14100-static int
14101-YYID (int yyi)
14102-#else
14103-static int
14104-YYID (yyi)
14105- int yyi;
14106-#endif
14107-{
14108- return yyi;
14109-}
14110-#endif
14111-
14112-#if ! defined yyoverflow || YYERROR_VERBOSE
14113-
14114-/* The parser invokes alloca or malloc; define the necessary symbols. */
14115-
14116-# ifdef YYSTACK_USE_ALLOCA
14117-# if YYSTACK_USE_ALLOCA
14118-# ifdef __GNUC__
14119-# define YYSTACK_ALLOC __builtin_alloca
14120-# elif defined __BUILTIN_VA_ARG_INCR
14121-# include <alloca.h> /* INFRINGES ON USER NAME SPACE */
14122-# elif defined _AIX
14123-# define YYSTACK_ALLOC __alloca
14124-# elif defined _MSC_VER
14125-# include <malloc.h> /* INFRINGES ON USER NAME SPACE */
14126-# define alloca _alloca
14127-# else
14128-# define YYSTACK_ALLOC alloca
14129-# if ! defined _ALLOCA_H && ! defined _STDLIB_H && (defined __STDC__ || defined __C99__FUNC__ \
14130- || defined __cplusplus || defined _MSC_VER)
14131-# include <stdlib.h> /* INFRINGES ON USER NAME SPACE */
14132-# ifndef _STDLIB_H
14133-# define _STDLIB_H 1
14134-# endif
14135-# endif
14136-# endif
14137-# endif
14138-# endif
14139-
14140-# ifdef YYSTACK_ALLOC
14141- /* Pacify GCC's `empty if-body' warning. */
14142-# define YYSTACK_FREE(Ptr) do { /* empty */; } while (YYID (0))
14143-# ifndef YYSTACK_ALLOC_MAXIMUM
14144- /* The OS might guarantee only one guard page at the bottom of the stack,
14145- and a page size can be as small as 4096 bytes. So we cannot safely
14146- invoke alloca (N) if N exceeds 4096. Use a slightly smaller number
14147- to allow for a few compiler-allocated temporary stack slots. */
14148-# define YYSTACK_ALLOC_MAXIMUM 4032 /* reasonable circa 2006 */
14149-# endif
14150-# else
14151-# define YYSTACK_ALLOC YYMALLOC
14152-# define YYSTACK_FREE YYFREE
14153-# ifndef YYSTACK_ALLOC_MAXIMUM
14154-# define YYSTACK_ALLOC_MAXIMUM YYSIZE_MAXIMUM
14155-# endif
14156-# if (defined __cplusplus && ! defined _STDLIB_H \
14157- && ! ((defined YYMALLOC || defined malloc) \
14158- && (defined YYFREE || defined free)))
14159-# include <stdlib.h> /* INFRINGES ON USER NAME SPACE */
14160-# ifndef _STDLIB_H
14161-# define _STDLIB_H 1
14162-# endif
14163-# endif
14164-# ifndef YYMALLOC
14165-# define YYMALLOC malloc
14166-# if ! defined malloc && ! defined _STDLIB_H && (defined __STDC__ || defined __C99__FUNC__ \
14167- || defined __cplusplus || defined _MSC_VER)
14168-void *malloc (YYSIZE_T); /* INFRINGES ON USER NAME SPACE */
14169-# endif
14170-# endif
14171-# ifndef YYFREE
14172-# define YYFREE free
14173-# if ! defined free && ! defined _STDLIB_H && (defined __STDC__ || defined __C99__FUNC__ \
14174- || defined __cplusplus || defined _MSC_VER)
14175-void free (void *); /* INFRINGES ON USER NAME SPACE */
14176-# endif
14177-# endif
14178-# endif
14179-#endif /* ! defined yyoverflow || YYERROR_VERBOSE */
14180-
14181-
14182-#if (! defined yyoverflow \
14183- && (! defined __cplusplus \
14184- || (defined YYSTYPE_IS_TRIVIAL && YYSTYPE_IS_TRIVIAL)))
14185-
14186-/* A type that is properly aligned for any stack member. */
14187-union yyalloc
14188-{
14189- yytype_int16 yyss_alloc;
14190- YYSTYPE yyvs_alloc;
14191-};
14192-
14193-/* The size of the maximum gap between one aligned stack and the next. */
14194-# define YYSTACK_GAP_MAXIMUM (sizeof (union yyalloc) - 1)
14195-
14196-/* The size of an array large to enough to hold all stacks, each with
14197- N elements. */
14198-# define YYSTACK_BYTES(N) \
14199- ((N) * (sizeof (yytype_int16) + sizeof (YYSTYPE)) \
14200- + YYSTACK_GAP_MAXIMUM)
14201-
14202-/* Copy COUNT objects from FROM to TO. The source and destination do
14203- not overlap. */
14204-# ifndef YYCOPY
14205-# if defined __GNUC__ && 1 < __GNUC__
14206-# define YYCOPY(To, From, Count) \
14207- __builtin_memcpy (To, From, (Count) * sizeof (*(From)))
14208-# else
14209-# define YYCOPY(To, From, Count) \
14210- do \
14211- { \
14212- YYSIZE_T yyi; \
14213- for (yyi = 0; yyi < (Count); yyi++) \
14214- (To)[yyi] = (From)[yyi]; \
14215- } \
14216- while (YYID (0))
14217-# endif
14218-# endif
14219-
14220-/* Relocate STACK from its old location to the new one. The
14221- local variables YYSIZE and YYSTACKSIZE give the old and new number of
14222- elements in the stack, and YYPTR gives the new location of the
14223- stack. Advance YYPTR to a properly aligned location for the next
14224- stack. */
14225-# define YYSTACK_RELOCATE(Stack_alloc, Stack) \
14226- do \
14227- { \
14228- YYSIZE_T yynewbytes; \
14229- YYCOPY (&yyptr->Stack_alloc, Stack, yysize); \
14230- Stack = &yyptr->Stack_alloc; \
14231- yynewbytes = yystacksize * sizeof (*Stack) + YYSTACK_GAP_MAXIMUM; \
14232- yyptr += yynewbytes / sizeof (*yyptr); \
14233- } \
14234- while (YYID (0))
14235-
14236-#endif
14237-
14238-/* YYFINAL -- State number of the termination state. */
14239-#define YYFINAL 9
14240-/* YYLAST -- Last index in YYTABLE. */
14241-#define YYLAST 54
14242-
14243-/* YYNTOKENS -- Number of terminals. */
14244-#define YYNTOKENS 16
14245-/* YYNNTS -- Number of nonterminals. */
14246-#define YYNNTS 3
14247-/* YYNRULES -- Number of rules. */
14248-#define YYNRULES 13
14249-/* YYNRULES -- Number of states. */
14250-#define YYNSTATES 27
14251-
14252-/* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX. */
14253-#define YYUNDEFTOK 2
14254-#define YYMAXUTOK 262
14255-
14256-#define YYTRANSLATE(YYX) \
14257- ((unsigned int) (YYX) <= YYMAXUTOK ? yytranslate[YYX] : YYUNDEFTOK)
14258-
14259-/* YYTRANSLATE[YYLEX] -- Bison symbol number corresponding to YYLEX. */
14260-static const yytype_uint8 yytranslate[] =
14261-{
14262- 0, 2, 2, 2, 2, 2, 2, 2, 2, 2,
14263- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
14264- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
14265- 2, 2, 2, 10, 2, 2, 2, 2, 5, 2,
14266- 14, 15, 2, 2, 2, 2, 2, 2, 2, 2,
14267- 2, 2, 2, 2, 2, 2, 2, 2, 12, 2,
14268- 2, 2, 2, 3, 2, 2, 2, 2, 2, 2,
14269- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
14270- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
14271- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
14272- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
14273- 13, 2, 2, 2, 2, 2, 2, 2, 2, 2,
14274- 2, 2, 2, 2, 4, 2, 2, 2, 2, 2,
14275- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
14276- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
14277- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
14278- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
14279- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
14280- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
14281- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
14282- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
14283- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
14284- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
14285- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
14286- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
14287- 2, 2, 2, 2, 2, 2, 1, 2, 6, 7,
14288- 8, 9, 11
14289-};
14290-
14291-#if YYDEBUG
14292-/* YYPRHS[YYN] -- Index of the first RHS symbol of rule number YYN in
14293- YYRHS. */
14294-static const yytype_uint8 yyprhs[] =
14295-{
14296- 0, 0, 3, 5, 11, 15, 19, 23, 27, 31,
14297- 35, 38, 40, 42
14298-};
14299-
14300-/* YYRHS -- A `-1'-separated list of the rules' RHS. */
14301-static const yytype_int8 yyrhs[] =
14302-{
14303- 17, 0, -1, 18, -1, 18, 3, 18, 12, 18,
14304- -1, 18, 4, 18, -1, 18, 5, 18, -1, 18,
14305- 6, 18, -1, 18, 7, 18, -1, 18, 8, 18,
14306- -1, 18, 9, 18, -1, 10, 18, -1, 13, -1,
14307- 11, -1, 14, 18, 15, -1
14308-};
14309-
14310-/* YYRLINE[YYN] -- source line where rule number YYN was defined. */
14311-static const yytype_uint8 yyrline[] =
14312-{
14313- 0, 154, 154, 162, 166, 170, 174, 178, 182, 186,
14314- 190, 194, 198, 203
14315-};
14316-#endif
14317-
14318-#if YYDEBUG || YYERROR_VERBOSE || YYTOKEN_TABLE
14319-/* YYTNAME[SYMBOL-NUM] -- String name of the symbol SYMBOL-NUM.
14320- First, the terminals, then, starting at YYNTOKENS, nonterminals. */
14321-static const char *const yytname[] =
14322-{
14323- "$end", "error", "$undefined", "'?'", "'|'", "'&'", "EQUOP2", "CMPOP2",
14324- "ADDOP2", "MULOP2", "'!'", "NUMBER", "':'", "'n'", "'('", "')'",
14325- "$accept", "start", "exp", 0
14326-};
14327-#endif
14328-
14329-# ifdef YYPRINT
14330-/* YYTOKNUM[YYLEX-NUM] -- Internal token number corresponding to
14331- token YYLEX-NUM. */
14332-static const yytype_uint16 yytoknum[] =
14333-{
14334- 0, 256, 257, 63, 124, 38, 258, 259, 260, 261,
14335- 33, 262, 58, 110, 40, 41
14336-};
14337-# endif
14338-
14339-/* YYR1[YYN] -- Symbol number of symbol that rule YYN derives. */
14340-static const yytype_uint8 yyr1[] =
14341-{
14342- 0, 16, 17, 18, 18, 18, 18, 18, 18, 18,
14343- 18, 18, 18, 18
14344-};
14345-
14346-/* YYR2[YYN] -- Number of symbols composing right hand side of rule YYN. */
14347-static const yytype_uint8 yyr2[] =
14348-{
14349- 0, 2, 1, 5, 3, 3, 3, 3, 3, 3,
14350- 2, 1, 1, 3
14351-};
14352-
14353-/* YYDEFACT[STATE-NAME] -- Default rule to reduce with in state
14354- STATE-NUM when YYTABLE doesn't specify something else to do. Zero
14355- means the default is an error. */
14356-static const yytype_uint8 yydefact[] =
14357-{
14358- 0, 0, 12, 11, 0, 0, 2, 10, 0, 1,
14359- 0, 0, 0, 0, 0, 0, 0, 13, 0, 4,
14360- 5, 6, 7, 8, 9, 0, 3
14361-};
14362-
14363-/* YYDEFGOTO[NTERM-NUM]. */
14364-static const yytype_int8 yydefgoto[] =
14365-{
14366- -1, 5, 6
14367-};
14368-
14369-/* YYPACT[STATE-NUM] -- Index in YYTABLE of the portion describing
14370- STATE-NUM. */
14371-#define YYPACT_NINF -10
14372-static const yytype_int8 yypact[] =
14373-{
14374- -9, -9, -10, -10, -9, 8, 36, -10, 13, -10,
14375- -9, -9, -9, -9, -9, -9, -9, -10, 26, 41,
14376- 45, 18, -2, 14, -10, -9, 36
14377-};
14378-
14379-/* YYPGOTO[NTERM-NUM]. */
14380-static const yytype_int8 yypgoto[] =
14381-{
14382- -10, -10, -1
14383-};
14384-
14385-/* YYTABLE[YYPACT[STATE-NUM]]. What to do in state STATE-NUM. If
14386- positive, shift that token. If negative, reduce the rule which
14387- number is the opposite. If zero, do what YYDEFACT says.
14388- If YYTABLE_NINF, syntax error. */
14389-#define YYTABLE_NINF -1
14390-static const yytype_uint8 yytable[] =
14391-{
14392- 7, 1, 2, 8, 3, 4, 15, 16, 9, 18,
14393- 19, 20, 21, 22, 23, 24, 10, 11, 12, 13,
14394- 14, 15, 16, 16, 26, 14, 15, 16, 17, 10,
14395- 11, 12, 13, 14, 15, 16, 0, 0, 25, 10,
14396- 11, 12, 13, 14, 15, 16, 12, 13, 14, 15,
14397- 16, 13, 14, 15, 16
14398-};
14399-
14400-static const yytype_int8 yycheck[] =
14401-{
14402- 1, 10, 11, 4, 13, 14, 8, 9, 0, 10,
14403- 11, 12, 13, 14, 15, 16, 3, 4, 5, 6,
14404- 7, 8, 9, 9, 25, 7, 8, 9, 15, 3,
14405- 4, 5, 6, 7, 8, 9, -1, -1, 12, 3,
14406- 4, 5, 6, 7, 8, 9, 5, 6, 7, 8,
14407- 9, 6, 7, 8, 9
14408-};
14409-
14410-/* YYSTOS[STATE-NUM] -- The (internal number of the) accessing
14411- symbol of state STATE-NUM. */
14412-static const yytype_uint8 yystos[] =
14413-{
14414- 0, 10, 11, 13, 14, 17, 18, 18, 18, 0,
14415- 3, 4, 5, 6, 7, 8, 9, 15, 18, 18,
14416- 18, 18, 18, 18, 18, 12, 18
14417-};
14418-
14419-#define yyerrok (yyerrstatus = 0)
14420-#define yyclearin (yychar = YYEMPTY)
14421-#define YYEMPTY (-2)
14422-#define YYEOF 0
14423-
14424-#define YYACCEPT goto yyacceptlab
14425-#define YYABORT goto yyabortlab
14426-#define YYERROR goto yyerrorlab
14427-
14428-
14429-/* Like YYERROR except do call yyerror. This remains here temporarily
14430- to ease the transition to the new meaning of YYERROR, for GCC.
14431- Once GCC version 2 has supplanted version 1, this can go. */
14432-
14433-#define YYFAIL goto yyerrlab
14434-
14435-#define YYRECOVERING() (!!yyerrstatus)
14436-
14437-#define YYBACKUP(Token, Value) \
14438-do \
14439- if (yychar == YYEMPTY && yylen == 1) \
14440- { \
14441- yychar = (Token); \
14442- yylval = (Value); \
14443- yytoken = YYTRANSLATE (yychar); \
14444- YYPOPSTACK (1); \
14445- goto yybackup; \
14446- } \
14447- else \
14448- { \
14449- yyerror (YY_("syntax error: cannot back up")); \
14450- YYERROR; \
14451- } \
14452-while (YYID (0))
14453-
14454-
14455-#define YYTERROR 1
14456-#define YYERRCODE 256
14457-
14458-
14459-/* YYLLOC_DEFAULT -- Set CURRENT to span from RHS[1] to RHS[N].
14460- If N is 0, then set CURRENT to the empty location which ends
14461- the previous symbol: RHS[0] (always defined). */
14462-
14463-#define YYRHSLOC(Rhs, K) ((Rhs)[K])
14464-#ifndef YYLLOC_DEFAULT
14465-# define YYLLOC_DEFAULT(Current, Rhs, N) \
14466- do \
14467- if (YYID (N)) \
14468- { \
14469- (Current).first_line = YYRHSLOC (Rhs, 1).first_line; \
14470- (Current).first_column = YYRHSLOC (Rhs, 1).first_column; \
14471- (Current).last_line = YYRHSLOC (Rhs, N).last_line; \
14472- (Current).last_column = YYRHSLOC (Rhs, N).last_column; \
14473- } \
14474- else \
14475- { \
14476- (Current).first_line = (Current).last_line = \
14477- YYRHSLOC (Rhs, 0).last_line; \
14478- (Current).first_column = (Current).last_column = \
14479- YYRHSLOC (Rhs, 0).last_column; \
14480- } \
14481- while (YYID (0))
14482-#endif
14483-
14484-
14485-/* YY_LOCATION_PRINT -- Print the location on the stream.
14486- This macro was not mandated originally: define only if we know
14487- we won't break user code: when these are the locations we know. */
14488-
14489-#ifndef YY_LOCATION_PRINT
14490-# if YYLTYPE_IS_TRIVIAL
14491-# define YY_LOCATION_PRINT(File, Loc) \
14492- fprintf (File, "%d.%d-%d.%d", \
14493- (Loc).first_line, (Loc).first_column, \
14494- (Loc).last_line, (Loc).last_column)
14495-# else
14496-# define YY_LOCATION_PRINT(File, Loc) ((void) 0)
14497-# endif
14498-#endif
14499-
14500-
14501-/* YYLEX -- calling `yylex' with the right arguments. */
14502-
14503-#ifdef YYLEX_PARAM
14504-# define YYLEX yylex (&yylval, YYLEX_PARAM)
14505-#else
14506-# define YYLEX yylex (&yylval)
14507-#endif
14508-
14509-/* Enable debugging if requested. */
14510-#if YYDEBUG
14511-
14512-# ifndef YYFPRINTF
14513-# include <stdio.h> /* INFRINGES ON USER NAME SPACE */
14514-# define YYFPRINTF fprintf
14515-# endif
14516-
14517-# define YYDPRINTF(Args) \
14518-do { \
14519- if (yydebug) \
14520- YYFPRINTF Args; \
14521-} while (YYID (0))
14522-
14523-# define YY_SYMBOL_PRINT(Title, Type, Value, Location) \
14524-do { \
14525- if (yydebug) \
14526- { \
14527- YYFPRINTF (stderr, "%s ", Title); \
14528- yy_symbol_print (stderr, \
14529- Type, Value); \
14530- YYFPRINTF (stderr, "\n"); \
14531- } \
14532-} while (YYID (0))
14533-
14534-
14535-/*--------------------------------.
14536-| Print this symbol on YYOUTPUT. |
14537-`--------------------------------*/
14538-
14539-/*ARGSUSED*/
14540-#if (defined __STDC__ || defined __C99__FUNC__ \
14541- || defined __cplusplus || defined _MSC_VER)
14542-static void
14543-yy_symbol_value_print (FILE *yyoutput, int yytype, YYSTYPE const * const yyvaluep)
14544-#else
14545-static void
14546-yy_symbol_value_print (yyoutput, yytype, yyvaluep)
14547- FILE *yyoutput;
14548- int yytype;
14549- YYSTYPE const * const yyvaluep;
14550-#endif
14551-{
14552- if (!yyvaluep)
14553- return;
14554-# ifdef YYPRINT
14555- if (yytype < YYNTOKENS)
14556- YYPRINT (yyoutput, yytoknum[yytype], *yyvaluep);
14557-# else
14558- YYUSE (yyoutput);
14559-# endif
14560- switch (yytype)
14561- {
14562- default:
14563- break;
14564- }
14565-}
14566-
14567-
14568-/*--------------------------------.
14569-| Print this symbol on YYOUTPUT. |
14570-`--------------------------------*/
14571-
14572-#if (defined __STDC__ || defined __C99__FUNC__ \
14573- || defined __cplusplus || defined _MSC_VER)
14574-static void
14575-yy_symbol_print (FILE *yyoutput, int yytype, YYSTYPE const * const yyvaluep)
14576-#else
14577-static void
14578-yy_symbol_print (yyoutput, yytype, yyvaluep)
14579- FILE *yyoutput;
14580- int yytype;
14581- YYSTYPE const * const yyvaluep;
14582-#endif
14583-{
14584- if (yytype < YYNTOKENS)
14585- YYFPRINTF (yyoutput, "token %s (", yytname[yytype]);
14586- else
14587- YYFPRINTF (yyoutput, "nterm %s (", yytname[yytype]);
14588-
14589- yy_symbol_value_print (yyoutput, yytype, yyvaluep);
14590- YYFPRINTF (yyoutput, ")");
14591-}
14592-
14593-/*------------------------------------------------------------------.
14594-| yy_stack_print -- Print the state stack from its BOTTOM up to its |
14595-| TOP (included). |
14596-`------------------------------------------------------------------*/
14597-
14598-#if (defined __STDC__ || defined __C99__FUNC__ \
14599- || defined __cplusplus || defined _MSC_VER)
14600-static void
14601-yy_stack_print (yytype_int16 *yybottom, yytype_int16 *yytop)
14602-#else
14603-static void
14604-yy_stack_print (yybottom, yytop)
14605- yytype_int16 *yybottom;
14606- yytype_int16 *yytop;
14607-#endif
14608-{
14609- YYFPRINTF (stderr, "Stack now");
14610- for (; yybottom <= yytop; yybottom++)
14611- {
14612- int yybot = *yybottom;
14613- YYFPRINTF (stderr, " %d", yybot);
14614- }
14615- YYFPRINTF (stderr, "\n");
14616-}
14617-
14618-# define YY_STACK_PRINT(Bottom, Top) \
14619-do { \
14620- if (yydebug) \
14621- yy_stack_print ((Bottom), (Top)); \
14622-} while (YYID (0))
14623-
14624-
14625-/*------------------------------------------------.
14626-| Report that the YYRULE is going to be reduced. |
14627-`------------------------------------------------*/
14628-
14629-#if (defined __STDC__ || defined __C99__FUNC__ \
14630- || defined __cplusplus || defined _MSC_VER)
14631-static void
14632-yy_reduce_print (YYSTYPE *yyvsp, int yyrule)
14633-#else
14634-static void
14635-yy_reduce_print (yyvsp, yyrule)
14636- YYSTYPE *yyvsp;
14637- int yyrule;
14638-#endif
14639-{
14640- int yynrhs = yyr2[yyrule];
14641- int yyi;
14642- unsigned long int yylno = yyrline[yyrule];
14643- YYFPRINTF (stderr, "Reducing stack by rule %d (line %lu):\n",
14644- yyrule - 1, yylno);
14645- /* The symbols being reduced. */
14646- for (yyi = 0; yyi < yynrhs; yyi++)
14647- {
14648- YYFPRINTF (stderr, " $%d = ", yyi + 1);
14649- yy_symbol_print (stderr, yyrhs[yyprhs[yyrule] + yyi],
14650- &(yyvsp[(yyi + 1) - (yynrhs)])
14651- );
14652- YYFPRINTF (stderr, "\n");
14653- }
14654-}
14655-
14656-# define YY_REDUCE_PRINT(Rule) \
14657-do { \
14658- if (yydebug) \
14659- yy_reduce_print (yyvsp, Rule); \
14660-} while (YYID (0))
14661-
14662-/* Nonzero means print parse trace. It is left uninitialized so that
14663- multiple parsers can coexist. */
14664-int yydebug;
14665-#else /* !YYDEBUG */
14666-# define YYDPRINTF(Args)
14667-# define YY_SYMBOL_PRINT(Title, Type, Value, Location)
14668-# define YY_STACK_PRINT(Bottom, Top)
14669-# define YY_REDUCE_PRINT(Rule)
14670-#endif /* !YYDEBUG */
14671-
14672-
14673-/* YYINITDEPTH -- initial size of the parser's stacks. */
14674-#ifndef YYINITDEPTH
14675-# define YYINITDEPTH 200
14676-#endif
14677-
14678-/* YYMAXDEPTH -- maximum size the stacks can grow to (effective only
14679- if the built-in stack extension method is used).
14680-
14681- Do not make this value too large; the results are undefined if
14682- YYSTACK_ALLOC_MAXIMUM < YYSTACK_BYTES (YYMAXDEPTH)
14683- evaluated with infinite-precision integer arithmetic. */
14684-
14685-#ifndef YYMAXDEPTH
14686-# define YYMAXDEPTH 10000
14687-#endif
14688-
14689-
14690-
14691-#if YYERROR_VERBOSE
14692-
14693-# ifndef yystrlen
14694-# if defined __GLIBC__ && defined _STRING_H
14695-# define yystrlen strlen
14696-# else
14697-/* Return the length of YYSTR. */
14698-#if (defined __STDC__ || defined __C99__FUNC__ \
14699- || defined __cplusplus || defined _MSC_VER)
14700-static YYSIZE_T
14701-yystrlen (const char *yystr)
14702-#else
14703-static YYSIZE_T
14704-yystrlen (yystr)
14705- const char *yystr;
14706-#endif
14707-{
14708- YYSIZE_T yylen;
14709- for (yylen = 0; yystr[yylen]; yylen++)
14710- continue;
14711- return yylen;
14712-}
14713-# endif
14714-# endif
14715-
14716-# ifndef yystpcpy
14717-# if defined __GLIBC__ && defined _STRING_H && defined _GNU_SOURCE
14718-# define yystpcpy stpcpy
14719-# else
14720-/* Copy YYSRC to YYDEST, returning the address of the terminating '\0' in
14721- YYDEST. */
14722-#if (defined __STDC__ || defined __C99__FUNC__ \
14723- || defined __cplusplus || defined _MSC_VER)
14724-static char *
14725-yystpcpy (char *yydest, const char *yysrc)
14726-#else
14727-static char *
14728-yystpcpy (yydest, yysrc)
14729- char *yydest;
14730- const char *yysrc;
14731-#endif
14732-{
14733- char *yyd = yydest;
14734- const char *yys = yysrc;
14735-
14736- while ((*yyd++ = *yys++) != '\0')
14737- continue;
14738-
14739- return yyd - 1;
14740-}
14741-# endif
14742-# endif
14743-
14744-# ifndef yytnamerr
14745-/* Copy to YYRES the contents of YYSTR after stripping away unnecessary
14746- quotes and backslashes, so that it's suitable for yyerror. The
14747- heuristic is that double-quoting is unnecessary unless the string
14748- contains an apostrophe, a comma, or backslash (other than
14749- backslash-backslash). YYSTR is taken from yytname. If YYRES is
14750- null, do not copy; instead, return the length of what the result
14751- would have been. */
14752-static YYSIZE_T
14753-yytnamerr (char *yyres, const char *yystr)
14754-{
14755- if (*yystr == '"')
14756- {
14757- YYSIZE_T yyn = 0;
14758- char const *yyp = yystr;
14759-
14760- for (;;)
14761- switch (*++yyp)
14762- {
14763- case '\'':
14764- case ',':
14765- goto do_not_strip_quotes;
14766-
14767- case '\\':
14768- if (*++yyp != '\\')
14769- goto do_not_strip_quotes;
14770- /* Fall through. */
14771- default:
14772- if (yyres)
14773- yyres[yyn] = *yyp;
14774- yyn++;
14775- break;
14776-
14777- case '"':
14778- if (yyres)
14779- yyres[yyn] = '\0';
14780- return yyn;
14781- }
14782- do_not_strip_quotes: ;
14783- }
14784-
14785- if (! yyres)
14786- return yystrlen (yystr);
14787-
14788- return yystpcpy (yyres, yystr) - yyres;
14789-}
14790-# endif
14791-
14792-/* Copy into YYRESULT an error message about the unexpected token
14793- YYCHAR while in state YYSTATE. Return the number of bytes copied,
14794- including the terminating null byte. If YYRESULT is null, do not
14795- copy anything; just return the number of bytes that would be
14796- copied. As a special case, return 0 if an ordinary "syntax error"
14797- message will do. Return YYSIZE_MAXIMUM if overflow occurs during
14798- size calculation. */
14799-static YYSIZE_T
14800-yysyntax_error (char *yyresult, int yystate, int yychar)
14801-{
14802- int yyn = yypact[yystate];
14803-
14804- if (! (YYPACT_NINF < yyn && yyn <= YYLAST))
14805- return 0;
14806- else
14807- {
14808- int yytype = YYTRANSLATE (yychar);
14809- YYSIZE_T yysize0 = yytnamerr (0, yytname[yytype]);
14810- YYSIZE_T yysize = yysize0;
14811- YYSIZE_T yysize1;
14812- int yysize_overflow = 0;
14813- enum { YYERROR_VERBOSE_ARGS_MAXIMUM = 5 };
14814- char const *yyarg[YYERROR_VERBOSE_ARGS_MAXIMUM];
14815- int yyx;
14816-
14817-# if 0
14818- /* This is so xgettext sees the translatable formats that are
14819- constructed on the fly. */
14820- YY_("syntax error, unexpected %s");
14821- YY_("syntax error, unexpected %s, expecting %s");
14822- YY_("syntax error, unexpected %s, expecting %s or %s");
14823- YY_("syntax error, unexpected %s, expecting %s or %s or %s");
14824- YY_("syntax error, unexpected %s, expecting %s or %s or %s or %s");
14825-# endif
14826- char *yyfmt;
14827- char const *yyf;
14828- static char const yyunexpected[] = "syntax error, unexpected %s";
14829- static char const yyexpecting[] = ", expecting %s";
14830- static char const yyor[] = " or %s";
14831- char yyformat[sizeof yyunexpected
14832- + sizeof yyexpecting - 1
14833- + ((YYERROR_VERBOSE_ARGS_MAXIMUM - 2)
14834- * (sizeof yyor - 1))];
14835- char const *yyprefix = yyexpecting;
14836-
14837- /* Start YYX at -YYN if negative to avoid negative indexes in
14838- YYCHECK. */
14839- int yyxbegin = yyn < 0 ? -yyn : 0;
14840-
14841- /* Stay within bounds of both yycheck and yytname. */
14842- int yychecklim = YYLAST - yyn + 1;
14843- int yyxend = yychecklim < YYNTOKENS ? yychecklim : YYNTOKENS;
14844- int yycount = 1;
14845-
14846- yyarg[0] = yytname[yytype];
14847- yyfmt = yystpcpy (yyformat, yyunexpected);
14848-
14849- for (yyx = yyxbegin; yyx < yyxend; ++yyx)
14850- if (yycheck[yyx + yyn] == yyx && yyx != YYTERROR)
14851- {
14852- if (yycount == YYERROR_VERBOSE_ARGS_MAXIMUM)
14853- {
14854- yycount = 1;
14855- yysize = yysize0;
14856- yyformat[sizeof yyunexpected - 1] = '\0';
14857- break;
14858- }
14859- yyarg[yycount++] = yytname[yyx];
14860- yysize1 = yysize + yytnamerr (0, yytname[yyx]);
14861- yysize_overflow |= (yysize1 < yysize);
14862- yysize = yysize1;
14863- yyfmt = yystpcpy (yyfmt, yyprefix);
14864- yyprefix = yyor;
14865- }
14866-
14867- yyf = YY_(yyformat);
14868- yysize1 = yysize + yystrlen (yyf);
14869- yysize_overflow |= (yysize1 < yysize);
14870- yysize = yysize1;
14871-
14872- if (yysize_overflow)
14873- return YYSIZE_MAXIMUM;
14874-
14875- if (yyresult)
14876- {
14877- /* Avoid sprintf, as that infringes on the user's name space.
14878- Don't have undefined behavior even if the translation
14879- produced a string with the wrong number of "%s"s. */
14880- char *yyp = yyresult;
14881- int yyi = 0;
14882- while ((*yyp = *yyf) != '\0')
14883- {
14884- if (*yyp == '%' && yyf[1] == 's' && yyi < yycount)
14885- {
14886- yyp += yytnamerr (yyp, yyarg[yyi++]);
14887- yyf += 2;
14888- }
14889- else
14890- {
14891- yyp++;
14892- yyf++;
14893- }
14894- }
14895- }
14896- return yysize;
14897- }
14898-}
14899-#endif /* YYERROR_VERBOSE */
14900-
14901-
14902-/*-----------------------------------------------.
14903-| Release the memory associated to this symbol. |
14904-`-----------------------------------------------*/
14905-
14906-/*ARGSUSED*/
14907-#if (defined __STDC__ || defined __C99__FUNC__ \
14908- || defined __cplusplus || defined _MSC_VER)
14909-static void
14910-yydestruct (const char *yymsg, int yytype, YYSTYPE *yyvaluep)
14911-#else
14912-static void
14913-yydestruct (yymsg, yytype, yyvaluep)
14914- const char *yymsg;
14915- int yytype;
14916- YYSTYPE *yyvaluep;
14917-#endif
14918-{
14919- YYUSE (yyvaluep);
14920-
14921- if (!yymsg)
14922- yymsg = "Deleting";
14923- YY_SYMBOL_PRINT (yymsg, yytype, yyvaluep, yylocationp);
14924-
14925- switch (yytype)
14926- {
14927-
14928- default:
14929- break;
14930- }
14931-}
14932-
14933-/* Prevent warnings from -Wmissing-prototypes. */
14934-#ifdef YYPARSE_PARAM
14935-#if defined __STDC__ || defined __cplusplus
14936-int yyparse (void *YYPARSE_PARAM);
14937-#else
14938-int yyparse ();
14939-#endif
14940-#else /* ! YYPARSE_PARAM */
14941-#if defined __STDC__ || defined __cplusplus
14942-int yyparse (void);
14943-#else
14944-int yyparse ();
14945-#endif
14946-#endif /* ! YYPARSE_PARAM */
14947-
14948-
14949-
14950-
14951-
14952-/*-------------------------.
14953-| yyparse or yypush_parse. |
14954-`-------------------------*/
14955-
14956-#ifdef YYPARSE_PARAM
14957-#if (defined __STDC__ || defined __C99__FUNC__ \
14958- || defined __cplusplus || defined _MSC_VER)
14959-int
14960-yyparse (void *YYPARSE_PARAM)
14961-#else
14962-int
14963-yyparse (YYPARSE_PARAM)
14964- void *YYPARSE_PARAM;
14965-#endif
14966-#else /* ! YYPARSE_PARAM */
14967-#if (defined __STDC__ || defined __C99__FUNC__ \
14968- || defined __cplusplus || defined _MSC_VER)
14969-int
14970-yyparse (void)
14971-#else
14972-int
14973-yyparse ()
14974-
14975-#endif
14976-#endif
14977-{
14978-/* The lookahead symbol. */
14979-int yychar;
14980-
14981-/* The semantic value of the lookahead symbol. */
14982-YYSTYPE yylval;
14983-
14984- /* Number of syntax errors so far. */
14985- int yynerrs;
14986-
14987- int yystate;
14988- /* Number of tokens to shift before error messages enabled. */
14989- int yyerrstatus;
14990-
14991- /* The stacks and their tools:
14992- `yyss': related to states.
14993- `yyvs': related to semantic values.
14994-
14995- Refer to the stacks thru separate pointers, to allow yyoverflow
14996- to reallocate them elsewhere. */
14997-
14998- /* The state stack. */
14999- yytype_int16 yyssa[YYINITDEPTH];
15000- yytype_int16 *yyss;
15001- yytype_int16 *yyssp;
15002-
15003- /* The semantic value stack. */
15004- YYSTYPE yyvsa[YYINITDEPTH];
15005- YYSTYPE *yyvs;
15006- YYSTYPE *yyvsp;
15007-
15008- YYSIZE_T yystacksize;
15009-
15010- int yyn;
15011- int yyresult;
15012- /* Lookahead token as an internal (translated) token number. */
15013- int yytoken;
15014- /* The variables used to return semantic value and location from the
15015- action routines. */
15016- YYSTYPE yyval;
15017-
15018-#if YYERROR_VERBOSE
15019- /* Buffer for error messages, and its allocated size. */
15020- char yymsgbuf[128];
15021- char *yymsg = yymsgbuf;
15022- YYSIZE_T yymsg_alloc = sizeof yymsgbuf;
15023-#endif
15024-
15025-#define YYPOPSTACK(N) (yyvsp -= (N), yyssp -= (N))
15026-
15027- /* The number of symbols on the RHS of the reduced rule.
15028- Keep to zero when no symbol should be popped. */
15029- int yylen = 0;
15030-
15031- yytoken = 0;
15032- yyss = yyssa;
15033- yyvs = yyvsa;
15034- yystacksize = YYINITDEPTH;
15035-
15036- YYDPRINTF ((stderr, "Starting parse\n"));
15037-
15038- yystate = 0;
15039- yyerrstatus = 0;
15040- yynerrs = 0;
15041- yychar = YYEMPTY; /* Cause a token to be read. */
15042-
15043- /* Initialize stack pointers.
15044- Waste one element of value and location stack
15045- so that they stay on the same level as the state stack.
15046- The wasted elements are never initialized. */
15047- yyssp = yyss;
15048- yyvsp = yyvs;
15049-
15050- goto yysetstate;
15051-
15052-/*------------------------------------------------------------.
15053-| yynewstate -- Push a new state, which is found in yystate. |
15054-`------------------------------------------------------------*/
15055- yynewstate:
15056- /* In all cases, when you get here, the value and location stacks
15057- have just been pushed. So pushing a state here evens the stacks. */
15058- yyssp++;
15059-
15060- yysetstate:
15061- *yyssp = yystate;
15062-
15063- if (yyss + yystacksize - 1 <= yyssp)
15064- {
15065- /* Get the current used size of the three stacks, in elements. */
15066- YYSIZE_T yysize = yyssp - yyss + 1;
15067-
15068-#ifdef yyoverflow
15069- {
15070- /* Give user a chance to reallocate the stack. Use copies of
15071- these so that the &'s don't force the real ones into
15072- memory. */
15073- YYSTYPE *yyvs1 = yyvs;
15074- yytype_int16 *yyss1 = yyss;
15075-
15076- /* Each stack pointer address is followed by the size of the
15077- data in use in that stack, in bytes. This used to be a
15078- conditional around just the two extra args, but that might
15079- be undefined if yyoverflow is a macro. */
15080- yyoverflow (YY_("memory exhausted"),
15081- &yyss1, yysize * sizeof (*yyssp),
15082- &yyvs1, yysize * sizeof (*yyvsp),
15083- &yystacksize);
15084-
15085- yyss = yyss1;
15086- yyvs = yyvs1;
15087- }
15088-#else /* no yyoverflow */
15089-# ifndef YYSTACK_RELOCATE
15090- goto yyexhaustedlab;
15091-# else
15092- /* Extend the stack our own way. */
15093- if (YYMAXDEPTH <= yystacksize)
15094- goto yyexhaustedlab;
15095- yystacksize *= 2;
15096- if (YYMAXDEPTH < yystacksize)
15097- yystacksize = YYMAXDEPTH;
15098-
15099- {
15100- yytype_int16 *yyss1 = yyss;
15101- union yyalloc *yyptr =
15102- (union yyalloc *) YYSTACK_ALLOC (YYSTACK_BYTES (yystacksize));
15103- if (! yyptr)
15104- goto yyexhaustedlab;
15105- YYSTACK_RELOCATE (yyss_alloc, yyss);
15106- YYSTACK_RELOCATE (yyvs_alloc, yyvs);
15107-# undef YYSTACK_RELOCATE
15108- if (yyss1 != yyssa)
15109- YYSTACK_FREE (yyss1);
15110- }
15111-# endif
15112-#endif /* no yyoverflow */
15113-
15114- yyssp = yyss + yysize - 1;
15115- yyvsp = yyvs + yysize - 1;
15116-
15117- YYDPRINTF ((stderr, "Stack size increased to %lu\n",
15118- (unsigned long int) yystacksize));
15119-
15120- if (yyss + yystacksize - 1 <= yyssp)
15121- YYABORT;
15122- }
15123-
15124- YYDPRINTF ((stderr, "Entering state %d\n", yystate));
15125-
15126- if (yystate == YYFINAL)
15127- YYACCEPT;
15128-
15129- goto yybackup;
15130-
15131-/*-----------.
15132-| yybackup. |
15133-`-----------*/
15134-yybackup:
15135-
15136- /* Do appropriate processing given the current state. Read a
15137- lookahead token if we need one and don't already have one. */
15138-
15139- /* First try to decide what to do without reference to lookahead token. */
15140- yyn = yypact[yystate];
15141- if (yyn == YYPACT_NINF)
15142- goto yydefault;
15143-
15144- /* Not known => get a lookahead token if don't already have one. */
15145-
15146- /* YYCHAR is either YYEMPTY or YYEOF or a valid lookahead symbol. */
15147- if (yychar == YYEMPTY)
15148- {
15149- YYDPRINTF ((stderr, "Reading a token: "));
15150- yychar = YYLEX;
15151- }
15152-
15153- if (yychar <= YYEOF)
15154- {
15155- yychar = yytoken = YYEOF;
15156- YYDPRINTF ((stderr, "Now at end of input.\n"));
15157- }
15158- else
15159- {
15160- yytoken = YYTRANSLATE (yychar);
15161- YY_SYMBOL_PRINT ("Next token is", yytoken, &yylval, &yylloc);
15162- }
15163-
15164- /* If the proper action on seeing token YYTOKEN is to reduce or to
15165- detect an error, take that action. */
15166- yyn += yytoken;
15167- if (yyn < 0 || YYLAST < yyn || yycheck[yyn] != yytoken)
15168- goto yydefault;
15169- yyn = yytable[yyn];
15170- if (yyn <= 0)
15171- {
15172- if (yyn == 0 || yyn == YYTABLE_NINF)
15173- goto yyerrlab;
15174- yyn = -yyn;
15175- goto yyreduce;
15176- }
15177-
15178- /* Count tokens shifted since error; after three, turn off error
15179- status. */
15180- if (yyerrstatus)
15181- yyerrstatus--;
15182-
15183- /* Shift the lookahead token. */
15184- YY_SYMBOL_PRINT ("Shifting", yytoken, &yylval, &yylloc);
15185-
15186- /* Discard the shifted token. */
15187- yychar = YYEMPTY;
15188-
15189- yystate = yyn;
15190- *++yyvsp = yylval;
15191-
15192- goto yynewstate;
15193-
15194-
15195-/*-----------------------------------------------------------.
15196-| yydefault -- do the default action for the current state. |
15197-`-----------------------------------------------------------*/
15198-yydefault:
15199- yyn = yydefact[yystate];
15200- if (yyn == 0)
15201- goto yyerrlab;
15202- goto yyreduce;
15203-
15204-
15205-/*-----------------------------.
15206-| yyreduce -- Do a reduction. |
15207-`-----------------------------*/
15208-yyreduce:
15209- /* yyn is the number of a rule to reduce with. */
15210- yylen = yyr2[yyn];
15211-
15212- /* If YYLEN is nonzero, implement the default value of the action:
15213- `$$ = $1'.
15214-
15215- Otherwise, the following line sets YYVAL to garbage.
15216- This behavior is undocumented and Bison
15217- users should not rely upon it. Assigning to YYVAL
15218- unconditionally makes the parser a bit smaller, and it avoids a
15219- GCC warning that YYVAL may be used uninitialized. */
15220- yyval = yyvsp[1-yylen];
15221-
15222-
15223- YY_REDUCE_PRINT (yyn);
15224- switch (yyn)
15225- {
15226- case 2:
15227-
15228-/* Line 1455 of yacc.c */
15229-#line 155 "plural.y"
15230- {
15231- if ((yyvsp[(1) - (1)].exp) == NULL)
15232- YYABORT;
15233- ((struct parse_args *) arg)->res = (yyvsp[(1) - (1)].exp);
15234- }
15235- break;
15236-
15237- case 3:
15238-
15239-/* Line 1455 of yacc.c */
15240-#line 163 "plural.y"
15241- {
15242- (yyval.exp) = new_exp_3 (qmop, (yyvsp[(1) - (5)].exp), (yyvsp[(3) - (5)].exp), (yyvsp[(5) - (5)].exp));
15243- }
15244- break;
15245-
15246- case 4:
15247-
15248-/* Line 1455 of yacc.c */
15249-#line 167 "plural.y"
15250- {
15251- (yyval.exp) = new_exp_2 (lor, (yyvsp[(1) - (3)].exp), (yyvsp[(3) - (3)].exp));
15252- }
15253- break;
15254-
15255- case 5:
15256-
15257-/* Line 1455 of yacc.c */
15258-#line 171 "plural.y"
15259- {
15260- (yyval.exp) = new_exp_2 (land, (yyvsp[(1) - (3)].exp), (yyvsp[(3) - (3)].exp));
15261- }
15262- break;
15263-
15264- case 6:
15265-
15266-/* Line 1455 of yacc.c */
15267-#line 175 "plural.y"
15268- {
15269- (yyval.exp) = new_exp_2 ((yyvsp[(2) - (3)].op), (yyvsp[(1) - (3)].exp), (yyvsp[(3) - (3)].exp));
15270- }
15271- break;
15272-
15273- case 7:
15274-
15275-/* Line 1455 of yacc.c */
15276-#line 179 "plural.y"
15277- {
15278- (yyval.exp) = new_exp_2 ((yyvsp[(2) - (3)].op), (yyvsp[(1) - (3)].exp), (yyvsp[(3) - (3)].exp));
15279- }
15280- break;
15281-
15282- case 8:
15283-
15284-/* Line 1455 of yacc.c */
15285-#line 183 "plural.y"
15286- {
15287- (yyval.exp) = new_exp_2 ((yyvsp[(2) - (3)].op), (yyvsp[(1) - (3)].exp), (yyvsp[(3) - (3)].exp));
15288- }
15289- break;
15290-
15291- case 9:
15292-
15293-/* Line 1455 of yacc.c */
15294-#line 187 "plural.y"
15295- {
15296- (yyval.exp) = new_exp_2 ((yyvsp[(2) - (3)].op), (yyvsp[(1) - (3)].exp), (yyvsp[(3) - (3)].exp));
15297- }
15298- break;
15299-
15300- case 10:
15301-
15302-/* Line 1455 of yacc.c */
15303-#line 191 "plural.y"
15304- {
15305- (yyval.exp) = new_exp_1 (lnot, (yyvsp[(2) - (2)].exp));
15306- }
15307- break;
15308-
15309- case 11:
15310-
15311-/* Line 1455 of yacc.c */
15312-#line 195 "plural.y"
15313- {
15314- (yyval.exp) = new_exp_0 (var);
15315- }
15316- break;
15317-
15318- case 12:
15319-
15320-/* Line 1455 of yacc.c */
15321-#line 199 "plural.y"
15322- {
15323- if (((yyval.exp) = new_exp_0 (num)) != NULL)
15324- (yyval.exp)->val.num = (yyvsp[(1) - (1)].num);
15325- }
15326- break;
15327-
15328- case 13:
15329-
15330-/* Line 1455 of yacc.c */
15331-#line 204 "plural.y"
15332- {
15333- (yyval.exp) = (yyvsp[(2) - (3)].exp);
15334- }
15335- break;
15336-
15337-
15338-
15339-/* Line 1455 of yacc.c */
15340-#line 1592 "plural.c"
15341- default: break;
15342- }
15343- YY_SYMBOL_PRINT ("-> $$ =", yyr1[yyn], &yyval, &yyloc);
15344-
15345- YYPOPSTACK (yylen);
15346- yylen = 0;
15347- YY_STACK_PRINT (yyss, yyssp);
15348-
15349- *++yyvsp = yyval;
15350-
15351- /* Now `shift' the result of the reduction. Determine what state
15352- that goes to, based on the state we popped back to and the rule
15353- number reduced by. */
15354-
15355- yyn = yyr1[yyn];
15356-
15357- yystate = yypgoto[yyn - YYNTOKENS] + *yyssp;
15358- if (0 <= yystate && yystate <= YYLAST && yycheck[yystate] == *yyssp)
15359- yystate = yytable[yystate];
15360- else
15361- yystate = yydefgoto[yyn - YYNTOKENS];
15362-
15363- goto yynewstate;
15364-
15365-
15366-/*------------------------------------.
15367-| yyerrlab -- here on detecting error |
15368-`------------------------------------*/
15369-yyerrlab:
15370- /* If not already recovering from an error, report this error. */
15371- if (!yyerrstatus)
15372- {
15373- ++yynerrs;
15374-#if ! YYERROR_VERBOSE
15375- yyerror (YY_("syntax error"));
15376-#else
15377- {
15378- YYSIZE_T yysize = yysyntax_error (0, yystate, yychar);
15379- if (yymsg_alloc < yysize && yymsg_alloc < YYSTACK_ALLOC_MAXIMUM)
15380- {
15381- YYSIZE_T yyalloc = 2 * yysize;
15382- if (! (yysize <= yyalloc && yyalloc <= YYSTACK_ALLOC_MAXIMUM))
15383- yyalloc = YYSTACK_ALLOC_MAXIMUM;
15384- if (yymsg != yymsgbuf)
15385- YYSTACK_FREE (yymsg);
15386- yymsg = (char *) YYSTACK_ALLOC (yyalloc);
15387- if (yymsg)
15388- yymsg_alloc = yyalloc;
15389- else
15390- {
15391- yymsg = yymsgbuf;
15392- yymsg_alloc = sizeof yymsgbuf;
15393- }
15394- }
15395-
15396- if (0 < yysize && yysize <= yymsg_alloc)
15397- {
15398- (void) yysyntax_error (yymsg, yystate, yychar);
15399- yyerror (yymsg);
15400- }
15401- else
15402- {
15403- yyerror (YY_("syntax error"));
15404- if (yysize != 0)
15405- goto yyexhaustedlab;
15406- }
15407- }
15408-#endif
15409- }
15410-
15411-
15412-
15413- if (yyerrstatus == 3)
15414- {
15415- /* If just tried and failed to reuse lookahead token after an
15416- error, discard it. */
15417-
15418- if (yychar <= YYEOF)
15419- {
15420- /* Return failure if at end of input. */
15421- if (yychar == YYEOF)
15422- YYABORT;
15423- }
15424- else
15425- {
15426- yydestruct ("Error: discarding",
15427- yytoken, &yylval);
15428- yychar = YYEMPTY;
15429- }
15430- }
15431-
15432- /* Else will try to reuse lookahead token after shifting the error
15433- token. */
15434- goto yyerrlab1;
15435-
15436-
15437-/*---------------------------------------------------.
15438-| yyerrorlab -- error raised explicitly by YYERROR. |
15439-`---------------------------------------------------*/
15440-yyerrorlab:
15441-
15442- /* Pacify compilers like GCC when the user code never invokes
15443- YYERROR and the label yyerrorlab therefore never appears in user
15444- code. */
15445- if (/*CONSTCOND*/ 0)
15446- goto yyerrorlab;
15447-
15448- /* Do not reclaim the symbols of the rule which action triggered
15449- this YYERROR. */
15450- YYPOPSTACK (yylen);
15451- yylen = 0;
15452- YY_STACK_PRINT (yyss, yyssp);
15453- yystate = *yyssp;
15454- goto yyerrlab1;
15455-
15456-
15457-/*-------------------------------------------------------------.
15458-| yyerrlab1 -- common code for both syntax error and YYERROR. |
15459-`-------------------------------------------------------------*/
15460-yyerrlab1:
15461- yyerrstatus = 3; /* Each real token shifted decrements this. */
15462-
15463- for (;;)
15464- {
15465- yyn = yypact[yystate];
15466- if (yyn != YYPACT_NINF)
15467- {
15468- yyn += YYTERROR;
15469- if (0 <= yyn && yyn <= YYLAST && yycheck[yyn] == YYTERROR)
15470- {
15471- yyn = yytable[yyn];
15472- if (0 < yyn)
15473- break;
15474- }
15475- }
15476-
15477- /* Pop the current state because it cannot handle the error token. */
15478- if (yyssp == yyss)
15479- YYABORT;
15480-
15481-
15482- yydestruct ("Error: popping",
15483- yystos[yystate], yyvsp);
15484- YYPOPSTACK (1);
15485- yystate = *yyssp;
15486- YY_STACK_PRINT (yyss, yyssp);
15487- }
15488-
15489- *++yyvsp = yylval;
15490-
15491-
15492- /* Shift the error token. */
15493- YY_SYMBOL_PRINT ("Shifting", yystos[yyn], yyvsp, yylsp);
15494-
15495- yystate = yyn;
15496- goto yynewstate;
15497-
15498-
15499-/*-------------------------------------.
15500-| yyacceptlab -- YYACCEPT comes here. |
15501-`-------------------------------------*/
15502-yyacceptlab:
15503- yyresult = 0;
15504- goto yyreturn;
15505-
15506-/*-----------------------------------.
15507-| yyabortlab -- YYABORT comes here. |
15508-`-----------------------------------*/
15509-yyabortlab:
15510- yyresult = 1;
15511- goto yyreturn;
15512-
15513-#if !defined(yyoverflow) || YYERROR_VERBOSE
15514-/*-------------------------------------------------.
15515-| yyexhaustedlab -- memory exhaustion comes here. |
15516-`-------------------------------------------------*/
15517-yyexhaustedlab:
15518- yyerror (YY_("memory exhausted"));
15519- yyresult = 2;
15520- /* Fall through. */
15521-#endif
15522-
15523-yyreturn:
15524- if (yychar != YYEMPTY)
15525- yydestruct ("Cleanup: discarding lookahead",
15526- yytoken, &yylval);
15527- /* Do not reclaim the symbols of the rule which action triggered
15528- this YYABORT or YYACCEPT. */
15529- YYPOPSTACK (yylen);
15530- YY_STACK_PRINT (yyss, yyssp);
15531- while (yyssp != yyss)
15532- {
15533- yydestruct ("Cleanup: popping",
15534- yystos[*yyssp], yyvsp);
15535- YYPOPSTACK (1);
15536- }
15537-#ifndef yyoverflow
15538- if (yyss != yyssa)
15539- YYSTACK_FREE (yyss);
15540-#endif
15541-#if YYERROR_VERBOSE
15542- if (yymsg != yymsgbuf)
15543- YYSTACK_FREE (yymsg);
15544-#endif
15545- /* Make sure YYID is used. */
15546- return YYID (yyresult);
15547-}
15548-
15549-
15550-
15551-/* Line 1675 of yacc.c */
15552-#line 209 "plural.y"
15553-
15554-
15555-void
15556-internal_function
15557-FREE_EXPRESSION (struct expression *exp)
15558-{
15559- if (exp == NULL)
15560- return;
15561-
15562- /* Handle the recursive case. */
15563- switch (exp->nargs)
15564- {
15565- case 3:
15566- FREE_EXPRESSION (exp->val.args[2]);
15567- /* FALLTHROUGH */
15568- case 2:
15569- FREE_EXPRESSION (exp->val.args[1]);
15570- /* FALLTHROUGH */
15571- case 1:
15572- FREE_EXPRESSION (exp->val.args[0]);
15573- /* FALLTHROUGH */
15574- default:
15575- break;
15576- }
15577-
15578- free (exp);
15579-}
15580-
15581-
15582-static int
15583-yylex (YYSTYPE *lval, const char **pexp)
15584-{
15585- const char *exp = *pexp;
15586- int result;
15587-
15588- while (1)
15589- {
15590- if (exp[0] == '\0')
15591- {
15592- *pexp = exp;
15593- return YYEOF;
15594- }
15595-
15596- if (exp[0] != ' ' && exp[0] != '\t')
15597- break;
15598-
15599- ++exp;
15600- }
15601-
15602- result = *exp++;
15603- switch (result)
15604- {
15605- case '0': case '1': case '2': case '3': case '4':
15606- case '5': case '6': case '7': case '8': case '9':
15607- {
15608- unsigned long int n = result - '0';
15609- while (exp[0] >= '0' && exp[0] <= '9')
15610- {
15611- n *= 10;
15612- n += exp[0] - '0';
15613- ++exp;
15614- }
15615- lval->num = n;
15616- result = NUMBER;
15617- }
15618- break;
15619-
15620- case '=':
15621- if (exp[0] == '=')
15622- {
15623- ++exp;
15624- lval->op = equal;
15625- result = EQUOP2;
15626- }
15627- else
15628- result = YYERRCODE;
15629- break;
15630-
15631- case '!':
15632- if (exp[0] == '=')
15633- {
15634- ++exp;
15635- lval->op = not_equal;
15636- result = EQUOP2;
15637- }
15638- break;
15639-
15640- case '&':
15641- case '|':
15642- if (exp[0] == result)
15643- ++exp;
15644- else
15645- result = YYERRCODE;
15646- break;
15647-
15648- case '<':
15649- if (exp[0] == '=')
15650- {
15651- ++exp;
15652- lval->op = less_or_equal;
15653- }
15654- else
15655- lval->op = less_than;
15656- result = CMPOP2;
15657- break;
15658-
15659- case '>':
15660- if (exp[0] == '=')
15661- {
15662- ++exp;
15663- lval->op = greater_or_equal;
15664- }
15665- else
15666- lval->op = greater_than;
15667- result = CMPOP2;
15668- break;
15669-
15670- case '*':
15671- lval->op = mult;
15672- result = MULOP2;
15673- break;
15674-
15675- case '/':
15676- lval->op = divide;
15677- result = MULOP2;
15678- break;
15679-
15680- case '%':
15681- lval->op = module;
15682- result = MULOP2;
15683- break;
15684-
15685- case '+':
15686- lval->op = plus;
15687- result = ADDOP2;
15688- break;
15689-
15690- case '-':
15691- lval->op = minus;
15692- result = ADDOP2;
15693- break;
15694-
15695- case 'n':
15696- case '?':
15697- case ':':
15698- case '(':
15699- case ')':
15700- /* Nothing, just return the character. */
15701- break;
15702-
15703- case ';':
15704- case '\n':
15705- case '\0':
15706- /* Be safe and let the user call this function again. */
15707- --exp;
15708- result = YYEOF;
15709- break;
15710-
15711- default:
15712- result = YYERRCODE;
15713-#if YYDEBUG != 0
15714- --exp;
15715-#endif
15716- break;
15717- }
15718-
15719- *pexp = exp;
15720-
15721- return result;
15722-}
15723-
15724-
15725-static void
15726-yyerror (const char *str)
15727-{
15728- /* Do nothing. We don't print error messages here. */
15729-}
15730-
15731--- a/intl/plural.y
15732+++ /dev/null
15733@@ -1,385 +0,0 @@
15734-%{
15735-/* Expression parsing for plural form selection.
15736- Copyright (C) 2000-2001, 2003, 2005-2006 Free Software Foundation, Inc.
15737- Written by Ulrich Drepper <drepper@cygnus.com>, 2000.
15738-
15739- This program is free software; you can redistribute it and/or modify it
15740- under the terms of the GNU Library General Public License as published
15741- by the Free Software Foundation; either version 2, or (at your option)
15742- any later version.
15743-
15744- This program is distributed in the hope that it will be useful,
15745- but WITHOUT ANY WARRANTY; without even the implied warranty of
15746- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15747- Library General Public License for more details.
15748-
15749- You should have received a copy of the GNU Library General Public
15750- License along with this program; if not, write to the Free Software
15751- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
15752- USA. */
15753-
15754-/* For bison < 2.0, the bison generated parser uses alloca. AIX 3 forces us
15755- to put this declaration at the beginning of the file. The declaration in
15756- bison's skeleton file comes too late. This must come before <config.h>
15757- because <config.h> may include arbitrary system headers.
15758- This can go away once the AM_INTL_SUBDIR macro requires bison >= 2.0. */
15759-#if defined _AIX && !defined __GNUC__
15760- #pragma alloca
15761-#endif
15762-
15763-#ifdef HAVE_CONFIG_H
15764-# include <config.h>
15765-#endif
15766-
15767-#include <stddef.h>
15768-#include <stdlib.h>
15769-#include <string.h>
15770-#include "plural-exp.h"
15771-
15772-/* The main function generated by the parser is called __gettextparse,
15773- but we want it to be called PLURAL_PARSE. */
15774-#ifndef _LIBC
15775-# define __gettextparse PLURAL_PARSE
15776-#endif
15777-
15778-#define YYLEX_PARAM &((struct parse_args *) arg)->cp
15779-#define YYPARSE_PARAM arg
15780-%}
15781-%pure_parser
15782-%expect 7
15783-
15784-%union {
15785- unsigned long int num;
15786- enum expression_operator op;
15787- struct expression *exp;
15788-}
15789-
15790-%{
15791-/* Prototypes for local functions. */
15792-static int yylex (YYSTYPE *lval, const char **pexp);
15793-static void yyerror (const char *str);
15794-
15795-/* Allocation of expressions. */
15796-
15797-static struct expression *
15798-new_exp (int nargs, enum expression_operator op,
15799- struct expression * const *args)
15800-{
15801- int i;
15802- struct expression *newp;
15803-
15804- /* If any of the argument could not be malloc'ed, just return NULL. */
15805- for (i = nargs - 1; i >= 0; i--)
15806- if (args[i] == NULL)
15807- goto fail;
15808-
15809- /* Allocate a new expression. */
15810- newp = (struct expression *) malloc (sizeof (*newp));
15811- if (newp != NULL)
15812- {
15813- newp->nargs = nargs;
15814- newp->operation = op;
15815- for (i = nargs - 1; i >= 0; i--)
15816- newp->val.args[i] = args[i];
15817- return newp;
15818- }
15819-
15820- fail:
15821- for (i = nargs - 1; i >= 0; i--)
15822- FREE_EXPRESSION (args[i]);
15823-
15824- return NULL;
15825-}
15826-
15827-static inline struct expression *
15828-new_exp_0 (enum expression_operator op)
15829-{
15830- return new_exp (0, op, NULL);
15831-}
15832-
15833-static inline struct expression *
15834-new_exp_1 (enum expression_operator op, struct expression *right)
15835-{
15836- struct expression *args[1];
15837-
15838- args[0] = right;
15839- return new_exp (1, op, args);
15840-}
15841-
15842-static struct expression *
15843-new_exp_2 (enum expression_operator op, struct expression *left,
15844- struct expression *right)
15845-{
15846- struct expression *args[2];
15847-
15848- args[0] = left;
15849- args[1] = right;
15850- return new_exp (2, op, args);
15851-}
15852-
15853-static inline struct expression *
15854-new_exp_3 (enum expression_operator op, struct expression *bexp,
15855- struct expression *tbranch, struct expression *fbranch)
15856-{
15857- struct expression *args[3];
15858-
15859- args[0] = bexp;
15860- args[1] = tbranch;
15861- args[2] = fbranch;
15862- return new_exp (3, op, args);
15863-}
15864-
15865-%}
15866-
15867-/* This declares that all operators have the same associativity and the
15868- precedence order as in C. See [Harbison, Steele: C, A Reference Manual].
15869- There is no unary minus and no bitwise operators.
15870- Operators with the same syntactic behaviour have been merged into a single
15871- token, to save space in the array generated by bison. */
15872-%right '?' /* ? */
15873-%left '|' /* || */
15874-%left '&' /* && */
15875-%left EQUOP2 /* == != */
15876-%left CMPOP2 /* < > <= >= */
15877-%left ADDOP2 /* + - */
15878-%left MULOP2 /* * / % */
15879-%right '!' /* ! */
15880-
15881-%token <op> EQUOP2 CMPOP2 ADDOP2 MULOP2
15882-%token <num> NUMBER
15883-%type <exp> exp
15884-
15885-%%
15886-
15887-start: exp
15888- {
15889- if ($1 == NULL)
15890- YYABORT;
15891- ((struct parse_args *) arg)->res = $1;
15892- }
15893- ;
15894-
15895-exp: exp '?' exp ':' exp
15896- {
15897- $$ = new_exp_3 (qmop, $1, $3, $5);
15898- }
15899- | exp '|' exp
15900- {
15901- $$ = new_exp_2 (lor, $1, $3);
15902- }
15903- | exp '&' exp
15904- {
15905- $$ = new_exp_2 (land, $1, $3);
15906- }
15907- | exp EQUOP2 exp
15908- {
15909- $$ = new_exp_2 ($2, $1, $3);
15910- }
15911- | exp CMPOP2 exp
15912- {
15913- $$ = new_exp_2 ($2, $1, $3);
15914- }
15915- | exp ADDOP2 exp
15916- {
15917- $$ = new_exp_2 ($2, $1, $3);
15918- }
15919- | exp MULOP2 exp
15920- {
15921- $$ = new_exp_2 ($2, $1, $3);
15922- }
15923- | '!' exp
15924- {
15925- $$ = new_exp_1 (lnot, $2);
15926- }
15927- | 'n'
15928- {
15929- $$ = new_exp_0 (var);
15930- }
15931- | NUMBER
15932- {
15933- if (($$ = new_exp_0 (num)) != NULL)
15934- $$->val.num = $1;
15935- }
15936- | '(' exp ')'
15937- {
15938- $$ = $2;
15939- }
15940- ;
15941-
15942-%%
15943-
15944-void
15945-internal_function
15946-FREE_EXPRESSION (struct expression *exp)
15947-{
15948- if (exp == NULL)
15949- return;
15950-
15951- /* Handle the recursive case. */
15952- switch (exp->nargs)
15953- {
15954- case 3:
15955- FREE_EXPRESSION (exp->val.args[2]);
15956- /* FALLTHROUGH */
15957- case 2:
15958- FREE_EXPRESSION (exp->val.args[1]);
15959- /* FALLTHROUGH */
15960- case 1:
15961- FREE_EXPRESSION (exp->val.args[0]);
15962- /* FALLTHROUGH */
15963- default:
15964- break;
15965- }
15966-
15967- free (exp);
15968-}
15969-
15970-
15971-static int
15972-yylex (YYSTYPE *lval, const char **pexp)
15973-{
15974- const char *exp = *pexp;
15975- int result;
15976-
15977- while (1)
15978- {
15979- if (exp[0] == '\0')
15980- {
15981- *pexp = exp;
15982- return YYEOF;
15983- }
15984-
15985- if (exp[0] != ' ' && exp[0] != '\t')
15986- break;
15987-
15988- ++exp;
15989- }
15990-
15991- result = *exp++;
15992- switch (result)
15993- {
15994- case '0': case '1': case '2': case '3': case '4':
15995- case '5': case '6': case '7': case '8': case '9':
15996- {
15997- unsigned long int n = result - '0';
15998- while (exp[0] >= '0' && exp[0] <= '9')
15999- {
16000- n *= 10;
16001- n += exp[0] - '0';
16002- ++exp;
16003- }
16004- lval->num = n;
16005- result = NUMBER;
16006- }
16007- break;
16008-
16009- case '=':
16010- if (exp[0] == '=')
16011- {
16012- ++exp;
16013- lval->op = equal;
16014- result = EQUOP2;
16015- }
16016- else
16017- result = YYERRCODE;
16018- break;
16019-
16020- case '!':
16021- if (exp[0] == '=')
16022- {
16023- ++exp;
16024- lval->op = not_equal;
16025- result = EQUOP2;
16026- }
16027- break;
16028-
16029- case '&':
16030- case '|':
16031- if (exp[0] == result)
16032- ++exp;
16033- else
16034- result = YYERRCODE;
16035- break;
16036-
16037- case '<':
16038- if (exp[0] == '=')
16039- {
16040- ++exp;
16041- lval->op = less_or_equal;
16042- }
16043- else
16044- lval->op = less_than;
16045- result = CMPOP2;
16046- break;
16047-
16048- case '>':
16049- if (exp[0] == '=')
16050- {
16051- ++exp;
16052- lval->op = greater_or_equal;
16053- }
16054- else
16055- lval->op = greater_than;
16056- result = CMPOP2;
16057- break;
16058-
16059- case '*':
16060- lval->op = mult;
16061- result = MULOP2;
16062- break;
16063-
16064- case '/':
16065- lval->op = divide;
16066- result = MULOP2;
16067- break;
16068-
16069- case '%':
16070- lval->op = module;
16071- result = MULOP2;
16072- break;
16073-
16074- case '+':
16075- lval->op = plus;
16076- result = ADDOP2;
16077- break;
16078-
16079- case '-':
16080- lval->op = minus;
16081- result = ADDOP2;
16082- break;
16083-
16084- case 'n':
16085- case '?':
16086- case ':':
16087- case '(':
16088- case ')':
16089- /* Nothing, just return the character. */
16090- break;
16091-
16092- case ';':
16093- case '\n':
16094- case '\0':
16095- /* Be safe and let the user call this function again. */
16096- --exp;
16097- result = YYEOF;
16098- break;
16099-
16100- default:
16101- result = YYERRCODE;
16102-#if YYDEBUG != 0
16103- --exp;
16104-#endif
16105- break;
16106- }
16107-
16108- *pexp = exp;
16109-
16110- return result;
16111-}
16112-
16113-
16114-static void
16115-yyerror (const char *str)
16116-{
16117- /* Do nothing. We don't print error messages here. */
16118-}
16119--- a/intl/printf-args.c
16120+++ /dev/null
16121@@ -1,188 +0,0 @@
16122-/* Decomposed printf argument list.
16123- Copyright (C) 1999, 2002-2003, 2005-2007 Free Software Foundation, Inc.
16124-
16125- This program is free software; you can redistribute it and/or modify it
16126- under the terms of the GNU Library General Public License as published
16127- by the Free Software Foundation; either version 2, or (at your option)
16128- any later version.
16129-
16130- This program is distributed in the hope that it will be useful,
16131- but WITHOUT ANY WARRANTY; without even the implied warranty of
16132- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16133- Library General Public License for more details.
16134-
16135- You should have received a copy of the GNU Library General Public
16136- License along with this program; if not, write to the Free Software
16137- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
16138- USA. */
16139-
16140-/* This file can be parametrized with the following macros:
16141- ENABLE_UNISTDIO Set to 1 to enable the unistdio extensions.
16142- PRINTF_FETCHARGS Name of the function to be defined.
16143- STATIC Set to 'static' to declare the function static. */
16144-
16145-#ifndef PRINTF_FETCHARGS
16146-# include <config.h>
16147-#endif
16148-
16149-/* Specification. */
16150-#ifndef PRINTF_FETCHARGS
16151-# include "printf-args.h"
16152-#endif
16153-
16154-#ifdef STATIC
16155-STATIC
16156-#endif
16157-int
16158-PRINTF_FETCHARGS (va_list args, arguments *a)
16159-{
16160- size_t i;
16161- argument *ap;
16162-
16163- for (i = 0, ap = &a->arg[0]; i < a->count; i++, ap++)
16164- switch (ap->type)
16165- {
16166- case TYPE_SCHAR:
16167- ap->a.a_schar = va_arg (args, /*signed char*/ int);
16168- break;
16169- case TYPE_UCHAR:
16170- ap->a.a_uchar = va_arg (args, /*unsigned char*/ int);
16171- break;
16172- case TYPE_SHORT:
16173- ap->a.a_short = va_arg (args, /*short*/ int);
16174- break;
16175- case TYPE_USHORT:
16176- ap->a.a_ushort = va_arg (args, /*unsigned short*/ int);
16177- break;
16178- case TYPE_INT:
16179- ap->a.a_int = va_arg (args, int);
16180- break;
16181- case TYPE_UINT:
16182- ap->a.a_uint = va_arg (args, unsigned int);
16183- break;
16184- case TYPE_LONGINT:
16185- ap->a.a_longint = va_arg (args, long int);
16186- break;
16187- case TYPE_ULONGINT:
16188- ap->a.a_ulongint = va_arg (args, unsigned long int);
16189- break;
16190-#if HAVE_LONG_LONG_INT
16191- case TYPE_LONGLONGINT:
16192- ap->a.a_longlongint = va_arg (args, long long int);
16193- break;
16194- case TYPE_ULONGLONGINT:
16195- ap->a.a_ulonglongint = va_arg (args, unsigned long long int);
16196- break;
16197-#endif
16198- case TYPE_DOUBLE:
16199- ap->a.a_double = va_arg (args, double);
16200- break;
16201- case TYPE_LONGDOUBLE:
16202- ap->a.a_longdouble = va_arg (args, long double);
16203- break;
16204- case TYPE_CHAR:
16205- ap->a.a_char = va_arg (args, int);
16206- break;
16207-#if HAVE_WINT_T
16208- case TYPE_WIDE_CHAR:
16209- /* Although ISO C 99 7.24.1.(2) says that wint_t is "unchanged by
16210- default argument promotions", this is not the case in mingw32,
16211- where wint_t is 'unsigned short'. */
16212- ap->a.a_wide_char =
16213- (sizeof (wint_t) < sizeof (int)
16214- ? va_arg (args, int)
16215- : va_arg (args, wint_t));
16216- break;
16217-#endif
16218- case TYPE_STRING:
16219- ap->a.a_string = va_arg (args, const char *);
16220- /* A null pointer is an invalid argument for "%s", but in practice
16221- it occurs quite frequently in printf statements that produce
16222- debug output. Use a fallback in this case. */
16223- if (ap->a.a_string == NULL)
16224- ap->a.a_string = "(NULL)";
16225- break;
16226-#if HAVE_WCHAR_T
16227- case TYPE_WIDE_STRING:
16228- ap->a.a_wide_string = va_arg (args, const wchar_t *);
16229- /* A null pointer is an invalid argument for "%ls", but in practice
16230- it occurs quite frequently in printf statements that produce
16231- debug output. Use a fallback in this case. */
16232- if (ap->a.a_wide_string == NULL)
16233- {
16234- static const wchar_t wide_null_string[] =
16235- {
16236- (wchar_t)'(',
16237- (wchar_t)'N', (wchar_t)'U', (wchar_t)'L', (wchar_t)'L',
16238- (wchar_t)')',
16239- (wchar_t)0
16240- };
16241- ap->a.a_wide_string = wide_null_string;
16242- }
16243- break;
16244-#endif
16245- case TYPE_POINTER:
16246- ap->a.a_pointer = va_arg (args, void *);
16247- break;
16248- case TYPE_COUNT_SCHAR_POINTER:
16249- ap->a.a_count_schar_pointer = va_arg (args, signed char *);
16250- break;
16251- case TYPE_COUNT_SHORT_POINTER:
16252- ap->a.a_count_short_pointer = va_arg (args, short *);
16253- break;
16254- case TYPE_COUNT_INT_POINTER:
16255- ap->a.a_count_int_pointer = va_arg (args, int *);
16256- break;
16257- case TYPE_COUNT_LONGINT_POINTER:
16258- ap->a.a_count_longint_pointer = va_arg (args, long int *);
16259- break;
16260-#if HAVE_LONG_LONG_INT
16261- case TYPE_COUNT_LONGLONGINT_POINTER:
16262- ap->a.a_count_longlongint_pointer = va_arg (args, long long int *);
16263- break;
16264-#endif
16265-#if ENABLE_UNISTDIO
16266- /* The unistdio extensions. */
16267- case TYPE_U8_STRING:
16268- ap->a.a_u8_string = va_arg (args, const uint8_t *);
16269- /* A null pointer is an invalid argument for "%U", but in practice
16270- it occurs quite frequently in printf statements that produce
16271- debug output. Use a fallback in this case. */
16272- if (ap->a.a_u8_string == NULL)
16273- {
16274- static const uint8_t u8_null_string[] =
16275- { '(', 'N', 'U', 'L', 'L', ')', 0 };
16276- ap->a.a_u8_string = u8_null_string;
16277- }
16278- break;
16279- case TYPE_U16_STRING:
16280- ap->a.a_u16_string = va_arg (args, const uint16_t *);
16281- /* A null pointer is an invalid argument for "%lU", but in practice
16282- it occurs quite frequently in printf statements that produce
16283- debug output. Use a fallback in this case. */
16284- if (ap->a.a_u16_string == NULL)
16285- {
16286- static const uint16_t u16_null_string[] =
16287- { '(', 'N', 'U', 'L', 'L', ')', 0 };
16288- ap->a.a_u16_string = u16_null_string;
16289- }
16290- break;
16291- case TYPE_U32_STRING:
16292- ap->a.a_u32_string = va_arg (args, const uint32_t *);
16293- /* A null pointer is an invalid argument for "%llU", but in practice
16294- it occurs quite frequently in printf statements that produce
16295- debug output. Use a fallback in this case. */
16296- if (ap->a.a_u32_string == NULL)
16297- {
16298- static const uint32_t u32_null_string[] =
16299- { '(', 'N', 'U', 'L', 'L', ')', 0 };
16300- ap->a.a_u32_string = u32_null_string;
16301- }
16302- break;
16303-#endif
16304- default:
16305- /* Unknown type. */
16306- return -1;
16307- }
16308- return 0;
16309-}
16310--- a/intl/printf-args.h
16311+++ /dev/null
16312@@ -1,155 +0,0 @@
16313-/* Decomposed printf argument list.
16314- Copyright (C) 1999, 2002-2003, 2006-2007 Free Software Foundation, Inc.
16315-
16316- This program is free software; you can redistribute it and/or modify it
16317- under the terms of the GNU Library General Public License as published
16318- by the Free Software Foundation; either version 2, or (at your option)
16319- any later version.
16320-
16321- This program is distributed in the hope that it will be useful,
16322- but WITHOUT ANY WARRANTY; without even the implied warranty of
16323- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16324- Library General Public License for more details.
16325-
16326- You should have received a copy of the GNU Library General Public
16327- License along with this program; if not, write to the Free Software
16328- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
16329- USA. */
16330-
16331-#ifndef _PRINTF_ARGS_H
16332-#define _PRINTF_ARGS_H
16333-
16334-/* This file can be parametrized with the following macros:
16335- ENABLE_UNISTDIO Set to 1 to enable the unistdio extensions.
16336- PRINTF_FETCHARGS Name of the function to be declared.
16337- STATIC Set to 'static' to declare the function static. */
16338-
16339-/* Default parameters. */
16340-#ifndef PRINTF_FETCHARGS
16341-# define PRINTF_FETCHARGS printf_fetchargs
16342-#endif
16343-
16344-/* Get size_t. */
16345-#include <stddef.h>
16346-
16347-/* Get wchar_t. */
16348-#if HAVE_WCHAR_T
16349-# include <stddef.h>
16350-#endif
16351-
16352-/* Get wint_t. */
16353-#if HAVE_WINT_T
16354-# include <wchar.h>
16355-#endif
16356-
16357-/* Get va_list. */
16358-#include <stdarg.h>
16359-
16360-
16361-/* Argument types */
16362-typedef enum
16363-{
16364- TYPE_NONE,
16365- TYPE_SCHAR,
16366- TYPE_UCHAR,
16367- TYPE_SHORT,
16368- TYPE_USHORT,
16369- TYPE_INT,
16370- TYPE_UINT,
16371- TYPE_LONGINT,
16372- TYPE_ULONGINT,
16373-#if HAVE_LONG_LONG_INT
16374- TYPE_LONGLONGINT,
16375- TYPE_ULONGLONGINT,
16376-#endif
16377- TYPE_DOUBLE,
16378- TYPE_LONGDOUBLE,
16379- TYPE_CHAR,
16380-#if HAVE_WINT_T
16381- TYPE_WIDE_CHAR,
16382-#endif
16383- TYPE_STRING,
16384-#if HAVE_WCHAR_T
16385- TYPE_WIDE_STRING,
16386-#endif
16387- TYPE_POINTER,
16388- TYPE_COUNT_SCHAR_POINTER,
16389- TYPE_COUNT_SHORT_POINTER,
16390- TYPE_COUNT_INT_POINTER,
16391- TYPE_COUNT_LONGINT_POINTER
16392-#if HAVE_LONG_LONG_INT
16393-, TYPE_COUNT_LONGLONGINT_POINTER
16394-#endif
16395-#if ENABLE_UNISTDIO
16396- /* The unistdio extensions. */
16397-, TYPE_U8_STRING
16398-, TYPE_U16_STRING
16399-, TYPE_U32_STRING
16400-#endif
16401-} arg_type;
16402-
16403-/* Polymorphic argument */
16404-typedef struct
16405-{
16406- arg_type type;
16407- union
16408- {
16409- signed char a_schar;
16410- unsigned char a_uchar;
16411- short a_short;
16412- unsigned short a_ushort;
16413- int a_int;
16414- unsigned int a_uint;
16415- long int a_longint;
16416- unsigned long int a_ulongint;
16417-#if HAVE_LONG_LONG_INT
16418- long long int a_longlongint;
16419- unsigned long long int a_ulonglongint;
16420-#endif
16421- float a_float;
16422- double a_double;
16423- long double a_longdouble;
16424- int a_char;
16425-#if HAVE_WINT_T
16426- wint_t a_wide_char;
16427-#endif
16428- const char* a_string;
16429-#if HAVE_WCHAR_T
16430- const wchar_t* a_wide_string;
16431-#endif
16432- void* a_pointer;
16433- signed char * a_count_schar_pointer;
16434- short * a_count_short_pointer;
16435- int * a_count_int_pointer;
16436- long int * a_count_longint_pointer;
16437-#if HAVE_LONG_LONG_INT
16438- long long int * a_count_longlongint_pointer;
16439-#endif
16440-#if ENABLE_UNISTDIO
16441- /* The unistdio extensions. */
16442- const uint8_t * a_u8_string;
16443- const uint16_t * a_u16_string;
16444- const uint32_t * a_u32_string;
16445-#endif
16446- }
16447- a;
16448-}
16449-argument;
16450-
16451-typedef struct
16452-{
16453- size_t count;
16454- argument *arg;
16455-}
16456-arguments;
16457-
16458-
16459-/* Fetch the arguments, putting them into a. */
16460-#ifdef STATIC
16461-STATIC
16462-#else
16463-extern
16464-#endif
16465-int PRINTF_FETCHARGS (va_list args, arguments *a);
16466-
16467-#endif /* _PRINTF_ARGS_H */
16468--- a/intl/printf-parse.c
16469+++ /dev/null
16470@@ -1,590 +0,0 @@
16471-/* Formatted output to strings.
16472- Copyright (C) 1999-2000, 2002-2003, 2006-2007 Free Software Foundation, Inc.
16473-
16474- This program is free software; you can redistribute it and/or modify it
16475- under the terms of the GNU Library General Public License as published
16476- by the Free Software Foundation; either version 2, or (at your option)
16477- any later version.
16478-
16479- This program is distributed in the hope that it will be useful,
16480- but WITHOUT ANY WARRANTY; without even the implied warranty of
16481- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16482- Library General Public License for more details.
16483-
16484- You should have received a copy of the GNU Library General Public
16485- License along with this program; if not, write to the Free Software
16486- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
16487- USA. */
16488-
16489-/* This file can be parametrized with the following macros:
16490- CHAR_T The element type of the format string.
16491- CHAR_T_ONLY_ASCII Set to 1 to enable verification that all characters
16492- in the format string are ASCII.
16493- DIRECTIVE Structure denoting a format directive.
16494- Depends on CHAR_T.
16495- DIRECTIVES Structure denoting the set of format directives of a
16496- format string. Depends on CHAR_T.
16497- PRINTF_PARSE Function that parses a format string.
16498- Depends on CHAR_T.
16499- STATIC Set to 'static' to declare the function static.
16500- ENABLE_UNISTDIO Set to 1 to enable the unistdio extensions. */
16501-
16502-#ifndef PRINTF_PARSE
16503-# include <config.h>
16504-#endif
16505-
16506-/* Specification. */
16507-#ifndef PRINTF_PARSE
16508-# include "printf-parse.h"
16509-#endif
16510-
16511-/* Default parameters. */
16512-#ifndef PRINTF_PARSE
16513-# define PRINTF_PARSE printf_parse
16514-# define CHAR_T char
16515-# define DIRECTIVE char_directive
16516-# define DIRECTIVES char_directives
16517-#endif
16518-
16519-/* Get size_t, NULL. */
16520-#include <stddef.h>
16521-
16522-/* Get intmax_t. */
16523-#if defined IN_LIBINTL || defined IN_LIBASPRINTF
16524-# if HAVE_STDINT_H_WITH_UINTMAX
16525-# include <stdint.h>
16526-# endif
16527-# if HAVE_INTTYPES_H_WITH_UINTMAX
16528-# include <inttypes.h>
16529-# endif
16530-#else
16531-# include <stdint.h>
16532-#endif
16533-
16534-/* malloc(), realloc(), free(). */
16535-#include <stdlib.h>
16536-
16537-/* errno. */
16538-#include <errno.h>
16539-
16540-/* Checked size_t computations. */
16541-#include "xsize.h"
16542-
16543-#if CHAR_T_ONLY_ASCII
16544-/* c_isascii(). */
16545-# include "c-ctype.h"
16546-#endif
16547-
16548-#ifdef STATIC
16549-STATIC
16550-#endif
16551-int
16552-PRINTF_PARSE (const CHAR_T *format, DIRECTIVES *d, arguments *a)
16553-{
16554- const CHAR_T *cp = format; /* pointer into format */
16555- size_t arg_posn = 0; /* number of regular arguments consumed */
16556- size_t d_allocated; /* allocated elements of d->dir */
16557- size_t a_allocated; /* allocated elements of a->arg */
16558- size_t max_width_length = 0;
16559- size_t max_precision_length = 0;
16560-
16561- d->count = 0;
16562- d_allocated = 1;
16563- d->dir = (DIRECTIVE *) malloc (d_allocated * sizeof (DIRECTIVE));
16564- if (d->dir == NULL)
16565- /* Out of memory. */
16566- goto out_of_memory_1;
16567-
16568- a->count = 0;
16569- a_allocated = 0;
16570- a->arg = NULL;
16571-
16572-#define REGISTER_ARG(_index_,_type_) \
16573- { \
16574- size_t n = (_index_); \
16575- if (n >= a_allocated) \
16576- { \
16577- size_t memory_size; \
16578- argument *memory; \
16579- \
16580- a_allocated = xtimes (a_allocated, 2); \
16581- if (a_allocated <= n) \
16582- a_allocated = xsum (n, 1); \
16583- memory_size = xtimes (a_allocated, sizeof (argument)); \
16584- if (size_overflow_p (memory_size)) \
16585- /* Overflow, would lead to out of memory. */ \
16586- goto out_of_memory; \
16587- memory = (argument *) (a->arg \
16588- ? realloc (a->arg, memory_size) \
16589- : malloc (memory_size)); \
16590- if (memory == NULL) \
16591- /* Out of memory. */ \
16592- goto out_of_memory; \
16593- a->arg = memory; \
16594- } \
16595- while (a->count <= n) \
16596- a->arg[a->count++].type = TYPE_NONE; \
16597- if (a->arg[n].type == TYPE_NONE) \
16598- a->arg[n].type = (_type_); \
16599- else if (a->arg[n].type != (_type_)) \
16600- /* Ambiguous type for positional argument. */ \
16601- goto error; \
16602- }
16603-
16604- while (*cp != '\0')
16605- {
16606- CHAR_T c = *cp++;
16607- if (c == '%')
16608- {
16609- size_t arg_index = ARG_NONE;
16610- DIRECTIVE *dp = &d->dir[d->count]; /* pointer to next directive */
16611-
16612- /* Initialize the next directive. */
16613- dp->dir_start = cp - 1;
16614- dp->flags = 0;
16615- dp->width_start = NULL;
16616- dp->width_end = NULL;
16617- dp->width_arg_index = ARG_NONE;
16618- dp->precision_start = NULL;
16619- dp->precision_end = NULL;
16620- dp->precision_arg_index = ARG_NONE;
16621- dp->arg_index = ARG_NONE;
16622-
16623- /* Test for positional argument. */
16624- if (*cp >= '0' && *cp <= '9')
16625- {
16626- const CHAR_T *np;
16627-
16628- for (np = cp; *np >= '0' && *np <= '9'; np++)
16629- ;
16630- if (*np == '$')
16631- {
16632- size_t n = 0;
16633-
16634- for (np = cp; *np >= '0' && *np <= '9'; np++)
16635- n = xsum (xtimes (n, 10), *np - '0');
16636- if (n == 0)
16637- /* Positional argument 0. */
16638- goto error;
16639- if (size_overflow_p (n))
16640- /* n too large, would lead to out of memory later. */
16641- goto error;
16642- arg_index = n - 1;
16643- cp = np + 1;
16644- }
16645- }
16646-
16647- /* Read the flags. */
16648- for (;;)
16649- {
16650- if (*cp == '\'')
16651- {
16652- dp->flags |= FLAG_GROUP;
16653- cp++;
16654- }
16655- else if (*cp == '-')
16656- {
16657- dp->flags |= FLAG_LEFT;
16658- cp++;
16659- }
16660- else if (*cp == '+')
16661- {
16662- dp->flags |= FLAG_SHOWSIGN;
16663- cp++;
16664- }
16665- else if (*cp == ' ')
16666- {
16667- dp->flags |= FLAG_SPACE;
16668- cp++;
16669- }
16670- else if (*cp == '#')
16671- {
16672- dp->flags |= FLAG_ALT;
16673- cp++;
16674- }
16675- else if (*cp == '0')
16676- {
16677- dp->flags |= FLAG_ZERO;
16678- cp++;
16679- }
16680- else
16681- break;
16682- }
16683-
16684- /* Parse the field width. */
16685- if (*cp == '*')
16686- {
16687- dp->width_start = cp;
16688- cp++;
16689- dp->width_end = cp;
16690- if (max_width_length < 1)
16691- max_width_length = 1;
16692-
16693- /* Test for positional argument. */
16694- if (*cp >= '0' && *cp <= '9')
16695- {
16696- const CHAR_T *np;
16697-
16698- for (np = cp; *np >= '0' && *np <= '9'; np++)
16699- ;
16700- if (*np == '$')
16701- {
16702- size_t n = 0;
16703-
16704- for (np = cp; *np >= '0' && *np <= '9'; np++)
16705- n = xsum (xtimes (n, 10), *np - '0');
16706- if (n == 0)
16707- /* Positional argument 0. */
16708- goto error;
16709- if (size_overflow_p (n))
16710- /* n too large, would lead to out of memory later. */
16711- goto error;
16712- dp->width_arg_index = n - 1;
16713- cp = np + 1;
16714- }
16715- }
16716- if (dp->width_arg_index == ARG_NONE)
16717- {
16718- dp->width_arg_index = arg_posn++;
16719- if (dp->width_arg_index == ARG_NONE)
16720- /* arg_posn wrapped around. */
16721- goto error;
16722- }
16723- REGISTER_ARG (dp->width_arg_index, TYPE_INT);
16724- }
16725- else if (*cp >= '0' && *cp <= '9')
16726- {
16727- size_t width_length;
16728-
16729- dp->width_start = cp;
16730- for (; *cp >= '0' && *cp <= '9'; cp++)
16731- ;
16732- dp->width_end = cp;
16733- width_length = dp->width_end - dp->width_start;
16734- if (max_width_length < width_length)
16735- max_width_length = width_length;
16736- }
16737-
16738- /* Parse the precision. */
16739- if (*cp == '.')
16740- {
16741- cp++;
16742- if (*cp == '*')
16743- {
16744- dp->precision_start = cp - 1;
16745- cp++;
16746- dp->precision_end = cp;
16747- if (max_precision_length < 2)
16748- max_precision_length = 2;
16749-
16750- /* Test for positional argument. */
16751- if (*cp >= '0' && *cp <= '9')
16752- {
16753- const CHAR_T *np;
16754-
16755- for (np = cp; *np >= '0' && *np <= '9'; np++)
16756- ;
16757- if (*np == '$')
16758- {
16759- size_t n = 0;
16760-
16761- for (np = cp; *np >= '0' && *np <= '9'; np++)
16762- n = xsum (xtimes (n, 10), *np - '0');
16763- if (n == 0)
16764- /* Positional argument 0. */
16765- goto error;
16766- if (size_overflow_p (n))
16767- /* n too large, would lead to out of memory
16768- later. */
16769- goto error;
16770- dp->precision_arg_index = n - 1;
16771- cp = np + 1;
16772- }
16773- }
16774- if (dp->precision_arg_index == ARG_NONE)
16775- {
16776- dp->precision_arg_index = arg_posn++;
16777- if (dp->precision_arg_index == ARG_NONE)
16778- /* arg_posn wrapped around. */
16779- goto error;
16780- }
16781- REGISTER_ARG (dp->precision_arg_index, TYPE_INT);
16782- }
16783- else
16784- {
16785- size_t precision_length;
16786-
16787- dp->precision_start = cp - 1;
16788- for (; *cp >= '0' && *cp <= '9'; cp++)
16789- ;
16790- dp->precision_end = cp;
16791- precision_length = dp->precision_end - dp->precision_start;
16792- if (max_precision_length < precision_length)
16793- max_precision_length = precision_length;
16794- }
16795- }
16796-
16797- {
16798- arg_type type;
16799-
16800- /* Parse argument type/size specifiers. */
16801- {
16802- int flags = 0;
16803-
16804- for (;;)
16805- {
16806- if (*cp == 'h')
16807- {
16808- flags |= (1 << (flags & 1));
16809- cp++;
16810- }
16811- else if (*cp == 'L')
16812- {
16813- flags |= 4;
16814- cp++;
16815- }
16816- else if (*cp == 'l')
16817- {
16818- flags += 8;
16819- cp++;
16820- }
16821- else if (*cp == 'j')
16822- {
16823- if (sizeof (intmax_t) > sizeof (long))
16824- {
16825- /* intmax_t = long long */
16826- flags += 16;
16827- }
16828- else if (sizeof (intmax_t) > sizeof (int))
16829- {
16830- /* intmax_t = long */
16831- flags += 8;
16832- }
16833- cp++;
16834- }
16835- else if (*cp == 'z' || *cp == 'Z')
16836- {
16837- /* 'z' is standardized in ISO C 99, but glibc uses 'Z'
16838- because the warning facility in gcc-2.95.2 understands
16839- only 'Z' (see gcc-2.95.2/gcc/c-common.c:1784). */
16840- if (sizeof (size_t) > sizeof (long))
16841- {
16842- /* size_t = long long */
16843- flags += 16;
16844- }
16845- else if (sizeof (size_t) > sizeof (int))
16846- {
16847- /* size_t = long */
16848- flags += 8;
16849- }
16850- cp++;
16851- }
16852- else if (*cp == 't')
16853- {
16854- if (sizeof (ptrdiff_t) > sizeof (long))
16855- {
16856- /* ptrdiff_t = long long */
16857- flags += 16;
16858- }
16859- else if (sizeof (ptrdiff_t) > sizeof (int))
16860- {
16861- /* ptrdiff_t = long */
16862- flags += 8;
16863- }
16864- cp++;
16865- }
16866- else
16867- break;
16868- }
16869-
16870- /* Read the conversion character. */
16871- c = *cp++;
16872- switch (c)
16873- {
16874- case 'd': case 'i':
16875-#if HAVE_LONG_LONG_INT
16876- /* If 'long long' exists and is larger than 'long': */
16877- if (flags >= 16 || (flags & 4))
16878- type = TYPE_LONGLONGINT;
16879- else
16880-#endif
16881- /* If 'long long' exists and is the same as 'long', we parse
16882- "lld" into TYPE_LONGINT. */
16883- if (flags >= 8)
16884- type = TYPE_LONGINT;
16885- else if (flags & 2)
16886- type = TYPE_SCHAR;
16887- else if (flags & 1)
16888- type = TYPE_SHORT;
16889- else
16890- type = TYPE_INT;
16891- break;
16892- case 'o': case 'u': case 'x': case 'X':
16893-#if HAVE_LONG_LONG_INT
16894- /* If 'long long' exists and is larger than 'long': */
16895- if (flags >= 16 || (flags & 4))
16896- type = TYPE_ULONGLONGINT;
16897- else
16898-#endif
16899- /* If 'unsigned long long' exists and is the same as
16900- 'unsigned long', we parse "llu" into TYPE_ULONGINT. */
16901- if (flags >= 8)
16902- type = TYPE_ULONGINT;
16903- else if (flags & 2)
16904- type = TYPE_UCHAR;
16905- else if (flags & 1)
16906- type = TYPE_USHORT;
16907- else
16908- type = TYPE_UINT;
16909- break;
16910- case 'f': case 'F': case 'e': case 'E': case 'g': case 'G':
16911- case 'a': case 'A':
16912- if (flags >= 16 || (flags & 4))
16913- type = TYPE_LONGDOUBLE;
16914- else
16915- type = TYPE_DOUBLE;
16916- break;
16917- case 'c':
16918- if (flags >= 8)
16919-#if HAVE_WINT_T
16920- type = TYPE_WIDE_CHAR;
16921-#else
16922- goto error;
16923-#endif
16924- else
16925- type = TYPE_CHAR;
16926- break;
16927-#if HAVE_WINT_T
16928- case 'C':
16929- type = TYPE_WIDE_CHAR;
16930- c = 'c';
16931- break;
16932-#endif
16933- case 's':
16934- if (flags >= 8)
16935-#if HAVE_WCHAR_T
16936- type = TYPE_WIDE_STRING;
16937-#else
16938- goto error;
16939-#endif
16940- else
16941- type = TYPE_STRING;
16942- break;
16943-#if HAVE_WCHAR_T
16944- case 'S':
16945- type = TYPE_WIDE_STRING;
16946- c = 's';
16947- break;
16948-#endif
16949- case 'p':
16950- type = TYPE_POINTER;
16951- break;
16952- case 'n':
16953-#if HAVE_LONG_LONG_INT
16954- /* If 'long long' exists and is larger than 'long': */
16955- if (flags >= 16 || (flags & 4))
16956- type = TYPE_COUNT_LONGLONGINT_POINTER;
16957- else
16958-#endif
16959- /* If 'long long' exists and is the same as 'long', we parse
16960- "lln" into TYPE_COUNT_LONGINT_POINTER. */
16961- if (flags >= 8)
16962- type = TYPE_COUNT_LONGINT_POINTER;
16963- else if (flags & 2)
16964- type = TYPE_COUNT_SCHAR_POINTER;
16965- else if (flags & 1)
16966- type = TYPE_COUNT_SHORT_POINTER;
16967- else
16968- type = TYPE_COUNT_INT_POINTER;
16969- break;
16970-#if ENABLE_UNISTDIO
16971- /* The unistdio extensions. */
16972- case 'U':
16973- if (flags >= 16)
16974- type = TYPE_U32_STRING;
16975- else if (flags >= 8)
16976- type = TYPE_U16_STRING;
16977- else
16978- type = TYPE_U8_STRING;
16979- break;
16980-#endif
16981- case '%':
16982- type = TYPE_NONE;
16983- break;
16984- default:
16985- /* Unknown conversion character. */
16986- goto error;
16987- }
16988- }
16989-
16990- if (type != TYPE_NONE)
16991- {
16992- dp->arg_index = arg_index;
16993- if (dp->arg_index == ARG_NONE)
16994- {
16995- dp->arg_index = arg_posn++;
16996- if (dp->arg_index == ARG_NONE)
16997- /* arg_posn wrapped around. */
16998- goto error;
16999- }
17000- REGISTER_ARG (dp->arg_index, type);
17001- }
17002- dp->conversion = c;
17003- dp->dir_end = cp;
17004- }
17005-
17006- d->count++;
17007- if (d->count >= d_allocated)
17008- {
17009- size_t memory_size;
17010- DIRECTIVE *memory;
17011-
17012- d_allocated = xtimes (d_allocated, 2);
17013- memory_size = xtimes (d_allocated, sizeof (DIRECTIVE));
17014- if (size_overflow_p (memory_size))
17015- /* Overflow, would lead to out of memory. */
17016- goto out_of_memory;
17017- memory = (DIRECTIVE *) realloc (d->dir, memory_size);
17018- if (memory == NULL)
17019- /* Out of memory. */
17020- goto out_of_memory;
17021- d->dir = memory;
17022- }
17023- }
17024-#if CHAR_T_ONLY_ASCII
17025- else if (!c_isascii (c))
17026- {
17027- /* Non-ASCII character. Not supported. */
17028- goto error;
17029- }
17030-#endif
17031- }
17032- d->dir[d->count].dir_start = cp;
17033-
17034- d->max_width_length = max_width_length;
17035- d->max_precision_length = max_precision_length;
17036- return 0;
17037-
17038-error:
17039- if (a->arg)
17040- free (a->arg);
17041- if (d->dir)
17042- free (d->dir);
17043- errno = EINVAL;
17044- return -1;
17045-
17046-out_of_memory:
17047- if (a->arg)
17048- free (a->arg);
17049- if (d->dir)
17050- free (d->dir);
17051-out_of_memory_1:
17052- errno = ENOMEM;
17053- return -1;
17054-}
17055-
17056-#undef PRINTF_PARSE
17057-#undef DIRECTIVES
17058-#undef DIRECTIVE
17059-#undef CHAR_T_ONLY_ASCII
17060-#undef CHAR_T
17061--- a/intl/printf-parse.h
17062+++ /dev/null
17063@@ -1,75 +0,0 @@
17064-/* Parse printf format string.
17065- Copyright (C) 1999, 2002-2003 Free Software Foundation, Inc.
17066-
17067- This program is free software; you can redistribute it and/or modify it
17068- under the terms of the GNU Library General Public License as published
17069- by the Free Software Foundation; either version 2, or (at your option)
17070- any later version.
17071-
17072- This program is distributed in the hope that it will be useful,
17073- but WITHOUT ANY WARRANTY; without even the implied warranty of
17074- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17075- Library General Public License for more details.
17076-
17077- You should have received a copy of the GNU Library General Public
17078- License along with this program; if not, write to the Free Software
17079- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
17080- USA. */
17081-
17082-#ifndef _PRINTF_PARSE_H
17083-#define _PRINTF_PARSE_H
17084-
17085-#include "printf-args.h"
17086-
17087-
17088-/* Flags */
17089-#define FLAG_GROUP 1 /* ' flag */
17090-#define FLAG_LEFT 2 /* - flag */
17091-#define FLAG_SHOWSIGN 4 /* + flag */
17092-#define FLAG_SPACE 8 /* space flag */
17093-#define FLAG_ALT 16 /* # flag */
17094-#define FLAG_ZERO 32
17095-
17096-/* arg_index value indicating that no argument is consumed. */
17097-#define ARG_NONE (~(size_t)0)
17098-
17099-/* A parsed directive. */
17100-typedef struct
17101-{
17102- const char* dir_start;
17103- const char* dir_end;
17104- int flags;
17105- const char* width_start;
17106- const char* width_end;
17107- size_t width_arg_index;
17108- const char* precision_start;
17109- const char* precision_end;
17110- size_t precision_arg_index;
17111- char conversion; /* d i o u x X f e E g G c s p n U % but not C S */
17112- size_t arg_index;
17113-}
17114-char_directive;
17115-
17116-/* A parsed format string. */
17117-typedef struct
17118-{
17119- size_t count;
17120- char_directive *dir;
17121- size_t max_width_length;
17122- size_t max_precision_length;
17123-}
17124-char_directives;
17125-
17126-
17127-/* Parses the format string. Fills in the number N of directives, and fills
17128- in directives[0], ..., directives[N-1], and sets directives[N].dir_start
17129- to the end of the format string. Also fills in the arg_type fields of the
17130- arguments and the needed count of arguments. */
17131-#ifdef STATIC
17132-STATIC
17133-#else
17134-extern
17135-#endif
17136-int printf_parse (const char *format, char_directives *d, arguments *a);
17137-
17138-#endif /* _PRINTF_PARSE_H */
17139--- a/intl/printf.c
17140+++ /dev/null
17141@@ -1,427 +0,0 @@
17142-/* Formatted output to strings, using POSIX/XSI format strings with positions.
17143- Copyright (C) 2003, 2006-2007 Free Software Foundation, Inc.
17144- Written by Bruno Haible <bruno@clisp.org>, 2003.
17145-
17146- This program is free software; you can redistribute it and/or modify it
17147- under the terms of the GNU Library General Public License as published
17148- by the Free Software Foundation; either version 2, or (at your option)
17149- any later version.
17150-
17151- This program is distributed in the hope that it will be useful,
17152- but WITHOUT ANY WARRANTY; without even the implied warranty of
17153- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17154- Library General Public License for more details.
17155-
17156- You should have received a copy of the GNU Library General Public
17157- License along with this program; if not, write to the Free Software
17158- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
17159- USA. */
17160-
17161-#ifdef HAVE_CONFIG_H
17162-# include <config.h>
17163-#endif
17164-
17165-#ifdef __GNUC__
17166-# define alloca __builtin_alloca
17167-# define HAVE_ALLOCA 1
17168-#else
17169-# ifdef _MSC_VER
17170-# include <malloc.h>
17171-# define alloca _alloca
17172-# else
17173-# if defined HAVE_ALLOCA_H || defined _LIBC
17174-# include <alloca.h>
17175-# else
17176-# ifdef _AIX
17177- #pragma alloca
17178-# else
17179-# ifndef alloca
17180-char *alloca ();
17181-# endif
17182-# endif
17183-# endif
17184-# endif
17185-#endif
17186-
17187-#include <stdio.h>
17188-
17189-#if !HAVE_POSIX_PRINTF
17190-
17191-#include <errno.h>
17192-#include <limits.h>
17193-#include <stdlib.h>
17194-#include <string.h>
17195-
17196-/* Some systems, like OSF/1 4.0 and Woe32, don't have EOVERFLOW. */
17197-#ifndef EOVERFLOW
17198-# define EOVERFLOW E2BIG
17199-#endif
17200-
17201-/* When building a DLL, we must export some functions. Note that because
17202- the functions are only defined for binary backward compatibility, we
17203- don't need to use __declspec(dllimport) in any case. */
17204-#if defined _MSC_VER && BUILDING_DLL
17205-# define DLL_EXPORTED __declspec(dllexport)
17206-#else
17207-# define DLL_EXPORTED
17208-#endif
17209-
17210-#define STATIC static
17211-
17212-/* This needs to be consistent with libgnuintl.h.in. */
17213-#if defined __NetBSD__ || defined __BEOS__ || defined __CYGWIN__ || defined __MINGW32__
17214-/* Don't break __attribute__((format(printf,M,N))).
17215- This redefinition is only possible because the libc in NetBSD, Cygwin,
17216- mingw does not have a function __printf__. */
17217-# define libintl_printf __printf__
17218-#endif
17219-
17220-/* Define auxiliary functions declared in "printf-args.h". */
17221-#include "printf-args.c"
17222-
17223-/* Define auxiliary functions declared in "printf-parse.h". */
17224-#include "printf-parse.c"
17225-
17226-/* Define functions declared in "vasnprintf.h". */
17227-#define vasnprintf libintl_vasnprintf
17228-#include "vasnprintf.c"
17229-#if 0 /* not needed */
17230-#define asnprintf libintl_asnprintf
17231-#include "asnprintf.c"
17232-#endif
17233-
17234-DLL_EXPORTED
17235-int
17236-libintl_vfprintf (FILE *stream, const char *format, va_list args)
17237-{
17238- if (strchr (format, '$') == NULL)
17239- return vfprintf (stream, format, args);
17240- else
17241- {
17242- size_t length;
17243- char *result = libintl_vasnprintf (NULL, &length, format, args);
17244- int retval = -1;
17245- if (result != NULL)
17246- {
17247- size_t written = fwrite (result, 1, length, stream);
17248- free (result);
17249- if (written == length)
17250- {
17251- if (length > INT_MAX)
17252- errno = EOVERFLOW;
17253- else
17254- retval = length;
17255- }
17256- }
17257- return retval;
17258- }
17259-}
17260-
17261-DLL_EXPORTED
17262-int
17263-libintl_fprintf (FILE *stream, const char *format, ...)
17264-{
17265- va_list args;
17266- int retval;
17267-
17268- va_start (args, format);
17269- retval = libintl_vfprintf (stream, format, args);
17270- va_end (args);
17271- return retval;
17272-}
17273-
17274-DLL_EXPORTED
17275-int
17276-libintl_vprintf (const char *format, va_list args)
17277-{
17278- return libintl_vfprintf (stdout, format, args);
17279-}
17280-
17281-DLL_EXPORTED
17282-int
17283-libintl_printf (const char *format, ...)
17284-{
17285- va_list args;
17286- int retval;
17287-
17288- va_start (args, format);
17289- retval = libintl_vprintf (format, args);
17290- va_end (args);
17291- return retval;
17292-}
17293-
17294-DLL_EXPORTED
17295-int
17296-libintl_vsprintf (char *resultbuf, const char *format, va_list args)
17297-{
17298- if (strchr (format, '$') == NULL)
17299- return vsprintf (resultbuf, format, args);
17300- else
17301- {
17302- size_t length = (size_t) ~0 / (4 * sizeof (char));
17303- char *result = libintl_vasnprintf (resultbuf, &length, format, args);
17304- if (result != resultbuf)
17305- {
17306- free (result);
17307- return -1;
17308- }
17309- if (length > INT_MAX)
17310- {
17311- errno = EOVERFLOW;
17312- return -1;
17313- }
17314- else
17315- return length;
17316- }
17317-}
17318-
17319-DLL_EXPORTED
17320-int
17321-libintl_sprintf (char *resultbuf, const char *format, ...)
17322-{
17323- va_list args;
17324- int retval;
17325-
17326- va_start (args, format);
17327- retval = libintl_vsprintf (resultbuf, format, args);
17328- va_end (args);
17329- return retval;
17330-}
17331-
17332-#if HAVE_SNPRINTF
17333-
17334-# if HAVE_DECL__SNPRINTF
17335- /* Windows. */
17336-# define system_vsnprintf _vsnprintf
17337-# else
17338- /* Unix. */
17339-# define system_vsnprintf vsnprintf
17340-# endif
17341-
17342-DLL_EXPORTED
17343-int
17344-libintl_vsnprintf (char *resultbuf, size_t length, const char *format, va_list args)
17345-{
17346- if (strchr (format, '$') == NULL)
17347- return system_vsnprintf (resultbuf, length, format, args);
17348- else
17349- {
17350- size_t maxlength = length;
17351- char *result = libintl_vasnprintf (resultbuf, &length, format, args);
17352- if (result != resultbuf)
17353- {
17354- if (maxlength > 0)
17355- {
17356- size_t pruned_length =
17357- (length < maxlength ? length : maxlength - 1);
17358- memcpy (resultbuf, result, pruned_length);
17359- resultbuf[pruned_length] = '\0';
17360- }
17361- free (result);
17362- }
17363- if (length > INT_MAX)
17364- {
17365- errno = EOVERFLOW;
17366- return -1;
17367- }
17368- else
17369- return length;
17370- }
17371-}
17372-
17373-DLL_EXPORTED
17374-int
17375-libintl_snprintf (char *resultbuf, size_t length, const char *format, ...)
17376-{
17377- va_list args;
17378- int retval;
17379-
17380- va_start (args, format);
17381- retval = libintl_vsnprintf (resultbuf, length, format, args);
17382- va_end (args);
17383- return retval;
17384-}
17385-
17386-#endif
17387-
17388-#if HAVE_ASPRINTF
17389-
17390-DLL_EXPORTED
17391-int
17392-libintl_vasprintf (char **resultp, const char *format, va_list args)
17393-{
17394- size_t length;
17395- char *result = libintl_vasnprintf (NULL, &length, format, args);
17396- if (result == NULL)
17397- return -1;
17398- if (length > INT_MAX)
17399- {
17400- free (result);
17401- errno = EOVERFLOW;
17402- return -1;
17403- }
17404- *resultp = result;
17405- return length;
17406-}
17407-
17408-DLL_EXPORTED
17409-int
17410-libintl_asprintf (char **resultp, const char *format, ...)
17411-{
17412- va_list args;
17413- int retval;
17414-
17415- va_start (args, format);
17416- retval = libintl_vasprintf (resultp, format, args);
17417- va_end (args);
17418- return retval;
17419-}
17420-
17421-#endif
17422-
17423-#if HAVE_FWPRINTF
17424-
17425-#include <wchar.h>
17426-
17427-#define WIDE_CHAR_VERSION 1
17428-
17429-#include "wprintf-parse.h"
17430-/* Define auxiliary functions declared in "wprintf-parse.h". */
17431-#define CHAR_T wchar_t
17432-#define DIRECTIVE wchar_t_directive
17433-#define DIRECTIVES wchar_t_directives
17434-#define PRINTF_PARSE wprintf_parse
17435-#include "printf-parse.c"
17436-
17437-/* Define functions declared in "vasnprintf.h". */
17438-#define vasnwprintf libintl_vasnwprintf
17439-#include "vasnprintf.c"
17440-#if 0 /* not needed */
17441-#define asnwprintf libintl_asnwprintf
17442-#include "asnprintf.c"
17443-#endif
17444-
17445-# if HAVE_DECL__SNWPRINTF
17446- /* Windows. */
17447-# define system_vswprintf _vsnwprintf
17448-# else
17449- /* Unix. */
17450-# define system_vswprintf vswprintf
17451-# endif
17452-
17453-DLL_EXPORTED
17454-int
17455-libintl_vfwprintf (FILE *stream, const wchar_t *format, va_list args)
17456-{
17457- if (wcschr (format, '$') == NULL)
17458- return vfwprintf (stream, format, args);
17459- else
17460- {
17461- size_t length;
17462- wchar_t *result = libintl_vasnwprintf (NULL, &length, format, args);
17463- int retval = -1;
17464- if (result != NULL)
17465- {
17466- size_t i;
17467- for (i = 0; i < length; i++)
17468- if (fputwc (result[i], stream) == WEOF)
17469- break;
17470- free (result);
17471- if (i == length)
17472- {
17473- if (length > INT_MAX)
17474- errno = EOVERFLOW;
17475- else
17476- retval = length;
17477- }
17478- }
17479- return retval;
17480- }
17481-}
17482-
17483-DLL_EXPORTED
17484-int
17485-libintl_fwprintf (FILE *stream, const wchar_t *format, ...)
17486-{
17487- va_list args;
17488- int retval;
17489-
17490- va_start (args, format);
17491- retval = libintl_vfwprintf (stream, format, args);
17492- va_end (args);
17493- return retval;
17494-}
17495-
17496-DLL_EXPORTED
17497-int
17498-libintl_vwprintf (const wchar_t *format, va_list args)
17499-{
17500- return libintl_vfwprintf (stdout, format, args);
17501-}
17502-
17503-DLL_EXPORTED
17504-int
17505-libintl_wprintf (const wchar_t *format, ...)
17506-{
17507- va_list args;
17508- int retval;
17509-
17510- va_start (args, format);
17511- retval = libintl_vwprintf (format, args);
17512- va_end (args);
17513- return retval;
17514-}
17515-
17516-DLL_EXPORTED
17517-int
17518-libintl_vswprintf (wchar_t *resultbuf, size_t length, const wchar_t *format, va_list args)
17519-{
17520- if (wcschr (format, '$') == NULL)
17521- return system_vswprintf (resultbuf, length, format, args);
17522- else
17523- {
17524- size_t maxlength = length;
17525- wchar_t *result = libintl_vasnwprintf (resultbuf, &length, format, args);
17526- if (result != resultbuf)
17527- {
17528- if (maxlength > 0)
17529- {
17530- size_t pruned_length =
17531- (length < maxlength ? length : maxlength - 1);
17532- memcpy (resultbuf, result, pruned_length * sizeof (wchar_t));
17533- resultbuf[pruned_length] = 0;
17534- }
17535- free (result);
17536- /* Unlike vsnprintf, which has to return the number of character that
17537- would have been produced if the resultbuf had been sufficiently
17538- large, the vswprintf function has to return a negative value if
17539- the resultbuf was not sufficiently large. */
17540- if (length >= maxlength)
17541- return -1;
17542- }
17543- if (length > INT_MAX)
17544- {
17545- errno = EOVERFLOW;
17546- return -1;
17547- }
17548- else
17549- return length;
17550- }
17551-}
17552-
17553-DLL_EXPORTED
17554-int
17555-libintl_swprintf (wchar_t *resultbuf, size_t length, const wchar_t *format, ...)
17556-{
17557- va_list args;
17558- int retval;
17559-
17560- va_start (args, format);
17561- retval = libintl_vswprintf (resultbuf, length, format, args);
17562- va_end (args);
17563- return retval;
17564-}
17565-
17566-#endif
17567-
17568-#endif
17569--- a/intl/ref-add.sin
17570+++ /dev/null
17571@@ -1,31 +0,0 @@
17572-# Add this package to a list of references stored in a text file.
17573-#
17574-# Copyright (C) 2000 Free Software Foundation, Inc.
17575-#
17576-# This program is free software; you can redistribute it and/or modify it
17577-# under the terms of the GNU Library General Public License as published
17578-# by the Free Software Foundation; either version 2, or (at your option)
17579-# any later version.
17580-#
17581-# This program is distributed in the hope that it will be useful,
17582-# but WITHOUT ANY WARRANTY; without even the implied warranty of
17583-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17584-# Library General Public License for more details.
17585-#
17586-# You should have received a copy of the GNU Library General Public
17587-# License along with this program; if not, write to the Free Software
17588-# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
17589-# USA.
17590-#
17591-# Written by Bruno Haible <haible@clisp.cons.org>.
17592-#
17593-/^# Packages using this file: / {
17594- s/# Packages using this file://
17595- ta
17596- :a
17597- s/ @PACKAGE@ / @PACKAGE@ /
17598- tb
17599- s/ $/ @PACKAGE@ /
17600- :b
17601- s/^/# Packages using this file:/
17602-}
17603--- a/intl/ref-del.sin
17604+++ /dev/null
17605@@ -1,26 +0,0 @@
17606-# Remove this package from a list of references stored in a text file.
17607-#
17608-# Copyright (C) 2000 Free Software Foundation, Inc.
17609-#
17610-# This program is free software; you can redistribute it and/or modify it
17611-# under the terms of the GNU Library General Public License as published
17612-# by the Free Software Foundation; either version 2, or (at your option)
17613-# any later version.
17614-#
17615-# This program is distributed in the hope that it will be useful,
17616-# but WITHOUT ANY WARRANTY; without even the implied warranty of
17617-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17618-# Library General Public License for more details.
17619-#
17620-# You should have received a copy of the GNU Library General Public
17621-# License along with this program; if not, write to the Free Software
17622-# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
17623-# USA.
17624-#
17625-# Written by Bruno Haible <haible@clisp.cons.org>.
17626-#
17627-/^# Packages using this file: / {
17628- s/# Packages using this file://
17629- s/ @PACKAGE@ / /
17630- s/^/# Packages using this file:/
17631-}
17632--- a/intl/relocatable.c
17633+++ /dev/null
17634@@ -1,468 +0,0 @@
17635-/* Provide relocatable packages.
17636- Copyright (C) 2003-2006 Free Software Foundation, Inc.
17637- Written by Bruno Haible <bruno@clisp.org>, 2003.
17638-
17639- This program is free software; you can redistribute it and/or modify it
17640- under the terms of the GNU Library General Public License as published
17641- by the Free Software Foundation; either version 2, or (at your option)
17642- any later version.
17643-
17644- This program is distributed in the hope that it will be useful,
17645- but WITHOUT ANY WARRANTY; without even the implied warranty of
17646- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17647- Library General Public License for more details.
17648-
17649- You should have received a copy of the GNU Library General Public
17650- License along with this program; if not, write to the Free Software
17651- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
17652- USA. */
17653-
17654-
17655-/* Tell glibc's <stdio.h> to provide a prototype for getline().
17656- This must come before <config.h> because <config.h> may include
17657- <features.h>, and once <features.h> has been included, it's too late. */
17658-#ifndef _GNU_SOURCE
17659-# define _GNU_SOURCE 1
17660-#endif
17661-
17662-#include <config.h>
17663-
17664-/* Specification. */
17665-#include "relocatable.h"
17666-
17667-#if ENABLE_RELOCATABLE
17668-
17669-#include <stddef.h>
17670-#include <stdio.h>
17671-#include <stdlib.h>
17672-#include <string.h>
17673-
17674-#ifdef NO_XMALLOC
17675-# define xmalloc malloc
17676-#else
17677-# include "xalloc.h"
17678-#endif
17679-
17680-#if defined _WIN32 || defined __WIN32__ || defined __CYGWIN__
17681-# define WIN32_LEAN_AND_MEAN
17682-# include <windows.h>
17683-#endif
17684-
17685-#if DEPENDS_ON_LIBCHARSET
17686-# include <libcharset.h>
17687-#endif
17688-#if DEPENDS_ON_LIBICONV && HAVE_ICONV
17689-# include <iconv.h>
17690-#endif
17691-#if DEPENDS_ON_LIBINTL && ENABLE_NLS
17692-# include <libintl.h>
17693-#endif
17694-
17695-/* Faked cheap 'bool'. */
17696-#undef bool
17697-#undef false
17698-#undef true
17699-#define bool int
17700-#define false 0
17701-#define true 1
17702-
17703-/* Pathname support.
17704- ISSLASH(C) tests whether C is a directory separator character.
17705- IS_PATH_WITH_DIR(P) tests whether P contains a directory specification.
17706- */
17707-#if defined _WIN32 || defined __WIN32__ || defined __CYGWIN__ || defined __EMX__ || defined __DJGPP__
17708- /* Win32, Cygwin, OS/2, DOS */
17709-# define ISSLASH(C) ((C) == '/' || (C) == '\\')
17710-# define HAS_DEVICE(P) \
17711- ((((P)[0] >= 'A' && (P)[0] <= 'Z') || ((P)[0] >= 'a' && (P)[0] <= 'z')) \
17712- && (P)[1] == ':')
17713-# define IS_PATH_WITH_DIR(P) \
17714- (strchr (P, '/') != NULL || strchr (P, '\\') != NULL || HAS_DEVICE (P))
17715-# define FILE_SYSTEM_PREFIX_LEN(P) (HAS_DEVICE (P) ? 2 : 0)
17716-#else
17717- /* Unix */
17718-# define ISSLASH(C) ((C) == '/')
17719-# define IS_PATH_WITH_DIR(P) (strchr (P, '/') != NULL)
17720-# define FILE_SYSTEM_PREFIX_LEN(P) 0
17721-#endif
17722-
17723-/* Original installation prefix. */
17724-static char *orig_prefix;
17725-static size_t orig_prefix_len;
17726-/* Current installation prefix. */
17727-static char *curr_prefix;
17728-static size_t curr_prefix_len;
17729-/* These prefixes do not end in a slash. Anything that will be concatenated
17730- to them must start with a slash. */
17731-
17732-/* Sets the original and the current installation prefix of this module.
17733- Relocation simply replaces a pathname starting with the original prefix
17734- by the corresponding pathname with the current prefix instead. Both
17735- prefixes should be directory names without trailing slash (i.e. use ""
17736- instead of "/"). */
17737-static void
17738-set_this_relocation_prefix (const char *orig_prefix_arg,
17739- const char *curr_prefix_arg)
17740-{
17741- if (orig_prefix_arg != NULL && curr_prefix_arg != NULL
17742- /* Optimization: if orig_prefix and curr_prefix are equal, the
17743- relocation is a nop. */
17744- && strcmp (orig_prefix_arg, curr_prefix_arg) != 0)
17745- {
17746- /* Duplicate the argument strings. */
17747- char *memory;
17748-
17749- orig_prefix_len = strlen (orig_prefix_arg);
17750- curr_prefix_len = strlen (curr_prefix_arg);
17751- memory = (char *) xmalloc (orig_prefix_len + 1 + curr_prefix_len + 1);
17752-#ifdef NO_XMALLOC
17753- if (memory != NULL)
17754-#endif
17755- {
17756- memcpy (memory, orig_prefix_arg, orig_prefix_len + 1);
17757- orig_prefix = memory;
17758- memory += orig_prefix_len + 1;
17759- memcpy (memory, curr_prefix_arg, curr_prefix_len + 1);
17760- curr_prefix = memory;
17761- return;
17762- }
17763- }
17764- orig_prefix = NULL;
17765- curr_prefix = NULL;
17766- /* Don't worry about wasted memory here - this function is usually only
17767- called once. */
17768-}
17769-
17770-/* Sets the original and the current installation prefix of the package.
17771- Relocation simply replaces a pathname starting with the original prefix
17772- by the corresponding pathname with the current prefix instead. Both
17773- prefixes should be directory names without trailing slash (i.e. use ""
17774- instead of "/"). */
17775-void
17776-set_relocation_prefix (const char *orig_prefix_arg, const char *curr_prefix_arg)
17777-{
17778- set_this_relocation_prefix (orig_prefix_arg, curr_prefix_arg);
17779-
17780- /* Now notify all dependent libraries. */
17781-#if DEPENDS_ON_LIBCHARSET
17782- libcharset_set_relocation_prefix (orig_prefix_arg, curr_prefix_arg);
17783-#endif
17784-#if DEPENDS_ON_LIBICONV && HAVE_ICONV && _LIBICONV_VERSION >= 0x0109
17785- libiconv_set_relocation_prefix (orig_prefix_arg, curr_prefix_arg);
17786-#endif
17787-#if DEPENDS_ON_LIBINTL && ENABLE_NLS && defined libintl_set_relocation_prefix
17788- libintl_set_relocation_prefix (orig_prefix_arg, curr_prefix_arg);
17789-#endif
17790-}
17791-
17792-#if !defined IN_LIBRARY || (defined PIC && defined INSTALLDIR)
17793-
17794-/* Convenience function:
17795- Computes the current installation prefix, based on the original
17796- installation prefix, the original installation directory of a particular
17797- file, and the current pathname of this file. Returns NULL upon failure. */
17798-#ifdef IN_LIBRARY
17799-#define compute_curr_prefix local_compute_curr_prefix
17800-static
17801-#endif
17802-const char *
17803-compute_curr_prefix (const char *orig_installprefix,
17804- const char *orig_installdir,
17805- const char *curr_pathname)
17806-{
17807- const char *curr_installdir;
17808- const char *rel_installdir;
17809-
17810- if (curr_pathname == NULL)
17811- return NULL;
17812-
17813- /* Determine the relative installation directory, relative to the prefix.
17814- This is simply the difference between orig_installprefix and
17815- orig_installdir. */
17816- if (strncmp (orig_installprefix, orig_installdir, strlen (orig_installprefix))
17817- != 0)
17818- /* Shouldn't happen - nothing should be installed outside $(prefix). */
17819- return NULL;
17820- rel_installdir = orig_installdir + strlen (orig_installprefix);
17821-
17822- /* Determine the current installation directory. */
17823- {
17824- const char *p_base = curr_pathname + FILE_SYSTEM_PREFIX_LEN (curr_pathname);
17825- const char *p = curr_pathname + strlen (curr_pathname);
17826- char *q;
17827-
17828- while (p > p_base)
17829- {
17830- p--;
17831- if (ISSLASH (*p))
17832- break;
17833- }
17834-
17835- q = (char *) xmalloc (p - curr_pathname + 1);
17836-#ifdef NO_XMALLOC
17837- if (q == NULL)
17838- return NULL;
17839-#endif
17840- memcpy (q, curr_pathname, p - curr_pathname);
17841- q[p - curr_pathname] = '\0';
17842- curr_installdir = q;
17843- }
17844-
17845- /* Compute the current installation prefix by removing the trailing
17846- rel_installdir from it. */
17847- {
17848- const char *rp = rel_installdir + strlen (rel_installdir);
17849- const char *cp = curr_installdir + strlen (curr_installdir);
17850- const char *cp_base =
17851- curr_installdir + FILE_SYSTEM_PREFIX_LEN (curr_installdir);
17852-
17853- while (rp > rel_installdir && cp > cp_base)
17854- {
17855- bool same = false;
17856- const char *rpi = rp;
17857- const char *cpi = cp;
17858-
17859- while (rpi > rel_installdir && cpi > cp_base)
17860- {
17861- rpi--;
17862- cpi--;
17863- if (ISSLASH (*rpi) || ISSLASH (*cpi))
17864- {
17865- if (ISSLASH (*rpi) && ISSLASH (*cpi))
17866- same = true;
17867- break;
17868- }
17869- /* Do case-insensitive comparison if the filesystem is always or
17870- often case-insensitive. It's better to accept the comparison
17871- if the difference is only in case, rather than to fail. */
17872-#if defined _WIN32 || defined __WIN32__ || defined __CYGWIN__ || defined __EMX__ || defined __DJGPP__
17873- /* Win32, Cygwin, OS/2, DOS - case insignificant filesystem */
17874- if ((*rpi >= 'a' && *rpi <= 'z' ? *rpi - 'a' + 'A' : *rpi)
17875- != (*cpi >= 'a' && *cpi <= 'z' ? *cpi - 'a' + 'A' : *cpi))
17876- break;
17877-#else
17878- if (*rpi != *cpi)
17879- break;
17880-#endif
17881- }
17882- if (!same)
17883- break;
17884- /* The last pathname component was the same. opi and cpi now point
17885- to the slash before it. */
17886- rp = rpi;
17887- cp = cpi;
17888- }
17889-
17890- if (rp > rel_installdir)
17891- /* Unexpected: The curr_installdir does not end with rel_installdir. */
17892- return NULL;
17893-
17894- {
17895- size_t curr_prefix_len = cp - curr_installdir;
17896- char *curr_prefix;
17897-
17898- curr_prefix = (char *) xmalloc (curr_prefix_len + 1);
17899-#ifdef NO_XMALLOC
17900- if (curr_prefix == NULL)
17901- return NULL;
17902-#endif
17903- memcpy (curr_prefix, curr_installdir, curr_prefix_len);
17904- curr_prefix[curr_prefix_len] = '\0';
17905-
17906- return curr_prefix;
17907- }
17908- }
17909-}
17910-
17911-#endif /* !IN_LIBRARY || PIC */
17912-
17913-#if defined PIC && defined INSTALLDIR
17914-
17915-/* Full pathname of shared library, or NULL. */
17916-static char *shared_library_fullname;
17917-
17918-#if defined _WIN32 || defined __WIN32__ || defined __CYGWIN__
17919-
17920-/* Determine the full pathname of the shared library when it is loaded. */
17921-
17922-BOOL WINAPI
17923-DllMain (HINSTANCE module_handle, DWORD event, LPVOID reserved)
17924-{
17925- (void) reserved;
17926-
17927- if (event == DLL_PROCESS_ATTACH)
17928- {
17929- /* The DLL is being loaded into an application's address range. */
17930- static char location[MAX_PATH];
17931-
17932- if (!GetModuleFileName (module_handle, location, sizeof (location)))
17933- /* Shouldn't happen. */
17934- return FALSE;
17935-
17936- if (!IS_PATH_WITH_DIR (location))
17937- /* Shouldn't happen. */
17938- return FALSE;
17939-
17940- {
17941-#if defined __CYGWIN__
17942- /* On Cygwin, we need to convert paths coming from Win32 system calls
17943- to the Unix-like slashified notation. */
17944- static char location_as_posix_path[2 * MAX_PATH];
17945- /* There's no error return defined for cygwin_conv_to_posix_path.
17946- See cygwin-api/func-cygwin-conv-to-posix-path.html.
17947- Does it overflow the buffer of expected size MAX_PATH or does it
17948- truncate the path? I don't know. Let's catch both. */
17949- cygwin_conv_to_posix_path (location, location_as_posix_path);
17950- location_as_posix_path[MAX_PATH - 1] = '\0';
17951- if (strlen (location_as_posix_path) >= MAX_PATH - 1)
17952- /* A sign of buffer overflow or path truncation. */
17953- return FALSE;
17954- shared_library_fullname = strdup (location_as_posix_path);
17955-#else
17956- shared_library_fullname = strdup (location);
17957-#endif
17958- }
17959- }
17960-
17961- return TRUE;
17962-}
17963-
17964-#else /* Unix except Cygwin */
17965-
17966-static void
17967-find_shared_library_fullname ()
17968-{
17969-#if defined __linux__ && __GLIBC__ >= 2
17970- /* Linux has /proc/self/maps. glibc 2 has the getline() function. */
17971- FILE *fp;
17972-
17973- /* Open the current process' maps file. It describes one VMA per line. */
17974- fp = fopen ("/proc/self/maps", "r");
17975- if (fp)
17976- {
17977- unsigned long address = (unsigned long) &find_shared_library_fullname;
17978- for (;;)
17979- {
17980- unsigned long start, end;
17981- int c;
17982-
17983- if (fscanf (fp, "%lx-%lx", &start, &end) != 2)
17984- break;
17985- if (address >= start && address <= end - 1)
17986- {
17987- /* Found it. Now see if this line contains a filename. */
17988- while (c = getc (fp), c != EOF && c != '\n' && c != '/')
17989- continue;
17990- if (c == '/')
17991- {
17992- size_t size;
17993- int len;
17994-
17995- ungetc (c, fp);
17996- shared_library_fullname = NULL; size = 0;
17997- len = getline (&shared_library_fullname, &size, fp);
17998- if (len >= 0)
17999- {
18000- /* Success: filled shared_library_fullname. */
18001- if (len > 0 && shared_library_fullname[len - 1] == '\n')
18002- shared_library_fullname[len - 1] = '\0';
18003- }
18004- }
18005- break;
18006- }
18007- while (c = getc (fp), c != EOF && c != '\n')
18008- continue;
18009- }
18010- fclose (fp);
18011- }
18012-#endif
18013-}
18014-
18015-#endif /* (WIN32 or Cygwin) / (Unix except Cygwin) */
18016-
18017-/* Return the full pathname of the current shared library.
18018- Return NULL if unknown.
18019- Guaranteed to work only on Linux, Cygwin and Woe32. */
18020-static char *
18021-get_shared_library_fullname ()
18022-{
18023-#if !(defined _WIN32 || defined __WIN32__ || defined __CYGWIN__)
18024- static bool tried_find_shared_library_fullname;
18025- if (!tried_find_shared_library_fullname)
18026- {
18027- find_shared_library_fullname ();
18028- tried_find_shared_library_fullname = true;
18029- }
18030-#endif
18031- return shared_library_fullname;
18032-}
18033-
18034-#endif /* PIC */
18035-
18036-/* Returns the pathname, relocated according to the current installation
18037- directory. */
18038-const char *
18039-relocate (const char *pathname)
18040-{
18041-#if defined PIC && defined INSTALLDIR
18042- static int initialized;
18043-
18044- /* Initialization code for a shared library. */
18045- if (!initialized)
18046- {
18047- /* At this point, orig_prefix and curr_prefix likely have already been
18048- set through the main program's set_program_name_and_installdir
18049- function. This is sufficient in the case that the library has
18050- initially been installed in the same orig_prefix. But we can do
18051- better, to also cover the cases that 1. it has been installed
18052- in a different prefix before being moved to orig_prefix and (later)
18053- to curr_prefix, 2. unlike the program, it has not moved away from
18054- orig_prefix. */
18055- const char *orig_installprefix = INSTALLPREFIX;
18056- const char *orig_installdir = INSTALLDIR;
18057- const char *curr_prefix_better;
18058-
18059- curr_prefix_better =
18060- compute_curr_prefix (orig_installprefix, orig_installdir,
18061- get_shared_library_fullname ());
18062- if (curr_prefix_better == NULL)
18063- curr_prefix_better = curr_prefix;
18064-
18065- set_relocation_prefix (orig_installprefix, curr_prefix_better);
18066-
18067- initialized = 1;
18068- }
18069-#endif
18070-
18071- /* Note: It is not necessary to perform case insensitive comparison here,
18072- even for DOS-like filesystems, because the pathname argument was
18073- typically created from the same Makefile variable as orig_prefix came
18074- from. */
18075- if (orig_prefix != NULL && curr_prefix != NULL
18076- && strncmp (pathname, orig_prefix, orig_prefix_len) == 0)
18077- {
18078- if (pathname[orig_prefix_len] == '\0')
18079- /* pathname equals orig_prefix. */
18080- return curr_prefix;
18081- if (ISSLASH (pathname[orig_prefix_len]))
18082- {
18083- /* pathname starts with orig_prefix. */
18084- const char *pathname_tail = &pathname[orig_prefix_len];
18085- char *result =
18086- (char *) xmalloc (curr_prefix_len + strlen (pathname_tail) + 1);
18087-
18088-#ifdef NO_XMALLOC
18089- if (result != NULL)
18090-#endif
18091- {
18092- memcpy (result, curr_prefix, curr_prefix_len);
18093- strcpy (result + curr_prefix_len, pathname_tail);
18094- return result;
18095- }
18096- }
18097- }
18098- /* Nothing to relocate. */
18099- return pathname;
18100-}
18101-
18102-#endif
18103--- a/intl/relocatable.h
18104+++ /dev/null
18105@@ -1,79 +0,0 @@
18106-/* Provide relocatable packages.
18107- Copyright (C) 2003, 2005 Free Software Foundation, Inc.
18108- Written by Bruno Haible <bruno@clisp.org>, 2003.
18109-
18110- This program is free software; you can redistribute it and/or modify it
18111- under the terms of the GNU Library General Public License as published
18112- by the Free Software Foundation; either version 2, or (at your option)
18113- any later version.
18114-
18115- This program is distributed in the hope that it will be useful,
18116- but WITHOUT ANY WARRANTY; without even the implied warranty of
18117- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18118- Library General Public License for more details.
18119-
18120- You should have received a copy of the GNU Library General Public
18121- License along with this program; if not, write to the Free Software
18122- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
18123- USA. */
18124-
18125-#ifndef _RELOCATABLE_H
18126-#define _RELOCATABLE_H
18127-
18128-#ifdef __cplusplus
18129-extern "C" {
18130-#endif
18131-
18132-
18133-/* This can be enabled through the configure --enable-relocatable option. */
18134-#if ENABLE_RELOCATABLE
18135-
18136-/* When building a DLL, we must export some functions. Note that because
18137- this is a private .h file, we don't need to use __declspec(dllimport)
18138- in any case. */
18139-#if HAVE_VISIBILITY && BUILDING_DLL
18140-# define RELOCATABLE_DLL_EXPORTED __attribute__((__visibility__("default")))
18141-#elif defined _MSC_VER && BUILDING_DLL
18142-# define RELOCATABLE_DLL_EXPORTED __declspec(dllexport)
18143-#else
18144-# define RELOCATABLE_DLL_EXPORTED
18145-#endif
18146-
18147-/* Sets the original and the current installation prefix of the package.
18148- Relocation simply replaces a pathname starting with the original prefix
18149- by the corresponding pathname with the current prefix instead. Both
18150- prefixes should be directory names without trailing slash (i.e. use ""
18151- instead of "/"). */
18152-extern RELOCATABLE_DLL_EXPORTED void
18153- set_relocation_prefix (const char *orig_prefix,
18154- const char *curr_prefix);
18155-
18156-/* Returns the pathname, relocated according to the current installation
18157- directory. */
18158-extern const char * relocate (const char *pathname);
18159-
18160-/* Memory management: relocate() leaks memory, because it has to construct
18161- a fresh pathname. If this is a problem because your program calls
18162- relocate() frequently, think about caching the result. */
18163-
18164-/* Convenience function:
18165- Computes the current installation prefix, based on the original
18166- installation prefix, the original installation directory of a particular
18167- file, and the current pathname of this file. Returns NULL upon failure. */
18168-extern const char * compute_curr_prefix (const char *orig_installprefix,
18169- const char *orig_installdir,
18170- const char *curr_pathname);
18171-
18172-#else
18173-
18174-/* By default, we use the hardwired pathnames. */
18175-#define relocate(pathname) (pathname)
18176-
18177-#endif
18178-
18179-
18180-#ifdef __cplusplus
18181-}
18182-#endif
18183-
18184-#endif /* _RELOCATABLE_H */
18185--- a/intl/textdomain.c
18186+++ /dev/null
18187@@ -1,127 +0,0 @@
18188-/* Implementation of the textdomain(3) function.
18189- Copyright (C) 1995-1998, 2000-2003, 2005-2006 Free Software Foundation, Inc.
18190-
18191- This program is free software; you can redistribute it and/or modify it
18192- under the terms of the GNU Library General Public License as published
18193- by the Free Software Foundation; either version 2, or (at your option)
18194- any later version.
18195-
18196- This program is distributed in the hope that it will be useful,
18197- but WITHOUT ANY WARRANTY; without even the implied warranty of
18198- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18199- Library General Public License for more details.
18200-
18201- You should have received a copy of the GNU Library General Public
18202- License along with this program; if not, write to the Free Software
18203- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
18204- USA. */
18205-
18206-#ifdef HAVE_CONFIG_H
18207-# include <config.h>
18208-#endif
18209-
18210-#include <stdlib.h>
18211-#include <string.h>
18212-
18213-#include "gettextP.h"
18214-#ifdef _LIBC
18215-# include <libintl.h>
18216-#else
18217-# include "libgnuintl.h"
18218-#endif
18219-
18220-/* Handle multi-threaded applications. */
18221-#ifdef _LIBC
18222-# include <bits/libc-lock.h>
18223-# define gl_rwlock_define __libc_rwlock_define
18224-# define gl_rwlock_wrlock __libc_rwlock_wrlock
18225-# define gl_rwlock_unlock __libc_rwlock_unlock
18226-#else
18227-# include "lock.h"
18228-#endif
18229-
18230-/* @@ end of prolog @@ */
18231-
18232-
18233-/* Names for the libintl functions are a problem. They must not clash
18234- with existing names and they should follow ANSI C. But this source
18235- code is also used in GNU C Library where the names have a __
18236- prefix. So we have to make a difference here. */
18237-#ifdef _LIBC
18238-# define TEXTDOMAIN __textdomain
18239-# ifndef strdup
18240-# define strdup(str) __strdup (str)
18241-# endif
18242-#else
18243-# define TEXTDOMAIN libintl_textdomain
18244-#endif
18245-
18246-/* Lock variable to protect the global data in the gettext implementation. */
18247-gl_rwlock_define (extern, _nl_state_lock attribute_hidden)
18248-
18249-/* Set the current default message catalog to DOMAINNAME.
18250- If DOMAINNAME is null, return the current default.
18251- If DOMAINNAME is "", reset to the default of "messages". */
18252-char *
18253-TEXTDOMAIN (const char *domainname)
18254-{
18255- char *new_domain;
18256- char *old_domain;
18257-
18258- /* A NULL pointer requests the current setting. */
18259- if (domainname == NULL)
18260- return (char *) _nl_current_default_domain;
18261-
18262- gl_rwlock_wrlock (_nl_state_lock);
18263-
18264- old_domain = (char *) _nl_current_default_domain;
18265-
18266- /* If domain name is the null string set to default domain "messages". */
18267- if (domainname[0] == '\0'
18268- || strcmp (domainname, _nl_default_default_domain) == 0)
18269- {
18270- _nl_current_default_domain = _nl_default_default_domain;
18271- new_domain = (char *) _nl_current_default_domain;
18272- }
18273- else if (strcmp (domainname, old_domain) == 0)
18274- /* This can happen and people will use it to signal that some
18275- environment variable changed. */
18276- new_domain = old_domain;
18277- else
18278- {
18279- /* If the following malloc fails `_nl_current_default_domain'
18280- will be NULL. This value will be returned and so signals we
18281- are out of core. */
18282-#if defined _LIBC || defined HAVE_STRDUP
18283- new_domain = strdup (domainname);
18284-#else
18285- size_t len = strlen (domainname) + 1;
18286- new_domain = (char *) malloc (len);
18287- if (new_domain != NULL)
18288- memcpy (new_domain, domainname, len);
18289-#endif
18290-
18291- if (new_domain != NULL)
18292- _nl_current_default_domain = new_domain;
18293- }
18294-
18295- /* We use this possibility to signal a change of the loaded catalogs
18296- since this is most likely the case and there is no other easy we
18297- to do it. Do it only when the call was successful. */
18298- if (new_domain != NULL)
18299- {
18300- ++_nl_msg_cat_cntr;
18301-
18302- if (old_domain != new_domain && old_domain != _nl_default_default_domain)
18303- free (old_domain);
18304- }
18305-
18306- gl_rwlock_unlock (_nl_state_lock);
18307-
18308- return new_domain;
18309-}
18310-
18311-#ifdef _LIBC
18312-/* Alias for function name in GNU C Library. */
18313-weak_alias (__textdomain, textdomain);
18314-#endif
18315--- a/intl/tsearch.c
18316+++ /dev/null
18317@@ -1,684 +0,0 @@
18318-/* Copyright (C) 1995, 1996, 1997, 2000, 2006 Free Software Foundation, Inc.
18319- Contributed by Bernd Schmidt <crux@Pool.Informatik.RWTH-Aachen.DE>, 1997.
18320-
18321- NOTE: The canonical source of this file is maintained with the GNU C
18322- Library. Bugs can be reported to bug-glibc@gnu.org.
18323-
18324- This program is free software; you can redistribute it and/or modify it
18325- under the terms of the GNU Library General Public License as published
18326- by the Free Software Foundation; either version 2, or (at your option)
18327- any later version.
18328-
18329- This program is distributed in the hope that it will be useful,
18330- but WITHOUT ANY WARRANTY; without even the implied warranty of
18331- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18332- Library General Public License for more details.
18333-
18334- You should have received a copy of the GNU Library General Public
18335- License along with this program; if not, write to the Free Software
18336- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
18337- USA. */
18338-
18339-/* Tree search for red/black trees.
18340- The algorithm for adding nodes is taken from one of the many "Algorithms"
18341- books by Robert Sedgewick, although the implementation differs.
18342- The algorithm for deleting nodes can probably be found in a book named
18343- "Introduction to Algorithms" by Cormen/Leiserson/Rivest. At least that's
18344- the book that my professor took most algorithms from during the "Data
18345- Structures" course...
18346-
18347- Totally public domain. */
18348-
18349-/* Red/black trees are binary trees in which the edges are colored either red
18350- or black. They have the following properties:
18351- 1. The number of black edges on every path from the root to a leaf is
18352- constant.
18353- 2. No two red edges are adjacent.
18354- Therefore there is an upper bound on the length of every path, it's
18355- O(log n) where n is the number of nodes in the tree. No path can be longer
18356- than 1+2*P where P is the length of the shortest path in the tree.
18357- Useful for the implementation:
18358- 3. If one of the children of a node is NULL, then the other one is red
18359- (if it exists).
18360-
18361- In the implementation, not the edges are colored, but the nodes. The color
18362- interpreted as the color of the edge leading to this node. The color is
18363- meaningless for the root node, but we color the root node black for
18364- convenience. All added nodes are red initially.
18365-
18366- Adding to a red/black tree is rather easy. The right place is searched
18367- with a usual binary tree search. Additionally, whenever a node N is
18368- reached that has two red successors, the successors are colored black and
18369- the node itself colored red. This moves red edges up the tree where they
18370- pose less of a problem once we get to really insert the new node. Changing
18371- N's color to red may violate rule 2, however, so rotations may become
18372- necessary to restore the invariants. Adding a new red leaf may violate
18373- the same rule, so afterwards an additional check is run and the tree
18374- possibly rotated.
18375-
18376- Deleting is hairy. There are mainly two nodes involved: the node to be
18377- deleted (n1), and another node that is to be unchained from the tree (n2).
18378- If n1 has a successor (the node with a smallest key that is larger than
18379- n1), then the successor becomes n2 and its contents are copied into n1,
18380- otherwise n1 becomes n2.
18381- Unchaining a node may violate rule 1: if n2 is black, one subtree is
18382- missing one black edge afterwards. The algorithm must try to move this
18383- error upwards towards the root, so that the subtree that does not have
18384- enough black edges becomes the whole tree. Once that happens, the error
18385- has disappeared. It may not be necessary to go all the way up, since it
18386- is possible that rotations and recoloring can fix the error before that.
18387-
18388- Although the deletion algorithm must walk upwards through the tree, we
18389- do not store parent pointers in the nodes. Instead, delete allocates a
18390- small array of parent pointers and fills it while descending the tree.
18391- Since we know that the length of a path is O(log n), where n is the number
18392- of nodes, this is likely to use less memory. */
18393-
18394-/* Tree rotations look like this:
18395- A C
18396- / \ / \
18397- B C A G
18398- / \ / \ --> / \
18399- D E F G B F
18400- / \
18401- D E
18402-
18403- In this case, A has been rotated left. This preserves the ordering of the
18404- binary tree. */
18405-
18406-#include <config.h>
18407-
18408-/* Specification. */
18409-#ifdef IN_LIBINTL
18410-# include "tsearch.h"
18411-#else
18412-# include <search.h>
18413-#endif
18414-
18415-#include <stdlib.h>
18416-
18417-typedef int (*__compar_fn_t) (const void *, const void *);
18418-typedef void (*__action_fn_t) (const void *, VISIT, int);
18419-
18420-#ifndef weak_alias
18421-# define __tsearch tsearch
18422-# define __tfind tfind
18423-# define __tdelete tdelete
18424-# define __twalk twalk
18425-#endif
18426-
18427-#ifndef internal_function
18428-/* Inside GNU libc we mark some function in a special way. In other
18429- environments simply ignore the marking. */
18430-# define internal_function
18431-#endif
18432-
18433-typedef struct node_t
18434-{
18435- /* Callers expect this to be the first element in the structure - do not
18436- move! */
18437- const void *key;
18438- struct node_t *left;
18439- struct node_t *right;
18440- unsigned int red:1;
18441-} *node;
18442-typedef const struct node_t *const_node;
18443-
18444-#undef DEBUGGING
18445-
18446-#ifdef DEBUGGING
18447-
18448-/* Routines to check tree invariants. */
18449-
18450-#include <assert.h>
18451-
18452-#define CHECK_TREE(a) check_tree(a)
18453-
18454-static void
18455-check_tree_recurse (node p, int d_sofar, int d_total)
18456-{
18457- if (p == NULL)
18458- {
18459- assert (d_sofar == d_total);
18460- return;
18461- }
18462-
18463- check_tree_recurse (p->left, d_sofar + (p->left && !p->left->red), d_total);
18464- check_tree_recurse (p->right, d_sofar + (p->right && !p->right->red), d_total);
18465- if (p->left)
18466- assert (!(p->left->red && p->red));
18467- if (p->right)
18468- assert (!(p->right->red && p->red));
18469-}
18470-
18471-static void
18472-check_tree (node root)
18473-{
18474- int cnt = 0;
18475- node p;
18476- if (root == NULL)
18477- return;
18478- root->red = 0;
18479- for(p = root->left; p; p = p->left)
18480- cnt += !p->red;
18481- check_tree_recurse (root, 0, cnt);
18482-}
18483-
18484-
18485-#else
18486-
18487-#define CHECK_TREE(a)
18488-
18489-#endif
18490-
18491-/* Possibly "split" a node with two red successors, and/or fix up two red
18492- edges in a row. ROOTP is a pointer to the lowest node we visited, PARENTP
18493- and GPARENTP pointers to its parent/grandparent. P_R and GP_R contain the
18494- comparison values that determined which way was taken in the tree to reach
18495- ROOTP. MODE is 1 if we need not do the split, but must check for two red
18496- edges between GPARENTP and ROOTP. */
18497-static void
18498-maybe_split_for_insert (node *rootp, node *parentp, node *gparentp,
18499- int p_r, int gp_r, int mode)
18500-{
18501- node root = *rootp;
18502- node *rp, *lp;
18503- rp = &(*rootp)->right;
18504- lp = &(*rootp)->left;
18505-
18506- /* See if we have to split this node (both successors red). */
18507- if (mode == 1
18508- || ((*rp) != NULL && (*lp) != NULL && (*rp)->red && (*lp)->red))
18509- {
18510- /* This node becomes red, its successors black. */
18511- root->red = 1;
18512- if (*rp)
18513- (*rp)->red = 0;
18514- if (*lp)
18515- (*lp)->red = 0;
18516-
18517- /* If the parent of this node is also red, we have to do
18518- rotations. */
18519- if (parentp != NULL && (*parentp)->red)
18520- {
18521- node gp = *gparentp;
18522- node p = *parentp;
18523- /* There are two main cases:
18524- 1. The edge types (left or right) of the two red edges differ.
18525- 2. Both red edges are of the same type.
18526- There exist two symmetries of each case, so there is a total of
18527- 4 cases. */
18528- if ((p_r > 0) != (gp_r > 0))
18529- {
18530- /* Put the child at the top of the tree, with its parent
18531- and grandparent as successors. */
18532- p->red = 1;
18533- gp->red = 1;
18534- root->red = 0;
18535- if (p_r < 0)
18536- {
18537- /* Child is left of parent. */
18538- p->left = *rp;
18539- *rp = p;
18540- gp->right = *lp;
18541- *lp = gp;
18542- }
18543- else
18544- {
18545- /* Child is right of parent. */
18546- p->right = *lp;
18547- *lp = p;
18548- gp->left = *rp;
18549- *rp = gp;
18550- }
18551- *gparentp = root;
18552- }
18553- else
18554- {
18555- *gparentp = *parentp;
18556- /* Parent becomes the top of the tree, grandparent and
18557- child are its successors. */
18558- p->red = 0;
18559- gp->red = 1;
18560- if (p_r < 0)
18561- {
18562- /* Left edges. */
18563- gp->left = p->right;
18564- p->right = gp;
18565- }
18566- else
18567- {
18568- /* Right edges. */
18569- gp->right = p->left;
18570- p->left = gp;
18571- }
18572- }
18573- }
18574- }
18575-}
18576-
18577-/* Find or insert datum into search tree.
18578- KEY is the key to be located, ROOTP is the address of tree root,
18579- COMPAR the ordering function. */
18580-void *
18581-__tsearch (const void *key, void **vrootp, __compar_fn_t compar)
18582-{
18583- node q;
18584- node *parentp = NULL, *gparentp = NULL;
18585- node *rootp = (node *) vrootp;
18586- node *nextp;
18587- int r = 0, p_r = 0, gp_r = 0; /* No they might not, Mr Compiler. */
18588-
18589- if (rootp == NULL)
18590- return NULL;
18591-
18592- /* This saves some additional tests below. */
18593- if (*rootp != NULL)
18594- (*rootp)->red = 0;
18595-
18596- CHECK_TREE (*rootp);
18597-
18598- nextp = rootp;
18599- while (*nextp != NULL)
18600- {
18601- node root = *rootp;
18602- r = (*compar) (key, root->key);
18603- if (r == 0)
18604- return root;
18605-
18606- maybe_split_for_insert (rootp, parentp, gparentp, p_r, gp_r, 0);
18607- /* If that did any rotations, parentp and gparentp are now garbage.
18608- That doesn't matter, because the values they contain are never
18609- used again in that case. */
18610-
18611- nextp = r < 0 ? &root->left : &root->right;
18612- if (*nextp == NULL)
18613- break;
18614-
18615- gparentp = parentp;
18616- parentp = rootp;
18617- rootp = nextp;
18618-
18619- gp_r = p_r;
18620- p_r = r;
18621- }
18622-
18623- q = (struct node_t *) malloc (sizeof (struct node_t));
18624- if (q != NULL)
18625- {
18626- *nextp = q; /* link new node to old */
18627- q->key = key; /* initialize new node */
18628- q->red = 1;
18629- q->left = q->right = NULL;
18630-
18631- if (nextp != rootp)
18632- /* There may be two red edges in a row now, which we must avoid by
18633- rotating the tree. */
18634- maybe_split_for_insert (nextp, rootp, parentp, r, p_r, 1);
18635- }
18636-
18637- return q;
18638-}
18639-#ifdef weak_alias
18640-weak_alias (__tsearch, tsearch)
18641-#endif
18642-
18643-
18644-/* Find datum in search tree.
18645- KEY is the key to be located, ROOTP is the address of tree root,
18646- COMPAR the ordering function. */
18647-void *
18648-__tfind (key, vrootp, compar)
18649- const void *key;
18650- void *const *vrootp;
18651- __compar_fn_t compar;
18652-{
18653- node *rootp = (node *) vrootp;
18654-
18655- if (rootp == NULL)
18656- return NULL;
18657-
18658- CHECK_TREE (*rootp);
18659-
18660- while (*rootp != NULL)
18661- {
18662- node root = *rootp;
18663- int r;
18664-
18665- r = (*compar) (key, root->key);
18666- if (r == 0)
18667- return root;
18668-
18669- rootp = r < 0 ? &root->left : &root->right;
18670- }
18671- return NULL;
18672-}
18673-#ifdef weak_alias
18674-weak_alias (__tfind, tfind)
18675-#endif
18676-
18677-
18678-/* Delete node with given key.
18679- KEY is the key to be deleted, ROOTP is the address of the root of tree,
18680- COMPAR the comparison function. */
18681-void *
18682-__tdelete (const void *key, void **vrootp, __compar_fn_t compar)
18683-{
18684- node p, q, r, retval;
18685- int cmp;
18686- node *rootp = (node *) vrootp;
18687- node root, unchained;
18688- /* Stack of nodes so we remember the parents without recursion. It's
18689- _very_ unlikely that there are paths longer than 40 nodes. The tree
18690- would need to have around 250.000 nodes. */
18691- int stacksize = 100;
18692- int sp = 0;
18693- node *nodestack[100];
18694-
18695- if (rootp == NULL)
18696- return NULL;
18697- p = *rootp;
18698- if (p == NULL)
18699- return NULL;
18700-
18701- CHECK_TREE (p);
18702-
18703- while ((cmp = (*compar) (key, (*rootp)->key)) != 0)
18704- {
18705- if (sp == stacksize)
18706- abort ();
18707-
18708- nodestack[sp++] = rootp;
18709- p = *rootp;
18710- rootp = ((cmp < 0)
18711- ? &(*rootp)->left
18712- : &(*rootp)->right);
18713- if (*rootp == NULL)
18714- return NULL;
18715- }
18716-
18717- /* This is bogus if the node to be deleted is the root... this routine
18718- really should return an integer with 0 for success, -1 for failure
18719- and errno = ESRCH or something. */
18720- retval = p;
18721-
18722- /* We don't unchain the node we want to delete. Instead, we overwrite
18723- it with its successor and unchain the successor. If there is no
18724- successor, we really unchain the node to be deleted. */
18725-
18726- root = *rootp;
18727-
18728- r = root->right;
18729- q = root->left;
18730-
18731- if (q == NULL || r == NULL)
18732- unchained = root;
18733- else
18734- {
18735- node *parent = rootp, *up = &root->right;
18736- for (;;)
18737- {
18738- if (sp == stacksize)
18739- abort ();
18740- nodestack[sp++] = parent;
18741- parent = up;
18742- if ((*up)->left == NULL)
18743- break;
18744- up = &(*up)->left;
18745- }
18746- unchained = *up;
18747- }
18748-
18749- /* We know that either the left or right successor of UNCHAINED is NULL.
18750- R becomes the other one, it is chained into the parent of UNCHAINED. */
18751- r = unchained->left;
18752- if (r == NULL)
18753- r = unchained->right;
18754- if (sp == 0)
18755- *rootp = r;
18756- else
18757- {
18758- q = *nodestack[sp-1];
18759- if (unchained == q->right)
18760- q->right = r;
18761- else
18762- q->left = r;
18763- }
18764-
18765- if (unchained != root)
18766- root->key = unchained->key;
18767- if (!unchained->red)
18768- {
18769- /* Now we lost a black edge, which means that the number of black
18770- edges on every path is no longer constant. We must balance the
18771- tree. */
18772- /* NODESTACK now contains all parents of R. R is likely to be NULL
18773- in the first iteration. */
18774- /* NULL nodes are considered black throughout - this is necessary for
18775- correctness. */
18776- while (sp > 0 && (r == NULL || !r->red))
18777- {
18778- node *pp = nodestack[sp - 1];
18779- p = *pp;
18780- /* Two symmetric cases. */
18781- if (r == p->left)
18782- {
18783- /* Q is R's brother, P is R's parent. The subtree with root
18784- R has one black edge less than the subtree with root Q. */
18785- q = p->right;
18786- if (q->red)
18787- {
18788- /* If Q is red, we know that P is black. We rotate P left
18789- so that Q becomes the top node in the tree, with P below
18790- it. P is colored red, Q is colored black.
18791- This action does not change the black edge count for any
18792- leaf in the tree, but we will be able to recognize one
18793- of the following situations, which all require that Q
18794- is black. */
18795- q->red = 0;
18796- p->red = 1;
18797- /* Left rotate p. */
18798- p->right = q->left;
18799- q->left = p;
18800- *pp = q;
18801- /* Make sure pp is right if the case below tries to use
18802- it. */
18803- nodestack[sp++] = pp = &q->left;
18804- q = p->right;
18805- }
18806- /* We know that Q can't be NULL here. We also know that Q is
18807- black. */
18808- if ((q->left == NULL || !q->left->red)
18809- && (q->right == NULL || !q->right->red))
18810- {
18811- /* Q has two black successors. We can simply color Q red.
18812- The whole subtree with root P is now missing one black
18813- edge. Note that this action can temporarily make the
18814- tree invalid (if P is red). But we will exit the loop
18815- in that case and set P black, which both makes the tree
18816- valid and also makes the black edge count come out
18817- right. If P is black, we are at least one step closer
18818- to the root and we'll try again the next iteration. */
18819- q->red = 1;
18820- r = p;
18821- }
18822- else
18823- {
18824- /* Q is black, one of Q's successors is red. We can
18825- repair the tree with one operation and will exit the
18826- loop afterwards. */
18827- if (q->right == NULL || !q->right->red)
18828- {
18829- /* The left one is red. We perform the same action as
18830- in maybe_split_for_insert where two red edges are
18831- adjacent but point in different directions:
18832- Q's left successor (let's call it Q2) becomes the
18833- top of the subtree we are looking at, its parent (Q)
18834- and grandparent (P) become its successors. The former
18835- successors of Q2 are placed below P and Q.
18836- P becomes black, and Q2 gets the color that P had.
18837- This changes the black edge count only for node R and
18838- its successors. */
18839- node q2 = q->left;
18840- q2->red = p->red;
18841- p->right = q2->left;
18842- q->left = q2->right;
18843- q2->right = q;
18844- q2->left = p;
18845- *pp = q2;
18846- p->red = 0;
18847- }
18848- else
18849- {
18850- /* It's the right one. Rotate P left. P becomes black,
18851- and Q gets the color that P had. Q's right successor
18852- also becomes black. This changes the black edge
18853- count only for node R and its successors. */
18854- q->red = p->red;
18855- p->red = 0;
18856-
18857- q->right->red = 0;
18858-
18859- /* left rotate p */
18860- p->right = q->left;
18861- q->left = p;
18862- *pp = q;
18863- }
18864-
18865- /* We're done. */
18866- sp = 1;
18867- r = NULL;
18868- }
18869- }
18870- else
18871- {
18872- /* Comments: see above. */
18873- q = p->left;
18874- if (q->red)
18875- {
18876- q->red = 0;
18877- p->red = 1;
18878- p->left = q->right;
18879- q->right = p;
18880- *pp = q;
18881- nodestack[sp++] = pp = &q->right;
18882- q = p->left;
18883- }
18884- if ((q->right == NULL || !q->right->red)
18885- && (q->left == NULL || !q->left->red))
18886- {
18887- q->red = 1;
18888- r = p;
18889- }
18890- else
18891- {
18892- if (q->left == NULL || !q->left->red)
18893- {
18894- node q2 = q->right;
18895- q2->red = p->red;
18896- p->left = q2->right;
18897- q->right = q2->left;
18898- q2->left = q;
18899- q2->right = p;
18900- *pp = q2;
18901- p->red = 0;
18902- }
18903- else
18904- {
18905- q->red = p->red;
18906- p->red = 0;
18907- q->left->red = 0;
18908- p->left = q->right;
18909- q->right = p;
18910- *pp = q;
18911- }
18912- sp = 1;
18913- r = NULL;
18914- }
18915- }
18916- --sp;
18917- }
18918- if (r != NULL)
18919- r->red = 0;
18920- }
18921-
18922- free (unchained);
18923- return retval;
18924-}
18925-#ifdef weak_alias
18926-weak_alias (__tdelete, tdelete)
18927-#endif
18928-
18929-
18930-/* Walk the nodes of a tree.
18931- ROOT is the root of the tree to be walked, ACTION the function to be
18932- called at each node. LEVEL is the level of ROOT in the whole tree. */
18933-static void
18934-internal_function
18935-trecurse (const void *vroot, __action_fn_t action, int level)
18936-{
18937- const_node root = (const_node) vroot;
18938-
18939- if (root->left == NULL && root->right == NULL)
18940- (*action) (root, leaf, level);
18941- else
18942- {
18943- (*action) (root, preorder, level);
18944- if (root->left != NULL)
18945- trecurse (root->left, action, level + 1);
18946- (*action) (root, postorder, level);
18947- if (root->right != NULL)
18948- trecurse (root->right, action, level + 1);
18949- (*action) (root, endorder, level);
18950- }
18951-}
18952-
18953-
18954-/* Walk the nodes of a tree.
18955- ROOT is the root of the tree to be walked, ACTION the function to be
18956- called at each node. */
18957-void
18958-__twalk (const void *vroot, __action_fn_t action)
18959-{
18960- const_node root = (const_node) vroot;
18961-
18962- CHECK_TREE (root);
18963-
18964- if (root != NULL && action != NULL)
18965- trecurse (root, action, 0);
18966-}
18967-#ifdef weak_alias
18968-weak_alias (__twalk, twalk)
18969-#endif
18970-
18971-
18972-#ifdef _LIBC
18973-
18974-/* The standardized functions miss an important functionality: the
18975- tree cannot be removed easily. We provide a function to do this. */
18976-static void
18977-internal_function
18978-tdestroy_recurse (node root, __free_fn_t freefct)
18979-{
18980- if (root->left != NULL)
18981- tdestroy_recurse (root->left, freefct);
18982- if (root->right != NULL)
18983- tdestroy_recurse (root->right, freefct);
18984- (*freefct) ((void *) root->key);
18985- /* Free the node itself. */
18986- free (root);
18987-}
18988-
18989-void
18990-__tdestroy (void *vroot, __free_fn_t freefct)
18991-{
18992- node root = (node) vroot;
18993-
18994- CHECK_TREE (root);
18995-
18996- if (root != NULL)
18997- tdestroy_recurse (root, freefct);
18998-}
18999-weak_alias (__tdestroy, tdestroy)
19000-
19001-#endif /* _LIBC */
19002--- a/intl/tsearch.h
19003+++ /dev/null
19004@@ -1,83 +0,0 @@
19005-/* Binary tree data structure.
19006- Copyright (C) 2006 Free Software Foundation, Inc.
19007-
19008- This program is free software; you can redistribute it and/or modify it
19009- under the terms of the GNU Library General Public License as published
19010- by the Free Software Foundation; either version 2, or (at your option)
19011- any later version.
19012-
19013- This program is distributed in the hope that it will be useful,
19014- but WITHOUT ANY WARRANTY; without even the implied warranty of
19015- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
19016- Library General Public License for more details.
19017-
19018- You should have received a copy of the GNU Library General Public
19019- License along with this program; if not, write to the Free Software
19020- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
19021- USA. */
19022-
19023-#ifndef _TSEARCH_H
19024-#define _TSEARCH_H
19025-
19026-#if HAVE_TSEARCH
19027-
19028-/* Get tseach(), tfind(), tdelete(), twalk() declarations. */
19029-#include <search.h>
19030-
19031-#else
19032-
19033-#ifdef __cplusplus
19034-extern "C" {
19035-#endif
19036-
19037-/* See <http://www.opengroup.org/susv3xbd/search.h.html>,
19038- <http://www.opengroup.org/susv3xsh/tsearch.html>
19039- for details. */
19040-
19041-typedef enum
19042-{
19043- preorder,
19044- postorder,
19045- endorder,
19046- leaf
19047-}
19048-VISIT;
19049-
19050-/* Searches an element in the tree *VROOTP that compares equal to KEY.
19051- If one is found, it is returned. Otherwise, a new element equal to KEY
19052- is inserted in the tree and is returned. */
19053-extern void * tsearch (const void *key, void **vrootp,
19054- int (*compar) (const void *, const void *));
19055-
19056-/* Searches an element in the tree *VROOTP that compares equal to KEY.
19057- If one is found, it is returned. Otherwise, NULL is returned. */
19058-extern void * tfind (const void *key, void *const *vrootp,
19059- int (*compar) (const void *, const void *));
19060-
19061-/* Searches an element in the tree *VROOTP that compares equal to KEY.
19062- If one is found, it is removed from the tree, and its parent node is
19063- returned. Otherwise, NULL is returned. */
19064-extern void * tdelete (const void *key, void **vrootp,
19065- int (*compar) (const void *, const void *));
19066-
19067-/* Perform a depth-first, left-to-right traversal of the tree VROOT.
19068- The ACTION function is called:
19069- - for non-leaf nodes: 3 times, before the left subtree traversal,
19070- after the left subtree traversal but before the right subtree traversal,
19071- and after the right subtree traversal,
19072- - for leaf nodes: once.
19073- The arguments passed to ACTION are:
19074- 1. the node; it can be casted to a 'const void * const *', i.e. into a
19075- pointer to the key,
19076- 2. an indicator which visit of the node this is,
19077- 3. the level of the node in the tree (0 for the root). */
19078-extern void twalk (const void *vroot,
19079- void (*action) (const void *, VISIT, int));
19080-
19081-#ifdef __cplusplus
19082-}
19083-#endif
19084-
19085-#endif
19086-
19087-#endif /* _TSEARCH_H */
19088--- a/intl/vasnprintf.c
19089+++ /dev/null
19090@@ -1,4677 +0,0 @@
19091-/* vsprintf with automatic memory allocation.
19092- Copyright (C) 1999, 2002-2007 Free Software Foundation, Inc.
19093-
19094- This program is free software; you can redistribute it and/or modify it
19095- under the terms of the GNU Library General Public License as published
19096- by the Free Software Foundation; either version 2, or (at your option)
19097- any later version.
19098-
19099- This program is distributed in the hope that it will be useful,
19100- but WITHOUT ANY WARRANTY; without even the implied warranty of
19101- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
19102- Library General Public License for more details.
19103-
19104- You should have received a copy of the GNU Library General Public
19105- License along with this program; if not, write to the Free Software
19106- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
19107- USA. */
19108-
19109-/* This file can be parametrized with the following macros:
19110- VASNPRINTF The name of the function being defined.
19111- FCHAR_T The element type of the format string.
19112- DCHAR_T The element type of the destination (result) string.
19113- FCHAR_T_ONLY_ASCII Set to 1 to enable verification that all characters
19114- in the format string are ASCII. MUST be set if
19115- FCHAR_T and DCHAR_T are not the same type.
19116- DIRECTIVE Structure denoting a format directive.
19117- Depends on FCHAR_T.
19118- DIRECTIVES Structure denoting the set of format directives of a
19119- format string. Depends on FCHAR_T.
19120- PRINTF_PARSE Function that parses a format string.
19121- Depends on FCHAR_T.
19122- DCHAR_CPY memcpy like function for DCHAR_T[] arrays.
19123- DCHAR_SET memset like function for DCHAR_T[] arrays.
19124- DCHAR_MBSNLEN mbsnlen like function for DCHAR_T[] arrays.
19125- SNPRINTF The system's snprintf (or similar) function.
19126- This may be either snprintf or swprintf.
19127- TCHAR_T The element type of the argument and result string
19128- of the said SNPRINTF function. This may be either
19129- char or wchar_t. The code exploits that
19130- sizeof (TCHAR_T) | sizeof (DCHAR_T) and
19131- alignof (TCHAR_T) <= alignof (DCHAR_T).
19132- DCHAR_IS_TCHAR Set to 1 if DCHAR_T and TCHAR_T are the same type.
19133- DCHAR_CONV_FROM_ENCODING A function to convert from char[] to DCHAR[].
19134- DCHAR_IS_UINT8_T Set to 1 if DCHAR_T is uint8_t.
19135- DCHAR_IS_UINT16_T Set to 1 if DCHAR_T is uint16_t.
19136- DCHAR_IS_UINT32_T Set to 1 if DCHAR_T is uint32_t. */
19137-
19138-/* Tell glibc's <stdio.h> to provide a prototype for snprintf().
19139- This must come before <config.h> because <config.h> may include
19140- <features.h>, and once <features.h> has been included, it's too late. */
19141-#ifndef _GNU_SOURCE
19142-# define _GNU_SOURCE 1
19143-#endif
19144-
19145-#ifndef VASNPRINTF
19146-# include <config.h>
19147-#endif
19148-#ifndef IN_LIBINTL
19149-# include <alloca.h>
19150-#endif
19151-
19152-/* Specification. */
19153-#ifndef VASNPRINTF
19154-# if WIDE_CHAR_VERSION
19155-# include "vasnwprintf.h"
19156-# else
19157-# include "vasnprintf.h"
19158-# endif
19159-#endif
19160-
19161-#include <locale.h> /* localeconv() */
19162-#include <stdio.h> /* snprintf(), sprintf() */
19163-#include <stdlib.h> /* abort(), malloc(), realloc(), free() */
19164-#include <string.h> /* memcpy(), strlen() */
19165-#include <errno.h> /* errno */
19166-#include <limits.h> /* CHAR_BIT */
19167-#include <float.h> /* DBL_MAX_EXP, LDBL_MAX_EXP */
19168-#if HAVE_NL_LANGINFO
19169-# include <langinfo.h>
19170-#endif
19171-#ifndef VASNPRINTF
19172-# if WIDE_CHAR_VERSION
19173-# include "wprintf-parse.h"
19174-# else
19175-# include "printf-parse.h"
19176-# endif
19177-#endif
19178-
19179-/* Checked size_t computations. */
19180-#include "xsize.h"
19181-
19182-#if (NEED_PRINTF_DOUBLE || NEED_PRINTF_LONG_DOUBLE) && !defined IN_LIBINTL
19183-# include <math.h>
19184-# include "float+.h"
19185-#endif
19186-
19187-#if (NEED_PRINTF_DOUBLE || NEED_PRINTF_INFINITE_DOUBLE) && !defined IN_LIBINTL
19188-# include <math.h>
19189-# include "isnan.h"
19190-#endif
19191-
19192-#if (NEED_PRINTF_LONG_DOUBLE || NEED_PRINTF_INFINITE_LONG_DOUBLE) && !defined IN_LIBINTL
19193-# include <math.h>
19194-# include "isnanl-nolibm.h"
19195-# include "fpucw.h"
19196-#endif
19197-
19198-#if (NEED_PRINTF_DIRECTIVE_A || NEED_PRINTF_DOUBLE) && !defined IN_LIBINTL
19199-# include <math.h>
19200-# include "isnan.h"
19201-# include "printf-frexp.h"
19202-#endif
19203-
19204-#if (NEED_PRINTF_DIRECTIVE_A || NEED_PRINTF_LONG_DOUBLE) && !defined IN_LIBINTL
19205-# include <math.h>
19206-# include "isnanl-nolibm.h"
19207-# include "printf-frexpl.h"
19208-# include "fpucw.h"
19209-#endif
19210-
19211-/* Some systems, like OSF/1 4.0 and Woe32, don't have EOVERFLOW. */
19212-#ifndef EOVERFLOW
19213-# define EOVERFLOW E2BIG
19214-#endif
19215-
19216-#if HAVE_WCHAR_T
19217-# if HAVE_WCSLEN
19218-# define local_wcslen wcslen
19219-# else
19220- /* Solaris 2.5.1 has wcslen() in a separate library libw.so. To avoid
19221- a dependency towards this library, here is a local substitute.
19222- Define this substitute only once, even if this file is included
19223- twice in the same compilation unit. */
19224-# ifndef local_wcslen_defined
19225-# define local_wcslen_defined 1
19226-static size_t
19227-local_wcslen (const wchar_t *s)
19228-{
19229- const wchar_t *ptr;
19230-
19231- for (ptr = s; *ptr != (wchar_t) 0; ptr++)
19232- ;
19233- return ptr - s;
19234-}
19235-# endif
19236-# endif
19237-#endif
19238-
19239-/* Default parameters. */
19240-#ifndef VASNPRINTF
19241-# if WIDE_CHAR_VERSION
19242-# define VASNPRINTF vasnwprintf
19243-# define FCHAR_T wchar_t
19244-# define DCHAR_T wchar_t
19245-# define TCHAR_T wchar_t
19246-# define DCHAR_IS_TCHAR 1
19247-# define DIRECTIVE wchar_t_directive
19248-# define DIRECTIVES wchar_t_directives
19249-# define PRINTF_PARSE wprintf_parse
19250-# define DCHAR_CPY wmemcpy
19251-# else
19252-# define VASNPRINTF vasnprintf
19253-# define FCHAR_T char
19254-# define DCHAR_T char
19255-# define TCHAR_T char
19256-# define DCHAR_IS_TCHAR 1
19257-# define DIRECTIVE char_directive
19258-# define DIRECTIVES char_directives
19259-# define PRINTF_PARSE printf_parse
19260-# define DCHAR_CPY memcpy
19261-# endif
19262-#endif
19263-#if WIDE_CHAR_VERSION
19264- /* TCHAR_T is wchar_t. */
19265-# define USE_SNPRINTF 1
19266-# if HAVE_DECL__SNWPRINTF
19267- /* On Windows, the function swprintf() has a different signature than
19268- on Unix; we use the _snwprintf() function instead. */
19269-# define SNPRINTF _snwprintf
19270-# else
19271- /* Unix. */
19272-# define SNPRINTF swprintf
19273-# endif
19274-#else
19275- /* TCHAR_T is char. */
19276-# /* Use snprintf if it exists under the name 'snprintf' or '_snprintf'.
19277- But don't use it on BeOS, since BeOS snprintf produces no output if the
19278- size argument is >= 0x3000000. */
19279-# if (HAVE_DECL__SNPRINTF || HAVE_SNPRINTF) && !defined __BEOS__
19280-# define USE_SNPRINTF 1
19281-# else
19282-# define USE_SNPRINTF 0
19283-# endif
19284-# if HAVE_DECL__SNPRINTF
19285- /* Windows. */
19286-# define SNPRINTF _snprintf
19287-# else
19288- /* Unix. */
19289-# define SNPRINTF snprintf
19290- /* Here we need to call the native snprintf, not rpl_snprintf. */
19291-# undef snprintf
19292-# endif
19293-#endif
19294-/* Here we need to call the native sprintf, not rpl_sprintf. */
19295-#undef sprintf
19296-
19297-#if (NEED_PRINTF_DIRECTIVE_A || NEED_PRINTF_LONG_DOUBLE || NEED_PRINTF_DOUBLE || NEED_PRINTF_INFINITE_DOUBLE) && !defined IN_LIBINTL
19298-/* Determine the decimal-point character according to the current locale. */
19299-# ifndef decimal_point_char_defined
19300-# define decimal_point_char_defined 1
19301-static char
19302-decimal_point_char ()
19303-{
19304- const char *point;
19305- /* Determine it in a multithread-safe way. We know nl_langinfo is
19306- multithread-safe on glibc systems, but is not required to be multithread-
19307- safe by POSIX. sprintf(), however, is multithread-safe. localeconv()
19308- is rarely multithread-safe. */
19309-# if HAVE_NL_LANGINFO && __GLIBC__
19310- point = nl_langinfo (RADIXCHAR);
19311-# elif 1
19312- char pointbuf[5];
19313- sprintf (pointbuf, "%#.0f", 1.0);
19314- point = &pointbuf[1];
19315-# else
19316- point = localeconv () -> decimal_point;
19317-# endif
19318- /* The decimal point is always a single byte: either '.' or ','. */
19319- return (point[0] != '\0' ? point[0] : '.');
19320-}
19321-# endif
19322-#endif
19323-
19324-#if NEED_PRINTF_INFINITE_DOUBLE && !NEED_PRINTF_DOUBLE && !defined IN_LIBINTL
19325-
19326-/* Equivalent to !isfinite(x) || x == 0, but does not require libm. */
19327-static int
19328-is_infinite_or_zero (double x)
19329-{
19330- return isnan (x) || x + x == x;
19331-}
19332-
19333-#endif
19334-
19335-#if NEED_PRINTF_INFINITE_LONG_DOUBLE && !NEED_PRINTF_LONG_DOUBLE && !defined IN_LIBINTL
19336-
19337-/* Equivalent to !isfinite(x), but does not require libm. */
19338-static int
19339-is_infinitel (long double x)
19340-{
19341- return isnanl (x) || (x + x == x && x != 0.0L);
19342-}
19343-
19344-#endif
19345-
19346-#if (NEED_PRINTF_LONG_DOUBLE || NEED_PRINTF_DOUBLE) && !defined IN_LIBINTL
19347-
19348-/* Converting 'long double' to decimal without rare rounding bugs requires
19349- real bignums. We use the naming conventions of GNU gmp, but vastly simpler
19350- (and slower) algorithms. */
19351-
19352-typedef unsigned int mp_limb_t;
19353-# define GMP_LIMB_BITS 32
19354-typedef int mp_limb_verify[2 * (sizeof (mp_limb_t) * CHAR_BIT == GMP_LIMB_BITS) - 1];
19355-
19356-typedef unsigned long long mp_twolimb_t;
19357-# define GMP_TWOLIMB_BITS 64
19358-typedef int mp_twolimb_verify[2 * (sizeof (mp_twolimb_t) * CHAR_BIT == GMP_TWOLIMB_BITS) - 1];
19359-
19360-/* Representation of a bignum >= 0. */
19361-typedef struct
19362-{
19363- size_t nlimbs;
19364- mp_limb_t *limbs; /* Bits in little-endian order, allocated with malloc(). */
19365-} mpn_t;
19366-
19367-/* Compute the product of two bignums >= 0.
19368- Return the allocated memory in case of success, NULL in case of memory
19369- allocation failure. */
19370-static void *
19371-multiply (mpn_t src1, mpn_t src2, mpn_t *dest)
19372-{
19373- const mp_limb_t *p1;
19374- const mp_limb_t *p2;
19375- size_t len1;
19376- size_t len2;
19377-
19378- if (src1.nlimbs <= src2.nlimbs)
19379- {
19380- len1 = src1.nlimbs;
19381- p1 = src1.limbs;
19382- len2 = src2.nlimbs;
19383- p2 = src2.limbs;
19384- }
19385- else
19386- {
19387- len1 = src2.nlimbs;
19388- p1 = src2.limbs;
19389- len2 = src1.nlimbs;
19390- p2 = src1.limbs;
19391- }
19392- /* Now 0 <= len1 <= len2. */
19393- if (len1 == 0)
19394- {
19395- /* src1 or src2 is zero. */
19396- dest->nlimbs = 0;
19397- dest->limbs = (mp_limb_t *) malloc (1);
19398- }
19399- else
19400- {
19401- /* Here 1 <= len1 <= len2. */
19402- size_t dlen;
19403- mp_limb_t *dp;
19404- size_t k, i, j;
19405-
19406- dlen = len1 + len2;
19407- dp = (mp_limb_t *) malloc (dlen * sizeof (mp_limb_t));
19408- if (dp == NULL)
19409- return NULL;
19410- for (k = len2; k > 0; )
19411- dp[--k] = 0;
19412- for (i = 0; i < len1; i++)
19413- {
19414- mp_limb_t digit1 = p1[i];
19415- mp_twolimb_t carry = 0;
19416- for (j = 0; j < len2; j++)
19417- {
19418- mp_limb_t digit2 = p2[j];
19419- carry += (mp_twolimb_t) digit1 * (mp_twolimb_t) digit2;
19420- carry += dp[i + j];
19421- dp[i + j] = (mp_limb_t) carry;
19422- carry = carry >> GMP_LIMB_BITS;
19423- }
19424- dp[i + len2] = (mp_limb_t) carry;
19425- }
19426- /* Normalise. */
19427- while (dlen > 0 && dp[dlen - 1] == 0)
19428- dlen--;
19429- dest->nlimbs = dlen;
19430- dest->limbs = dp;
19431- }
19432- return dest->limbs;
19433-}
19434-
19435-/* Compute the quotient of a bignum a >= 0 and a bignum b > 0.
19436- a is written as a = q * b + r with 0 <= r < b. q is the quotient, r
19437- the remainder.
19438- Finally, round-to-even is performed: If r > b/2 or if r = b/2 and q is odd,
19439- q is incremented.
19440- Return the allocated memory in case of success, NULL in case of memory
19441- allocation failure. */
19442-static void *
19443-divide (mpn_t a, mpn_t b, mpn_t *q)
19444-{
19445- /* Algorithm:
19446- First normalise a and b: a=[a[m-1],...,a[0]], b=[b[n-1],...,b[0]]
19447- with m>=0 and n>0 (in base beta = 2^GMP_LIMB_BITS).
19448- If m<n, then q:=0 and r:=a.
19449- If m>=n=1, perform a single-precision division:
19450- r:=0, j:=m,
19451- while j>0 do
19452- {Here (q[m-1]*beta^(m-1)+...+q[j]*beta^j) * b[0] + r*beta^j =
19453- = a[m-1]*beta^(m-1)+...+a[j]*beta^j und 0<=r<b[0]<beta}
19454- j:=j-1, r:=r*beta+a[j], q[j]:=floor(r/b[0]), r:=r-b[0]*q[j].
19455- Normalise [q[m-1],...,q[0]], yields q.
19456- If m>=n>1, perform a multiple-precision division:
19457- We have a/b < beta^(m-n+1).
19458- s:=intDsize-1-(hightest bit in b[n-1]), 0<=s<intDsize.
19459- Shift a and b left by s bits, copying them. r:=a.
19460- r=[r[m],...,r[0]], b=[b[n-1],...,b[0]] with b[n-1]>=beta/2.
19461- For j=m-n,...,0: {Here 0 <= r < b*beta^(j+1).}
19462- Compute q* :
19463- q* := floor((r[j+n]*beta+r[j+n-1])/b[n-1]).
19464- In case of overflow (q* >= beta) set q* := beta-1.
19465- Compute c2 := ((r[j+n]*beta+r[j+n-1]) - q* * b[n-1])*beta + r[j+n-2]
19466- and c3 := b[n-2] * q*.
19467- {We have 0 <= c2 < 2*beta^2, even 0 <= c2 < beta^2 if no overflow
19468- occurred. Furthermore 0 <= c3 < beta^2.
19469- If there was overflow and
19470- r[j+n]*beta+r[j+n-1] - q* * b[n-1] >= beta, i.e. c2 >= beta^2,
19471- the next test can be skipped.}
19472- While c3 > c2, {Here 0 <= c2 < c3 < beta^2}
19473- Put q* := q* - 1, c2 := c2 + b[n-1]*beta, c3 := c3 - b[n-2].
19474- If q* > 0:
19475- Put r := r - b * q* * beta^j. In detail:
19476- [r[n+j],...,r[j]] := [r[n+j],...,r[j]] - q* * [b[n-1],...,b[0]].
19477- hence: u:=0, for i:=0 to n-1 do
19478- u := u + q* * b[i],
19479- r[j+i]:=r[j+i]-(u mod beta) (+ beta, if carry),
19480- u:=u div beta (+ 1, if carry in subtraction)
19481- r[n+j]:=r[n+j]-u.
19482- {Since always u = (q* * [b[i-1],...,b[0]] div beta^i) + 1
19483- < q* + 1 <= beta,
19484- the carry u does not overflow.}
19485- If a negative carry occurs, put q* := q* - 1
19486- and [r[n+j],...,r[j]] := [r[n+j],...,r[j]] + [0,b[n-1],...,b[0]].
19487- Set q[j] := q*.
19488- Normalise [q[m-n],..,q[0]]; this yields the quotient q.
19489- Shift [r[n-1],...,r[0]] right by s bits and normalise; this yields the
19490- rest r.
19491- The room for q[j] can be allocated at the memory location of r[n+j].
19492- Finally, round-to-even:
19493- Shift r left by 1 bit.
19494- If r > b or if r = b and q[0] is odd, q := q+1.
19495- */
19496- const mp_limb_t *a_ptr = a.limbs;
19497- size_t a_len = a.nlimbs;
19498- const mp_limb_t *b_ptr = b.limbs;
19499- size_t b_len = b.nlimbs;
19500- mp_limb_t *roomptr;
19501- mp_limb_t *tmp_roomptr = NULL;
19502- mp_limb_t *q_ptr;
19503- size_t q_len;
19504- mp_limb_t *r_ptr;
19505- size_t r_len;
19506-
19507- /* Allocate room for a_len+2 digits.
19508- (Need a_len+1 digits for the real division and 1 more digit for the
19509- final rounding of q.) */
19510- roomptr = (mp_limb_t *) malloc ((a_len + 2) * sizeof (mp_limb_t));
19511- if (roomptr == NULL)
19512- return NULL;
19513-
19514- /* Normalise a. */
19515- while (a_len > 0 && a_ptr[a_len - 1] == 0)
19516- a_len--;
19517-
19518- /* Normalise b. */
19519- for (;;)
19520- {
19521- if (b_len == 0)
19522- /* Division by zero. */
19523- abort ();
19524- if (b_ptr[b_len - 1] == 0)
19525- b_len--;
19526- else
19527- break;
19528- }
19529-
19530- /* Here m = a_len >= 0 and n = b_len > 0. */
19531-
19532- if (a_len < b_len)
19533- {
19534- /* m<n: trivial case. q=0, r := copy of a. */
19535- r_ptr = roomptr;
19536- r_len = a_len;
19537- memcpy (r_ptr, a_ptr, a_len * sizeof (mp_limb_t));
19538- q_ptr = roomptr + a_len;
19539- q_len = 0;
19540- }
19541- else if (b_len == 1)
19542- {
19543- /* n=1: single precision division.
19544- beta^(m-1) <= a < beta^m ==> beta^(m-2) <= a/b < beta^m */
19545- r_ptr = roomptr;
19546- q_ptr = roomptr + 1;
19547- {
19548- mp_limb_t den = b_ptr[0];
19549- mp_limb_t remainder = 0;
19550- const mp_limb_t *sourceptr = a_ptr + a_len;
19551- mp_limb_t *destptr = q_ptr + a_len;
19552- size_t count;
19553- for (count = a_len; count > 0; count--)
19554- {
19555- mp_twolimb_t num =
19556- ((mp_twolimb_t) remainder << GMP_LIMB_BITS) | *--sourceptr;
19557- *--destptr = num / den;
19558- remainder = num % den;
19559- }
19560- /* Normalise and store r. */
19561- if (remainder > 0)
19562- {
19563- r_ptr[0] = remainder;
19564- r_len = 1;
19565- }
19566- else
19567- r_len = 0;
19568- /* Normalise q. */
19569- q_len = a_len;
19570- if (q_ptr[q_len - 1] == 0)
19571- q_len--;
19572- }
19573- }
19574- else
19575- {
19576- /* n>1: multiple precision division.
19577- beta^(m-1) <= a < beta^m, beta^(n-1) <= b < beta^n ==>
19578- beta^(m-n-1) <= a/b < beta^(m-n+1). */
19579- /* Determine s. */
19580- size_t s;
19581- {
19582- mp_limb_t msd = b_ptr[b_len - 1]; /* = b[n-1], > 0 */
19583- s = 31;
19584- if (msd >= 0x10000)
19585- {
19586- msd = msd >> 16;
19587- s -= 16;
19588- }
19589- if (msd >= 0x100)
19590- {
19591- msd = msd >> 8;
19592- s -= 8;
19593- }
19594- if (msd >= 0x10)
19595- {
19596- msd = msd >> 4;
19597- s -= 4;
19598- }
19599- if (msd >= 0x4)
19600- {
19601- msd = msd >> 2;
19602- s -= 2;
19603- }
19604- if (msd >= 0x2)
19605- {
19606- msd = msd >> 1;
19607- s -= 1;
19608- }
19609- }
19610- /* 0 <= s < GMP_LIMB_BITS.
19611- Copy b, shifting it left by s bits. */
19612- if (s > 0)
19613- {
19614- tmp_roomptr = (mp_limb_t *) malloc (b_len * sizeof (mp_limb_t));
19615- if (tmp_roomptr == NULL)
19616- {
19617- free (roomptr);
19618- return NULL;
19619- }
19620- {
19621- const mp_limb_t *sourceptr = b_ptr;
19622- mp_limb_t *destptr = tmp_roomptr;
19623- mp_twolimb_t accu = 0;
19624- size_t count;
19625- for (count = b_len; count > 0; count--)
19626- {
19627- accu += (mp_twolimb_t) *sourceptr++ << s;
19628- *destptr++ = (mp_limb_t) accu;
19629- accu = accu >> GMP_LIMB_BITS;
19630- }
19631- /* accu must be zero, since that was how s was determined. */
19632- if (accu != 0)
19633- abort ();
19634- }
19635- b_ptr = tmp_roomptr;
19636- }
19637- /* Copy a, shifting it left by s bits, yields r.
19638- Memory layout:
19639- At the beginning: r = roomptr[0..a_len],
19640- at the end: r = roomptr[0..b_len-1], q = roomptr[b_len..a_len] */
19641- r_ptr = roomptr;
19642- if (s == 0)
19643- {
19644- memcpy (r_ptr, a_ptr, a_len * sizeof (mp_limb_t));
19645- r_ptr[a_len] = 0;
19646- }
19647- else
19648- {
19649- const mp_limb_t *sourceptr = a_ptr;
19650- mp_limb_t *destptr = r_ptr;
19651- mp_twolimb_t accu = 0;
19652- size_t count;
19653- for (count = a_len; count > 0; count--)
19654- {
19655- accu += (mp_twolimb_t) *sourceptr++ << s;
19656- *destptr++ = (mp_limb_t) accu;
19657- accu = accu >> GMP_LIMB_BITS;
19658- }
19659- *destptr++ = (mp_limb_t) accu;
19660- }
19661- q_ptr = roomptr + b_len;
19662- q_len = a_len - b_len + 1; /* q will have m-n+1 limbs */
19663- {
19664- size_t j = a_len - b_len; /* m-n */
19665- mp_limb_t b_msd = b_ptr[b_len - 1]; /* b[n-1] */
19666- mp_limb_t b_2msd = b_ptr[b_len - 2]; /* b[n-2] */
19667- mp_twolimb_t b_msdd = /* b[n-1]*beta+b[n-2] */
19668- ((mp_twolimb_t) b_msd << GMP_LIMB_BITS) | b_2msd;
19669- /* Division loop, traversed m-n+1 times.
19670- j counts down, b is unchanged, beta/2 <= b[n-1] < beta. */
19671- for (;;)
19672- {
19673- mp_limb_t q_star;
19674- mp_limb_t c1;
19675- if (r_ptr[j + b_len] < b_msd) /* r[j+n] < b[n-1] ? */
19676- {
19677- /* Divide r[j+n]*beta+r[j+n-1] by b[n-1], no overflow. */
19678- mp_twolimb_t num =
19679- ((mp_twolimb_t) r_ptr[j + b_len] << GMP_LIMB_BITS)
19680- | r_ptr[j + b_len - 1];
19681- q_star = num / b_msd;
19682- c1 = num % b_msd;
19683- }
19684- else
19685- {
19686- /* Overflow, hence r[j+n]*beta+r[j+n-1] >= beta*b[n-1]. */
19687- q_star = (mp_limb_t)~(mp_limb_t)0; /* q* = beta-1 */
19688- /* Test whether r[j+n]*beta+r[j+n-1] - (beta-1)*b[n-1] >= beta
19689- <==> r[j+n]*beta+r[j+n-1] + b[n-1] >= beta*b[n-1]+beta
19690- <==> b[n-1] < floor((r[j+n]*beta+r[j+n-1]+b[n-1])/beta)
19691- {<= beta !}.
19692- If yes, jump directly to the subtraction loop.
19693- (Otherwise, r[j+n]*beta+r[j+n-1] - (beta-1)*b[n-1] < beta
19694- <==> floor((r[j+n]*beta+r[j+n-1]+b[n-1])/beta) = b[n-1] ) */
19695- if (r_ptr[j + b_len] > b_msd
19696- || (c1 = r_ptr[j + b_len - 1] + b_msd) < b_msd)
19697- /* r[j+n] >= b[n-1]+1 or
19698- r[j+n] = b[n-1] and the addition r[j+n-1]+b[n-1] gives a
19699- carry. */
19700- goto subtract;
19701- }
19702- /* q_star = q*,
19703- c1 = (r[j+n]*beta+r[j+n-1]) - q* * b[n-1] (>=0, <beta). */
19704- {
19705- mp_twolimb_t c2 = /* c1*beta+r[j+n-2] */
19706- ((mp_twolimb_t) c1 << GMP_LIMB_BITS) | r_ptr[j + b_len - 2];
19707- mp_twolimb_t c3 = /* b[n-2] * q* */
19708- (mp_twolimb_t) b_2msd * (mp_twolimb_t) q_star;
19709- /* While c2 < c3, increase c2 and decrease c3.
19710- Consider c3-c2. While it is > 0, decrease it by
19711- b[n-1]*beta+b[n-2]. Because of b[n-1]*beta+b[n-2] >= beta^2/2
19712- this can happen only twice. */
19713- if (c3 > c2)
19714- {
19715- q_star = q_star - 1; /* q* := q* - 1 */
19716- if (c3 - c2 > b_msdd)
19717- q_star = q_star - 1; /* q* := q* - 1 */
19718- }
19719- }
19720- if (q_star > 0)
19721- subtract:
19722- {
19723- /* Subtract r := r - b * q* * beta^j. */
19724- mp_limb_t cr;
19725- {
19726- const mp_limb_t *sourceptr = b_ptr;
19727- mp_limb_t *destptr = r_ptr + j;
19728- mp_twolimb_t carry = 0;
19729- size_t count;
19730- for (count = b_len; count > 0; count--)
19731- {
19732- /* Here 0 <= carry <= q*. */
19733- carry =
19734- carry
19735- + (mp_twolimb_t) q_star * (mp_twolimb_t) *sourceptr++
19736- + (mp_limb_t) ~(*destptr);
19737- /* Here 0 <= carry <= beta*q* + beta-1. */
19738- *destptr++ = ~(mp_limb_t) carry;
19739- carry = carry >> GMP_LIMB_BITS; /* <= q* */
19740- }
19741- cr = (mp_limb_t) carry;
19742- }
19743- /* Subtract cr from r_ptr[j + b_len], then forget about
19744- r_ptr[j + b_len]. */
19745- if (cr > r_ptr[j + b_len])
19746- {
19747- /* Subtraction gave a carry. */
19748- q_star = q_star - 1; /* q* := q* - 1 */
19749- /* Add b back. */
19750- {
19751- const mp_limb_t *sourceptr = b_ptr;
19752- mp_limb_t *destptr = r_ptr + j;
19753- mp_limb_t carry = 0;
19754- size_t count;
19755- for (count = b_len; count > 0; count--)
19756- {
19757- mp_limb_t source1 = *sourceptr++;
19758- mp_limb_t source2 = *destptr;
19759- *destptr++ = source1 + source2 + carry;
19760- carry =
19761- (carry
19762- ? source1 >= (mp_limb_t) ~source2
19763- : source1 > (mp_limb_t) ~source2);
19764- }
19765- }
19766- /* Forget about the carry and about r[j+n]. */
19767- }
19768- }
19769- /* q* is determined. Store it as q[j]. */
19770- q_ptr[j] = q_star;
19771- if (j == 0)
19772- break;
19773- j--;
19774- }
19775- }
19776- r_len = b_len;
19777- /* Normalise q. */
19778- if (q_ptr[q_len - 1] == 0)
19779- q_len--;
19780-# if 0 /* Not needed here, since we need r only to compare it with b/2, and
19781- b is shifted left by s bits. */
19782- /* Shift r right by s bits. */
19783- if (s > 0)
19784- {
19785- mp_limb_t ptr = r_ptr + r_len;
19786- mp_twolimb_t accu = 0;
19787- size_t count;
19788- for (count = r_len; count > 0; count--)
19789- {
19790- accu = (mp_twolimb_t) (mp_limb_t) accu << GMP_LIMB_BITS;
19791- accu += (mp_twolimb_t) *--ptr << (GMP_LIMB_BITS - s);
19792- *ptr = (mp_limb_t) (accu >> GMP_LIMB_BITS);
19793- }
19794- }
19795-# endif
19796- /* Normalise r. */
19797- while (r_len > 0 && r_ptr[r_len - 1] == 0)
19798- r_len--;
19799- }
19800- /* Compare r << 1 with b. */
19801- if (r_len > b_len)
19802- goto increment_q;
19803- {
19804- size_t i;
19805- for (i = b_len;;)
19806- {
19807- mp_limb_t r_i =
19808- (i <= r_len && i > 0 ? r_ptr[i - 1] >> (GMP_LIMB_BITS - 1) : 0)
19809- | (i < r_len ? r_ptr[i] << 1 : 0);
19810- mp_limb_t b_i = (i < b_len ? b_ptr[i] : 0);
19811- if (r_i > b_i)
19812- goto increment_q;
19813- if (r_i < b_i)
19814- goto keep_q;
19815- if (i == 0)
19816- break;
19817- i--;
19818- }
19819- }
19820- if (q_len > 0 && ((q_ptr[0] & 1) != 0))
19821- /* q is odd. */
19822- increment_q:
19823- {
19824- size_t i;
19825- for (i = 0; i < q_len; i++)
19826- if (++(q_ptr[i]) != 0)
19827- goto keep_q;
19828- q_ptr[q_len++] = 1;
19829- }
19830- keep_q:
19831- if (tmp_roomptr != NULL)
19832- free (tmp_roomptr);
19833- q->limbs = q_ptr;
19834- q->nlimbs = q_len;
19835- return roomptr;
19836-}
19837-
19838-/* Convert a bignum a >= 0, multiplied with 10^extra_zeroes, to decimal
19839- representation.
19840- Destroys the contents of a.
19841- Return the allocated memory - containing the decimal digits in low-to-high
19842- order, terminated with a NUL character - in case of success, NULL in case
19843- of memory allocation failure. */
19844-static char *
19845-convert_to_decimal (mpn_t a, size_t extra_zeroes)
19846-{
19847- mp_limb_t *a_ptr = a.limbs;
19848- size_t a_len = a.nlimbs;
19849- /* 0.03345 is slightly larger than log(2)/(9*log(10)). */
19850- size_t c_len = 9 * ((size_t)(a_len * (GMP_LIMB_BITS * 0.03345f)) + 1);
19851- char *c_ptr = (char *) malloc (xsum (c_len, extra_zeroes));
19852- if (c_ptr != NULL)
19853- {
19854- char *d_ptr = c_ptr;
19855- for (; extra_zeroes > 0; extra_zeroes--)
19856- *d_ptr++ = '0';
19857- while (a_len > 0)
19858- {
19859- /* Divide a by 10^9, in-place. */
19860- mp_limb_t remainder = 0;
19861- mp_limb_t *ptr = a_ptr + a_len;
19862- size_t count;
19863- for (count = a_len; count > 0; count--)
19864- {
19865- mp_twolimb_t num =
19866- ((mp_twolimb_t) remainder << GMP_LIMB_BITS) | *--ptr;
19867- *ptr = num / 1000000000;
19868- remainder = num % 1000000000;
19869- }
19870- /* Store the remainder as 9 decimal digits. */
19871- for (count = 9; count > 0; count--)
19872- {
19873- *d_ptr++ = '0' + (remainder % 10);
19874- remainder = remainder / 10;
19875- }
19876- /* Normalize a. */
19877- if (a_ptr[a_len - 1] == 0)
19878- a_len--;
19879- }
19880- /* Remove leading zeroes. */
19881- while (d_ptr > c_ptr && d_ptr[-1] == '0')
19882- d_ptr--;
19883- /* But keep at least one zero. */
19884- if (d_ptr == c_ptr)
19885- *d_ptr++ = '0';
19886- /* Terminate the string. */
19887- *d_ptr = '\0';
19888- }
19889- return c_ptr;
19890-}
19891-
19892-# if NEED_PRINTF_LONG_DOUBLE
19893-
19894-/* Assuming x is finite and >= 0:
19895- write x as x = 2^e * m, where m is a bignum.
19896- Return the allocated memory in case of success, NULL in case of memory
19897- allocation failure. */
19898-static void *
19899-decode_long_double (long double x, int *ep, mpn_t *mp)
19900-{
19901- mpn_t m;
19902- int exp;
19903- long double y;
19904- size_t i;
19905-
19906- /* Allocate memory for result. */
19907- m.nlimbs = (LDBL_MANT_BIT + GMP_LIMB_BITS - 1) / GMP_LIMB_BITS;
19908- m.limbs = (mp_limb_t *) malloc (m.nlimbs * sizeof (mp_limb_t));
19909- if (m.limbs == NULL)
19910- return NULL;
19911- /* Split into exponential part and mantissa. */
19912- y = frexpl (x, &exp);
19913- if (!(y >= 0.0L && y < 1.0L))
19914- abort ();
19915- /* x = 2^exp * y = 2^(exp - LDBL_MANT_BIT) * (y * LDBL_MANT_BIT), and the
19916- latter is an integer. */
19917- /* Convert the mantissa (y * LDBL_MANT_BIT) to a sequence of limbs.
19918- I'm not sure whether it's safe to cast a 'long double' value between
19919- 2^31 and 2^32 to 'unsigned int', therefore play safe and cast only
19920- 'long double' values between 0 and 2^16 (to 'unsigned int' or 'int',
19921- doesn't matter). */
19922-# if (LDBL_MANT_BIT % GMP_LIMB_BITS) != 0
19923-# if (LDBL_MANT_BIT % GMP_LIMB_BITS) > GMP_LIMB_BITS / 2
19924- {
19925- mp_limb_t hi, lo;
19926- y *= (mp_limb_t) 1 << (LDBL_MANT_BIT % (GMP_LIMB_BITS / 2));
19927- hi = (int) y;
19928- y -= hi;
19929- if (!(y >= 0.0L && y < 1.0L))
19930- abort ();
19931- y *= (mp_limb_t) 1 << (GMP_LIMB_BITS / 2);
19932- lo = (int) y;
19933- y -= lo;
19934- if (!(y >= 0.0L && y < 1.0L))
19935- abort ();
19936- m.limbs[LDBL_MANT_BIT / GMP_LIMB_BITS] = (hi << (GMP_LIMB_BITS / 2)) | lo;
19937- }
19938-# else
19939- {
19940- mp_limb_t d;
19941- y *= (mp_limb_t) 1 << (LDBL_MANT_BIT % GMP_LIMB_BITS);
19942- d = (int) y;
19943- y -= d;
19944- if (!(y >= 0.0L && y < 1.0L))
19945- abort ();
19946- m.limbs[LDBL_MANT_BIT / GMP_LIMB_BITS] = d;
19947- }
19948-# endif
19949-# endif
19950- for (i = LDBL_MANT_BIT / GMP_LIMB_BITS; i > 0; )
19951- {
19952- mp_limb_t hi, lo;
19953- y *= (mp_limb_t) 1 << (GMP_LIMB_BITS / 2);
19954- hi = (int) y;
19955- y -= hi;
19956- if (!(y >= 0.0L && y < 1.0L))
19957- abort ();
19958- y *= (mp_limb_t) 1 << (GMP_LIMB_BITS / 2);
19959- lo = (int) y;
19960- y -= lo;
19961- if (!(y >= 0.0L && y < 1.0L))
19962- abort ();
19963- m.limbs[--i] = (hi << (GMP_LIMB_BITS / 2)) | lo;
19964- }
19965- if (!(y == 0.0L))
19966- abort ();
19967- /* Normalise. */
19968- while (m.nlimbs > 0 && m.limbs[m.nlimbs - 1] == 0)
19969- m.nlimbs--;
19970- *mp = m;
19971- *ep = exp - LDBL_MANT_BIT;
19972- return m.limbs;
19973-}
19974-
19975-# endif
19976-
19977-# if NEED_PRINTF_DOUBLE
19978-
19979-/* Assuming x is finite and >= 0:
19980- write x as x = 2^e * m, where m is a bignum.
19981- Return the allocated memory in case of success, NULL in case of memory
19982- allocation failure. */
19983-static void *
19984-decode_double (double x, int *ep, mpn_t *mp)
19985-{
19986- mpn_t m;
19987- int exp;
19988- double y;
19989- size_t i;
19990-
19991- /* Allocate memory for result. */
19992- m.nlimbs = (DBL_MANT_BIT + GMP_LIMB_BITS - 1) / GMP_LIMB_BITS;
19993- m.limbs = (mp_limb_t *) malloc (m.nlimbs * sizeof (mp_limb_t));
19994- if (m.limbs == NULL)
19995- return NULL;
19996- /* Split into exponential part and mantissa. */
19997- y = frexp (x, &exp);
19998- if (!(y >= 0.0 && y < 1.0))
19999- abort ();
20000- /* x = 2^exp * y = 2^(exp - DBL_MANT_BIT) * (y * DBL_MANT_BIT), and the
20001- latter is an integer. */
20002- /* Convert the mantissa (y * DBL_MANT_BIT) to a sequence of limbs.
20003- I'm not sure whether it's safe to cast a 'double' value between
20004- 2^31 and 2^32 to 'unsigned int', therefore play safe and cast only
20005- 'double' values between 0 and 2^16 (to 'unsigned int' or 'int',
20006- doesn't matter). */
20007-# if (DBL_MANT_BIT % GMP_LIMB_BITS) != 0
20008-# if (DBL_MANT_BIT % GMP_LIMB_BITS) > GMP_LIMB_BITS / 2
20009- {
20010- mp_limb_t hi, lo;
20011- y *= (mp_limb_t) 1 << (DBL_MANT_BIT % (GMP_LIMB_BITS / 2));
20012- hi = (int) y;
20013- y -= hi;
20014- if (!(y >= 0.0 && y < 1.0))
20015- abort ();
20016- y *= (mp_limb_t) 1 << (GMP_LIMB_BITS / 2);
20017- lo = (int) y;
20018- y -= lo;
20019- if (!(y >= 0.0 && y < 1.0))
20020- abort ();
20021- m.limbs[DBL_MANT_BIT / GMP_LIMB_BITS] = (hi << (GMP_LIMB_BITS / 2)) | lo;
20022- }
20023-# else
20024- {
20025- mp_limb_t d;
20026- y *= (mp_limb_t) 1 << (DBL_MANT_BIT % GMP_LIMB_BITS);
20027- d = (int) y;
20028- y -= d;
20029- if (!(y >= 0.0 && y < 1.0))
20030- abort ();
20031- m.limbs[DBL_MANT_BIT / GMP_LIMB_BITS] = d;
20032- }
20033-# endif
20034-# endif
20035- for (i = DBL_MANT_BIT / GMP_LIMB_BITS; i > 0; )
20036- {
20037- mp_limb_t hi, lo;
20038- y *= (mp_limb_t) 1 << (GMP_LIMB_BITS / 2);
20039- hi = (int) y;
20040- y -= hi;
20041- if (!(y >= 0.0 && y < 1.0))
20042- abort ();
20043- y *= (mp_limb_t) 1 << (GMP_LIMB_BITS / 2);
20044- lo = (int) y;
20045- y -= lo;
20046- if (!(y >= 0.0 && y < 1.0))
20047- abort ();
20048- m.limbs[--i] = (hi << (GMP_LIMB_BITS / 2)) | lo;
20049- }
20050- if (!(y == 0.0))
20051- abort ();
20052- /* Normalise. */
20053- while (m.nlimbs > 0 && m.limbs[m.nlimbs - 1] == 0)
20054- m.nlimbs--;
20055- *mp = m;
20056- *ep = exp - DBL_MANT_BIT;
20057- return m.limbs;
20058-}
20059-
20060-# endif
20061-
20062-/* Assuming x = 2^e * m is finite and >= 0, and n is an integer:
20063- Returns the decimal representation of round (x * 10^n).
20064- Return the allocated memory - containing the decimal digits in low-to-high
20065- order, terminated with a NUL character - in case of success, NULL in case
20066- of memory allocation failure. */
20067-static char *
20068-scale10_round_decimal_decoded (int e, mpn_t m, void *memory, int n)
20069-{
20070- int s;
20071- size_t extra_zeroes;
20072- unsigned int abs_n;
20073- unsigned int abs_s;
20074- mp_limb_t *pow5_ptr;
20075- size_t pow5_len;
20076- unsigned int s_limbs;
20077- unsigned int s_bits;
20078- mpn_t pow5;
20079- mpn_t z;
20080- void *z_memory;
20081- char *digits;
20082-
20083- if (memory == NULL)
20084- return NULL;
20085- /* x = 2^e * m, hence
20086- y = round (2^e * 10^n * m) = round (2^(e+n) * 5^n * m)
20087- = round (2^s * 5^n * m). */
20088- s = e + n;
20089- extra_zeroes = 0;
20090- /* Factor out a common power of 10 if possible. */
20091- if (s > 0 && n > 0)
20092- {
20093- extra_zeroes = (s < n ? s : n);
20094- s -= extra_zeroes;
20095- n -= extra_zeroes;
20096- }
20097- /* Here y = round (2^s * 5^n * m) * 10^extra_zeroes.
20098- Before converting to decimal, we need to compute
20099- z = round (2^s * 5^n * m). */
20100- /* Compute 5^|n|, possibly shifted by |s| bits if n and s have the same
20101- sign. 2.322 is slightly larger than log(5)/log(2). */
20102- abs_n = (n >= 0 ? n : -n);
20103- abs_s = (s >= 0 ? s : -s);
20104- pow5_ptr = (mp_limb_t *) malloc (((int)(abs_n * (2.322f / GMP_LIMB_BITS)) + 1
20105- + abs_s / GMP_LIMB_BITS + 1)
20106- * sizeof (mp_limb_t));
20107- if (pow5_ptr == NULL)
20108- {
20109- free (memory);
20110- return NULL;
20111- }
20112- /* Initialize with 1. */
20113- pow5_ptr[0] = 1;
20114- pow5_len = 1;
20115- /* Multiply with 5^|n|. */
20116- if (abs_n > 0)
20117- {
20118- static mp_limb_t const small_pow5[13 + 1] =
20119- {
20120- 1, 5, 25, 125, 625, 3125, 15625, 78125, 390625, 1953125, 9765625,
20121- 48828125, 244140625, 1220703125
20122- };
20123- unsigned int n13;
20124- for (n13 = 0; n13 <= abs_n; n13 += 13)
20125- {
20126- mp_limb_t digit1 = small_pow5[n13 + 13 <= abs_n ? 13 : abs_n - n13];
20127- size_t j;
20128- mp_twolimb_t carry = 0;
20129- for (j = 0; j < pow5_len; j++)
20130- {
20131- mp_limb_t digit2 = pow5_ptr[j];
20132- carry += (mp_twolimb_t) digit1 * (mp_twolimb_t) digit2;
20133- pow5_ptr[j] = (mp_limb_t) carry;
20134- carry = carry >> GMP_LIMB_BITS;
20135- }
20136- if (carry > 0)
20137- pow5_ptr[pow5_len++] = (mp_limb_t) carry;
20138- }
20139- }
20140- s_limbs = abs_s / GMP_LIMB_BITS;
20141- s_bits = abs_s % GMP_LIMB_BITS;
20142- if (n >= 0 ? s >= 0 : s <= 0)
20143- {
20144- /* Multiply with 2^|s|. */
20145- if (s_bits > 0)
20146- {
20147- mp_limb_t *ptr = pow5_ptr;
20148- mp_twolimb_t accu = 0;
20149- size_t count;
20150- for (count = pow5_len; count > 0; count--)
20151- {
20152- accu += (mp_twolimb_t) *ptr << s_bits;
20153- *ptr++ = (mp_limb_t) accu;
20154- accu = accu >> GMP_LIMB_BITS;
20155- }
20156- if (accu > 0)
20157- {
20158- *ptr = (mp_limb_t) accu;
20159- pow5_len++;
20160- }
20161- }
20162- if (s_limbs > 0)
20163- {
20164- size_t count;
20165- for (count = pow5_len; count > 0;)
20166- {
20167- count--;
20168- pow5_ptr[s_limbs + count] = pow5_ptr[count];
20169- }
20170- for (count = s_limbs; count > 0;)
20171- {
20172- count--;
20173- pow5_ptr[count] = 0;
20174- }
20175- pow5_len += s_limbs;
20176- }
20177- pow5.limbs = pow5_ptr;
20178- pow5.nlimbs = pow5_len;
20179- if (n >= 0)
20180- {
20181- /* Multiply m with pow5. No division needed. */
20182- z_memory = multiply (m, pow5, &z);
20183- }
20184- else
20185- {
20186- /* Divide m by pow5 and round. */
20187- z_memory = divide (m, pow5, &z);
20188- }
20189- }
20190- else
20191- {
20192- pow5.limbs = pow5_ptr;
20193- pow5.nlimbs = pow5_len;
20194- if (n >= 0)
20195- {
20196- /* n >= 0, s < 0.
20197- Multiply m with pow5, then divide by 2^|s|. */
20198- mpn_t numerator;
20199- mpn_t denominator;
20200- void *tmp_memory;
20201- tmp_memory = multiply (m, pow5, &numerator);
20202- if (tmp_memory == NULL)
20203- {
20204- free (pow5_ptr);
20205- free (memory);
20206- return NULL;
20207- }
20208- /* Construct 2^|s|. */
20209- {
20210- mp_limb_t *ptr = pow5_ptr + pow5_len;
20211- size_t i;
20212- for (i = 0; i < s_limbs; i++)
20213- ptr[i] = 0;
20214- ptr[s_limbs] = (mp_limb_t) 1 << s_bits;
20215- denominator.limbs = ptr;
20216- denominator.nlimbs = s_limbs + 1;
20217- }
20218- z_memory = divide (numerator, denominator, &z);
20219- free (tmp_memory);
20220- }
20221- else
20222- {
20223- /* n < 0, s > 0.
20224- Multiply m with 2^s, then divide by pow5. */
20225- mpn_t numerator;
20226- mp_limb_t *num_ptr;
20227- num_ptr = (mp_limb_t *) malloc ((m.nlimbs + s_limbs + 1)
20228- * sizeof (mp_limb_t));
20229- if (num_ptr == NULL)
20230- {
20231- free (pow5_ptr);
20232- free (memory);
20233- return NULL;
20234- }
20235- {
20236- mp_limb_t *destptr = num_ptr;
20237- {
20238- size_t i;
20239- for (i = 0; i < s_limbs; i++)
20240- *destptr++ = 0;
20241- }
20242- if (s_bits > 0)
20243- {
20244- const mp_limb_t *sourceptr = m.limbs;
20245- mp_twolimb_t accu = 0;
20246- size_t count;
20247- for (count = m.nlimbs; count > 0; count--)
20248- {
20249- accu += (mp_twolimb_t) *sourceptr++ << s_bits;
20250- *destptr++ = (mp_limb_t) accu;
20251- accu = accu >> GMP_LIMB_BITS;
20252- }
20253- if (accu > 0)
20254- *destptr++ = (mp_limb_t) accu;
20255- }
20256- else
20257- {
20258- const mp_limb_t *sourceptr = m.limbs;
20259- size_t count;
20260- for (count = m.nlimbs; count > 0; count--)
20261- *destptr++ = *sourceptr++;
20262- }
20263- numerator.limbs = num_ptr;
20264- numerator.nlimbs = destptr - num_ptr;
20265- }
20266- z_memory = divide (numerator, pow5, &z);
20267- free (num_ptr);
20268- }
20269- }
20270- free (pow5_ptr);
20271- free (memory);
20272-
20273- /* Here y = round (x * 10^n) = z * 10^extra_zeroes. */
20274-
20275- if (z_memory == NULL)
20276- return NULL;
20277- digits = convert_to_decimal (z, extra_zeroes);
20278- free (z_memory);
20279- return digits;
20280-}
20281-
20282-# if NEED_PRINTF_LONG_DOUBLE
20283-
20284-/* Assuming x is finite and >= 0, and n is an integer:
20285- Returns the decimal representation of round (x * 10^n).
20286- Return the allocated memory - containing the decimal digits in low-to-high
20287- order, terminated with a NUL character - in case of success, NULL in case
20288- of memory allocation failure. */
20289-static char *
20290-scale10_round_decimal_long_double (long double x, int n)
20291-{
20292- int e;
20293- mpn_t m;
20294- void *memory = decode_long_double (x, &e, &m);
20295- return scale10_round_decimal_decoded (e, m, memory, n);
20296-}
20297-
20298-# endif
20299-
20300-# if NEED_PRINTF_DOUBLE
20301-
20302-/* Assuming x is finite and >= 0, and n is an integer:
20303- Returns the decimal representation of round (x * 10^n).
20304- Return the allocated memory - containing the decimal digits in low-to-high
20305- order, terminated with a NUL character - in case of success, NULL in case
20306- of memory allocation failure. */
20307-static char *
20308-scale10_round_decimal_double (double x, int n)
20309-{
20310- int e;
20311- mpn_t m;
20312- void *memory = decode_double (x, &e, &m);
20313- return scale10_round_decimal_decoded (e, m, memory, n);
20314-}
20315-
20316-# endif
20317-
20318-# if NEED_PRINTF_LONG_DOUBLE
20319-
20320-/* Assuming x is finite and > 0:
20321- Return an approximation for n with 10^n <= x < 10^(n+1).
20322- The approximation is usually the right n, but may be off by 1 sometimes. */
20323-static int
20324-floorlog10l (long double x)
20325-{
20326- int exp;
20327- long double y;
20328- double z;
20329- double l;
20330-
20331- /* Split into exponential part and mantissa. */
20332- y = frexpl (x, &exp);
20333- if (!(y >= 0.0L && y < 1.0L))
20334- abort ();
20335- if (y == 0.0L)
20336- return INT_MIN;
20337- if (y < 0.5L)
20338- {
20339- while (y < (1.0L / (1 << (GMP_LIMB_BITS / 2)) / (1 << (GMP_LIMB_BITS / 2))))
20340- {
20341- y *= 1.0L * (1 << (GMP_LIMB_BITS / 2)) * (1 << (GMP_LIMB_BITS / 2));
20342- exp -= GMP_LIMB_BITS;
20343- }
20344- if (y < (1.0L / (1 << 16)))
20345- {
20346- y *= 1.0L * (1 << 16);
20347- exp -= 16;
20348- }
20349- if (y < (1.0L / (1 << 8)))
20350- {
20351- y *= 1.0L * (1 << 8);
20352- exp -= 8;
20353- }
20354- if (y < (1.0L / (1 << 4)))
20355- {
20356- y *= 1.0L * (1 << 4);
20357- exp -= 4;
20358- }
20359- if (y < (1.0L / (1 << 2)))
20360- {
20361- y *= 1.0L * (1 << 2);
20362- exp -= 2;
20363- }
20364- if (y < (1.0L / (1 << 1)))
20365- {
20366- y *= 1.0L * (1 << 1);
20367- exp -= 1;
20368- }
20369- }
20370- if (!(y >= 0.5L && y < 1.0L))
20371- abort ();
20372- /* Compute an approximation for l = log2(x) = exp + log2(y). */
20373- l = exp;
20374- z = y;
20375- if (z < 0.70710678118654752444)
20376- {
20377- z *= 1.4142135623730950488;
20378- l -= 0.5;
20379- }
20380- if (z < 0.8408964152537145431)
20381- {
20382- z *= 1.1892071150027210667;
20383- l -= 0.25;
20384- }
20385- if (z < 0.91700404320467123175)
20386- {
20387- z *= 1.0905077326652576592;
20388- l -= 0.125;
20389- }
20390- if (z < 0.9576032806985736469)
20391- {
20392- z *= 1.0442737824274138403;
20393- l -= 0.0625;
20394- }
20395- /* Now 0.95 <= z <= 1.01. */
20396- z = 1 - z;
20397- /* log(1-z) = - z - z^2/2 - z^3/3 - z^4/4 - ...
20398- Four terms are enough to get an approximation with error < 10^-7. */
20399- l -= z * (1.0 + z * (0.5 + z * ((1.0 / 3) + z * 0.25)));
20400- /* Finally multiply with log(2)/log(10), yields an approximation for
20401- log10(x). */
20402- l *= 0.30102999566398119523;
20403- /* Round down to the next integer. */
20404- return (int) l + (l < 0 ? -1 : 0);
20405-}
20406-
20407-# endif
20408-
20409-# if NEED_PRINTF_DOUBLE
20410-
20411-/* Assuming x is finite and > 0:
20412- Return an approximation for n with 10^n <= x < 10^(n+1).
20413- The approximation is usually the right n, but may be off by 1 sometimes. */
20414-static int
20415-floorlog10 (double x)
20416-{
20417- int exp;
20418- double y;
20419- double z;
20420- double l;
20421-
20422- /* Split into exponential part and mantissa. */
20423- y = frexp (x, &exp);
20424- if (!(y >= 0.0 && y < 1.0))
20425- abort ();
20426- if (y == 0.0)
20427- return INT_MIN;
20428- if (y < 0.5)
20429- {
20430- while (y < (1.0 / (1 << (GMP_LIMB_BITS / 2)) / (1 << (GMP_LIMB_BITS / 2))))
20431- {
20432- y *= 1.0 * (1 << (GMP_LIMB_BITS / 2)) * (1 << (GMP_LIMB_BITS / 2));
20433- exp -= GMP_LIMB_BITS;
20434- }
20435- if (y < (1.0 / (1 << 16)))
20436- {
20437- y *= 1.0 * (1 << 16);
20438- exp -= 16;
20439- }
20440- if (y < (1.0 / (1 << 8)))
20441- {
20442- y *= 1.0 * (1 << 8);
20443- exp -= 8;
20444- }
20445- if (y < (1.0 / (1 << 4)))
20446- {
20447- y *= 1.0 * (1 << 4);
20448- exp -= 4;
20449- }
20450- if (y < (1.0 / (1 << 2)))
20451- {
20452- y *= 1.0 * (1 << 2);
20453- exp -= 2;
20454- }
20455- if (y < (1.0 / (1 << 1)))
20456- {
20457- y *= 1.0 * (1 << 1);
20458- exp -= 1;
20459- }
20460- }
20461- if (!(y >= 0.5 && y < 1.0))
20462- abort ();
20463- /* Compute an approximation for l = log2(x) = exp + log2(y). */
20464- l = exp;
20465- z = y;
20466- if (z < 0.70710678118654752444)
20467- {
20468- z *= 1.4142135623730950488;
20469- l -= 0.5;
20470- }
20471- if (z < 0.8408964152537145431)
20472- {
20473- z *= 1.1892071150027210667;
20474- l -= 0.25;
20475- }
20476- if (z < 0.91700404320467123175)
20477- {
20478- z *= 1.0905077326652576592;
20479- l -= 0.125;
20480- }
20481- if (z < 0.9576032806985736469)
20482- {
20483- z *= 1.0442737824274138403;
20484- l -= 0.0625;
20485- }
20486- /* Now 0.95 <= z <= 1.01. */
20487- z = 1 - z;
20488- /* log(1-z) = - z - z^2/2 - z^3/3 - z^4/4 - ...
20489- Four terms are enough to get an approximation with error < 10^-7. */
20490- l -= z * (1.0 + z * (0.5 + z * ((1.0 / 3) + z * 0.25)));
20491- /* Finally multiply with log(2)/log(10), yields an approximation for
20492- log10(x). */
20493- l *= 0.30102999566398119523;
20494- /* Round down to the next integer. */
20495- return (int) l + (l < 0 ? -1 : 0);
20496-}
20497-
20498-# endif
20499-
20500-#endif
20501-
20502-DCHAR_T *
20503-VASNPRINTF (DCHAR_T *resultbuf, size_t *lengthp,
20504- const FCHAR_T *format, va_list args)
20505-{
20506- DIRECTIVES d;
20507- arguments a;
20508-
20509- if (PRINTF_PARSE (format, &d, &a) < 0)
20510- /* errno is already set. */
20511- return NULL;
20512-
20513-#define CLEANUP() \
20514- free (d.dir); \
20515- if (a.arg) \
20516- free (a.arg);
20517-
20518- if (PRINTF_FETCHARGS (args, &a) < 0)
20519- {
20520- CLEANUP ();
20521- errno = EINVAL;
20522- return NULL;
20523- }
20524-
20525- {
20526- size_t buf_neededlength;
20527- TCHAR_T *buf;
20528- TCHAR_T *buf_malloced;
20529- const FCHAR_T *cp;
20530- size_t i;
20531- DIRECTIVE *dp;
20532- /* Output string accumulator. */
20533- DCHAR_T *result;
20534- size_t allocated;
20535- size_t length;
20536-
20537- /* Allocate a small buffer that will hold a directive passed to
20538- sprintf or snprintf. */
20539- buf_neededlength =
20540- xsum4 (7, d.max_width_length, d.max_precision_length, 6);
20541-#if HAVE_ALLOCA
20542- if (buf_neededlength < 4000 / sizeof (TCHAR_T))
20543- {
20544- buf = (TCHAR_T *) alloca (buf_neededlength * sizeof (TCHAR_T));
20545- buf_malloced = NULL;
20546- }
20547- else
20548-#endif
20549- {
20550- size_t buf_memsize = xtimes (buf_neededlength, sizeof (TCHAR_T));
20551- if (size_overflow_p (buf_memsize))
20552- goto out_of_memory_1;
20553- buf = (TCHAR_T *) malloc (buf_memsize);
20554- if (buf == NULL)
20555- goto out_of_memory_1;
20556- buf_malloced = buf;
20557- }
20558-
20559- if (resultbuf != NULL)
20560- {
20561- result = resultbuf;
20562- allocated = *lengthp;
20563- }
20564- else
20565- {
20566- result = NULL;
20567- allocated = 0;
20568- }
20569- length = 0;
20570- /* Invariants:
20571- result is either == resultbuf or == NULL or malloc-allocated.
20572- If length > 0, then result != NULL. */
20573-
20574- /* Ensures that allocated >= needed. Aborts through a jump to
20575- out_of_memory if needed is SIZE_MAX or otherwise too big. */
20576-#define ENSURE_ALLOCATION(needed) \
20577- if ((needed) > allocated) \
20578- { \
20579- size_t memory_size; \
20580- DCHAR_T *memory; \
20581- \
20582- allocated = (allocated > 0 ? xtimes (allocated, 2) : 12); \
20583- if ((needed) > allocated) \
20584- allocated = (needed); \
20585- memory_size = xtimes (allocated, sizeof (DCHAR_T)); \
20586- if (size_overflow_p (memory_size)) \
20587- goto out_of_memory; \
20588- if (result == resultbuf || result == NULL) \
20589- memory = (DCHAR_T *) malloc (memory_size); \
20590- else \
20591- memory = (DCHAR_T *) realloc (result, memory_size); \
20592- if (memory == NULL) \
20593- goto out_of_memory; \
20594- if (result == resultbuf && length > 0) \
20595- DCHAR_CPY (memory, result, length); \
20596- result = memory; \
20597- }
20598-
20599- for (cp = format, i = 0, dp = &d.dir[0]; ; cp = dp->dir_end, i++, dp++)
20600- {
20601- if (cp != dp->dir_start)
20602- {
20603- size_t n = dp->dir_start - cp;
20604- size_t augmented_length = xsum (length, n);
20605-
20606- ENSURE_ALLOCATION (augmented_length);
20607- /* This copies a piece of FCHAR_T[] into a DCHAR_T[]. Here we
20608- need that the format string contains only ASCII characters
20609- if FCHAR_T and DCHAR_T are not the same type. */
20610- if (sizeof (FCHAR_T) == sizeof (DCHAR_T))
20611- {
20612- DCHAR_CPY (result + length, (const DCHAR_T *) cp, n);
20613- length = augmented_length;
20614- }
20615- else
20616- {
20617- do
20618- result[length++] = (unsigned char) *cp++;
20619- while (--n > 0);
20620- }
20621- }
20622- if (i == d.count)
20623- break;
20624-
20625- /* Execute a single directive. */
20626- if (dp->conversion == '%')
20627- {
20628- size_t augmented_length;
20629-
20630- if (!(dp->arg_index == ARG_NONE))
20631- abort ();
20632- augmented_length = xsum (length, 1);
20633- ENSURE_ALLOCATION (augmented_length);
20634- result[length] = '%';
20635- length = augmented_length;
20636- }
20637- else
20638- {
20639- if (!(dp->arg_index != ARG_NONE))
20640- abort ();
20641-
20642- if (dp->conversion == 'n')
20643- {
20644- switch (a.arg[dp->arg_index].type)
20645- {
20646- case TYPE_COUNT_SCHAR_POINTER:
20647- *a.arg[dp->arg_index].a.a_count_schar_pointer = length;
20648- break;
20649- case TYPE_COUNT_SHORT_POINTER:
20650- *a.arg[dp->arg_index].a.a_count_short_pointer = length;
20651- break;
20652- case TYPE_COUNT_INT_POINTER:
20653- *a.arg[dp->arg_index].a.a_count_int_pointer = length;
20654- break;
20655- case TYPE_COUNT_LONGINT_POINTER:
20656- *a.arg[dp->arg_index].a.a_count_longint_pointer = length;
20657- break;
20658-#if HAVE_LONG_LONG_INT
20659- case TYPE_COUNT_LONGLONGINT_POINTER:
20660- *a.arg[dp->arg_index].a.a_count_longlongint_pointer = length;
20661- break;
20662-#endif
20663- default:
20664- abort ();
20665- }
20666- }
20667-#if ENABLE_UNISTDIO
20668- /* The unistdio extensions. */
20669- else if (dp->conversion == 'U')
20670- {
20671- arg_type type = a.arg[dp->arg_index].type;
20672- int flags = dp->flags;
20673- int has_width;
20674- size_t width;
20675- int has_precision;
20676- size_t precision;
20677-
20678- has_width = 0;
20679- width = 0;
20680- if (dp->width_start != dp->width_end)
20681- {
20682- if (dp->width_arg_index != ARG_NONE)
20683- {
20684- int arg;
20685-
20686- if (!(a.arg[dp->width_arg_index].type == TYPE_INT))
20687- abort ();
20688- arg = a.arg[dp->width_arg_index].a.a_int;
20689- if (arg < 0)
20690- {
20691- /* "A negative field width is taken as a '-' flag
20692- followed by a positive field width." */
20693- flags |= FLAG_LEFT;
20694- width = (unsigned int) (-arg);
20695- }
20696- else
20697- width = arg;
20698- }
20699- else
20700- {
20701- const FCHAR_T *digitp = dp->width_start;
20702-
20703- do
20704- width = xsum (xtimes (width, 10), *digitp++ - '0');
20705- while (digitp != dp->width_end);
20706- }
20707- has_width = 1;
20708- }
20709-
20710- has_precision = 0;
20711- precision = 0;
20712- if (dp->precision_start != dp->precision_end)
20713- {
20714- if (dp->precision_arg_index != ARG_NONE)
20715- {
20716- int arg;
20717-
20718- if (!(a.arg[dp->precision_arg_index].type == TYPE_INT))
20719- abort ();
20720- arg = a.arg[dp->precision_arg_index].a.a_int;
20721- /* "A negative precision is taken as if the precision
20722- were omitted." */
20723- if (arg >= 0)
20724- {
20725- precision = arg;
20726- has_precision = 1;
20727- }
20728- }
20729- else
20730- {
20731- const FCHAR_T *digitp = dp->precision_start + 1;
20732-
20733- precision = 0;
20734- while (digitp != dp->precision_end)
20735- precision = xsum (xtimes (precision, 10), *digitp++ - '0');
20736- has_precision = 1;
20737- }
20738- }
20739-
20740- switch (type)
20741- {
20742- case TYPE_U8_STRING:
20743- {
20744- const uint8_t *arg = a.arg[dp->arg_index].a.a_u8_string;
20745- const uint8_t *arg_end;
20746- size_t characters;
20747-
20748- if (has_precision)
20749- {
20750- /* Use only PRECISION characters, from the left. */
20751- arg_end = arg;
20752- characters = 0;
20753- for (; precision > 0; precision--)
20754- {
20755- int count = u8_strmblen (arg_end);
20756- if (count == 0)
20757- break;
20758- if (count < 0)
20759- {
20760- if (!(result == resultbuf || result == NULL))
20761- free (result);
20762- if (buf_malloced != NULL)
20763- free (buf_malloced);
20764- CLEANUP ();
20765- errno = EILSEQ;
20766- return NULL;
20767- }
20768- arg_end += count;
20769- characters++;
20770- }
20771- }
20772- else if (has_width)
20773- {
20774- /* Use the entire string, and count the number of
20775- characters. */
20776- arg_end = arg;
20777- characters = 0;
20778- for (;;)
20779- {
20780- int count = u8_strmblen (arg_end);
20781- if (count == 0)
20782- break;
20783- if (count < 0)
20784- {
20785- if (!(result == resultbuf || result == NULL))
20786- free (result);
20787- if (buf_malloced != NULL)
20788- free (buf_malloced);
20789- CLEANUP ();
20790- errno = EILSEQ;
20791- return NULL;
20792- }
20793- arg_end += count;
20794- characters++;
20795- }
20796- }
20797- else
20798- {
20799- /* Use the entire string. */
20800- arg_end = arg + u8_strlen (arg);
20801- /* The number of characters doesn't matter. */
20802- characters = 0;
20803- }
20804-
20805- if (has_width && width > characters
20806- && !(dp->flags & FLAG_LEFT))
20807- {
20808- size_t n = width - characters;
20809- ENSURE_ALLOCATION (xsum (length, n));
20810- DCHAR_SET (result + length, ' ', n);
20811- length += n;
20812- }
20813-
20814-# if DCHAR_IS_UINT8_T
20815- {
20816- size_t n = arg_end - arg;
20817- ENSURE_ALLOCATION (xsum (length, n));
20818- DCHAR_CPY (result + length, arg, n);
20819- length += n;
20820- }
20821-# else
20822- { /* Convert. */
20823- DCHAR_T *converted = result + length;
20824- size_t converted_len = allocated - length;
20825-# if DCHAR_IS_TCHAR
20826- /* Convert from UTF-8 to locale encoding. */
20827- if (u8_conv_to_encoding (locale_charset (),
20828- iconveh_question_mark,
20829- arg, arg_end - arg, NULL,
20830- &converted, &converted_len)
20831- < 0)
20832-# else
20833- /* Convert from UTF-8 to UTF-16/UTF-32. */
20834- converted =
20835- U8_TO_DCHAR (arg, arg_end - arg,
20836- converted, &converted_len);
20837- if (converted == NULL)
20838-# endif
20839- {
20840- int saved_errno = errno;
20841- if (!(result == resultbuf || result == NULL))
20842- free (result);
20843- if (buf_malloced != NULL)
20844- free (buf_malloced);
20845- CLEANUP ();
20846- errno = saved_errno;
20847- return NULL;
20848- }
20849- if (converted != result + length)
20850- {
20851- ENSURE_ALLOCATION (xsum (length, converted_len));
20852- DCHAR_CPY (result + length, converted, converted_len);
20853- free (converted);
20854- }
20855- length += converted_len;
20856- }
20857-# endif
20858-
20859- if (has_width && width > characters
20860- && (dp->flags & FLAG_LEFT))
20861- {
20862- size_t n = width - characters;
20863- ENSURE_ALLOCATION (xsum (length, n));
20864- DCHAR_SET (result + length, ' ', n);
20865- length += n;
20866- }
20867- }
20868- break;
20869-
20870- case TYPE_U16_STRING:
20871- {
20872- const uint16_t *arg = a.arg[dp->arg_index].a.a_u16_string;
20873- const uint16_t *arg_end;
20874- size_t characters;
20875-
20876- if (has_precision)
20877- {
20878- /* Use only PRECISION characters, from the left. */
20879- arg_end = arg;
20880- characters = 0;
20881- for (; precision > 0; precision--)
20882- {
20883- int count = u16_strmblen (arg_end);
20884- if (count == 0)
20885- break;
20886- if (count < 0)
20887- {
20888- if (!(result == resultbuf || result == NULL))
20889- free (result);
20890- if (buf_malloced != NULL)
20891- free (buf_malloced);
20892- CLEANUP ();
20893- errno = EILSEQ;
20894- return NULL;
20895- }
20896- arg_end += count;
20897- characters++;
20898- }
20899- }
20900- else if (has_width)
20901- {
20902- /* Use the entire string, and count the number of
20903- characters. */
20904- arg_end = arg;
20905- characters = 0;
20906- for (;;)
20907- {
20908- int count = u16_strmblen (arg_end);
20909- if (count == 0)
20910- break;
20911- if (count < 0)
20912- {
20913- if (!(result == resultbuf || result == NULL))
20914- free (result);
20915- if (buf_malloced != NULL)
20916- free (buf_malloced);
20917- CLEANUP ();
20918- errno = EILSEQ;
20919- return NULL;
20920- }
20921- arg_end += count;
20922- characters++;
20923- }
20924- }
20925- else
20926- {
20927- /* Use the entire string. */
20928- arg_end = arg + u16_strlen (arg);
20929- /* The number of characters doesn't matter. */
20930- characters = 0;
20931- }
20932-
20933- if (has_width && width > characters
20934- && !(dp->flags & FLAG_LEFT))
20935- {
20936- size_t n = width - characters;
20937- ENSURE_ALLOCATION (xsum (length, n));
20938- DCHAR_SET (result + length, ' ', n);
20939- length += n;
20940- }
20941-
20942-# if DCHAR_IS_UINT16_T
20943- {
20944- size_t n = arg_end - arg;
20945- ENSURE_ALLOCATION (xsum (length, n));
20946- DCHAR_CPY (result + length, arg, n);
20947- length += n;
20948- }
20949-# else
20950- { /* Convert. */
20951- DCHAR_T *converted = result + length;
20952- size_t converted_len = allocated - length;
20953-# if DCHAR_IS_TCHAR
20954- /* Convert from UTF-16 to locale encoding. */
20955- if (u16_conv_to_encoding (locale_charset (),
20956- iconveh_question_mark,
20957- arg, arg_end - arg, NULL,
20958- &converted, &converted_len)
20959- < 0)
20960-# else
20961- /* Convert from UTF-16 to UTF-8/UTF-32. */
20962- converted =
20963- U16_TO_DCHAR (arg, arg_end - arg,
20964- converted, &converted_len);
20965- if (converted == NULL)
20966-# endif
20967- {
20968- int saved_errno = errno;
20969- if (!(result == resultbuf || result == NULL))
20970- free (result);
20971- if (buf_malloced != NULL)
20972- free (buf_malloced);
20973- CLEANUP ();
20974- errno = saved_errno;
20975- return NULL;
20976- }
20977- if (converted != result + length)
20978- {
20979- ENSURE_ALLOCATION (xsum (length, converted_len));
20980- DCHAR_CPY (result + length, converted, converted_len);
20981- free (converted);
20982- }
20983- length += converted_len;
20984- }
20985-# endif
20986-
20987- if (has_width && width > characters
20988- && (dp->flags & FLAG_LEFT))
20989- {
20990- size_t n = width - characters;
20991- ENSURE_ALLOCATION (xsum (length, n));
20992- DCHAR_SET (result + length, ' ', n);
20993- length += n;
20994- }
20995- }
20996- break;
20997-
20998- case TYPE_U32_STRING:
20999- {
21000- const uint32_t *arg = a.arg[dp->arg_index].a.a_u32_string;
21001- const uint32_t *arg_end;
21002- size_t characters;
21003-
21004- if (has_precision)
21005- {
21006- /* Use only PRECISION characters, from the left. */
21007- arg_end = arg;
21008- characters = 0;
21009- for (; precision > 0; precision--)
21010- {
21011- int count = u32_strmblen (arg_end);
21012- if (count == 0)
21013- break;
21014- if (count < 0)
21015- {
21016- if (!(result == resultbuf || result == NULL))
21017- free (result);
21018- if (buf_malloced != NULL)
21019- free (buf_malloced);
21020- CLEANUP ();
21021- errno = EILSEQ;
21022- return NULL;
21023- }
21024- arg_end += count;
21025- characters++;
21026- }
21027- }
21028- else if (has_width)
21029- {
21030- /* Use the entire string, and count the number of
21031- characters. */
21032- arg_end = arg;
21033- characters = 0;
21034- for (;;)
21035- {
21036- int count = u32_strmblen (arg_end);
21037- if (count == 0)
21038- break;
21039- if (count < 0)
21040- {
21041- if (!(result == resultbuf || result == NULL))
21042- free (result);
21043- if (buf_malloced != NULL)
21044- free (buf_malloced);
21045- CLEANUP ();
21046- errno = EILSEQ;
21047- return NULL;
21048- }
21049- arg_end += count;
21050- characters++;
21051- }
21052- }
21053- else
21054- {
21055- /* Use the entire string. */
21056- arg_end = arg + u32_strlen (arg);
21057- /* The number of characters doesn't matter. */
21058- characters = 0;
21059- }
21060-
21061- if (has_width && width > characters
21062- && !(dp->flags & FLAG_LEFT))
21063- {
21064- size_t n = width - characters;
21065- ENSURE_ALLOCATION (xsum (length, n));
21066- DCHAR_SET (result + length, ' ', n);
21067- length += n;
21068- }
21069-
21070-# if DCHAR_IS_UINT32_T
21071- {
21072- size_t n = arg_end - arg;
21073- ENSURE_ALLOCATION (xsum (length, n));
21074- DCHAR_CPY (result + length, arg, n);
21075- length += n;
21076- }
21077-# else
21078- { /* Convert. */
21079- DCHAR_T *converted = result + length;
21080- size_t converted_len = allocated - length;
21081-# if DCHAR_IS_TCHAR
21082- /* Convert from UTF-32 to locale encoding. */
21083- if (u32_conv_to_encoding (locale_charset (),
21084- iconveh_question_mark,
21085- arg, arg_end - arg, NULL,
21086- &converted, &converted_len)
21087- < 0)
21088-# else
21089- /* Convert from UTF-32 to UTF-8/UTF-16. */
21090- converted =
21091- U32_TO_DCHAR (arg, arg_end - arg,
21092- converted, &converted_len);
21093- if (converted == NULL)
21094-# endif
21095- {
21096- int saved_errno = errno;
21097- if (!(result == resultbuf || result == NULL))
21098- free (result);
21099- if (buf_malloced != NULL)
21100- free (buf_malloced);
21101- CLEANUP ();
21102- errno = saved_errno;
21103- return NULL;
21104- }
21105- if (converted != result + length)
21106- {
21107- ENSURE_ALLOCATION (xsum (length, converted_len));
21108- DCHAR_CPY (result + length, converted, converted_len);
21109- free (converted);
21110- }
21111- length += converted_len;
21112- }
21113-# endif
21114-
21115- if (has_width && width > characters
21116- && (dp->flags & FLAG_LEFT))
21117- {
21118- size_t n = width - characters;
21119- ENSURE_ALLOCATION (xsum (length, n));
21120- DCHAR_SET (result + length, ' ', n);
21121- length += n;
21122- }
21123- }
21124- break;
21125-
21126- default:
21127- abort ();
21128- }
21129- }
21130-#endif
21131-#if (NEED_PRINTF_DIRECTIVE_A || NEED_PRINTF_LONG_DOUBLE || NEED_PRINTF_DOUBLE) && !defined IN_LIBINTL
21132- else if ((dp->conversion == 'a' || dp->conversion == 'A')
21133-# if !(NEED_PRINTF_DIRECTIVE_A || (NEED_PRINTF_LONG_DOUBLE && NEED_PRINTF_DOUBLE))
21134- && (0
21135-# if NEED_PRINTF_DOUBLE
21136- || a.arg[dp->arg_index].type == TYPE_DOUBLE
21137-# endif
21138-# if NEED_PRINTF_LONG_DOUBLE
21139- || a.arg[dp->arg_index].type == TYPE_LONGDOUBLE
21140-# endif
21141- )
21142-# endif
21143- )
21144- {
21145- arg_type type = a.arg[dp->arg_index].type;
21146- int flags = dp->flags;
21147- int has_width;
21148- size_t width;
21149- int has_precision;
21150- size_t precision;
21151- size_t tmp_length;
21152- DCHAR_T tmpbuf[700];
21153- DCHAR_T *tmp;
21154- DCHAR_T *pad_ptr;
21155- DCHAR_T *p;
21156-
21157- has_width = 0;
21158- width = 0;
21159- if (dp->width_start != dp->width_end)
21160- {
21161- if (dp->width_arg_index != ARG_NONE)
21162- {
21163- int arg;
21164-
21165- if (!(a.arg[dp->width_arg_index].type == TYPE_INT))
21166- abort ();
21167- arg = a.arg[dp->width_arg_index].a.a_int;
21168- if (arg < 0)
21169- {
21170- /* "A negative field width is taken as a '-' flag
21171- followed by a positive field width." */
21172- flags |= FLAG_LEFT;
21173- width = (unsigned int) (-arg);
21174- }
21175- else
21176- width = arg;
21177- }
21178- else
21179- {
21180- const FCHAR_T *digitp = dp->width_start;
21181-
21182- do
21183- width = xsum (xtimes (width, 10), *digitp++ - '0');
21184- while (digitp != dp->width_end);
21185- }
21186- has_width = 1;
21187- }
21188-
21189- has_precision = 0;
21190- precision = 0;
21191- if (dp->precision_start != dp->precision_end)
21192- {
21193- if (dp->precision_arg_index != ARG_NONE)
21194- {
21195- int arg;
21196-
21197- if (!(a.arg[dp->precision_arg_index].type == TYPE_INT))
21198- abort ();
21199- arg = a.arg[dp->precision_arg_index].a.a_int;
21200- /* "A negative precision is taken as if the precision
21201- were omitted." */
21202- if (arg >= 0)
21203- {
21204- precision = arg;
21205- has_precision = 1;
21206- }
21207- }
21208- else
21209- {
21210- const FCHAR_T *digitp = dp->precision_start + 1;
21211-
21212- precision = 0;
21213- while (digitp != dp->precision_end)
21214- precision = xsum (xtimes (precision, 10), *digitp++ - '0');
21215- has_precision = 1;
21216- }
21217- }
21218-
21219- /* Allocate a temporary buffer of sufficient size. */
21220- if (type == TYPE_LONGDOUBLE)
21221- tmp_length =
21222- (unsigned int) ((LDBL_DIG + 1)
21223- * 0.831 /* decimal -> hexadecimal */
21224- )
21225- + 1; /* turn floor into ceil */
21226- else
21227- tmp_length =
21228- (unsigned int) ((DBL_DIG + 1)
21229- * 0.831 /* decimal -> hexadecimal */
21230- )
21231- + 1; /* turn floor into ceil */
21232- if (tmp_length < precision)
21233- tmp_length = precision;
21234- /* Account for sign, decimal point etc. */
21235- tmp_length = xsum (tmp_length, 12);
21236-
21237- if (tmp_length < width)
21238- tmp_length = width;
21239-
21240- tmp_length = xsum (tmp_length, 1); /* account for trailing NUL */
21241-
21242- if (tmp_length <= sizeof (tmpbuf) / sizeof (DCHAR_T))
21243- tmp = tmpbuf;
21244- else
21245- {
21246- size_t tmp_memsize = xtimes (tmp_length, sizeof (DCHAR_T));
21247-
21248- if (size_overflow_p (tmp_memsize))
21249- /* Overflow, would lead to out of memory. */
21250- goto out_of_memory;
21251- tmp = (DCHAR_T *) malloc (tmp_memsize);
21252- if (tmp == NULL)
21253- /* Out of memory. */
21254- goto out_of_memory;
21255- }
21256-
21257- pad_ptr = NULL;
21258- p = tmp;
21259- if (type == TYPE_LONGDOUBLE)
21260- {
21261-# if NEED_PRINTF_DIRECTIVE_A || NEED_PRINTF_LONG_DOUBLE
21262- long double arg = a.arg[dp->arg_index].a.a_longdouble;
21263-
21264- if (isnanl (arg))
21265- {
21266- if (dp->conversion == 'A')
21267- {
21268- *p++ = 'N'; *p++ = 'A'; *p++ = 'N';
21269- }
21270- else
21271- {
21272- *p++ = 'n'; *p++ = 'a'; *p++ = 'n';
21273- }
21274- }
21275- else
21276- {
21277- int sign = 0;
21278- DECL_LONG_DOUBLE_ROUNDING
21279-
21280- BEGIN_LONG_DOUBLE_ROUNDING ();
21281-
21282- if (signbit (arg)) /* arg < 0.0L or negative zero */
21283- {
21284- sign = -1;
21285- arg = -arg;
21286- }
21287-
21288- if (sign < 0)
21289- *p++ = '-';
21290- else if (flags & FLAG_SHOWSIGN)
21291- *p++ = '+';
21292- else if (flags & FLAG_SPACE)
21293- *p++ = ' ';
21294-
21295- if (arg > 0.0L && arg + arg == arg)
21296- {
21297- if (dp->conversion == 'A')
21298- {
21299- *p++ = 'I'; *p++ = 'N'; *p++ = 'F';
21300- }
21301- else
21302- {
21303- *p++ = 'i'; *p++ = 'n'; *p++ = 'f';
21304- }
21305- }
21306- else
21307- {
21308- int exponent;
21309- long double mantissa;
21310-
21311- if (arg > 0.0L)
21312- mantissa = printf_frexpl (arg, &exponent);
21313- else
21314- {
21315- exponent = 0;
21316- mantissa = 0.0L;
21317- }
21318-
21319- if (has_precision
21320- && precision < (unsigned int) ((LDBL_DIG + 1) * 0.831) + 1)
21321- {
21322- /* Round the mantissa. */
21323- long double tail = mantissa;
21324- size_t q;
21325-
21326- for (q = precision; ; q--)
21327- {
21328- int digit = (int) tail;
21329- tail -= digit;
21330- if (q == 0)
21331- {
21332- if (digit & 1 ? tail >= 0.5L : tail > 0.5L)
21333- tail = 1 - tail;
21334- else
21335- tail = - tail;
21336- break;
21337- }
21338- tail *= 16.0L;
21339- }
21340- if (tail != 0.0L)
21341- for (q = precision; q > 0; q--)
21342- tail *= 0.0625L;
21343- mantissa += tail;
21344- }
21345-
21346- *p++ = '0';
21347- *p++ = dp->conversion - 'A' + 'X';
21348- pad_ptr = p;
21349- {
21350- int digit;
21351-
21352- digit = (int) mantissa;
21353- mantissa -= digit;
21354- *p++ = '0' + digit;
21355- if ((flags & FLAG_ALT)
21356- || mantissa > 0.0L || precision > 0)
21357- {
21358- *p++ = decimal_point_char ();
21359- /* This loop terminates because we assume
21360- that FLT_RADIX is a power of 2. */
21361- while (mantissa > 0.0L)
21362- {
21363- mantissa *= 16.0L;
21364- digit = (int) mantissa;
21365- mantissa -= digit;
21366- *p++ = digit
21367- + (digit < 10
21368- ? '0'
21369- : dp->conversion - 10);
21370- if (precision > 0)
21371- precision--;
21372- }
21373- while (precision > 0)
21374- {
21375- *p++ = '0';
21376- precision--;
21377- }
21378- }
21379- }
21380- *p++ = dp->conversion - 'A' + 'P';
21381-# if WIDE_CHAR_VERSION
21382- {
21383- static const wchar_t decimal_format[] =
21384- { '%', '+', 'd', '\0' };
21385- SNPRINTF (p, 6 + 1, decimal_format, exponent);
21386- }
21387- while (*p != '\0')
21388- p++;
21389-# else
21390- if (sizeof (DCHAR_T) == 1)
21391- {
21392- sprintf ((char *) p, "%+d", exponent);
21393- while (*p != '\0')
21394- p++;
21395- }
21396- else
21397- {
21398- char expbuf[6 + 1];
21399- const char *ep;
21400- sprintf (expbuf, "%+d", exponent);
21401- for (ep = expbuf; (*p = *ep) != '\0'; ep++)
21402- p++;
21403- }
21404-# endif
21405- }
21406-
21407- END_LONG_DOUBLE_ROUNDING ();
21408- }
21409-# else
21410- abort ();
21411-# endif
21412- }
21413- else
21414- {
21415-# if NEED_PRINTF_DIRECTIVE_A || NEED_PRINTF_DOUBLE
21416- double arg = a.arg[dp->arg_index].a.a_double;
21417-
21418- if (isnan (arg))
21419- {
21420- if (dp->conversion == 'A')
21421- {
21422- *p++ = 'N'; *p++ = 'A'; *p++ = 'N';
21423- }
21424- else
21425- {
21426- *p++ = 'n'; *p++ = 'a'; *p++ = 'n';
21427- }
21428- }
21429- else
21430- {
21431- int sign = 0;
21432-
21433- if (signbit (arg)) /* arg < 0.0 or negative zero */
21434- {
21435- sign = -1;
21436- arg = -arg;
21437- }
21438-
21439- if (sign < 0)
21440- *p++ = '-';
21441- else if (flags & FLAG_SHOWSIGN)
21442- *p++ = '+';
21443- else if (flags & FLAG_SPACE)
21444- *p++ = ' ';
21445-
21446- if (arg > 0.0 && arg + arg == arg)
21447- {
21448- if (dp->conversion == 'A')
21449- {
21450- *p++ = 'I'; *p++ = 'N'; *p++ = 'F';
21451- }
21452- else
21453- {
21454- *p++ = 'i'; *p++ = 'n'; *p++ = 'f';
21455- }
21456- }
21457- else
21458- {
21459- int exponent;
21460- double mantissa;
21461-
21462- if (arg > 0.0)
21463- mantissa = printf_frexp (arg, &exponent);
21464- else
21465- {
21466- exponent = 0;
21467- mantissa = 0.0;
21468- }
21469-
21470- if (has_precision
21471- && precision < (unsigned int) ((DBL_DIG + 1) * 0.831) + 1)
21472- {
21473- /* Round the mantissa. */
21474- double tail = mantissa;
21475- size_t q;
21476-
21477- for (q = precision; ; q--)
21478- {
21479- int digit = (int) tail;
21480- tail -= digit;
21481- if (q == 0)
21482- {
21483- if (digit & 1 ? tail >= 0.5 : tail > 0.5)
21484- tail = 1 - tail;
21485- else
21486- tail = - tail;
21487- break;
21488- }
21489- tail *= 16.0;
21490- }
21491- if (tail != 0.0)
21492- for (q = precision; q > 0; q--)
21493- tail *= 0.0625;
21494- mantissa += tail;
21495- }
21496-
21497- *p++ = '0';
21498- *p++ = dp->conversion - 'A' + 'X';
21499- pad_ptr = p;
21500- {
21501- int digit;
21502-
21503- digit = (int) mantissa;
21504- mantissa -= digit;
21505- *p++ = '0' + digit;
21506- if ((flags & FLAG_ALT)
21507- || mantissa > 0.0 || precision > 0)
21508- {
21509- *p++ = decimal_point_char ();
21510- /* This loop terminates because we assume
21511- that FLT_RADIX is a power of 2. */
21512- while (mantissa > 0.0)
21513- {
21514- mantissa *= 16.0;
21515- digit = (int) mantissa;
21516- mantissa -= digit;
21517- *p++ = digit
21518- + (digit < 10
21519- ? '0'
21520- : dp->conversion - 10);
21521- if (precision > 0)
21522- precision--;
21523- }
21524- while (precision > 0)
21525- {
21526- *p++ = '0';
21527- precision--;
21528- }
21529- }
21530- }
21531- *p++ = dp->conversion - 'A' + 'P';
21532-# if WIDE_CHAR_VERSION
21533- {
21534- static const wchar_t decimal_format[] =
21535- { '%', '+', 'd', '\0' };
21536- SNPRINTF (p, 6 + 1, decimal_format, exponent);
21537- }
21538- while (*p != '\0')
21539- p++;
21540-# else
21541- if (sizeof (DCHAR_T) == 1)
21542- {
21543- sprintf ((char *) p, "%+d", exponent);
21544- while (*p != '\0')
21545- p++;
21546- }
21547- else
21548- {
21549- char expbuf[6 + 1];
21550- const char *ep;
21551- sprintf (expbuf, "%+d", exponent);
21552- for (ep = expbuf; (*p = *ep) != '\0'; ep++)
21553- p++;
21554- }
21555-# endif
21556- }
21557- }
21558-# else
21559- abort ();
21560-# endif
21561- }
21562- /* The generated string now extends from tmp to p, with the
21563- zero padding insertion point being at pad_ptr. */
21564- if (has_width && p - tmp < width)
21565- {
21566- size_t pad = width - (p - tmp);
21567- DCHAR_T *end = p + pad;
21568-
21569- if (flags & FLAG_LEFT)
21570- {
21571- /* Pad with spaces on the right. */
21572- for (; pad > 0; pad--)
21573- *p++ = ' ';
21574- }
21575- else if ((flags & FLAG_ZERO) && pad_ptr != NULL)
21576- {
21577- /* Pad with zeroes. */
21578- DCHAR_T *q = end;
21579-
21580- while (p > pad_ptr)
21581- *--q = *--p;
21582- for (; pad > 0; pad--)
21583- *p++ = '0';
21584- }
21585- else
21586- {
21587- /* Pad with spaces on the left. */
21588- DCHAR_T *q = end;
21589-
21590- while (p > tmp)
21591- *--q = *--p;
21592- for (; pad > 0; pad--)
21593- *p++ = ' ';
21594- }
21595-
21596- p = end;
21597- }
21598-
21599- {
21600- size_t count = p - tmp;
21601-
21602- if (count >= tmp_length)
21603- /* tmp_length was incorrectly calculated - fix the
21604- code above! */
21605- abort ();
21606-
21607- /* Make room for the result. */
21608- if (count >= allocated - length)
21609- {
21610- size_t n = xsum (length, count);
21611-
21612- ENSURE_ALLOCATION (n);
21613- }
21614-
21615- /* Append the result. */
21616- memcpy (result + length, tmp, count * sizeof (DCHAR_T));
21617- if (tmp != tmpbuf)
21618- free (tmp);
21619- length += count;
21620- }
21621- }
21622-#endif
21623-#if (NEED_PRINTF_INFINITE_DOUBLE || NEED_PRINTF_DOUBLE || NEED_PRINTF_INFINITE_LONG_DOUBLE || NEED_PRINTF_LONG_DOUBLE) && !defined IN_LIBINTL
21624- else if ((dp->conversion == 'f' || dp->conversion == 'F'
21625- || dp->conversion == 'e' || dp->conversion == 'E'
21626- || dp->conversion == 'g' || dp->conversion == 'G'
21627- || dp->conversion == 'a' || dp->conversion == 'A')
21628- && (0
21629-# if NEED_PRINTF_DOUBLE
21630- || a.arg[dp->arg_index].type == TYPE_DOUBLE
21631-# elif NEED_PRINTF_INFINITE_DOUBLE
21632- || (a.arg[dp->arg_index].type == TYPE_DOUBLE
21633- /* The systems (mingw) which produce wrong output
21634- for Inf, -Inf, and NaN also do so for -0.0.
21635- Therefore we treat this case here as well. */
21636- && is_infinite_or_zero (a.arg[dp->arg_index].a.a_double))
21637-# endif
21638-# if NEED_PRINTF_LONG_DOUBLE
21639- || a.arg[dp->arg_index].type == TYPE_LONGDOUBLE
21640-# elif NEED_PRINTF_INFINITE_LONG_DOUBLE
21641- || (a.arg[dp->arg_index].type == TYPE_LONGDOUBLE
21642- /* Some systems produce wrong output for Inf,
21643- -Inf, and NaN. */
21644- && is_infinitel (a.arg[dp->arg_index].a.a_longdouble))
21645-# endif
21646- ))
21647- {
21648-# if (NEED_PRINTF_DOUBLE || NEED_PRINTF_INFINITE_DOUBLE) && (NEED_PRINTF_LONG_DOUBLE || NEED_PRINTF_INFINITE_LONG_DOUBLE)
21649- arg_type type = a.arg[dp->arg_index].type;
21650-# endif
21651- int flags = dp->flags;
21652- int has_width;
21653- size_t width;
21654- int has_precision;
21655- size_t precision;
21656- size_t tmp_length;
21657- DCHAR_T tmpbuf[700];
21658- DCHAR_T *tmp;
21659- DCHAR_T *pad_ptr;
21660- DCHAR_T *p;
21661-
21662- has_width = 0;
21663- width = 0;
21664- if (dp->width_start != dp->width_end)
21665- {
21666- if (dp->width_arg_index != ARG_NONE)
21667- {
21668- int arg;
21669-
21670- if (!(a.arg[dp->width_arg_index].type == TYPE_INT))
21671- abort ();
21672- arg = a.arg[dp->width_arg_index].a.a_int;
21673- if (arg < 0)
21674- {
21675- /* "A negative field width is taken as a '-' flag
21676- followed by a positive field width." */
21677- flags |= FLAG_LEFT;
21678- width = (unsigned int) (-arg);
21679- }
21680- else
21681- width = arg;
21682- }
21683- else
21684- {
21685- const FCHAR_T *digitp = dp->width_start;
21686-
21687- do
21688- width = xsum (xtimes (width, 10), *digitp++ - '0');
21689- while (digitp != dp->width_end);
21690- }
21691- has_width = 1;
21692- }
21693-
21694- has_precision = 0;
21695- precision = 0;
21696- if (dp->precision_start != dp->precision_end)
21697- {
21698- if (dp->precision_arg_index != ARG_NONE)
21699- {
21700- int arg;
21701-
21702- if (!(a.arg[dp->precision_arg_index].type == TYPE_INT))
21703- abort ();
21704- arg = a.arg[dp->precision_arg_index].a.a_int;
21705- /* "A negative precision is taken as if the precision
21706- were omitted." */
21707- if (arg >= 0)
21708- {
21709- precision = arg;
21710- has_precision = 1;
21711- }
21712- }
21713- else
21714- {
21715- const FCHAR_T *digitp = dp->precision_start + 1;
21716-
21717- precision = 0;
21718- while (digitp != dp->precision_end)
21719- precision = xsum (xtimes (precision, 10), *digitp++ - '0');
21720- has_precision = 1;
21721- }
21722- }
21723-
21724- /* POSIX specifies the default precision to be 6 for %f, %F,
21725- %e, %E, but not for %g, %G. Implementations appear to use
21726- the same default precision also for %g, %G. */
21727- if (!has_precision)
21728- precision = 6;
21729-
21730- /* Allocate a temporary buffer of sufficient size. */
21731-# if NEED_PRINTF_DOUBLE && NEED_PRINTF_LONG_DOUBLE
21732- tmp_length = (type == TYPE_LONGDOUBLE ? LDBL_DIG + 1 : DBL_DIG + 1);
21733-# elif NEED_PRINTF_INFINITE_DOUBLE && NEED_PRINTF_LONG_DOUBLE
21734- tmp_length = (type == TYPE_LONGDOUBLE ? LDBL_DIG + 1 : 0);
21735-# elif NEED_PRINTF_LONG_DOUBLE
21736- tmp_length = LDBL_DIG + 1;
21737-# elif NEED_PRINTF_DOUBLE
21738- tmp_length = DBL_DIG + 1;
21739-# else
21740- tmp_length = 0;
21741-# endif
21742- if (tmp_length < precision)
21743- tmp_length = precision;
21744-# if NEED_PRINTF_LONG_DOUBLE
21745-# if NEED_PRINTF_DOUBLE || NEED_PRINTF_INFINITE_DOUBLE
21746- if (type == TYPE_LONGDOUBLE)
21747-# endif
21748- if (dp->conversion == 'f' || dp->conversion == 'F')
21749- {
21750- long double arg = a.arg[dp->arg_index].a.a_longdouble;
21751- if (!(isnanl (arg) || arg + arg == arg))
21752- {
21753- /* arg is finite and nonzero. */
21754- int exponent = floorlog10l (arg < 0 ? -arg : arg);
21755- if (exponent >= 0 && tmp_length < exponent + precision)
21756- tmp_length = exponent + precision;
21757- }
21758- }
21759-# endif
21760-# if NEED_PRINTF_DOUBLE
21761-# if NEED_PRINTF_LONG_DOUBLE || NEED_PRINTF_INFINITE_LONG_DOUBLE
21762- if (type == TYPE_DOUBLE)
21763-# endif
21764- if (dp->conversion == 'f' || dp->conversion == 'F')
21765- {
21766- double arg = a.arg[dp->arg_index].a.a_double;
21767- if (!(isnan (arg) || arg + arg == arg))
21768- {
21769- /* arg is finite and nonzero. */
21770- int exponent = floorlog10 (arg < 0 ? -arg : arg);
21771- if (exponent >= 0 && tmp_length < exponent + precision)
21772- tmp_length = exponent + precision;
21773- }
21774- }
21775-# endif
21776- /* Account for sign, decimal point etc. */
21777- tmp_length = xsum (tmp_length, 12);
21778-
21779- if (tmp_length < width)
21780- tmp_length = width;
21781-
21782- tmp_length = xsum (tmp_length, 1); /* account for trailing NUL */
21783-
21784- if (tmp_length <= sizeof (tmpbuf) / sizeof (DCHAR_T))
21785- tmp = tmpbuf;
21786- else
21787- {
21788- size_t tmp_memsize = xtimes (tmp_length, sizeof (DCHAR_T));
21789-
21790- if (size_overflow_p (tmp_memsize))
21791- /* Overflow, would lead to out of memory. */
21792- goto out_of_memory;
21793- tmp = (DCHAR_T *) malloc (tmp_memsize);
21794- if (tmp == NULL)
21795- /* Out of memory. */
21796- goto out_of_memory;
21797- }
21798-
21799- pad_ptr = NULL;
21800- p = tmp;
21801-
21802-# if NEED_PRINTF_LONG_DOUBLE || NEED_PRINTF_INFINITE_LONG_DOUBLE
21803-# if NEED_PRINTF_DOUBLE || NEED_PRINTF_INFINITE_DOUBLE
21804- if (type == TYPE_LONGDOUBLE)
21805-# endif
21806- {
21807- long double arg = a.arg[dp->arg_index].a.a_longdouble;
21808-
21809- if (isnanl (arg))
21810- {
21811- if (dp->conversion >= 'A' && dp->conversion <= 'Z')
21812- {
21813- *p++ = 'N'; *p++ = 'A'; *p++ = 'N';
21814- }
21815- else
21816- {
21817- *p++ = 'n'; *p++ = 'a'; *p++ = 'n';
21818- }
21819- }
21820- else
21821- {
21822- int sign = 0;
21823- DECL_LONG_DOUBLE_ROUNDING
21824-
21825- BEGIN_LONG_DOUBLE_ROUNDING ();
21826-
21827- if (signbit (arg)) /* arg < 0.0L or negative zero */
21828- {
21829- sign = -1;
21830- arg = -arg;
21831- }
21832-
21833- if (sign < 0)
21834- *p++ = '-';
21835- else if (flags & FLAG_SHOWSIGN)
21836- *p++ = '+';
21837- else if (flags & FLAG_SPACE)
21838- *p++ = ' ';
21839-
21840- if (arg > 0.0L && arg + arg == arg)
21841- {
21842- if (dp->conversion >= 'A' && dp->conversion <= 'Z')
21843- {
21844- *p++ = 'I'; *p++ = 'N'; *p++ = 'F';
21845- }
21846- else
21847- {
21848- *p++ = 'i'; *p++ = 'n'; *p++ = 'f';
21849- }
21850- }
21851- else
21852- {
21853-# if NEED_PRINTF_LONG_DOUBLE
21854- pad_ptr = p;
21855-
21856- if (dp->conversion == 'f' || dp->conversion == 'F')
21857- {
21858- char *digits;
21859- size_t ndigits;
21860-
21861- digits =
21862- scale10_round_decimal_long_double (arg, precision);
21863- if (digits == NULL)
21864- {
21865- END_LONG_DOUBLE_ROUNDING ();
21866- goto out_of_memory;
21867- }
21868- ndigits = strlen (digits);
21869-
21870- if (ndigits > precision)
21871- do
21872- {
21873- --ndigits;
21874- *p++ = digits[ndigits];
21875- }
21876- while (ndigits > precision);
21877- else
21878- *p++ = '0';
21879- /* Here ndigits <= precision. */
21880- if ((flags & FLAG_ALT) || precision > 0)
21881- {
21882- *p++ = decimal_point_char ();
21883- for (; precision > ndigits; precision--)
21884- *p++ = '0';
21885- while (ndigits > 0)
21886- {
21887- --ndigits;
21888- *p++ = digits[ndigits];
21889- }
21890- }
21891-
21892- free (digits);
21893- }
21894- else if (dp->conversion == 'e' || dp->conversion == 'E')
21895- {
21896- int exponent;
21897-
21898- if (arg == 0.0L)
21899- {
21900- exponent = 0;
21901- *p++ = '0';
21902- if ((flags & FLAG_ALT) || precision > 0)
21903- {
21904- *p++ = decimal_point_char ();
21905- for (; precision > 0; precision--)
21906- *p++ = '0';
21907- }
21908- }
21909- else
21910- {
21911- /* arg > 0.0L. */
21912- int adjusted;
21913- char *digits;
21914- size_t ndigits;
21915-
21916- exponent = floorlog10l (arg);
21917- adjusted = 0;
21918- for (;;)
21919- {
21920- digits =
21921- scale10_round_decimal_long_double (arg,
21922- (int)precision - exponent);
21923- if (digits == NULL)
21924- {
21925- END_LONG_DOUBLE_ROUNDING ();
21926- goto out_of_memory;
21927- }
21928- ndigits = strlen (digits);
21929-
21930- if (ndigits == precision + 1)
21931- break;
21932- if (ndigits < precision
21933- || ndigits > precision + 2)
21934- /* The exponent was not guessed
21935- precisely enough. */
21936- abort ();
21937- if (adjusted)
21938- /* None of two values of exponent is
21939- the right one. Prevent an endless
21940- loop. */
21941- abort ();
21942- free (digits);
21943- if (ndigits == precision)
21944- exponent -= 1;
21945- else
21946- exponent += 1;
21947- adjusted = 1;
21948- }
21949-
21950- /* Here ndigits = precision+1. */
21951- *p++ = digits[--ndigits];
21952- if ((flags & FLAG_ALT) || precision > 0)
21953- {
21954- *p++ = decimal_point_char ();
21955- while (ndigits > 0)
21956- {
21957- --ndigits;
21958- *p++ = digits[ndigits];
21959- }
21960- }
21961-
21962- free (digits);
21963- }
21964-
21965- *p++ = dp->conversion; /* 'e' or 'E' */
21966-# if WIDE_CHAR_VERSION
21967- {
21968- static const wchar_t decimal_format[] =
21969- { '%', '+', '.', '2', 'd', '\0' };
21970- SNPRINTF (p, 6 + 1, decimal_format, exponent);
21971- }
21972- while (*p != '\0')
21973- p++;
21974-# else
21975- if (sizeof (DCHAR_T) == 1)
21976- {
21977- sprintf ((char *) p, "%+.2d", exponent);
21978- while (*p != '\0')
21979- p++;
21980- }
21981- else
21982- {
21983- char expbuf[6 + 1];
21984- const char *ep;
21985- sprintf (expbuf, "%+.2d", exponent);
21986- for (ep = expbuf; (*p = *ep) != '\0'; ep++)
21987- p++;
21988- }
21989-# endif
21990- }
21991- else if (dp->conversion == 'g' || dp->conversion == 'G')
21992- {
21993- if (precision == 0)
21994- precision = 1;
21995- /* precision >= 1. */
21996-
21997- if (arg == 0.0L)
21998- /* The exponent is 0, >= -4, < precision.
21999- Use fixed-point notation. */
22000- {
22001- size_t ndigits = precision;
22002- /* Number of trailing zeroes that have to be
22003- dropped. */
22004- size_t nzeroes =
22005- (flags & FLAG_ALT ? 0 : precision - 1);
22006-
22007- --ndigits;
22008- *p++ = '0';
22009- if ((flags & FLAG_ALT) || ndigits > nzeroes)
22010- {
22011- *p++ = decimal_point_char ();
22012- while (ndigits > nzeroes)
22013- {
22014- --ndigits;
22015- *p++ = '0';
22016- }
22017- }
22018- }
22019- else
22020- {
22021- /* arg > 0.0L. */
22022- int exponent;
22023- int adjusted;
22024- char *digits;
22025- size_t ndigits;
22026- size_t nzeroes;
22027-
22028- exponent = floorlog10l (arg);
22029- adjusted = 0;
22030- for (;;)
22031- {
22032- digits =
22033- scale10_round_decimal_long_double (arg,
22034- (int)(precision - 1) - exponent);
22035- if (digits == NULL)
22036- {
22037- END_LONG_DOUBLE_ROUNDING ();
22038- goto out_of_memory;
22039- }
22040- ndigits = strlen (digits);
22041-
22042- if (ndigits == precision)
22043- break;
22044- if (ndigits < precision - 1
22045- || ndigits > precision + 1)
22046- /* The exponent was not guessed
22047- precisely enough. */
22048- abort ();
22049- if (adjusted)
22050- /* None of two values of exponent is
22051- the right one. Prevent an endless
22052- loop. */
22053- abort ();
22054- free (digits);
22055- if (ndigits < precision)
22056- exponent -= 1;
22057- else
22058- exponent += 1;
22059- adjusted = 1;
22060- }
22061- /* Here ndigits = precision. */
22062-
22063- /* Determine the number of trailing zeroes
22064- that have to be dropped. */
22065- nzeroes = 0;
22066- if ((flags & FLAG_ALT) == 0)
22067- while (nzeroes < ndigits
22068- && digits[nzeroes] == '0')
22069- nzeroes++;
22070-
22071- /* The exponent is now determined. */
22072- if (exponent >= -4
22073- && exponent < (long)precision)
22074- {
22075- /* Fixed-point notation:
22076- max(exponent,0)+1 digits, then the
22077- decimal point, then the remaining
22078- digits without trailing zeroes. */
22079- if (exponent >= 0)
22080- {
22081- size_t count = exponent + 1;
22082- /* Note: count <= precision = ndigits. */
22083- for (; count > 0; count--)
22084- *p++ = digits[--ndigits];
22085- if ((flags & FLAG_ALT) || ndigits > nzeroes)
22086- {
22087- *p++ = decimal_point_char ();
22088- while (ndigits > nzeroes)
22089- {
22090- --ndigits;
22091- *p++ = digits[ndigits];
22092- }
22093- }
22094- }
22095- else
22096- {
22097- size_t count = -exponent - 1;
22098- *p++ = '0';
22099- *p++ = decimal_point_char ();
22100- for (; count > 0; count--)
22101- *p++ = '0';
22102- while (ndigits > nzeroes)
22103- {
22104- --ndigits;
22105- *p++ = digits[ndigits];
22106- }
22107- }
22108- }
22109- else
22110- {
22111- /* Exponential notation. */
22112- *p++ = digits[--ndigits];
22113- if ((flags & FLAG_ALT) || ndigits > nzeroes)
22114- {
22115- *p++ = decimal_point_char ();
22116- while (ndigits > nzeroes)
22117- {
22118- --ndigits;
22119- *p++ = digits[ndigits];
22120- }
22121- }
22122- *p++ = dp->conversion - 'G' + 'E'; /* 'e' or 'E' */
22123-# if WIDE_CHAR_VERSION
22124- {
22125- static const wchar_t decimal_format[] =
22126- { '%', '+', '.', '2', 'd', '\0' };
22127- SNPRINTF (p, 6 + 1, decimal_format, exponent);
22128- }
22129- while (*p != '\0')
22130- p++;
22131-# else
22132- if (sizeof (DCHAR_T) == 1)
22133- {
22134- sprintf ((char *) p, "%+.2d", exponent);
22135- while (*p != '\0')
22136- p++;
22137- }
22138- else
22139- {
22140- char expbuf[6 + 1];
22141- const char *ep;
22142- sprintf (expbuf, "%+.2d", exponent);
22143- for (ep = expbuf; (*p = *ep) != '\0'; ep++)
22144- p++;
22145- }
22146-# endif
22147- }
22148-
22149- free (digits);
22150- }
22151- }
22152- else
22153- abort ();
22154-# else
22155- /* arg is finite. */
22156- abort ();
22157-# endif
22158- }
22159-
22160- END_LONG_DOUBLE_ROUNDING ();
22161- }
22162- }
22163-# if NEED_PRINTF_DOUBLE || NEED_PRINTF_INFINITE_DOUBLE
22164- else
22165-# endif
22166-# endif
22167-# if NEED_PRINTF_DOUBLE || NEED_PRINTF_INFINITE_DOUBLE
22168- {
22169- double arg = a.arg[dp->arg_index].a.a_double;
22170-
22171- if (isnan (arg))
22172- {
22173- if (dp->conversion >= 'A' && dp->conversion <= 'Z')
22174- {
22175- *p++ = 'N'; *p++ = 'A'; *p++ = 'N';
22176- }
22177- else
22178- {
22179- *p++ = 'n'; *p++ = 'a'; *p++ = 'n';
22180- }
22181- }
22182- else
22183- {
22184- int sign = 0;
22185-
22186- if (signbit (arg)) /* arg < 0.0 or negative zero */
22187- {
22188- sign = -1;
22189- arg = -arg;
22190- }
22191-
22192- if (sign < 0)
22193- *p++ = '-';
22194- else if (flags & FLAG_SHOWSIGN)
22195- *p++ = '+';
22196- else if (flags & FLAG_SPACE)
22197- *p++ = ' ';
22198-
22199- if (arg > 0.0 && arg + arg == arg)
22200- {
22201- if (dp->conversion >= 'A' && dp->conversion <= 'Z')
22202- {
22203- *p++ = 'I'; *p++ = 'N'; *p++ = 'F';
22204- }
22205- else
22206- {
22207- *p++ = 'i'; *p++ = 'n'; *p++ = 'f';
22208- }
22209- }
22210- else
22211- {
22212-# if NEED_PRINTF_DOUBLE
22213- pad_ptr = p;
22214-
22215- if (dp->conversion == 'f' || dp->conversion == 'F')
22216- {
22217- char *digits;
22218- size_t ndigits;
22219-
22220- digits =
22221- scale10_round_decimal_double (arg, precision);
22222- if (digits == NULL)
22223- goto out_of_memory;
22224- ndigits = strlen (digits);
22225-
22226- if (ndigits > precision)
22227- do
22228- {
22229- --ndigits;
22230- *p++ = digits[ndigits];
22231- }
22232- while (ndigits > precision);
22233- else
22234- *p++ = '0';
22235- /* Here ndigits <= precision. */
22236- if ((flags & FLAG_ALT) || precision > 0)
22237- {
22238- *p++ = decimal_point_char ();
22239- for (; precision > ndigits; precision--)
22240- *p++ = '0';
22241- while (ndigits > 0)
22242- {
22243- --ndigits;
22244- *p++ = digits[ndigits];
22245- }
22246- }
22247-
22248- free (digits);
22249- }
22250- else if (dp->conversion == 'e' || dp->conversion == 'E')
22251- {
22252- int exponent;
22253-
22254- if (arg == 0.0)
22255- {
22256- exponent = 0;
22257- *p++ = '0';
22258- if ((flags & FLAG_ALT) || precision > 0)
22259- {
22260- *p++ = decimal_point_char ();
22261- for (; precision > 0; precision--)
22262- *p++ = '0';
22263- }
22264- }
22265- else
22266- {
22267- /* arg > 0.0. */
22268- int adjusted;
22269- char *digits;
22270- size_t ndigits;
22271-
22272- exponent = floorlog10 (arg);
22273- adjusted = 0;
22274- for (;;)
22275- {
22276- digits =
22277- scale10_round_decimal_double (arg,
22278- (int)precision - exponent);
22279- if (digits == NULL)
22280- goto out_of_memory;
22281- ndigits = strlen (digits);
22282-
22283- if (ndigits == precision + 1)
22284- break;
22285- if (ndigits < precision
22286- || ndigits > precision + 2)
22287- /* The exponent was not guessed
22288- precisely enough. */
22289- abort ();
22290- if (adjusted)
22291- /* None of two values of exponent is
22292- the right one. Prevent an endless
22293- loop. */
22294- abort ();
22295- free (digits);
22296- if (ndigits == precision)
22297- exponent -= 1;
22298- else
22299- exponent += 1;
22300- adjusted = 1;
22301- }
22302-
22303- /* Here ndigits = precision+1. */
22304- *p++ = digits[--ndigits];
22305- if ((flags & FLAG_ALT) || precision > 0)
22306- {
22307- *p++ = decimal_point_char ();
22308- while (ndigits > 0)
22309- {
22310- --ndigits;
22311- *p++ = digits[ndigits];
22312- }
22313- }
22314-
22315- free (digits);
22316- }
22317-
22318- *p++ = dp->conversion; /* 'e' or 'E' */
22319-# if WIDE_CHAR_VERSION
22320- {
22321- static const wchar_t decimal_format[] =
22322- /* Produce the same number of exponent digits
22323- as the native printf implementation. */
22324-# if (defined _WIN32 || defined __WIN32__) && ! defined __CYGWIN__
22325- { '%', '+', '.', '3', 'd', '\0' };
22326-# else
22327- { '%', '+', '.', '2', 'd', '\0' };
22328-# endif
22329- SNPRINTF (p, 6 + 1, decimal_format, exponent);
22330- }
22331- while (*p != '\0')
22332- p++;
22333-# else
22334- {
22335- static const char decimal_format[] =
22336- /* Produce the same number of exponent digits
22337- as the native printf implementation. */
22338-# if (defined _WIN32 || defined __WIN32__) && ! defined __CYGWIN__
22339- "%+.3d";
22340-# else
22341- "%+.2d";
22342-# endif
22343- if (sizeof (DCHAR_T) == 1)
22344- {
22345- sprintf ((char *) p, decimal_format, exponent);
22346- while (*p != '\0')
22347- p++;
22348- }
22349- else
22350- {
22351- char expbuf[6 + 1];
22352- const char *ep;
22353- sprintf (expbuf, decimal_format, exponent);
22354- for (ep = expbuf; (*p = *ep) != '\0'; ep++)
22355- p++;
22356- }
22357- }
22358-# endif
22359- }
22360- else if (dp->conversion == 'g' || dp->conversion == 'G')
22361- {
22362- if (precision == 0)
22363- precision = 1;
22364- /* precision >= 1. */
22365-
22366- if (arg == 0.0)
22367- /* The exponent is 0, >= -4, < precision.
22368- Use fixed-point notation. */
22369- {
22370- size_t ndigits = precision;
22371- /* Number of trailing zeroes that have to be
22372- dropped. */
22373- size_t nzeroes =
22374- (flags & FLAG_ALT ? 0 : precision - 1);
22375-
22376- --ndigits;
22377- *p++ = '0';
22378- if ((flags & FLAG_ALT) || ndigits > nzeroes)
22379- {
22380- *p++ = decimal_point_char ();
22381- while (ndigits > nzeroes)
22382- {
22383- --ndigits;
22384- *p++ = '0';
22385- }
22386- }
22387- }
22388- else
22389- {
22390- /* arg > 0.0. */
22391- int exponent;
22392- int adjusted;
22393- char *digits;
22394- size_t ndigits;
22395- size_t nzeroes;
22396-
22397- exponent = floorlog10 (arg);
22398- adjusted = 0;
22399- for (;;)
22400- {
22401- digits =
22402- scale10_round_decimal_double (arg,
22403- (int)(precision - 1) - exponent);
22404- if (digits == NULL)
22405- goto out_of_memory;
22406- ndigits = strlen (digits);
22407-
22408- if (ndigits == precision)
22409- break;
22410- if (ndigits < precision - 1
22411- || ndigits > precision + 1)
22412- /* The exponent was not guessed
22413- precisely enough. */
22414- abort ();
22415- if (adjusted)
22416- /* None of two values of exponent is
22417- the right one. Prevent an endless
22418- loop. */
22419- abort ();
22420- free (digits);
22421- if (ndigits < precision)
22422- exponent -= 1;
22423- else
22424- exponent += 1;
22425- adjusted = 1;
22426- }
22427- /* Here ndigits = precision. */
22428-
22429- /* Determine the number of trailing zeroes
22430- that have to be dropped. */
22431- nzeroes = 0;
22432- if ((flags & FLAG_ALT) == 0)
22433- while (nzeroes < ndigits
22434- && digits[nzeroes] == '0')
22435- nzeroes++;
22436-
22437- /* The exponent is now determined. */
22438- if (exponent >= -4
22439- && exponent < (long)precision)
22440- {
22441- /* Fixed-point notation:
22442- max(exponent,0)+1 digits, then the
22443- decimal point, then the remaining
22444- digits without trailing zeroes. */
22445- if (exponent >= 0)
22446- {
22447- size_t count = exponent + 1;
22448- /* Note: count <= precision = ndigits. */
22449- for (; count > 0; count--)
22450- *p++ = digits[--ndigits];
22451- if ((flags & FLAG_ALT) || ndigits > nzeroes)
22452- {
22453- *p++ = decimal_point_char ();
22454- while (ndigits > nzeroes)
22455- {
22456- --ndigits;
22457- *p++ = digits[ndigits];
22458- }
22459- }
22460- }
22461- else
22462- {
22463- size_t count = -exponent - 1;
22464- *p++ = '0';
22465- *p++ = decimal_point_char ();
22466- for (; count > 0; count--)
22467- *p++ = '0';
22468- while (ndigits > nzeroes)
22469- {
22470- --ndigits;
22471- *p++ = digits[ndigits];
22472- }
22473- }
22474- }
22475- else
22476- {
22477- /* Exponential notation. */
22478- *p++ = digits[--ndigits];
22479- if ((flags & FLAG_ALT) || ndigits > nzeroes)
22480- {
22481- *p++ = decimal_point_char ();
22482- while (ndigits > nzeroes)
22483- {
22484- --ndigits;
22485- *p++ = digits[ndigits];
22486- }
22487- }
22488- *p++ = dp->conversion - 'G' + 'E'; /* 'e' or 'E' */
22489-# if WIDE_CHAR_VERSION
22490- {
22491- static const wchar_t decimal_format[] =
22492- /* Produce the same number of exponent digits
22493- as the native printf implementation. */
22494-# if (defined _WIN32 || defined __WIN32__) && ! defined __CYGWIN__
22495- { '%', '+', '.', '3', 'd', '\0' };
22496-# else
22497- { '%', '+', '.', '2', 'd', '\0' };
22498-# endif
22499- SNPRINTF (p, 6 + 1, decimal_format, exponent);
22500- }
22501- while (*p != '\0')
22502- p++;
22503-# else
22504- {
22505- static const char decimal_format[] =
22506- /* Produce the same number of exponent digits
22507- as the native printf implementation. */
22508-# if (defined _WIN32 || defined __WIN32__) && ! defined __CYGWIN__
22509- "%+.3d";
22510-# else
22511- "%+.2d";
22512-# endif
22513- if (sizeof (DCHAR_T) == 1)
22514- {
22515- sprintf ((char *) p, decimal_format, exponent);
22516- while (*p != '\0')
22517- p++;
22518- }
22519- else
22520- {
22521- char expbuf[6 + 1];
22522- const char *ep;
22523- sprintf (expbuf, decimal_format, exponent);
22524- for (ep = expbuf; (*p = *ep) != '\0'; ep++)
22525- p++;
22526- }
22527- }
22528-# endif
22529- }
22530-
22531- free (digits);
22532- }
22533- }
22534- else
22535- abort ();
22536-# else
22537- /* arg is finite. */
22538- if (!(arg == 0.0))
22539- abort ();
22540-
22541- pad_ptr = p;
22542-
22543- if (dp->conversion == 'f' || dp->conversion == 'F')
22544- {
22545- *p++ = '0';
22546- if ((flags & FLAG_ALT) || precision > 0)
22547- {
22548- *p++ = decimal_point_char ();
22549- for (; precision > 0; precision--)
22550- *p++ = '0';
22551- }
22552- }
22553- else if (dp->conversion == 'e' || dp->conversion == 'E')
22554- {
22555- *p++ = '0';
22556- if ((flags & FLAG_ALT) || precision > 0)
22557- {
22558- *p++ = decimal_point_char ();
22559- for (; precision > 0; precision--)
22560- *p++ = '0';
22561- }
22562- *p++ = dp->conversion; /* 'e' or 'E' */
22563- *p++ = '+';
22564- /* Produce the same number of exponent digits as
22565- the native printf implementation. */
22566-# if (defined _WIN32 || defined __WIN32__) && ! defined __CYGWIN__
22567- *p++ = '0';
22568-# endif
22569- *p++ = '0';
22570- *p++ = '0';
22571- }
22572- else if (dp->conversion == 'g' || dp->conversion == 'G')
22573- {
22574- *p++ = '0';
22575- if (flags & FLAG_ALT)
22576- {
22577- size_t ndigits =
22578- (precision > 0 ? precision - 1 : 0);
22579- *p++ = decimal_point_char ();
22580- for (; ndigits > 0; --ndigits)
22581- *p++ = '0';
22582- }
22583- }
22584- else
22585- abort ();
22586-# endif
22587- }
22588- }
22589- }
22590-# endif
22591-
22592- /* The generated string now extends from tmp to p, with the
22593- zero padding insertion point being at pad_ptr. */
22594- if (has_width && p - tmp < width)
22595- {
22596- size_t pad = width - (p - tmp);
22597- DCHAR_T *end = p + pad;
22598-
22599- if (flags & FLAG_LEFT)
22600- {
22601- /* Pad with spaces on the right. */
22602- for (; pad > 0; pad--)
22603- *p++ = ' ';
22604- }
22605- else if ((flags & FLAG_ZERO) && pad_ptr != NULL)
22606- {
22607- /* Pad with zeroes. */
22608- DCHAR_T *q = end;
22609-
22610- while (p > pad_ptr)
22611- *--q = *--p;
22612- for (; pad > 0; pad--)
22613- *p++ = '0';
22614- }
22615- else
22616- {
22617- /* Pad with spaces on the left. */
22618- DCHAR_T *q = end;
22619-
22620- while (p > tmp)
22621- *--q = *--p;
22622- for (; pad > 0; pad--)
22623- *p++ = ' ';
22624- }
22625-
22626- p = end;
22627- }
22628-
22629- {
22630- size_t count = p - tmp;
22631-
22632- if (count >= tmp_length)
22633- /* tmp_length was incorrectly calculated - fix the
22634- code above! */
22635- abort ();
22636-
22637- /* Make room for the result. */
22638- if (count >= allocated - length)
22639- {
22640- size_t n = xsum (length, count);
22641-
22642- ENSURE_ALLOCATION (n);
22643- }
22644-
22645- /* Append the result. */
22646- memcpy (result + length, tmp, count * sizeof (DCHAR_T));
22647- if (tmp != tmpbuf)
22648- free (tmp);
22649- length += count;
22650- }
22651- }
22652-#endif
22653- else
22654- {
22655- arg_type type = a.arg[dp->arg_index].type;
22656- int flags = dp->flags;
22657-#if !USE_SNPRINTF || !DCHAR_IS_TCHAR || ENABLE_UNISTDIO || NEED_PRINTF_FLAG_ZERO || NEED_PRINTF_UNBOUNDED_PRECISION
22658- int has_width;
22659- size_t width;
22660-#endif
22661-#if !USE_SNPRINTF || NEED_PRINTF_UNBOUNDED_PRECISION
22662- int has_precision;
22663- size_t precision;
22664-#endif
22665-#if NEED_PRINTF_UNBOUNDED_PRECISION
22666- int prec_ourselves;
22667-#else
22668-# define prec_ourselves 0
22669-#endif
22670-#if !DCHAR_IS_TCHAR || ENABLE_UNISTDIO || NEED_PRINTF_FLAG_ZERO || NEED_PRINTF_UNBOUNDED_PRECISION
22671- int pad_ourselves;
22672-#else
22673-# define pad_ourselves 0
22674-#endif
22675- TCHAR_T *fbp;
22676- unsigned int prefix_count;
22677- int prefixes[2];
22678-#if !USE_SNPRINTF
22679- size_t tmp_length;
22680- TCHAR_T tmpbuf[700];
22681- TCHAR_T *tmp;
22682-#endif
22683-
22684-#if !USE_SNPRINTF || !DCHAR_IS_TCHAR || ENABLE_UNISTDIO || NEED_PRINTF_FLAG_ZERO || NEED_PRINTF_UNBOUNDED_PRECISION
22685- has_width = 0;
22686- width = 0;
22687- if (dp->width_start != dp->width_end)
22688- {
22689- if (dp->width_arg_index != ARG_NONE)
22690- {
22691- int arg;
22692-
22693- if (!(a.arg[dp->width_arg_index].type == TYPE_INT))
22694- abort ();
22695- arg = a.arg[dp->width_arg_index].a.a_int;
22696- if (arg < 0)
22697- {
22698- /* "A negative field width is taken as a '-' flag
22699- followed by a positive field width." */
22700- flags |= FLAG_LEFT;
22701- width = (unsigned int) (-arg);
22702- }
22703- else
22704- width = arg;
22705- }
22706- else
22707- {
22708- const FCHAR_T *digitp = dp->width_start;
22709-
22710- do
22711- width = xsum (xtimes (width, 10), *digitp++ - '0');
22712- while (digitp != dp->width_end);
22713- }
22714- has_width = 1;
22715- }
22716-#endif
22717-
22718-#if !USE_SNPRINTF || NEED_PRINTF_UNBOUNDED_PRECISION
22719- has_precision = 0;
22720- precision = 6;
22721- if (dp->precision_start != dp->precision_end)
22722- {
22723- if (dp->precision_arg_index != ARG_NONE)
22724- {
22725- int arg;
22726-
22727- if (!(a.arg[dp->precision_arg_index].type == TYPE_INT))
22728- abort ();
22729- arg = a.arg[dp->precision_arg_index].a.a_int;
22730- /* "A negative precision is taken as if the precision
22731- were omitted." */
22732- if (arg >= 0)
22733- {
22734- precision = arg;
22735- has_precision = 1;
22736- }
22737- }
22738- else
22739- {
22740- const FCHAR_T *digitp = dp->precision_start + 1;
22741-
22742- precision = 0;
22743- while (digitp != dp->precision_end)
22744- precision = xsum (xtimes (precision, 10), *digitp++ - '0');
22745- has_precision = 1;
22746- }
22747- }
22748-#endif
22749-
22750-#if !USE_SNPRINTF
22751- /* Allocate a temporary buffer of sufficient size for calling
22752- sprintf. */
22753- {
22754- switch (dp->conversion)
22755- {
22756-
22757- case 'd': case 'i': case 'u':
22758-# if HAVE_LONG_LONG_INT
22759- if (type == TYPE_LONGLONGINT || type == TYPE_ULONGLONGINT)
22760- tmp_length =
22761- (unsigned int) (sizeof (unsigned long long) * CHAR_BIT
22762- * 0.30103 /* binary -> decimal */
22763- )
22764- + 1; /* turn floor into ceil */
22765- else
22766-# endif
22767- if (type == TYPE_LONGINT || type == TYPE_ULONGINT)
22768- tmp_length =
22769- (unsigned int) (sizeof (unsigned long) * CHAR_BIT
22770- * 0.30103 /* binary -> decimal */
22771- )
22772- + 1; /* turn floor into ceil */
22773- else
22774- tmp_length =
22775- (unsigned int) (sizeof (unsigned int) * CHAR_BIT
22776- * 0.30103 /* binary -> decimal */
22777- )
22778- + 1; /* turn floor into ceil */
22779- if (tmp_length < precision)
22780- tmp_length = precision;
22781- /* Multiply by 2, as an estimate for FLAG_GROUP. */
22782- tmp_length = xsum (tmp_length, tmp_length);
22783- /* Add 1, to account for a leading sign. */
22784- tmp_length = xsum (tmp_length, 1);
22785- break;
22786-
22787- case 'o':
22788-# if HAVE_LONG_LONG_INT
22789- if (type == TYPE_LONGLONGINT || type == TYPE_ULONGLONGINT)
22790- tmp_length =
22791- (unsigned int) (sizeof (unsigned long long) * CHAR_BIT
22792- * 0.333334 /* binary -> octal */
22793- )
22794- + 1; /* turn floor into ceil */
22795- else
22796-# endif
22797- if (type == TYPE_LONGINT || type == TYPE_ULONGINT)
22798- tmp_length =
22799- (unsigned int) (sizeof (unsigned long) * CHAR_BIT
22800- * 0.333334 /* binary -> octal */
22801- )
22802- + 1; /* turn floor into ceil */
22803- else
22804- tmp_length =
22805- (unsigned int) (sizeof (unsigned int) * CHAR_BIT
22806- * 0.333334 /* binary -> octal */
22807- )
22808- + 1; /* turn floor into ceil */
22809- if (tmp_length < precision)
22810- tmp_length = precision;
22811- /* Add 1, to account for a leading sign. */
22812- tmp_length = xsum (tmp_length, 1);
22813- break;
22814-
22815- case 'x': case 'X':
22816-# if HAVE_LONG_LONG_INT
22817- if (type == TYPE_LONGLONGINT || type == TYPE_ULONGLONGINT)
22818- tmp_length =
22819- (unsigned int) (sizeof (unsigned long long) * CHAR_BIT
22820- * 0.25 /* binary -> hexadecimal */
22821- )
22822- + 1; /* turn floor into ceil */
22823- else
22824-# endif
22825- if (type == TYPE_LONGINT || type == TYPE_ULONGINT)
22826- tmp_length =
22827- (unsigned int) (sizeof (unsigned long) * CHAR_BIT
22828- * 0.25 /* binary -> hexadecimal */
22829- )
22830- + 1; /* turn floor into ceil */
22831- else
22832- tmp_length =
22833- (unsigned int) (sizeof (unsigned int) * CHAR_BIT
22834- * 0.25 /* binary -> hexadecimal */
22835- )
22836- + 1; /* turn floor into ceil */
22837- if (tmp_length < precision)
22838- tmp_length = precision;
22839- /* Add 2, to account for a leading sign or alternate form. */
22840- tmp_length = xsum (tmp_length, 2);
22841- break;
22842-
22843- case 'f': case 'F':
22844- if (type == TYPE_LONGDOUBLE)
22845- tmp_length =
22846- (unsigned int) (LDBL_MAX_EXP
22847- * 0.30103 /* binary -> decimal */
22848- * 2 /* estimate for FLAG_GROUP */
22849- )
22850- + 1 /* turn floor into ceil */
22851- + 10; /* sign, decimal point etc. */
22852- else
22853- tmp_length =
22854- (unsigned int) (DBL_MAX_EXP
22855- * 0.30103 /* binary -> decimal */
22856- * 2 /* estimate for FLAG_GROUP */
22857- )
22858- + 1 /* turn floor into ceil */
22859- + 10; /* sign, decimal point etc. */
22860- tmp_length = xsum (tmp_length, precision);
22861- break;
22862-
22863- case 'e': case 'E': case 'g': case 'G':
22864- tmp_length =
22865- 12; /* sign, decimal point, exponent etc. */
22866- tmp_length = xsum (tmp_length, precision);
22867- break;
22868-
22869- case 'a': case 'A':
22870- if (type == TYPE_LONGDOUBLE)
22871- tmp_length =
22872- (unsigned int) (LDBL_DIG
22873- * 0.831 /* decimal -> hexadecimal */
22874- )
22875- + 1; /* turn floor into ceil */
22876- else
22877- tmp_length =
22878- (unsigned int) (DBL_DIG
22879- * 0.831 /* decimal -> hexadecimal */
22880- )
22881- + 1; /* turn floor into ceil */
22882- if (tmp_length < precision)
22883- tmp_length = precision;
22884- /* Account for sign, decimal point etc. */
22885- tmp_length = xsum (tmp_length, 12);
22886- break;
22887-
22888- case 'c':
22889-# if HAVE_WINT_T && !WIDE_CHAR_VERSION
22890- if (type == TYPE_WIDE_CHAR)
22891- tmp_length = MB_CUR_MAX;
22892- else
22893-# endif
22894- tmp_length = 1;
22895- break;
22896-
22897- case 's':
22898-# if HAVE_WCHAR_T
22899- if (type == TYPE_WIDE_STRING)
22900- {
22901- tmp_length =
22902- local_wcslen (a.arg[dp->arg_index].a.a_wide_string);
22903-
22904-# if !WIDE_CHAR_VERSION
22905- tmp_length = xtimes (tmp_length, MB_CUR_MAX);
22906-# endif
22907- }
22908- else
22909-# endif
22910- tmp_length = strlen (a.arg[dp->arg_index].a.a_string);
22911- break;
22912-
22913- case 'p':
22914- tmp_length =
22915- (unsigned int) (sizeof (void *) * CHAR_BIT
22916- * 0.25 /* binary -> hexadecimal */
22917- )
22918- + 1 /* turn floor into ceil */
22919- + 2; /* account for leading 0x */
22920- break;
22921-
22922- default:
22923- abort ();
22924- }
22925-
22926-# if ENABLE_UNISTDIO
22927- /* Padding considers the number of characters, therefore the
22928- number of elements after padding may be
22929- > max (tmp_length, width)
22930- but is certainly
22931- <= tmp_length + width. */
22932- tmp_length = xsum (tmp_length, width);
22933-# else
22934- /* Padding considers the number of elements, says POSIX. */
22935- if (tmp_length < width)
22936- tmp_length = width;
22937-# endif
22938-
22939- tmp_length = xsum (tmp_length, 1); /* account for trailing NUL */
22940- }
22941-
22942- if (tmp_length <= sizeof (tmpbuf) / sizeof (TCHAR_T))
22943- tmp = tmpbuf;
22944- else
22945- {
22946- size_t tmp_memsize = xtimes (tmp_length, sizeof (TCHAR_T));
22947-
22948- if (size_overflow_p (tmp_memsize))
22949- /* Overflow, would lead to out of memory. */
22950- goto out_of_memory;
22951- tmp = (TCHAR_T *) malloc (tmp_memsize);
22952- if (tmp == NULL)
22953- /* Out of memory. */
22954- goto out_of_memory;
22955- }
22956-#endif
22957-
22958- /* Decide whether to handle the precision ourselves. */
22959-#if NEED_PRINTF_UNBOUNDED_PRECISION
22960- switch (dp->conversion)
22961- {
22962- case 'd': case 'i': case 'u':
22963- case 'o':
22964- case 'x': case 'X': case 'p':
22965- prec_ourselves = has_precision && (precision > 0);
22966- break;
22967- default:
22968- prec_ourselves = 0;
22969- break;
22970- }
22971-#endif
22972-
22973- /* Decide whether to perform the padding ourselves. */
22974-#if !DCHAR_IS_TCHAR || ENABLE_UNISTDIO || NEED_PRINTF_FLAG_ZERO || NEED_PRINTF_UNBOUNDED_PRECISION
22975- switch (dp->conversion)
22976- {
22977-# if !DCHAR_IS_TCHAR || ENABLE_UNISTDIO
22978- /* If we need conversion from TCHAR_T[] to DCHAR_T[], we need
22979- to perform the padding after this conversion. Functions
22980- with unistdio extensions perform the padding based on
22981- character count rather than element count. */
22982- case 'c': case 's':
22983-# endif
22984-# if NEED_PRINTF_FLAG_ZERO
22985- case 'f': case 'F': case 'e': case 'E': case 'g': case 'G':
22986- case 'a': case 'A':
22987-# endif
22988- pad_ourselves = 1;
22989- break;
22990- default:
22991- pad_ourselves = prec_ourselves;
22992- break;
22993- }
22994-#endif
22995-
22996- /* Construct the format string for calling snprintf or
22997- sprintf. */
22998- fbp = buf;
22999- *fbp++ = '%';
23000-#if NEED_PRINTF_FLAG_GROUPING
23001- /* The underlying implementation doesn't support the ' flag.
23002- Produce no grouping characters in this case; this is
23003- acceptable because the grouping is locale dependent. */
23004-#else
23005- if (flags & FLAG_GROUP)
23006- *fbp++ = '\'';
23007-#endif
23008- if (flags & FLAG_LEFT)
23009- *fbp++ = '-';
23010- if (flags & FLAG_SHOWSIGN)
23011- *fbp++ = '+';
23012- if (flags & FLAG_SPACE)
23013- *fbp++ = ' ';
23014- if (flags & FLAG_ALT)
23015- *fbp++ = '#';
23016- if (!pad_ourselves)
23017- {
23018- if (flags & FLAG_ZERO)
23019- *fbp++ = '0';
23020- if (dp->width_start != dp->width_end)
23021- {
23022- size_t n = dp->width_end - dp->width_start;
23023- /* The width specification is known to consist only
23024- of standard ASCII characters. */
23025- if (sizeof (FCHAR_T) == sizeof (TCHAR_T))
23026- {
23027- memcpy (fbp, dp->width_start, n * sizeof (TCHAR_T));
23028- fbp += n;
23029- }
23030- else
23031- {
23032- const FCHAR_T *mp = dp->width_start;
23033- do
23034- *fbp++ = (unsigned char) *mp++;
23035- while (--n > 0);
23036- }
23037- }
23038- }
23039- if (!prec_ourselves)
23040- {
23041- if (dp->precision_start != dp->precision_end)
23042- {
23043- size_t n = dp->precision_end - dp->precision_start;
23044- /* The precision specification is known to consist only
23045- of standard ASCII characters. */
23046- if (sizeof (FCHAR_T) == sizeof (TCHAR_T))
23047- {
23048- memcpy (fbp, dp->precision_start, n * sizeof (TCHAR_T));
23049- fbp += n;
23050- }
23051- else
23052- {
23053- const FCHAR_T *mp = dp->precision_start;
23054- do
23055- *fbp++ = (unsigned char) *mp++;
23056- while (--n > 0);
23057- }
23058- }
23059- }
23060-
23061- switch (type)
23062- {
23063-#if HAVE_LONG_LONG_INT
23064- case TYPE_LONGLONGINT:
23065- case TYPE_ULONGLONGINT:
23066-# if (defined _WIN32 || defined __WIN32__) && ! defined __CYGWIN__
23067- *fbp++ = 'I';
23068- *fbp++ = '6';
23069- *fbp++ = '4';
23070- break;
23071-# else
23072- *fbp++ = 'l';
23073- /*FALLTHROUGH*/
23074-# endif
23075-#endif
23076- case TYPE_LONGINT:
23077- case TYPE_ULONGINT:
23078-#if HAVE_WINT_T
23079- case TYPE_WIDE_CHAR:
23080-#endif
23081-#if HAVE_WCHAR_T
23082- case TYPE_WIDE_STRING:
23083-#endif
23084- *fbp++ = 'l';
23085- break;
23086- case TYPE_LONGDOUBLE:
23087- *fbp++ = 'L';
23088- break;
23089- default:
23090- break;
23091- }
23092-#if NEED_PRINTF_DIRECTIVE_F
23093- if (dp->conversion == 'F')
23094- *fbp = 'f';
23095- else
23096-#endif
23097- *fbp = dp->conversion;
23098-#if USE_SNPRINTF
23099-# if !(__GLIBC__ > 2 || (__GLIBC__ == 2 && __GLIBC_MINOR__ >= 3))
23100- fbp[1] = '%';
23101- fbp[2] = 'n';
23102- fbp[3] = '\0';
23103-# else
23104- /* On glibc2 systems from glibc >= 2.3 - probably also older
23105- ones - we know that snprintf's returns value conforms to
23106- ISO C 99: the gl_SNPRINTF_DIRECTIVE_N test passes.
23107- Therefore we can avoid using %n in this situation.
23108- On glibc2 systems from 2004-10-18 or newer, the use of %n
23109- in format strings in writable memory may crash the program
23110- (if compiled with _FORTIFY_SOURCE=2), so we should avoid it
23111- in this situation. */
23112- fbp[1] = '\0';
23113-# endif
23114-#else
23115- fbp[1] = '\0';
23116-#endif
23117-
23118- /* Construct the arguments for calling snprintf or sprintf. */
23119- prefix_count = 0;
23120- if (!pad_ourselves && dp->width_arg_index != ARG_NONE)
23121- {
23122- if (!(a.arg[dp->width_arg_index].type == TYPE_INT))
23123- abort ();
23124- prefixes[prefix_count++] = a.arg[dp->width_arg_index].a.a_int;
23125- }
23126- if (dp->precision_arg_index != ARG_NONE)
23127- {
23128- if (!(a.arg[dp->precision_arg_index].type == TYPE_INT))
23129- abort ();
23130- prefixes[prefix_count++] = a.arg[dp->precision_arg_index].a.a_int;
23131- }
23132-
23133-#if USE_SNPRINTF
23134- /* The SNPRINTF result is appended after result[0..length].
23135- The latter is an array of DCHAR_T; SNPRINTF appends an
23136- array of TCHAR_T to it. This is possible because
23137- sizeof (TCHAR_T) divides sizeof (DCHAR_T) and
23138- alignof (TCHAR_T) <= alignof (DCHAR_T). */
23139-# define TCHARS_PER_DCHAR (sizeof (DCHAR_T) / sizeof (TCHAR_T))
23140- /* Prepare checking whether snprintf returns the count
23141- via %n. */
23142- ENSURE_ALLOCATION (xsum (length, 1));
23143- *(TCHAR_T *) (result + length) = '\0';
23144-#endif
23145-
23146- for (;;)
23147- {
23148- int count = -1;
23149-
23150-#if USE_SNPRINTF
23151- int retcount = 0;
23152- size_t maxlen = allocated - length;
23153- /* SNPRINTF can fail if its second argument is
23154- > INT_MAX. */
23155- if (maxlen > INT_MAX / TCHARS_PER_DCHAR)
23156- maxlen = INT_MAX / TCHARS_PER_DCHAR;
23157- maxlen = maxlen * TCHARS_PER_DCHAR;
23158-# define SNPRINTF_BUF(arg) \
23159- switch (prefix_count) \
23160- { \
23161- case 0: \
23162- retcount = SNPRINTF ((TCHAR_T *) (result + length), \
23163- maxlen, buf, \
23164- arg, &count); \
23165- break; \
23166- case 1: \
23167- retcount = SNPRINTF ((TCHAR_T *) (result + length), \
23168- maxlen, buf, \
23169- prefixes[0], arg, &count); \
23170- break; \
23171- case 2: \
23172- retcount = SNPRINTF ((TCHAR_T *) (result + length), \
23173- maxlen, buf, \
23174- prefixes[0], prefixes[1], arg, \
23175- &count); \
23176- break; \
23177- default: \
23178- abort (); \
23179- }
23180-#else
23181-# define SNPRINTF_BUF(arg) \
23182- switch (prefix_count) \
23183- { \
23184- case 0: \
23185- count = sprintf (tmp, buf, arg); \
23186- break; \
23187- case 1: \
23188- count = sprintf (tmp, buf, prefixes[0], arg); \
23189- break; \
23190- case 2: \
23191- count = sprintf (tmp, buf, prefixes[0], prefixes[1],\
23192- arg); \
23193- break; \
23194- default: \
23195- abort (); \
23196- }
23197-#endif
23198-
23199- switch (type)
23200- {
23201- case TYPE_SCHAR:
23202- {
23203- int arg = a.arg[dp->arg_index].a.a_schar;
23204- SNPRINTF_BUF (arg);
23205- }
23206- break;
23207- case TYPE_UCHAR:
23208- {
23209- unsigned int arg = a.arg[dp->arg_index].a.a_uchar;
23210- SNPRINTF_BUF (arg);
23211- }
23212- break;
23213- case TYPE_SHORT:
23214- {
23215- int arg = a.arg[dp->arg_index].a.a_short;
23216- SNPRINTF_BUF (arg);
23217- }
23218- break;
23219- case TYPE_USHORT:
23220- {
23221- unsigned int arg = a.arg[dp->arg_index].a.a_ushort;
23222- SNPRINTF_BUF (arg);
23223- }
23224- break;
23225- case TYPE_INT:
23226- {
23227- int arg = a.arg[dp->arg_index].a.a_int;
23228- SNPRINTF_BUF (arg);
23229- }
23230- break;
23231- case TYPE_UINT:
23232- {
23233- unsigned int arg = a.arg[dp->arg_index].a.a_uint;
23234- SNPRINTF_BUF (arg);
23235- }
23236- break;
23237- case TYPE_LONGINT:
23238- {
23239- long int arg = a.arg[dp->arg_index].a.a_longint;
23240- SNPRINTF_BUF (arg);
23241- }
23242- break;
23243- case TYPE_ULONGINT:
23244- {
23245- unsigned long int arg = a.arg[dp->arg_index].a.a_ulongint;
23246- SNPRINTF_BUF (arg);
23247- }
23248- break;
23249-#if HAVE_LONG_LONG_INT
23250- case TYPE_LONGLONGINT:
23251- {
23252- long long int arg = a.arg[dp->arg_index].a.a_longlongint;
23253- SNPRINTF_BUF (arg);
23254- }
23255- break;
23256- case TYPE_ULONGLONGINT:
23257- {
23258- unsigned long long int arg = a.arg[dp->arg_index].a.a_ulonglongint;
23259- SNPRINTF_BUF (arg);
23260- }
23261- break;
23262-#endif
23263- case TYPE_DOUBLE:
23264- {
23265- double arg = a.arg[dp->arg_index].a.a_double;
23266- SNPRINTF_BUF (arg);
23267- }
23268- break;
23269- case TYPE_LONGDOUBLE:
23270- {
23271- long double arg = a.arg[dp->arg_index].a.a_longdouble;
23272- SNPRINTF_BUF (arg);
23273- }
23274- break;
23275- case TYPE_CHAR:
23276- {
23277- int arg = a.arg[dp->arg_index].a.a_char;
23278- SNPRINTF_BUF (arg);
23279- }
23280- break;
23281-#if HAVE_WINT_T
23282- case TYPE_WIDE_CHAR:
23283- {
23284- wint_t arg = a.arg[dp->arg_index].a.a_wide_char;
23285- SNPRINTF_BUF (arg);
23286- }
23287- break;
23288-#endif
23289- case TYPE_STRING:
23290- {
23291- const char *arg = a.arg[dp->arg_index].a.a_string;
23292- SNPRINTF_BUF (arg);
23293- }
23294- break;
23295-#if HAVE_WCHAR_T
23296- case TYPE_WIDE_STRING:
23297- {
23298- const wchar_t *arg = a.arg[dp->arg_index].a.a_wide_string;
23299- SNPRINTF_BUF (arg);
23300- }
23301- break;
23302-#endif
23303- case TYPE_POINTER:
23304- {
23305- void *arg = a.arg[dp->arg_index].a.a_pointer;
23306- SNPRINTF_BUF (arg);
23307- }
23308- break;
23309- default:
23310- abort ();
23311- }
23312-
23313-#if USE_SNPRINTF
23314- /* Portability: Not all implementations of snprintf()
23315- are ISO C 99 compliant. Determine the number of
23316- bytes that snprintf() has produced or would have
23317- produced. */
23318- if (count >= 0)
23319- {
23320- /* Verify that snprintf() has NUL-terminated its
23321- result. */
23322- if (count < maxlen
23323- && ((TCHAR_T *) (result + length)) [count] != '\0')
23324- abort ();
23325- /* Portability hack. */
23326- if (retcount > count)
23327- count = retcount;
23328- }
23329- else
23330- {
23331- /* snprintf() doesn't understand the '%n'
23332- directive. */
23333- if (fbp[1] != '\0')
23334- {
23335- /* Don't use the '%n' directive; instead, look
23336- at the snprintf() return value. */
23337- fbp[1] = '\0';
23338- continue;
23339- }
23340- else
23341- {
23342- /* Look at the snprintf() return value. */
23343- if (retcount < 0)
23344- {
23345- /* HP-UX 10.20 snprintf() is doubly deficient:
23346- It doesn't understand the '%n' directive,
23347- *and* it returns -1 (rather than the length
23348- that would have been required) when the
23349- buffer is too small. */
23350- size_t bigger_need =
23351- xsum (xtimes (allocated, 2), 12);
23352- ENSURE_ALLOCATION (bigger_need);
23353- continue;
23354- }
23355- else
23356- count = retcount;
23357- }
23358- }
23359-#endif
23360-
23361- /* Attempt to handle failure. */
23362- if (count < 0)
23363- {
23364- if (!(result == resultbuf || result == NULL))
23365- free (result);
23366- if (buf_malloced != NULL)
23367- free (buf_malloced);
23368- CLEANUP ();
23369- errno = EINVAL;
23370- return NULL;
23371- }
23372-
23373-#if USE_SNPRINTF
23374- /* Handle overflow of the allocated buffer.
23375- If such an overflow occurs, a C99 compliant snprintf()
23376- returns a count >= maxlen. However, a non-compliant
23377- snprintf() function returns only count = maxlen - 1. To
23378- cover both cases, test whether count >= maxlen - 1. */
23379- if ((unsigned int) count + 1 >= maxlen)
23380- {
23381- /* If maxlen already has attained its allowed maximum,
23382- allocating more memory will not increase maxlen.
23383- Instead of looping, bail out. */
23384- if (maxlen == INT_MAX / TCHARS_PER_DCHAR)
23385- goto overflow;
23386- else
23387- {
23388- /* Need at least count * sizeof (TCHAR_T) bytes.
23389- But allocate proportionally, to avoid looping
23390- eternally if snprintf() reports a too small
23391- count. */
23392- size_t n =
23393- xmax (xsum (length,
23394- (count + TCHARS_PER_DCHAR - 1)
23395- / TCHARS_PER_DCHAR),
23396- xtimes (allocated, 2));
23397-
23398- ENSURE_ALLOCATION (n);
23399- continue;
23400- }
23401- }
23402-#endif
23403-
23404-#if NEED_PRINTF_UNBOUNDED_PRECISION
23405- if (prec_ourselves)
23406- {
23407- /* Handle the precision. */
23408- TCHAR_T *prec_ptr =
23409-# if USE_SNPRINTF
23410- (TCHAR_T *) (result + length);
23411-# else
23412- tmp;
23413-# endif
23414- size_t prefix_count;
23415- size_t move;
23416-
23417- prefix_count = 0;
23418- /* Put the additional zeroes after the sign. */
23419- if (count >= 1
23420- && (*prec_ptr == '-' || *prec_ptr == '+'
23421- || *prec_ptr == ' '))
23422- prefix_count = 1;
23423- /* Put the additional zeroes after the 0x prefix if
23424- (flags & FLAG_ALT) || (dp->conversion == 'p'). */
23425- else if (count >= 2
23426- && prec_ptr[0] == '0'
23427- && (prec_ptr[1] == 'x' || prec_ptr[1] == 'X'))
23428- prefix_count = 2;
23429-
23430- move = count - prefix_count;
23431- if (precision > move)
23432- {
23433- /* Insert zeroes. */
23434- size_t insert = precision - move;
23435- TCHAR_T *prec_end;
23436-
23437-# if USE_SNPRINTF
23438- size_t n =
23439- xsum (length,
23440- (count + insert + TCHARS_PER_DCHAR - 1)
23441- / TCHARS_PER_DCHAR);
23442- length += (count + TCHARS_PER_DCHAR - 1) / TCHARS_PER_DCHAR;
23443- ENSURE_ALLOCATION (n);
23444- length -= (count + TCHARS_PER_DCHAR - 1) / TCHARS_PER_DCHAR;
23445- prec_ptr = (TCHAR_T *) (result + length);
23446-# endif
23447-
23448- prec_end = prec_ptr + count;
23449- prec_ptr += prefix_count;
23450-
23451- while (prec_end > prec_ptr)
23452- {
23453- prec_end--;
23454- prec_end[insert] = prec_end[0];
23455- }
23456-
23457- prec_end += insert;
23458- do
23459- *--prec_end = '0';
23460- while (prec_end > prec_ptr);
23461-
23462- count += insert;
23463- }
23464- }
23465-#endif
23466-
23467-#if !DCHAR_IS_TCHAR
23468-# if !USE_SNPRINTF
23469- if (count >= tmp_length)
23470- /* tmp_length was incorrectly calculated - fix the
23471- code above! */
23472- abort ();
23473-# endif
23474-
23475- /* Convert from TCHAR_T[] to DCHAR_T[]. */
23476- if (dp->conversion == 'c' || dp->conversion == 's')
23477- {
23478- /* type = TYPE_CHAR or TYPE_WIDE_CHAR or TYPE_STRING
23479- TYPE_WIDE_STRING.
23480- The result string is not certainly ASCII. */
23481- const TCHAR_T *tmpsrc;
23482- DCHAR_T *tmpdst;
23483- size_t tmpdst_len;
23484- /* This code assumes that TCHAR_T is 'char'. */
23485- typedef int TCHAR_T_verify
23486- [2 * (sizeof (TCHAR_T) == 1) - 1];
23487-# if USE_SNPRINTF
23488- tmpsrc = (TCHAR_T *) (result + length);
23489-# else
23490- tmpsrc = tmp;
23491-# endif
23492- tmpdst = NULL;
23493- tmpdst_len = 0;
23494- if (DCHAR_CONV_FROM_ENCODING (locale_charset (),
23495- iconveh_question_mark,
23496- tmpsrc, count,
23497- NULL,
23498- &tmpdst, &tmpdst_len)
23499- < 0)
23500- {
23501- int saved_errno = errno;
23502- if (!(result == resultbuf || result == NULL))
23503- free (result);
23504- if (buf_malloced != NULL)
23505- free (buf_malloced);
23506- CLEANUP ();
23507- errno = saved_errno;
23508- return NULL;
23509- }
23510- ENSURE_ALLOCATION (xsum (length, tmpdst_len));
23511- DCHAR_CPY (result + length, tmpdst, tmpdst_len);
23512- free (tmpdst);
23513- count = tmpdst_len;
23514- }
23515- else
23516- {
23517- /* The result string is ASCII.
23518- Simple 1:1 conversion. */
23519-# if USE_SNPRINTF
23520- /* If sizeof (DCHAR_T) == sizeof (TCHAR_T), it's a
23521- no-op conversion, in-place on the array starting
23522- at (result + length). */
23523- if (sizeof (DCHAR_T) != sizeof (TCHAR_T))
23524-# endif
23525- {
23526- const TCHAR_T *tmpsrc;
23527- DCHAR_T *tmpdst;
23528- size_t n;
23529-
23530-# if USE_SNPRINTF
23531- if (result == resultbuf)
23532- {
23533- tmpsrc = (TCHAR_T *) (result + length);
23534- /* ENSURE_ALLOCATION will not move tmpsrc
23535- (because it's part of resultbuf). */
23536- ENSURE_ALLOCATION (xsum (length, count));
23537- }
23538- else
23539- {
23540- /* ENSURE_ALLOCATION will move the array
23541- (because it uses realloc(). */
23542- ENSURE_ALLOCATION (xsum (length, count));
23543- tmpsrc = (TCHAR_T *) (result + length);
23544- }
23545-# else
23546- tmpsrc = tmp;
23547- ENSURE_ALLOCATION (xsum (length, count));
23548-# endif
23549- tmpdst = result + length;
23550- /* Copy backwards, because of overlapping. */
23551- tmpsrc += count;
23552- tmpdst += count;
23553- for (n = count; n > 0; n--)
23554- *--tmpdst = (unsigned char) *--tmpsrc;
23555- }
23556- }
23557-#endif
23558-
23559-#if DCHAR_IS_TCHAR && !USE_SNPRINTF
23560- /* Make room for the result. */
23561- if (count > allocated - length)
23562- {
23563- /* Need at least count elements. But allocate
23564- proportionally. */
23565- size_t n =
23566- xmax (xsum (length, count), xtimes (allocated, 2));
23567-
23568- ENSURE_ALLOCATION (n);
23569- }
23570-#endif
23571-
23572- /* Here count <= allocated - length. */
23573-
23574- /* Perform padding. */
23575-#if !DCHAR_IS_TCHAR || ENABLE_UNISTDIO || NEED_PRINTF_FLAG_ZERO || NEED_PRINTF_UNBOUNDED_PRECISION
23576- if (pad_ourselves && has_width)
23577- {
23578- size_t w;
23579-# if ENABLE_UNISTDIO
23580- /* Outside POSIX, it's preferrable to compare the width
23581- against the number of _characters_ of the converted
23582- value. */
23583- w = DCHAR_MBSNLEN (result + length, count);
23584-# else
23585- /* The width is compared against the number of _bytes_
23586- of the converted value, says POSIX. */
23587- w = count;
23588-# endif
23589- if (w < width)
23590- {
23591- size_t pad = width - w;
23592-# if USE_SNPRINTF
23593- /* Make room for the result. */
23594- if (xsum (count, pad) > allocated - length)
23595- {
23596- /* Need at least count + pad elements. But
23597- allocate proportionally. */
23598- size_t n =
23599- xmax (xsum3 (length, count, pad),
23600- xtimes (allocated, 2));
23601-
23602- length += count;
23603- ENSURE_ALLOCATION (n);
23604- length -= count;
23605- }
23606- /* Here count + pad <= allocated - length. */
23607-# endif
23608- {
23609-# if !DCHAR_IS_TCHAR || USE_SNPRINTF
23610- DCHAR_T * const rp = result + length;
23611-# else
23612- DCHAR_T * const rp = tmp;
23613-# endif
23614- DCHAR_T *p = rp + count;
23615- DCHAR_T *end = p + pad;
23616-# if NEED_PRINTF_FLAG_ZERO
23617- DCHAR_T *pad_ptr;
23618-# if !DCHAR_IS_TCHAR
23619- if (dp->conversion == 'c'
23620- || dp->conversion == 's')
23621- /* No zero-padding for string directives. */
23622- pad_ptr = NULL;
23623- else
23624-# endif
23625- {
23626- pad_ptr = (*rp == '-' ? rp + 1 : rp);
23627- /* No zero-padding of "inf" and "nan". */
23628- if ((*pad_ptr >= 'A' && *pad_ptr <= 'Z')
23629- || (*pad_ptr >= 'a' && *pad_ptr <= 'z'))
23630- pad_ptr = NULL;
23631- }
23632-# endif
23633- /* The generated string now extends from rp to p,
23634- with the zero padding insertion point being at
23635- pad_ptr. */
23636-
23637- count = count + pad; /* = end - rp */
23638-
23639- if (flags & FLAG_LEFT)
23640- {
23641- /* Pad with spaces on the right. */
23642- for (; pad > 0; pad--)
23643- *p++ = ' ';
23644- }
23645-# if NEED_PRINTF_FLAG_ZERO
23646- else if ((flags & FLAG_ZERO) && pad_ptr != NULL)
23647- {
23648- /* Pad with zeroes. */
23649- DCHAR_T *q = end;
23650-
23651- while (p > pad_ptr)
23652- *--q = *--p;
23653- for (; pad > 0; pad--)
23654- *p++ = '0';
23655- }
23656-# endif
23657- else
23658- {
23659- /* Pad with spaces on the left. */
23660- DCHAR_T *q = end;
23661-
23662- while (p > rp)
23663- *--q = *--p;
23664- for (; pad > 0; pad--)
23665- *p++ = ' ';
23666- }
23667- }
23668- }
23669- }
23670-#endif
23671-
23672-#if DCHAR_IS_TCHAR && !USE_SNPRINTF
23673- if (count >= tmp_length)
23674- /* tmp_length was incorrectly calculated - fix the
23675- code above! */
23676- abort ();
23677-#endif
23678-
23679- /* Here still count <= allocated - length. */
23680-
23681-#if !DCHAR_IS_TCHAR || USE_SNPRINTF
23682- /* The snprintf() result did fit. */
23683-#else
23684- /* Append the sprintf() result. */
23685- memcpy (result + length, tmp, count * sizeof (DCHAR_T));
23686-#endif
23687-#if !USE_SNPRINTF
23688- if (tmp != tmpbuf)
23689- free (tmp);
23690-#endif
23691-
23692-#if NEED_PRINTF_DIRECTIVE_F
23693- if (dp->conversion == 'F')
23694- {
23695- /* Convert the %f result to upper case for %F. */
23696- DCHAR_T *rp = result + length;
23697- size_t rc;
23698- for (rc = count; rc > 0; rc--, rp++)
23699- if (*rp >= 'a' && *rp <= 'z')
23700- *rp = *rp - 'a' + 'A';
23701- }
23702-#endif
23703-
23704- length += count;
23705- break;
23706- }
23707- }
23708- }
23709- }
23710-
23711- /* Add the final NUL. */
23712- ENSURE_ALLOCATION (xsum (length, 1));
23713- result[length] = '\0';
23714-
23715- if (result != resultbuf && length + 1 < allocated)
23716- {
23717- /* Shrink the allocated memory if possible. */
23718- DCHAR_T *memory;
23719-
23720- memory = (DCHAR_T *) realloc (result, (length + 1) * sizeof (DCHAR_T));
23721- if (memory != NULL)
23722- result = memory;
23723- }
23724-
23725- if (buf_malloced != NULL)
23726- free (buf_malloced);
23727- CLEANUP ();
23728- *lengthp = length;
23729- /* Note that we can produce a big string of a length > INT_MAX. POSIX
23730- says that snprintf() fails with errno = EOVERFLOW in this case, but
23731- that's only because snprintf() returns an 'int'. This function does
23732- not have this limitation. */
23733- return result;
23734-
23735- overflow:
23736- if (!(result == resultbuf || result == NULL))
23737- free (result);
23738- if (buf_malloced != NULL)
23739- free (buf_malloced);
23740- CLEANUP ();
23741- errno = EOVERFLOW;
23742- return NULL;
23743-
23744- out_of_memory:
23745- if (!(result == resultbuf || result == NULL))
23746- free (result);
23747- if (buf_malloced != NULL)
23748- free (buf_malloced);
23749- out_of_memory_1:
23750- CLEANUP ();
23751- errno = ENOMEM;
23752- return NULL;
23753- }
23754-}
23755-
23756-#undef TCHARS_PER_DCHAR
23757-#undef SNPRINTF
23758-#undef USE_SNPRINTF
23759-#undef DCHAR_CPY
23760-#undef PRINTF_PARSE
23761-#undef DIRECTIVES
23762-#undef DIRECTIVE
23763-#undef DCHAR_IS_TCHAR
23764-#undef TCHAR_T
23765-#undef DCHAR_T
23766-#undef FCHAR_T
23767-#undef VASNPRINTF
23768--- a/intl/vasnprintf.h
23769+++ /dev/null
23770@@ -1,78 +0,0 @@
23771-/* vsprintf with automatic memory allocation.
23772- Copyright (C) 2002-2004 Free Software Foundation, Inc.
23773-
23774- This program is free software; you can redistribute it and/or modify it
23775- under the terms of the GNU Library General Public License as published
23776- by the Free Software Foundation; either version 2, or (at your option)
23777- any later version.
23778-
23779- This program is distributed in the hope that it will be useful,
23780- but WITHOUT ANY WARRANTY; without even the implied warranty of
23781- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
23782- Library General Public License for more details.
23783-
23784- You should have received a copy of the GNU Library General Public
23785- License along with this program; if not, write to the Free Software
23786- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
23787- USA. */
23788-
23789-#ifndef _VASNPRINTF_H
23790-#define _VASNPRINTF_H
23791-
23792-/* Get va_list. */
23793-#include <stdarg.h>
23794-
23795-/* Get size_t. */
23796-#include <stddef.h>
23797-
23798-#ifndef __attribute__
23799-/* This feature is available in gcc versions 2.5 and later. */
23800-# if __GNUC__ < 2 || (__GNUC__ == 2 && __GNUC_MINOR__ < 5) || __STRICT_ANSI__
23801-# define __attribute__(Spec) /* empty */
23802-# endif
23803-/* The __-protected variants of `format' and `printf' attributes
23804- are accepted by gcc versions 2.6.4 (effectively 2.7) and later. */
23805-# if __GNUC__ < 2 || (__GNUC__ == 2 && __GNUC_MINOR__ < 7)
23806-# define __format__ format
23807-# define __printf__ printf
23808-# endif
23809-#endif
23810-
23811-#ifdef __cplusplus
23812-extern "C" {
23813-#endif
23814-
23815-/* Write formatted output to a string dynamically allocated with malloc().
23816- You can pass a preallocated buffer for the result in RESULTBUF and its
23817- size in *LENGTHP; otherwise you pass RESULTBUF = NULL.
23818- If successful, return the address of the string (this may be = RESULTBUF
23819- if no dynamic memory allocation was necessary) and set *LENGTHP to the
23820- number of resulting bytes, excluding the trailing NUL. Upon error, set
23821- errno and return NULL.
23822-
23823- When dynamic memory allocation occurs, the preallocated buffer is left
23824- alone (with possibly modified contents). This makes it possible to use
23825- a statically allocated or stack-allocated buffer, like this:
23826-
23827- char buf[100];
23828- size_t len = sizeof (buf);
23829- char *output = vasnprintf (buf, &len, format, args);
23830- if (output == NULL)
23831- ... error handling ...;
23832- else
23833- {
23834- ... use the output string ...;
23835- if (output != buf)
23836- free (output);
23837- }
23838- */
23839-extern char * asnprintf (char *resultbuf, size_t *lengthp, const char *format, ...)
23840- __attribute__ ((__format__ (__printf__, 3, 4)));
23841-extern char * vasnprintf (char *resultbuf, size_t *lengthp, const char *format, va_list args)
23842- __attribute__ ((__format__ (__printf__, 3, 0)));
23843-
23844-#ifdef __cplusplus
23845-}
23846-#endif
23847-
23848-#endif /* _VASNPRINTF_H */
23849--- a/intl/vasnwprintf.h
23850+++ /dev/null
23851@@ -1,46 +0,0 @@
23852-/* vswprintf with automatic memory allocation.
23853- Copyright (C) 2002-2003 Free Software Foundation, Inc.
23854-
23855- This program is free software; you can redistribute it and/or modify it
23856- under the terms of the GNU Library General Public License as published
23857- by the Free Software Foundation; either version 2, or (at your option)
23858- any later version.
23859-
23860- This program is distributed in the hope that it will be useful,
23861- but WITHOUT ANY WARRANTY; without even the implied warranty of
23862- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
23863- Library General Public License for more details.
23864-
23865- You should have received a copy of the GNU Library General Public
23866- License along with this program; if not, write to the Free Software
23867- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
23868- USA. */
23869-
23870-#ifndef _VASNWPRINTF_H
23871-#define _VASNWPRINTF_H
23872-
23873-/* Get va_list. */
23874-#include <stdarg.h>
23875-
23876-/* Get wchar_t, size_t. */
23877-#include <stddef.h>
23878-
23879-#ifdef __cplusplus
23880-extern "C" {
23881-#endif
23882-
23883-/* Write formatted output to a string dynamically allocated with malloc().
23884- You can pass a preallocated buffer for the result in RESULTBUF and its
23885- size in *LENGTHP; otherwise you pass RESULTBUF = NULL.
23886- If successful, return the address of the string (this may be = RESULTBUF
23887- if no dynamic memory allocation was necessary) and set *LENGTHP to the
23888- number of resulting bytes, excluding the trailing NUL. Upon error, set
23889- errno and return NULL. */
23890-extern wchar_t * asnwprintf (wchar_t *resultbuf, size_t *lengthp, const wchar_t *format, ...);
23891-extern wchar_t * vasnwprintf (wchar_t *resultbuf, size_t *lengthp, const wchar_t *format, va_list args);
23892-
23893-#ifdef __cplusplus
23894-}
23895-#endif
23896-
23897-#endif /* _VASNWPRINTF_H */
23898--- a/intl/version.c
23899+++ /dev/null
23900@@ -1,26 +0,0 @@
23901-/* libintl library version.
23902- Copyright (C) 2005 Free Software Foundation, Inc.
23903-
23904- This program is free software; you can redistribute it and/or modify it
23905- under the terms of the GNU Library General Public License as published
23906- by the Free Software Foundation; either version 2, or (at your option)
23907- any later version.
23908-
23909- This program is distributed in the hope that it will be useful,
23910- but WITHOUT ANY WARRANTY; without even the implied warranty of
23911- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
23912- Library General Public License for more details.
23913-
23914- You should have received a copy of the GNU Library General Public
23915- License along with this program; if not, write to the Free Software
23916- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
23917- USA. */
23918-
23919-#ifdef HAVE_CONFIG_H
23920-# include <config.h>
23921-#endif
23922-
23923-#include "libgnuintl.h"
23924-
23925-/* Version number: (major<<16) + (minor<<8) + subminor */
23926-int libintl_version = LIBINTL_VERSION;
23927--- a/intl/wprintf-parse.h
23928+++ /dev/null
23929@@ -1,75 +0,0 @@
23930-/* Parse printf format string.
23931- Copyright (C) 1999, 2002-2003 Free Software Foundation, Inc.
23932-
23933- This program is free software; you can redistribute it and/or modify it
23934- under the terms of the GNU Library General Public License as published
23935- by the Free Software Foundation; either version 2, or (at your option)
23936- any later version.
23937-
23938- This program is distributed in the hope that it will be useful,
23939- but WITHOUT ANY WARRANTY; without even the implied warranty of
23940- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
23941- Library General Public License for more details.
23942-
23943- You should have received a copy of the GNU Library General Public
23944- License along with this program; if not, write to the Free Software
23945- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
23946- USA. */
23947-
23948-#ifndef _WPRINTF_PARSE_H
23949-#define _WPRINTF_PARSE_H
23950-
23951-#include "printf-args.h"
23952-
23953-
23954-/* Flags */
23955-#define FLAG_GROUP 1 /* ' flag */
23956-#define FLAG_LEFT 2 /* - flag */
23957-#define FLAG_SHOWSIGN 4 /* + flag */
23958-#define FLAG_SPACE 8 /* space flag */
23959-#define FLAG_ALT 16 /* # flag */
23960-#define FLAG_ZERO 32
23961-
23962-/* arg_index value indicating that no argument is consumed. */
23963-#define ARG_NONE (~(size_t)0)
23964-
23965-/* A parsed directive. */
23966-typedef struct
23967-{
23968- const wchar_t* dir_start;
23969- const wchar_t* dir_end;
23970- int flags;
23971- const wchar_t* width_start;
23972- const wchar_t* width_end;
23973- size_t width_arg_index;
23974- const wchar_t* precision_start;
23975- const wchar_t* precision_end;
23976- size_t precision_arg_index;
23977- wchar_t conversion; /* d i o u x X f e E g G c s p n U % but not C S */
23978- size_t arg_index;
23979-}
23980-wchar_t_directive;
23981-
23982-/* A parsed format string. */
23983-typedef struct
23984-{
23985- size_t count;
23986- wchar_t_directive *dir;
23987- size_t max_width_length;
23988- size_t max_precision_length;
23989-}
23990-wchar_t_directives;
23991-
23992-
23993-/* Parses the format string. Fills in the number N of directives, and fills
23994- in directives[0], ..., directives[N-1], and sets directives[N].dir_start
23995- to the end of the format string. Also fills in the arg_type fields of the
23996- arguments and the needed count of arguments. */
23997-#ifdef STATIC
23998-STATIC
23999-#else
24000-extern
24001-#endif
24002-int wprintf_parse (const wchar_t *format, wchar_t_directives *d, arguments *a);
24003-
24004-#endif /* _WPRINTF_PARSE_H */
24005--- a/intl/xsize.h
24006+++ /dev/null
24007@@ -1,109 +0,0 @@
24008-/* xsize.h -- Checked size_t computations.
24009-
24010- Copyright (C) 2003 Free Software Foundation, Inc.
24011-
24012- This program is free software; you can redistribute it and/or modify it
24013- under the terms of the GNU Library General Public License as published
24014- by the Free Software Foundation; either version 2, or (at your option)
24015- any later version.
24016-
24017- This program is distributed in the hope that it will be useful,
24018- but WITHOUT ANY WARRANTY; without even the implied warranty of
24019- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
24020- Library General Public License for more details.
24021-
24022- You should have received a copy of the GNU Library General Public
24023- License along with this program; if not, write to the Free Software
24024- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
24025- USA. */
24026-
24027-#ifndef _XSIZE_H
24028-#define _XSIZE_H
24029-
24030-/* Get size_t. */
24031-#include <stddef.h>
24032-
24033-/* Get SIZE_MAX. */
24034-#include <limits.h>
24035-#if HAVE_STDINT_H
24036-# include <stdint.h>
24037-#endif
24038-
24039-/* The size of memory objects is often computed through expressions of
24040- type size_t. Example:
24041- void* p = malloc (header_size + n * element_size).
24042- These computations can lead to overflow. When this happens, malloc()
24043- returns a piece of memory that is way too small, and the program then
24044- crashes while attempting to fill the memory.
24045- To avoid this, the functions and macros in this file check for overflow.
24046- The convention is that SIZE_MAX represents overflow.
24047- malloc (SIZE_MAX) is not guaranteed to fail -- think of a malloc
24048- implementation that uses mmap --, it's recommended to use size_overflow_p()
24049- or size_in_bounds_p() before invoking malloc().
24050- The example thus becomes:
24051- size_t size = xsum (header_size, xtimes (n, element_size));
24052- void *p = (size_in_bounds_p (size) ? malloc (size) : NULL);
24053-*/
24054-
24055-/* Convert an arbitrary value >= 0 to type size_t. */
24056-#define xcast_size_t(N) \
24057- ((N) <= SIZE_MAX ? (size_t) (N) : SIZE_MAX)
24058-
24059-/* Sum of two sizes, with overflow check. */
24060-static inline size_t
24061-#if __GNUC__ >= 3
24062-__attribute__ ((__pure__))
24063-#endif
24064-xsum (size_t size1, size_t size2)
24065-{
24066- size_t sum = size1 + size2;
24067- return (sum >= size1 ? sum : SIZE_MAX);
24068-}
24069-
24070-/* Sum of three sizes, with overflow check. */
24071-static inline size_t
24072-#if __GNUC__ >= 3
24073-__attribute__ ((__pure__))
24074-#endif
24075-xsum3 (size_t size1, size_t size2, size_t size3)
24076-{
24077- return xsum (xsum (size1, size2), size3);
24078-}
24079-
24080-/* Sum of four sizes, with overflow check. */
24081-static inline size_t
24082-#if __GNUC__ >= 3
24083-__attribute__ ((__pure__))
24084-#endif
24085-xsum4 (size_t size1, size_t size2, size_t size3, size_t size4)
24086-{
24087- return xsum (xsum (xsum (size1, size2), size3), size4);
24088-}
24089-
24090-/* Maximum of two sizes, with overflow check. */
24091-static inline size_t
24092-#if __GNUC__ >= 3
24093-__attribute__ ((__pure__))
24094-#endif
24095-xmax (size_t size1, size_t size2)
24096-{
24097- /* No explicit check is needed here, because for any n:
24098- max (SIZE_MAX, n) == SIZE_MAX and max (n, SIZE_MAX) == SIZE_MAX. */
24099- return (size1 >= size2 ? size1 : size2);
24100-}
24101-
24102-/* Multiplication of a count with an element size, with overflow check.
24103- The count must be >= 0 and the element size must be > 0.
24104- This is a macro, not an inline function, so that it works correctly even
24105- when N is of a wider tupe and N > SIZE_MAX. */
24106-#define xtimes(N, ELSIZE) \
24107- ((N) <= SIZE_MAX / (ELSIZE) ? (size_t) (N) * (ELSIZE) : SIZE_MAX)
24108-
24109-/* Check for overflow. */
24110-#define size_overflow_p(SIZE) \
24111- ((SIZE) == SIZE_MAX)
24112-/* Check against overflow. */
24113-#define size_in_bounds_p(SIZE) \
24114- ((SIZE) != SIZE_MAX)
24115-
24116-#endif /* _XSIZE_H */
24117--- a/m4/intlmacosx.m4
24118+++ b/m4/intlmacosx.m4
24119@@ -1,50 +1,71 @@
24120-# intlmacosx.m4 serial 1 (gettext-0.17)
24121-dnl Copyright (C) 2004-2007 Free Software Foundation, Inc.
24122+# intlmacosx.m4 serial 6 (gettext-0.20)
24123+dnl Copyright (C) 2004-2014, 2016, 2019 Free Software Foundation, Inc.
24124 dnl This file is free software; the Free Software Foundation
24125 dnl gives unlimited permission to copy and/or distribute it,
24126 dnl with or without modifications, as long as this notice is preserved.
24127 dnl
24128-dnl This file can can be used in projects which are not available under
24129+dnl This file can be used in projects which are not available under
24130 dnl the GNU General Public License or the GNU Library General Public
24131 dnl License but which still want to provide support for the GNU gettext
24132 dnl functionality.
24133 dnl Please note that the actual code of the GNU gettext library is covered
24134 dnl by the GNU Library General Public License, and the rest of the GNU
24135-dnl gettext package package is covered by the GNU General Public License.
24136+dnl gettext package is covered by the GNU General Public License.
24137 dnl They are *not* in the public domain.
24138
24139-dnl Checks for special options needed on MacOS X.
24140+dnl Checks for special options needed on Mac OS X.
24141 dnl Defines INTL_MACOSX_LIBS.
24142 AC_DEFUN([gt_INTL_MACOSX],
24143 [
24144- dnl Check for API introduced in MacOS X 10.2.
24145+ dnl Check for API introduced in Mac OS X 10.4.
24146 AC_CACHE_CHECK([for CFPreferencesCopyAppValue],
24147- gt_cv_func_CFPreferencesCopyAppValue,
24148+ [gt_cv_func_CFPreferencesCopyAppValue],
24149 [gt_save_LIBS="$LIBS"
24150 LIBS="$LIBS -Wl,-framework -Wl,CoreFoundation"
24151- AC_TRY_LINK([#include <CoreFoundation/CFPreferences.h>],
24152- [CFPreferencesCopyAppValue(NULL, NULL)],
24153+ AC_LINK_IFELSE(
24154+ [AC_LANG_PROGRAM(
24155+ [[#include <CoreFoundation/CFPreferences.h>]],
24156+ [[CFPreferencesCopyAppValue(NULL, NULL)]])],
24157 [gt_cv_func_CFPreferencesCopyAppValue=yes],
24158 [gt_cv_func_CFPreferencesCopyAppValue=no])
24159 LIBS="$gt_save_LIBS"])
24160 if test $gt_cv_func_CFPreferencesCopyAppValue = yes; then
24161- AC_DEFINE([HAVE_CFPREFERENCESCOPYAPPVALUE], 1,
24162- [Define to 1 if you have the MacOS X function CFPreferencesCopyAppValue in the CoreFoundation framework.])
24163+ AC_DEFINE([HAVE_CFPREFERENCESCOPYAPPVALUE], [1],
24164+ [Define to 1 if you have the Mac OS X function CFPreferencesCopyAppValue in the CoreFoundation framework.])
24165 fi
24166- dnl Check for API introduced in MacOS X 10.3.
24167- AC_CACHE_CHECK([for CFLocaleCopyCurrent], gt_cv_func_CFLocaleCopyCurrent,
24168+ dnl Check for API introduced in Mac OS X 10.5.
24169+ AC_CACHE_CHECK([for CFLocaleCopyCurrent], [gt_cv_func_CFLocaleCopyCurrent],
24170 [gt_save_LIBS="$LIBS"
24171 LIBS="$LIBS -Wl,-framework -Wl,CoreFoundation"
24172- AC_TRY_LINK([#include <CoreFoundation/CFLocale.h>], [CFLocaleCopyCurrent();],
24173+ AC_LINK_IFELSE(
24174+ [AC_LANG_PROGRAM(
24175+ [[#include <CoreFoundation/CFLocale.h>]],
24176+ [[CFLocaleCopyCurrent();]])],
24177 [gt_cv_func_CFLocaleCopyCurrent=yes],
24178 [gt_cv_func_CFLocaleCopyCurrent=no])
24179 LIBS="$gt_save_LIBS"])
24180 if test $gt_cv_func_CFLocaleCopyCurrent = yes; then
24181- AC_DEFINE([HAVE_CFLOCALECOPYCURRENT], 1,
24182- [Define to 1 if you have the MacOS X function CFLocaleCopyCurrent in the CoreFoundation framework.])
24183+ AC_DEFINE([HAVE_CFLOCALECOPYCURRENT], [1],
24184+ [Define to 1 if you have the Mac OS X function CFLocaleCopyCurrent in the CoreFoundation framework.])
24185+ fi
24186+ AC_CACHE_CHECK([for CFLocaleCopyPreferredLanguages], [gt_cv_func_CFLocaleCopyPreferredLanguages],
24187+ [gt_save_LIBS="$LIBS"
24188+ LIBS="$LIBS -Wl,-framework -Wl,CoreFoundation"
24189+ AC_LINK_IFELSE(
24190+ [AC_LANG_PROGRAM(
24191+ [[#include <CoreFoundation/CFLocale.h>]],
24192+ [[CFLocaleCopyPreferredLanguages();]])],
24193+ [gt_cv_func_CFLocaleCopyPreferredLanguages=yes],
24194+ [gt_cv_func_CFLocaleCopyPreferredLanguages=no])
24195+ LIBS="$gt_save_LIBS"])
24196+ if test $gt_cv_func_CFLocaleCopyPreferredLanguages = yes; then
24197+ AC_DEFINE([HAVE_CFLOCALECOPYPREFERREDLANGUAGES], [1],
24198+ [Define to 1 if you have the Mac OS X function CFLocaleCopyPreferredLanguages in the CoreFoundation framework.])
24199 fi
24200 INTL_MACOSX_LIBS=
24201- if test $gt_cv_func_CFPreferencesCopyAppValue = yes || test $gt_cv_func_CFLocaleCopyCurrent = yes; then
24202+ if test $gt_cv_func_CFPreferencesCopyAppValue = yes \
24203+ || test $gt_cv_func_CFLocaleCopyCurrent = yes \
24204+ || test $gt_cv_func_CFLocaleCopyPreferredLanguages = yes; then
24205 INTL_MACOSX_LIBS="-Wl,-framework -Wl,CoreFoundation"
24206 fi
24207 AC_SUBST([INTL_MACOSX_LIBS])
24208--- a/po/ChangeLog
24209+++ b/po/ChangeLog
24210@@ -1,3 +1,11 @@
24211+2019-12-07 gettextize <bug-gnu-gettext@gnu.org>
24212+
24213+ * en@boldquot.header: Upgrade to gettext-0.20.1.
24214+ * en@quot.header: Upgrade to gettext-0.20.1.
24215+ * insert-header.sin: Upgrade to gettext-0.20.1.
24216+ * remove-potcdate.sin: Upgrade to gettext-0.20.1.
24217+ * Rules-quot: Upgrade to gettext-0.20.1.
24218+
24219 2009-08-11 Scott James Remnant <scott@netsplit.com>
24220
24221 * libnih.pot: Distribute the pot file
24222--- a/po/Rules-quot
24223+++ b/po/Rules-quot
24224@@ -1,4 +1,9 @@
24225 # Special Makefile rules for English message catalogs with quotation marks.
24226+#
24227+# Copyright (C) 2001-2017 Free Software Foundation, Inc.
24228+# This file, Rules-quot, and its auxiliary files (listed under
24229+# DISTFILES.common.extra1) are free software; the Free Software Foundation
24230+# gives unlimited permission to use, copy, distribute, and modify them.
24231
24232 DISTFILES.common.extra1 = quot.sed boldquot.sed en@quot.header en@boldquot.header insert-header.sin Rules-quot
24233
24234@@ -14,13 +19,23 @@ en@boldquot.po-update: en@boldquot.po-up
24235
24236 .insert-header.po-update-en:
24237 @lang=`echo $@ | sed -e 's/\.po-update-en$$//'`; \
24238- if test "$(PACKAGE)" = "gettext"; then PATH=`pwd`/../src:$$PATH; GETTEXTLIBDIR=`cd $(top_srcdir)/src && pwd`; export GETTEXTLIBDIR; fi; \
24239+ if test "$(PACKAGE)" = "gettext-tools" && test "$(CROSS_COMPILING)" != "yes"; then PATH=`pwd`/../src:$$PATH; GETTEXTLIBDIR=`cd $(top_srcdir)/src && pwd`; export GETTEXTLIBDIR; fi; \
24240 tmpdir=`pwd`; \
24241 echo "$$lang:"; \
24242 ll=`echo $$lang | sed -e 's/@.*//'`; \
24243 LC_ALL=C; export LC_ALL; \
24244 cd $(srcdir); \
24245- if $(MSGINIT) -i $(DOMAIN).pot --no-translator -l $$ll -o - 2>/dev/null | sed -f $$tmpdir/$$lang.insert-header | $(MSGCONV) -t UTF-8 | $(MSGFILTER) sed -f `echo $$lang | sed -e 's/.*@//'`.sed 2>/dev/null > $$tmpdir/$$lang.new.po; then \
24246+ if $(MSGINIT) $(MSGINIT_OPTIONS) -i $(DOMAIN).pot --no-translator -l $$lang -o - 2>/dev/null \
24247+ | $(SED) -f $$tmpdir/$$lang.insert-header | $(MSGCONV) -t UTF-8 | \
24248+ { case `$(MSGFILTER) --version | sed 1q | sed -e 's,^[^0-9]*,,'` in \
24249+ '' | 0.[0-9] | 0.[0-9].* | 0.1[0-8] | 0.1[0-8].*) \
24250+ $(MSGFILTER) $(SED) -f `echo $$lang | sed -e 's/.*@//'`.sed \
24251+ ;; \
24252+ *) \
24253+ $(MSGFILTER) `echo $$lang | sed -e 's/.*@//'` \
24254+ ;; \
24255+ esac } 2>/dev/null > $$tmpdir/$$lang.new.po \
24256+ ; then \
24257 if cmp $$lang.po $$tmpdir/$$lang.new.po >/dev/null 2>&1; then \
24258 rm -f $$tmpdir/$$lang.new.po; \
24259 else \
24260--- a/po/en@boldquot.header
24261+++ b/po/en@boldquot.header
24262@@ -2,7 +2,7 @@
24263 # The msgids must be ASCII and therefore cannot contain real quotation
24264 # characters, only substitutes like grave accent (0x60), apostrophe (0x27)
24265 # and double quote (0x22). These substitutes look strange; see
24266-# http://www.cl.cam.ac.uk/~mgk25/ucs/quotes.html
24267+# https://www.cl.cam.ac.uk/~mgk25/ucs/quotes.html
24268 #
24269 # This catalog translates grave accent (0x60) and apostrophe (0x27) to
24270 # left single quotation mark (U+2018) and right single quotation mark (U+2019).
24271--- a/po/en@quot.header
24272+++ b/po/en@quot.header
24273@@ -2,7 +2,7 @@
24274 # The msgids must be ASCII and therefore cannot contain real quotation
24275 # characters, only substitutes like grave accent (0x60), apostrophe (0x27)
24276 # and double quote (0x22). These substitutes look strange; see
24277-# http://www.cl.cam.ac.uk/~mgk25/ucs/quotes.html
24278+# https://www.cl.cam.ac.uk/~mgk25/ucs/quotes.html
24279 #
24280 # This catalog translates grave accent (0x60) and apostrophe (0x27) to
24281 # left single quotation mark (U+2018) and right single quotation mark (U+2019).
24282--- a/po/insert-header.sin
24283+++ b/po/insert-header.sin
24284@@ -1,5 +1,10 @@
24285 # Sed script that inserts the file called HEADER before the header entry.
24286 #
24287+# Copyright (C) 2001 Free Software Foundation, Inc.
24288+# Written by Bruno Haible <bruno@clisp.org>, 2001.
24289+# This file is free software; the Free Software Foundation gives
24290+# unlimited permission to use, copy, distribute, and modify it.
24291+#
24292 # At each occurrence of a line starting with "msgid ", we execute the following
24293 # commands. At the first occurrence, insert the file. At the following
24294 # occurrences, do nothing. The distinction between the first and the following
24295--- a/po/remove-potcdate.sin
24296+++ b/po/remove-potcdate.sin
24297@@ -1,6 +1,12 @@
24298-# Sed script that remove the POT-Creation-Date line in the header entry
24299+# Sed script that removes the POT-Creation-Date line in the header entry
24300 # from a POT file.
24301 #
24302+# Copyright (C) 2002 Free Software Foundation, Inc.
24303+# Copying and distribution of this file, with or without modification,
24304+# are permitted in any medium without royalty provided the copyright
24305+# notice and this notice are preserved. This file is offered as-is,
24306+# without any warranty.
24307+#
24308 # The distinction between the first and the following occurrences of the
24309 # pattern is achieved by looking at the hold space.
24310 /^"POT-Creation-Date: .*"$/{
diff --git a/meta-oe/recipes-support/libnih/libnih_1.0.3.bb b/meta-oe/recipes-support/libnih/libnih_1.0.3.bb
index fcb6bebd6..ff7a4ed10 100644
--- a/meta-oe/recipes-support/libnih/libnih_1.0.3.bb
+++ b/meta-oe/recipes-support/libnih/libnih_1.0.3.bb
@@ -20,19 +20,19 @@ SECTION = "libs"
20LICENSE = "GPL-2.0" 20LICENSE = "GPL-2.0"
21LIC_FILES_CHKSUM = "file://COPYING;md5=751419260aa954499f7abaabaa882bbe" 21LIC_FILES_CHKSUM = "file://COPYING;md5=751419260aa954499f7abaabaa882bbe"
22 22
23DEPENDS = "dbus libnih-native" 23DEPENDS = "dbus expat"
24DEPENDS_class-native = "dbus-native" 24DEPENDS_append_class-target = " libnih-native"
25 25
26SRC_URI = "https://launchpad.net/${BPN}/1.0/${PV}/+download/${BP}.tar.gz \ 26SRC_URI = "https://launchpad.net/${BPN}/1.0/${PV}/+download/${BP}.tar.gz \
27 file://libnih_1.0.3-4ubuntu16.patch \ 27 file://libnih_1.0.3-4ubuntu16.patch \
28 file://0001-signal.c-SIGCLD-and-SIGCHILD-are-same-on-sytem-V-sys.patch \ 28 file://0001-signal.c-SIGCLD-and-SIGCHILD-are-same-on-sytem-V-sys.patch \
29 file://0001-Update-autotool-files-also-make-it-work-with-latest-.patch \
29 " 30 "
30 31
31SRC_URI[md5sum] = "db7990ce55e01daffe19006524a1ccb0" 32SRC_URI[md5sum] = "db7990ce55e01daffe19006524a1ccb0"
32SRC_URI[sha256sum] = "897572df7565c0a90a81532671e23c63f99b4efde2eecbbf11e7857fbc61f405" 33SRC_URI[sha256sum] = "897572df7565c0a90a81532671e23c63f99b4efde2eecbbf11e7857fbc61f405"
33 34
34inherit autotools 35inherit autotools gettext
35inherit gettext
36 36
37do_configure_append () { 37do_configure_append () {
38 sed -i -e 's,lib/pkgconfig,${baselib}/pkgconfig,g' ${S}/nih/Makefile.in ${S}/nih-dbus/Makefile.in 38 sed -i -e 's,lib/pkgconfig,${baselib}/pkgconfig,g' ${S}/nih/Makefile.in ${S}/nih-dbus/Makefile.in