1
0
mirror of git://git.gnupg.org/gnupg.git synced 2024-12-31 11:41:32 +01:00

update to gettext 0.14.1

This commit is contained in:
Werner Koch 2004-08-10 17:23:10 +00:00
parent 3cbdcc3ab1
commit 87c05a6c59
29 changed files with 4000 additions and 2021 deletions

711
ABOUT-NLS
View File

@ -1,10 +1,11 @@
Notes on the Free Translation Project Notes on the Free Translation Project
************************************* *************************************
Free software is going international! The Free Translation Project Free software is going international! The Free Translation Project is
is a way to get maintainers of free software, translators, and users all a way to get maintainers of free software, translators, and users all
together, so that will gradually become able to speak many languages. together, so that free software will gradually become able to speak many
A few packages already provide translations for their messages. languages. A few packages already provide translations for their
messages.
If you found this `ABOUT-NLS' file inside a distribution, you may If you found this `ABOUT-NLS' file inside a distribution, you may
assume that the distributed package does use GNU `gettext' internally, assume that the distributed package does use GNU `gettext' internally,
@ -15,7 +16,7 @@ this package with messages translated.
Installers will find here some useful hints. These notes also Installers will find here some useful hints. These notes also
explain how users should proceed for getting the programs to use the explain how users should proceed for getting the programs to use the
available translations. They tell how people wanting to contribute and available translations. They tell how people wanting to contribute and
work at translations should contact the appropriate team. work on translations can contact the appropriate team.
When reporting bugs in the `intl/' directory or bugs which may be When reporting bugs in the `intl/' directory or bugs which may be
related to internationalization, you should tell about the version of related to internationalization, you should tell about the version of
@ -48,34 +49,34 @@ included `libintl'.
INSTALL Matters INSTALL Matters
=============== ===============
Some packages are "localizable" when properly installed; the Some packages are "localizable" when properly installed; the programs
programs they contain can be made to speak your own native language. they contain can be made to speak your own native language. Most such
Most such packages use GNU `gettext'. Other packages have their own packages use GNU `gettext'. Other packages have their own ways to
ways to internationalization, predating GNU `gettext'. internationalization, predating GNU `gettext'.
By default, this package will be installed to allow translation of By default, this package will be installed to allow translation of
messages. It will automatically detect whether the system already messages. It will automatically detect whether the system already
provides the GNU `gettext' functions. If not, the GNU `gettext' own provides the GNU `gettext' functions. If not, the included GNU
library will be used. This library is wholly contained within this `gettext' library will be used. This library is wholly contained
package, usually in the `intl/' subdirectory, so prior installation of within this package, usually in the `intl/' subdirectory, so prior
the GNU `gettext' package is _not_ required. Installers may use installation of the GNU `gettext' package is _not_ required.
special options at configuration time for changing the default Installers may use special options at configuration time for changing
behaviour. The commands: the default behaviour. The commands:
./configure --with-included-gettext ./configure --with-included-gettext
./configure --disable-nls ./configure --disable-nls
will respectively bypass any pre-existing `gettext' to use the will, respectively, bypass any pre-existing `gettext' to use the
internationalizing routines provided within this package, or else, internationalizing routines provided within this package, or else,
_totally_ disable translation of messages. _totally_ disable translation of messages.
When you already have GNU `gettext' installed on your system and run When you already have GNU `gettext' installed on your system and run
configure without an option for your new package, `configure' will configure without an option for your new package, `configure' will
probably detect the previously built and installed `libintl.a' file and probably detect the previously built and installed `libintl.a' file and
will decide to use this. This might be not what is desirable. You will decide to use this. This might not be desirable. You should use
should use the more recent version of the GNU `gettext' library. I.e. the more recent version of the GNU `gettext' library. I.e. if the file
if the file `intl/VERSION' shows that the library which comes with this `intl/VERSION' shows that the library which comes with this package is
package is more recent, you should use more recent, you should use
./configure --with-included-gettext ./configure --with-included-gettext
@ -86,7 +87,7 @@ and therefore it will not be used. The reason is that even an
emulation of `gettext' on top of `catgets' could not provide all the emulation of `gettext' on top of `catgets' could not provide all the
extensions of the GNU `gettext' library. extensions of the GNU `gettext' library.
Internationalized packages have usually many `po/LL.po' files, where Internationalized packages usually have many `po/LL.po' files, where
LL gives an ISO 639 two-letter code identifying the language. Unless LL gives an ISO 639 two-letter code identifying the language. Unless
translations have been forbidden at `configure' time by using the translations have been forbidden at `configure' time by using the
`--disable-nls' switch, all available translations are installed `--disable-nls' switch, all available translations are installed
@ -113,6 +114,13 @@ But in fact, some languages have dialects in different countries. For
example, `de_AT' is used for Austria, and `pt_BR' for Brazil. The example, `de_AT' is used for Austria, and `pt_BR' for Brazil. The
country code serves to distinguish the dialects. country code serves to distinguish the dialects.
The locale naming convention of `LL_CC', with `LL' denoting the
language and `CC' denoting the country, is the one use on systems based
on GNU libc. On other systems, some variations of this scheme are
used, such as `LL' or `LL_CC.ENCODING'. You can get the list of
locales supported by your system for your country by running the command
`locale -a | grep '^LL''.
Not all programs have translations for all languages. By default, an Not all programs have translations for all languages. By default, an
English message is shown in place of a nonexistent translation. If you English message is shown in place of a nonexistent translation. If you
understand other languages, you can set up a priority list of languages. understand other languages, you can set up a priority list of languages.
@ -124,6 +132,13 @@ system libraries. For example, some Swedish users who would rather
read translations in German than English for when Swedish is not read translations in German than English for when Swedish is not
available, set `LANGUAGE' to `sv:de' while leaving `LANG' to `sv_SE'. available, set `LANGUAGE' to `sv:de' while leaving `LANG' to `sv_SE'.
Special advice for Norwegian users: The language code for Norwegian
bokma*l changed from `no' to `nb' recently (in 2003). During the
transition period, while some message catalogs for this language are
installed under `nb' and some older ones under `no', it's recommended
for Norwegian users to set `LANGUAGE' to `nb:no' so that both newer and
older translations are used.
In the `LANGUAGE' environment variable, but not in the `LANG' In the `LANGUAGE' environment variable, but not in the `LANG'
environment variable, `LL_CC' combinations can be abbreviated as `LL' environment variable, `LL_CC' combinations can be abbreviated as `LL'
to denote the language's main dialect. For example, `de' is equivalent to denote the language's main dialect. For example, `de' is equivalent
@ -164,128 +179,558 @@ Available Packages
================== ==================
Languages are not equally supported in all packages. The following Languages are not equally supported in all packages. The following
matrix shows the current state of internationalization, as of September matrix shows the current state of internationalization, as of January
2001. The matrix shows, in regard of each package, for which languages 2004. The matrix shows, in regard of each package, for which languages
PO files have been submitted to translation coordination, with a PO files have been submitted to translation coordination, with a
translation percentage of at least 50%. translation percentage of at least 50%.
Ready PO files bg cs da de el en eo es et fi fr gl he hr id it ja Ready PO files af am ar az be bg bs ca cs da de el en en_GB eo es
+----------------------------------------------------+ +----------------------------------------------------+
a2ps | [] [] [] | a2ps | [] [] [] [] |
aegis | () |
ant-phone | () |
anubis | |
ap-utils | |
aspell | [] |
bash | [] [] [] [] | bash | [] [] [] [] |
bfd | | batchelor | |
binutils | [] | bfd | [] [] |
bison | [] [] [] [] [] | binutils | [] [] |
clisp | [] [] [] [] | bison | [] [] [] |
cpio | [] [] [] [] [] | bluez-pin | [] [] [] |
clisp | |
clisp | [] [] [] |
console-tools | [] [] |
coreutils | [] [] [] [] |
cpio | [] [] [] |
darkstat | [] () [] |
diffutils | [] [] [] [] [] [] [] | diffutils | [] [] [] [] [] [] [] |
enscript | [] [] | e2fsprogs | [] [] [] |
error | [] [] | enscript | [] [] [] [] |
fetchmail | | error | [] [] [] [] [] |
fileutils | [] [] [] [] [] [] [] [] | fetchmail | [] () [] [] [] [] |
findutils | [] [] [] [] [] [] [] [] | fileutils | [] [] [] |
flex | [] [] [] | findutils | [] [] [] [] [] [] [] |
freetype | | flex | [] [] [] [] |
gas | | fslint | |
gawk | [] [] | gas | [] |
gcal | | gawk | [] [] [] [] |
gcc | | gbiff | [] |
gettext | [] [] [] [] [] [] [] [] [] [] | gcal | [] |
gnupg | [] [] [] [] [] [] [] | gcc | [] [] |
gprof | | gettext | [] [] [] [] [] |
grep | [] [] [] [] [] [] [] [] | gettext-examples | [] [] [] [] |
hello | [] [] [] [] [] [] [] [] [] [] [] | gettext-runtime | [] [] [] [] [] |
id-utils | [] [] [] | gettext-tools | [] [] [] |
indent | [] [] [] [] [] | gimp-print | [] [] [] [] [] |
jpilot | [] | gliv | |
kbd | | glunarclock | [] [] |
ld | [] | gnubiff | [] |
libc | [] [] [] [] [] [] [] [] | gnucash | [] () [] [] |
gnucash-glossary | [] () [] |
gnupg | [] () [] [] [] [] |
gpe-aerial | [] |
gpe-beam | [] [] |
gpe-calendar | [] [] |
gpe-clock | [] [] |
gpe-conf | [] [] |
gpe-contacts | [] [] |
gpe-edit | [] |
gpe-go | [] |
gpe-login | [] [] |
gpe-ownerinfo | [] [] |
gpe-sketchbook | [] [] |
gpe-su | [] [] |
gpe-taskmanager | [] [] |
gpe-timesheet | [] |
gpe-today | [] [] |
gpe-todo | [] [] |
gphoto2 | [] [] [] [] |
gprof | [] [] [] |
gpsdrive | () () () |
gramadoir | [] |
grep | [] [] [] [] [] [] |
gretl | [] |
gtick | [] () |
hello | [] [] [] [] [] [] |
id-utils | [] [] |
indent | [] [] [] [] |
iso_3166 | [] [] [] [] [] [] [] [] [] [] |
iso_3166_1 | [] [] [] [] [] [] |
iso_3166_2 | |
iso_3166_3 | [] |
iso_4217 | [] [] [] [] |
iso_639 | |
jpilot | [] [] [] |
jtag | |
jwhois | [] |
kbd | [] [] [] [] [] |
latrine | () |
ld | [] [] |
libc | [] [] [] [] [] [] |
libgpewidget | [] [] |
libiconv | [] [] [] [] [] |
lifelines | [] () |
lilypond | [] | lilypond | [] |
lingoteach | |
lingoteach_lessons | () () |
lynx | [] [] [] [] | lynx | [] [] [] [] |
m4 | [] [] [] [] [] [] [] [] | m4 | [] [] [] [] |
mailutils | [] [] |
make | [] [] [] |
man-db | [] () [] [] () |
minicom | [] [] [] |
mysecretdiary | [] [] [] |
nano | [] () [] [] [] |
nano_1_0 | [] () [] [] [] |
opcodes | [] |
parted | [] [] [] [] [] |
ptx | [] [] [] [] [] |
python | |
radius | [] |
recode | [] [] [] [] [] [] [] |
rpm | [] [] |
screem | |
scrollkeeper | [] [] [] [] [] [] |
sed | [] [] [] [] [] [] |
sh-utils | [] [] [] |
shared-mime-info | |
sharutils | [] [] [] [] [] [] |
silky | () |
skencil | [] () [] |
sketch | [] () [] |
soundtracker | [] [] [] |
sp | [] |
tar | [] [] [] [] |
texinfo | [] [] [] |
textutils | [] [] [] [] |
tin | () () |
tp-robot | |
tuxpaint | [] [] [] [] [] [] [] |
unicode-han-tra... | |
unicode-transla... | |
util-linux | [] [] [] [] [] |
vorbis-tools | [] [] [] [] |
wastesedge | () |
wdiff | [] [] [] [] |
wget | [] [] [] [] [] [] |
xchat | [] [] [] [] |
xfree86_xkb_xml | [] [] |
xpad | [] |
+----------------------------------------------------+
af am ar az be bg bs ca cs da de el en en_GB eo es
4 0 0 1 9 4 1 40 41 60 78 17 1 5 13 68
et eu fa fi fr ga gl he hr hu id is it ja ko lg
+-------------------------------------------------+
a2ps | [] [] [] () () |
aegis | |
ant-phone | [] |
anubis | [] |
ap-utils | [] |
aspell | [] [] |
bash | [] [] |
batchelor | [] [] |
bfd | [] |
binutils | [] [] |
bison | [] [] [] [] |
bluez-pin | [] [] [] [] [] |
clisp | |
clisp | [] |
console-tools | |
coreutils | [] [] [] [] [] [] |
cpio | [] [] [] [] |
darkstat | () [] [] [] |
diffutils | [] [] [] [] [] [] [] |
e2fsprogs | |
enscript | [] [] |
error | [] [] [] [] |
fetchmail | [] |
fileutils | [] [] [] [] [] [] |
findutils | [] [] [] [] [] [] [] [] [] [] [] |
flex | [] [] [] |
fslint | [] |
gas | [] |
gawk | [] [] [] |
gbiff | [] |
gcal | [] |
gcc | [] |
gettext | [] [] [] |
gettext-examples | [] [] |
gettext-runtime | [] [] [] [] [] |
gettext-tools | [] [] [] |
gimp-print | [] [] |
gliv | () |
glunarclock | [] [] [] [] |
gnubiff | [] |
gnucash | () [] |
gnucash-glossary | [] |
gnupg | [] [] [] [] [] [] [] |
gpe-aerial | [] |
gpe-beam | [] |
gpe-calendar | [] [] [] |
gpe-clock | [] |
gpe-conf | [] |
gpe-contacts | [] [] |
gpe-edit | [] [] |
gpe-go | [] |
gpe-login | [] [] |
gpe-ownerinfo | [] [] [] |
gpe-sketchbook | [] |
gpe-su | [] |
gpe-taskmanager | [] |
gpe-timesheet | [] [] [] |
gpe-today | [] [] |
gpe-todo | [] [] |
gphoto2 | [] [] [] |
gprof | [] [] |
gpsdrive | () () () |
gramadoir | [] [] |
grep | [] [] [] [] [] [] [] [] [] [] [] |
gretl | [] [] |
gtick | [] [] [] |
hello | [] [] [] [] [] [] [] [] [] [] [] [] [] |
id-utils | [] [] [] [] |
indent | [] [] [] [] [] [] [] [] [] |
iso_3166 | [] [] [] [] [] [] [] |
iso_3166_1 | [] [] [] [] [] |
iso_3166_2 | |
iso_3166_3 | |
iso_4217 | [] [] [] [] [] [] |
iso_639 | |
jpilot | [] () |
jtag | [] |
jwhois | [] [] [] [] |
kbd | [] |
latrine | [] |
ld | [] |
libc | [] [] [] [] [] [] |
libgpewidget | [] [] [] [] |
libiconv | [] [] [] [] [] [] [] [] [] |
lifelines | () |
lilypond | [] |
lingoteach | [] [] |
lingoteach_lessons | |
lynx | [] [] [] [] |
m4 | [] [] [] [] |
mailutils | |
make | [] [] [] [] [] [] | make | [] [] [] [] [] [] |
mysecretdiary | [] | man-db | () () |
nano | [] [] [] | minicom | [] [] [] [] |
opcodes | | mysecretdiary | [] [] |
nano | [] [] [] [] |
nano_1_0 | [] [] [] [] |
opcodes | [] |
parted | [] [] [] | parted | [] [] [] |
ptx | [] [] [] [] [] [] [] | ptx | [] [] [] [] [] [] [] |
python | | python | |
recode | [] [] [] [] [] [] [] [] [] | radius | [] |
sed | [] [] [] [] [] [] [] [] [] [] [] [] | recode | [] [] [] [] [] [] |
sh-utils | [] [] [] [] [] [] [] [] [] [] | rpm | [] [] |
sharutils | [] [] [] [] [] [] [] [] | screem | |
sketch | | scrollkeeper | [] |
soundtracker | [] [] [] | sed | [] [] [] [] [] [] [] [] [] |
sp | | sh-utils | [] [] [] [] [] [] [] |
tar | [] [] [] [] [] [] [] [] | shared-mime-info | [] [] [] |
texinfo | [] [] [] [] [] [] | sharutils | [] [] [] [] [] |
textutils | [] [] [] [] [] [] [] [] | silky | () [] () () |
util-linux | [] [] | skencil | [] |
wdiff | [] [] [] | sketch | [] |
wget | [] [] [] [] [] [] [] [] [] [] | soundtracker | [] [] |
+----------------------------------------------------+ sp | [] () |
bg cs da de el en eo es et fi fr gl he hr id it ja tar | [] [] [] [] [] [] [] [] [] |
0 14 24 32 11 1 8 23 13 1 33 22 4 0 7 9 18 texinfo | [] [] [] [] |
textutils | [] [] [] [] [] [] |
tin | [] () |
tp-robot | [] |
tuxpaint | [] [] [] [] [] [] [] [] [] |
unicode-han-tra... | |
unicode-transla... | [] [] |
util-linux | [] [] [] [] () [] |
vorbis-tools | [] |
wastesedge | () |
wdiff | [] [] [] [] [] [] |
wget | [] [] [] [] [] [] [] |
xchat | [] [] [] |
xfree86_xkb_xml | [] [] |
xpad | [] [] |
+-------------------------------------------------+
et eu fa fi fr ga gl he hr hu id is it ja ko lg
22 2 1 26 106 28 24 8 10 41 33 1 26 33 12 0
ko lv nb nl nn no pl pt pt_BR ru sk sl sv tr uk zh lt lv mk mn ms mt nb nl nn no nso pl pt pt_BR ro ru
+----------------------------------------------------+ +-----------------------------------------------------+
a2ps | [] [] [] | 6 a2ps | [] [] () () [] [] [] |
bash | | 4 aegis | () () () |
bfd | | 0 ant-phone | [] [] |
binutils | | 1 anubis | [] [] [] [] [] [] |
bison | [] | 6 ap-utils | [] () [] |
clisp | [] | 5 aspell | [] |
cpio | [] [] [] [] [] | 10 bash | [] [] [] |
diffutils | [] [] [] [] | 11 batchelor | [] |
enscript | [] [] [] | 5 bfd | [] |
error | [] [] | 4 binutils | [] |
fetchmail | | 0 bison | [] [] [] [] [] |
fileutils | [] [] [] [] [] [] [] [] [] | 17 bluez-pin | [] [] [] |
findutils | [] [] [] [] [] [] [] [] | 16 clisp | |
flex | [] [] [] | 6 clisp | [] |
freetype | | 0 console-tools | [] |
gas | | 0 coreutils | [] [] |
gawk | [] | 3 cpio | [] [] [] [] [] |
gcal | | 0 darkstat | [] [] [] [] |
gcc | | 0 diffutils | [] [] [] [] [] [] |
gettext | [] [] [] [] [] [] [] [] | 18 e2fsprogs | [] |
gnupg | [] [] [] | 10 enscript | [] [] [] [] |
gprof | | 0 error | [] [] [] |
grep | [] [] [] [] | 12 fetchmail | [] [] () [] |
hello | [] [] [] [] [] [] [] [] [] [] [] | 22 fileutils | [] [] [] |
id-utils | [] [] [] | 6 findutils | [] [] [] [] [] |
indent | [] [] [] [] [] [] [] | 12 flex | [] [] [] [] |
jpilot | | 1 fslint | [] [] |
kbd | [] | 1 gas | |
ld | | 1 gawk | [] [] [] |
libc | [] [] [] [] [] [] [] [] | 16 gbiff | [] [] |
lilypond | [] [] | 3 gcal | |
lynx | [] [] [] [] | 8 gcc | |
m4 | [] [] [] [] | 12 gettext | [] [] [] |
make | [] [] [] [] [] [] | 12 gettext-examples | [] [] [] |
mysecretdiary | | 1 gettext-runtime | [] [] [] [] |
nano | [] | 4 gettext-tools | [] [] |
opcodes | [] | 1 gimp-print | [] |
parted | [] [] | 5 gliv | [] [] [] |
ptx | [] [] [] [] [] [] [] [] | 15 glunarclock | [] [] [] [] |
gnubiff | [] |
gnucash | [] [] () [] |
gnucash-glossary | [] [] |
gnupg | [] |
gpe-aerial | [] [] [] [] |
gpe-beam | [] [] [] [] |
gpe-calendar | [] [] [] [] |
gpe-clock | [] [] [] [] |
gpe-conf | [] [] [] [] |
gpe-contacts | [] [] [] [] |
gpe-edit | [] [] [] [] |
gpe-go | [] [] [] |
gpe-login | [] [] [] [] |
gpe-ownerinfo | [] [] [] [] |
gpe-sketchbook | [] [] [] [] |
gpe-su | [] [] [] [] |
gpe-taskmanager | [] [] [] [] |
gpe-timesheet | [] [] [] [] |
gpe-today | [] [] [] [] |
gpe-todo | [] [] [] [] |
gphoto2 | [] |
gprof | [] [] |
gpsdrive | () () [] |
gramadoir | () [] |
grep | [] [] [] [] [] |
gretl | |
gtick | [] [] [] |
hello | [] [] [] [] [] [] [] [] [] [] |
id-utils | [] [] [] [] |
indent | [] [] [] [] |
iso_3166 | [] [] [] |
iso_3166_1 | [] [] |
iso_3166_2 | |
iso_3166_3 | [] |
iso_4217 | [] [] [] [] [] [] [] [] |
iso_639 | [] |
jpilot | () () |
jtag | |
jwhois | [] [] [] [] () |
kbd | [] [] [] |
latrine | [] |
ld | |
libc | [] [] [] [] |
libgpewidget | [] [] [] |
libiconv | [] [] [] [] [] |
lifelines | |
lilypond | |
lingoteach | |
lingoteach_lessons | |
lynx | [] [] [] |
m4 | [] [] [] [] [] |
mailutils | [] [] [] |
make | [] [] [] [] |
man-db | [] |
minicom | [] [] [] [] |
mysecretdiary | [] [] [] |
nano | [] [] [] [] [] |
nano_1_0 | [] [] [] [] [] [] |
opcodes | [] [] |
parted | [] [] [] [] |
ptx | [] [] [] [] [] [] [] [] |
python | |
radius | [] [] |
recode | [] [] [] [] |
rpm | [] [] [] |
screem | |
scrollkeeper | [] [] [] [] [] |
sed | [] [] [] |
sh-utils | [] [] |
shared-mime-info | [] [] |
sharutils | [] [] |
silky | () |
skencil | [] [] |
sketch | [] [] |
soundtracker | |
sp | |
tar | [] [] [] [] [] [] |
texinfo | [] [] [] [] |
textutils | [] [] |
tin | |
tp-robot | [] |
tuxpaint | [] [] [] [] [] [] [] [] |
unicode-han-tra... | |
unicode-transla... | |
util-linux | [] [] [] |
vorbis-tools | [] [] [] |
wastesedge | |
wdiff | [] [] [] [] [] |
wget | [] [] [] |
xchat | [] [] [] |
xfree86_xkb_xml | [] [] |
xpad | [] [] |
+-----------------------------------------------------+
lt lv mk mn ms mt nb nl nn no nso pl pt pt_BR ro ru
1 2 0 3 12 0 10 69 6 7 1 40 26 36 76 63
sk sl sr sv ta th tr uk ven vi wa xh zh_CN zh_TW zu
+-----------------------------------------------------+
a2ps | [] [] [] [] | 16
aegis | | 0
ant-phone | | 3
anubis | [] [] | 9
ap-utils | () | 3
aspell | | 4
bash | | 9
batchelor | | 3
bfd | [] [] | 6
binutils | [] [] [] | 8
bison | [] [] | 14
bluez-pin | [] [] [] | 14
clisp | | 0
clisp | | 5
console-tools | | 3
coreutils | [] [] [] [] | 16
cpio | [] [] | 14
darkstat | [] [] [] () () | 12
diffutils | [] [] [] | 23
e2fsprogs | [] [] | 6
enscript | [] [] | 12
error | [] [] [] | 15
fetchmail | [] [] | 11
fileutils | [] [] [] [] [] | 17
findutils | [] [] [] [] [] [] | 29
flex | [] [] | 13
fslint | | 3
gas | [] | 3
gawk | [] [] | 12
gbiff | | 4
gcal | [] [] | 4
gcc | [] | 4
gettext | [] [] [] [] [] | 16
gettext-examples | [] [] [] [] [] | 14
gettext-runtime | [] [] [] [] [] [] [] [] | 22
gettext-tools | [] [] [] [] [] [] | 14
gimp-print | [] [] | 10
gliv | | 3
glunarclock | [] [] [] | 13
gnubiff | | 3
gnucash | [] [] | 9
gnucash-glossary | [] [] [] | 8
gnupg | [] [] [] [] | 17
gpe-aerial | [] | 7
gpe-beam | [] | 8
gpe-calendar | [] [] [] [] | 13
gpe-clock | [] [] [] | 10
gpe-conf | [] [] | 9
gpe-contacts | [] [] [] | 11
gpe-edit | [] [] [] [] [] | 12
gpe-go | | 5
gpe-login | [] [] [] [] [] | 13
gpe-ownerinfo | [] [] [] [] | 13
gpe-sketchbook | [] [] | 9
gpe-su | [] [] [] | 10
gpe-taskmanager | [] [] [] | 10
gpe-timesheet | [] [] [] [] | 12
gpe-today | [] [] [] [] [] | 13
gpe-todo | [] [] [] [] | 12
gphoto2 | [] [] [] | 11
gprof | [] [] | 9
gpsdrive | [] [] | 3
gramadoir | [] | 5
grep | [] [] [] [] | 26
gretl | | 3
gtick | | 7
hello | [] [] [] [] [] | 34
id-utils | [] [] | 12
indent | [] [] [] [] | 21
iso_3166 | [] [] [] [] [] [] [] | 27
iso_3166_1 | [] [] [] | 16
iso_3166_2 | | 0
iso_3166_3 | | 2
iso_4217 | [] [] [] [] [] [] | 24
iso_639 | | 1
jpilot | [] [] [] [] [] | 9
jtag | [] | 2
jwhois | () [] [] | 11
kbd | [] [] | 11
latrine | | 2
ld | [] [] | 5
libc | [] [] [] [] | 20
libgpewidget | [] [] [] [] | 13
libiconv | [] [] [] [] [] [] [] [] | 27
lifelines | [] | 2
lilypond | [] | 3
lingoteach | | 2
lingoteach_lessons | () | 0
lynx | [] [] [] | 14
m4 | [] [] | 15
mailutils | | 5
make | [] [] [] | 16
man-db | [] | 5
minicom | | 11
mysecretdiary | [] [] | 10
nano | [] [] [] [] | 17
nano_1_0 | [] [] [] | 17
opcodes | [] [] | 6
parted | [] [] [] | 15
ptx | [] [] | 22
python | | 0 python | | 0
recode | [] [] [] [] | 13 radius | | 4
sed | [] [] [] [] [] [] [] | 19 recode | [] [] [] | 20
sh-utils | [] [] [] [] [] [] [] [] [] [] [] | 21 rpm | [] [] | 9
sharutils | [] [] [] | 11 screem | [] [] | 2
sketch | | 0 scrollkeeper | [] [] [] | 15
soundtracker | | 3 sed | [] [] [] [] [] [] | 24
sp | | 0 sh-utils | [] [] | 14
tar | [] [] [] [] [] [] [] | 15 shared-mime-info | [] [] | 7
texinfo | [] | 7 sharutils | [] [] [] [] | 17
textutils | [] [] [] [] [] [] [] [] | 16 silky | () | 3
util-linux | [] [] | 4 skencil | [] | 6
wdiff | [] [] [] [] | 7 sketch | [] | 6
wget | [] [] [] [] [] [] [] | 17 soundtracker | [] [] | 7
+----------------------------------------------------+ sp | [] | 3
33 teams ko lv nb nl nn no pl pt pt_BR ru sk sl sv tr uk zh tar | [] [] [] [] [] | 24
53 domains 9 1 6 20 0 6 17 1 13 25 10 11 23 21 2 2 387 texinfo | [] [] [] | 14
textutils | [] [] [] [] | 16
tin | | 1
tp-robot | | 2
tuxpaint | [] [] [] [] [] | 29
unicode-han-tra... | | 0
unicode-transla... | | 2
util-linux | [] [] | 15
vorbis-tools | | 8
wastesedge | | 0
wdiff | [] [] [] | 18
wget | [] [] [] [] [] [] [] [] | 24
xchat | [] [] [] [] [] | 15
xfree86_xkb_xml | [] [] [] [] [] | 11
xpad | | 5
+-----------------------------------------------------+
63 teams sk sl sr sv ta th tr uk ven vi wa xh zh_CN zh_TW zu
131 domains 47 19 28 83 0 0 59 13 1 1 11 0 22 22 0 1373
Some counters in the preceding matrix are higher than the number of Some counters in the preceding matrix are higher than the number of
visible blocks let us expect. This is because a few extra PO files are visible blocks let us expect. This is because a few extra PO files are
@ -298,9 +743,9 @@ distributed as such by its maintainer. There might be an observable
lag between the mere existence a PO file and its wide availability in a lag between the mere existence a PO file and its wide availability in a
distribution. distribution.
If September 2001 seems to be old, you may fetch a more recent copy If January 2004 seems to be old, you may fetch a more recent copy of
of this `ABOUT-NLS' file on most GNU archive sites. The most this `ABOUT-NLS' file on most GNU archive sites. The most up-to-date
up-to-date matrix with full percentage details can be found at matrix with full percentage details can be found at
`http://www.iro.umontreal.ca/contrib/po/HTML/matrix.html'. `http://www.iro.umontreal.ca/contrib/po/HTML/matrix.html'.
Using `gettext' in new packages Using `gettext' in new packages
@ -315,7 +760,7 @@ library, whereas only free software can use `libintl' as a static
library or use modified versions of `libintl'. library or use modified versions of `libintl'.
Once the sources are changed appropriately and the setup can handle Once the sources are changed appropriately and the setup can handle
to use of `gettext' the only thing missing are the translations. The the use of `gettext' the only thing missing are the translations. The
Free Translation Project is also available for packages which are not Free Translation Project is also available for packages which are not
developed inside the GNU project. Therefore the information given above developed inside the GNU project. Therefore the information given above
applies also for every other Free Software Project. Contact applies also for every other Free Software Project. Contact

View File

@ -1,13 +1,4 @@
2003-04-29 David Shaw <dshaw@jabberwocky.com> 2004-01-29 GNU <bug-gnu-gettext@gnu.org>
* gettextP.h: Add comment for HP/UX users. Local fix for GnuPG. * Version 0.14.1 released.
2003-03-23 David Shaw <dshaw@jabberwocky.com>
* dcigettext.c (plural_lookup): Name conflict on some platforms
with "index". Local fix for GnuPG.
2001-09-13 GNU <bug-gnu-utils@gnu.org>
* Version 0.10.40 released.

View File

@ -1,5 +1,5 @@
# Makefile for directory with message catalog handling in GNU NLS Utilities. # Makefile for directory with message catalog handling library of GNU gettext
# Copyright (C) 1995-1998, 2000, 2001 Free Software Foundation, Inc. # Copyright (C) 1995-1998, 2000-2003 Free Software Foundation, Inc.
# #
# This program is free software; you can redistribute it and/or modify it # This program is free software; you can redistribute it and/or modify it
# under the terms of the GNU Library General Public License as published # under the terms of the GNU Library General Public License as published
@ -24,7 +24,7 @@ SHELL = /bin/sh
srcdir = @srcdir@ srcdir = @srcdir@
top_srcdir = @top_srcdir@ top_srcdir = @top_srcdir@
top_builddir = .. top_builddir = ..
VPATH = @srcdir@ VPATH = $(srcdir)
prefix = @prefix@ prefix = @prefix@
exec_prefix = @exec_prefix@ exec_prefix = @exec_prefix@
@ -40,7 +40,7 @@ subdir = intl
INSTALL = @INSTALL@ INSTALL = @INSTALL@
INSTALL_DATA = @INSTALL_DATA@ INSTALL_DATA = @INSTALL_DATA@
MKINSTALLDIRS = @MKINSTALLDIRS@ MKINSTALLDIRS = @MKINSTALLDIRS@
mkinstalldirs = $(SHELL) `case "$(MKINSTALLDIRS)" in /*) echo "$(MKINSTALLDIRS)" ;; *) echo "$(top_builddir)/$(MKINSTALLDIRS)" ;; esac` mkinstalldirs = $(SHELL) $(MKINSTALLDIRS)
l = @INTL_LIBTOOL_SUFFIX_PREFIX@ l = @INTL_LIBTOOL_SUFFIX_PREFIX@
@ -52,57 +52,91 @@ YACC = @INTLBISON@ -y -d
YFLAGS = --name-prefix=__gettext YFLAGS = --name-prefix=__gettext
DEFS = -DLOCALEDIR=\"$(localedir)\" -DLOCALE_ALIAS_PATH=\"$(aliaspath)\" \ DEFS = -DLOCALEDIR=\"$(localedir)\" -DLOCALE_ALIAS_PATH=\"$(aliaspath)\" \
-DLIBDIR=\"$(libdir)\" @DEFS@ -DLIBDIR=\"$(libdir)\" -DIN_LIBINTL \
-DENABLE_RELOCATABLE=1 -DIN_LIBRARY -DINSTALLDIR=\"$(libdir)\" -DNO_XMALLOC \
-Dset_relocation_prefix=libintl_set_relocation_prefix \
-Drelocate=libintl_relocate \
-DDEPENDS_ON_LIBICONV=1 @DEFS@
CPPFLAGS = @CPPFLAGS@ CPPFLAGS = @CPPFLAGS@
CFLAGS = @CFLAGS@ CFLAGS = @CFLAGS@
LDFLAGS = @LDFLAGS@ LDFLAGS = @LDFLAGS@
LIBS = @LIBS@
COMPILE = $(CC) -c $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) $(XCFLAGS) COMPILE = $(CC) -c $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) $(XCFLAGS)
HEADERS = $(COMHDRS) libgnuintl.h libgettext.h loadinfo.h HEADERS = \
COMHDRS = gettext.h gettextP.h hash-string.h gmo.h \
SOURCES = $(COMSRCS) intl-compat.c gettextP.h \
COMSRCS = bindtextdom.c dcgettext.c dgettext.c gettext.c \ hash-string.h \
finddomain.c loadmsgcat.c localealias.c textdomain.c l10nflist.c \ loadinfo.h \
explodename.c dcigettext.c dcngettext.c dngettext.c ngettext.c plural.y \ plural-exp.h \
localcharset.c eval-plural.h \
OBJECTS = @INTLOBJS@ bindtextdom.$lo dcgettext.$lo dgettext.$lo gettext.$lo \ localcharset.h \
finddomain.$lo loadmsgcat.$lo localealias.$lo textdomain.$lo l10nflist.$lo \ relocatable.h \
explodename.$lo dcigettext.$lo dcngettext.$lo dngettext.$lo ngettext.$lo \ xsize.h \
plural.$lo localcharset.$lo printf-args.h printf-args.c \
GETTOBJS = intl-compat.$lo printf-parse.h wprintf-parse.h printf-parse.c \
vasnprintf.h vasnwprintf.h vasnprintf.c \
os2compat.h \
libgnuintl.h.in
SOURCES = \
bindtextdom.c \
dcgettext.c \
dgettext.c \
gettext.c \
finddomain.c \
loadmsgcat.c \
localealias.c \
textdomain.c \
l10nflist.c \
explodename.c \
dcigettext.c \
dcngettext.c \
dngettext.c \
ngettext.c \
plural.y \
plural-exp.c \
localcharset.c \
relocatable.c \
localename.c \
log.c \
printf.c \
osdep.c \
os2compat.c \
intl-compat.c
OBJECTS = \
bindtextdom.$lo \
dcgettext.$lo \
dgettext.$lo \
gettext.$lo \
finddomain.$lo \
loadmsgcat.$lo \
localealias.$lo \
textdomain.$lo \
l10nflist.$lo \
explodename.$lo \
dcigettext.$lo \
dcngettext.$lo \
dngettext.$lo \
ngettext.$lo \
plural.$lo \
plural-exp.$lo \
localcharset.$lo \
relocatable.$lo \
localename.$lo \
log.$lo \
printf.$lo \
osdep.$lo \
intl-compat.$lo
DISTFILES.common = Makefile.in \ DISTFILES.common = Makefile.in \
config.charset locale.alias ref-add.sin ref-del.sin $(HEADERS) $(SOURCES) config.charset locale.alias ref-add.sin ref-del.sin $(HEADERS) $(SOURCES)
DISTFILES.generated = plural.c DISTFILES.generated = plural.c
DISTFILES.normal = VERSION DISTFILES.normal = VERSION
DISTFILES.gettext = COPYING.LIB-2 COPYING.LIB-2.1 libintl.glibc DISTFILES.gettext = COPYING.LIB-2.0 COPYING.LIB-2.1 libintl.glibc \
DISTFILES.obsolete = xopen-msg.sed linux-msg.sed po2tbl.sed.in cat-compat.c libgnuintl.h_vms Makefile.vms \
libgnuintl.h.msvc-static libgnuintl.h.msvc-shared README.woe32 Makefile.msvc
# Libtool's library version information for libintl. DISTFILES.obsolete = xopen-msg.sed linux-msg.sed po2tbl.sed.in cat-compat.c \
# Before making a gettext release, the gettext maintainer must change this COPYING.LIB-2 gettext.h libgettext.h plural-eval.c libgnuintl.h
# according to the libtool documentation, section "Library interface versions".
# Maintainers of other packages that include the intl directory must *not*
# change these values.
LTV_CURRENT=1
LTV_REVISION=1
LTV_AGE=0
.SUFFIXES:
.SUFFIXES: .c .y .o .lo .sin .sed
.c.o:
$(COMPILE) $<
.c.lo:
$(LIBTOOL) --mode=compile $(COMPILE) $<
.y.c:
$(YACC) $(YFLAGS) --output $@ $<
rm -f $*.h
.sin.sed:
sed -e '/^#/d' -e 's/@''PACKAGE''@/@PACKAGE@/g' $< > t-$@
mv t-$@ $@
INCLUDES = -I.. -I. -I$(top_srcdir)/intl
all: all-@USE_INCLUDED_LIBINTL@ all: all-@USE_INCLUDED_LIBINTL@
all-yes: libintl.$la libintl.h charset.alias ref-add.sed ref-del.sed all-yes: libintl.$la libintl.h charset.alias ref-add.sed ref-del.sed
@ -118,23 +152,102 @@ libintl.a libgnuintl.a: $(OBJECTS)
libintl.la libgnuintl.la: $(OBJECTS) libintl.la libgnuintl.la: $(OBJECTS)
$(LIBTOOL) --mode=link \ $(LIBTOOL) --mode=link \
$(CC) $(CPPFLAGS) $(CFLAGS) $(XCFLAGS) $(LDFLAGS) -o $@ \ $(CC) $(CPPFLAGS) $(CFLAGS) $(XCFLAGS) $(LDFLAGS) -o $@ \
$(OBJECTS) @LIBICONV@ \ $(OBJECTS) @LTLIBICONV@ $(LIBS) -lc \
-version-info $(LTV_CURRENT):$(LTV_REVISION):$(LTV_AGE) \ -version-info $(LTV_CURRENT):$(LTV_REVISION):$(LTV_AGE) \
-rpath $(libdir) \ -rpath $(libdir) \
-no-undefined -no-undefined
libintl.h: libgnuintl.h # Libtool's library version information for libintl.
cp $(srcdir)/libgnuintl.h libintl.h # Before making a gettext release, the gettext maintainer must change this
# according to the libtool documentation, section "Library interface versions".
# Maintainers of other packages that include the intl directory must *not*
# change these values.
LTV_CURRENT=7
LTV_REVISION=0
LTV_AGE=4
charset.alias: config.charset .SUFFIXES:
.SUFFIXES: .c .y .o .lo .sin .sed
.c.o:
$(COMPILE) $<
.y.c:
$(YACC) $(YFLAGS) --output $@ $<
rm -f $*.h
bindtextdom.lo: $(srcdir)/bindtextdom.c
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/bindtextdom.c
dcgettext.lo: $(srcdir)/dcgettext.c
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/dcgettext.c
dgettext.lo: $(srcdir)/dgettext.c
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/dgettext.c
gettext.lo: $(srcdir)/gettext.c
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/gettext.c
finddomain.lo: $(srcdir)/finddomain.c
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/finddomain.c
loadmsgcat.lo: $(srcdir)/loadmsgcat.c
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/loadmsgcat.c
localealias.lo: $(srcdir)/localealias.c
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/localealias.c
textdomain.lo: $(srcdir)/textdomain.c
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/textdomain.c
l10nflist.lo: $(srcdir)/l10nflist.c
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/l10nflist.c
explodename.lo: $(srcdir)/explodename.c
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/explodename.c
dcigettext.lo: $(srcdir)/dcigettext.c
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/dcigettext.c
dcngettext.lo: $(srcdir)/dcngettext.c
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/dcngettext.c
dngettext.lo: $(srcdir)/dngettext.c
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/dngettext.c
ngettext.lo: $(srcdir)/ngettext.c
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/ngettext.c
plural.lo: $(srcdir)/plural.c
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/plural.c
plural-exp.lo: $(srcdir)/plural-exp.c
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/plural-exp.c
localcharset.lo: $(srcdir)/localcharset.c
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/localcharset.c
relocatable.lo: $(srcdir)/relocatable.c
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/relocatable.c
localename.lo: $(srcdir)/localename.c
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/localename.c
log.lo: $(srcdir)/log.c
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/log.c
printf.lo: $(srcdir)/printf.c
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/printf.c
osdep.lo: $(srcdir)/osdep.c
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/osdep.c
intl-compat.lo: $(srcdir)/intl-compat.c
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/intl-compat.c
ref-add.sed: $(srcdir)/ref-add.sin
sed -e '/^#/d' -e 's/@''PACKAGE''@/@PACKAGE@/g' $(srcdir)/ref-add.sin > t-ref-add.sed
mv t-ref-add.sed ref-add.sed
ref-del.sed: $(srcdir)/ref-del.sin
sed -e '/^#/d' -e 's/@''PACKAGE''@/@PACKAGE@/g' $(srcdir)/ref-del.sin > t-ref-del.sed
mv t-ref-del.sed ref-del.sed
INCLUDES = -I. -I$(srcdir) -I..
libgnuintl.h: $(srcdir)/libgnuintl.h.in
sed -e 's,@''HAVE_POSIX_PRINTF''@,@HAVE_POSIX_PRINTF@,g' \
-e 's,@''HAVE_ASPRINTF''@,@HAVE_ASPRINTF@,g' \
-e 's,@''HAVE_SNPRINTF''@,@HAVE_SNPRINTF@,g' \
-e 's,@''HAVE_WPRINTF''@,@HAVE_WPRINTF@,g' \
< $(srcdir)/libgnuintl.h.in > libgnuintl.h
libintl.h: libgnuintl.h
cp libgnuintl.h libintl.h
charset.alias: $(srcdir)/config.charset
$(SHELL) $(srcdir)/config.charset '@host@' > t-$@ $(SHELL) $(srcdir)/config.charset '@host@' > t-$@
mv t-$@ $@ mv t-$@ $@
check: all check: all
# This installation goal is only used in GNU gettext. Packages which
# only use the library should use install instead.
# We must not install the libintl.h/libintl.a files if we are on a # We must not install the libintl.h/libintl.a files if we are on a
# system which has the GNU gettext() function in its C library or in a # system which has the GNU gettext() function in its C library or in a
# separate library. # separate library.
@ -142,17 +255,35 @@ check: all
# package, you have to use `configure --with-included-gettext'. # package, you have to use `configure --with-included-gettext'.
install: install-exec install-data install: install-exec install-data
install-exec: all install-exec: all
if test "$(PACKAGE)" = "gettext" \ if { test "$(PACKAGE)" = "gettext-runtime" || test "$(PACKAGE)" = "gettext-tools"; } \
&& test '@INTLOBJS@' = '$(GETTOBJS)'; then \ && test '@USE_INCLUDED_LIBINTL@' = yes; then \
$(mkinstalldirs) $(DESTDIR)$(libdir) $(DESTDIR)$(includedir); \ $(mkinstalldirs) $(DESTDIR)$(libdir) $(DESTDIR)$(includedir); \
$(INSTALL_DATA) libintl.h $(DESTDIR)$(includedir)/libintl.h; \ $(INSTALL_DATA) libintl.h $(DESTDIR)$(includedir)/libintl.h; \
$(LIBTOOL) --mode=install \ $(LIBTOOL) --mode=install \
$(INSTALL_DATA) libintl.$la $(DESTDIR)$(libdir)/libintl.$la; \ $(INSTALL_DATA) libintl.$la $(DESTDIR)$(libdir)/libintl.$la; \
if test "@RELOCATABLE@" = yes; then \
dependencies=`sed -n -e 's,^dependency_libs=\(.*\),\1,p' < $(DESTDIR)$(libdir)/libintl.la | sed -e "s,^',," -e "s,'\$$,,"`; \
if test -n "$$dependencies"; then \
rm -f $(DESTDIR)$(libdir)/libintl.la; \
fi; \
fi; \
else \
: ; \
fi
if test "$(PACKAGE)" = "gettext-tools" \
&& test '@USE_INCLUDED_LIBINTL@' = no; then \
$(mkinstalldirs) $(DESTDIR)$(libdir); \
$(LIBTOOL) --mode=install \
$(INSTALL_DATA) libgnuintl.$la $(DESTDIR)$(libdir)/libgnuintl.$la; \
rm -f $(DESTDIR)$(libdir)/preloadable_libintl.so; \
$(INSTALL_DATA) $(DESTDIR)$(libdir)/libgnuintl.so $(DESTDIR)$(libdir)/preloadable_libintl.so; \
$(LIBTOOL) --mode=uninstall \
rm -f $(DESTDIR)$(libdir)/libgnuintl.$la; \
else \ else \
: ; \ : ; \
fi fi
if test '@USE_INCLUDED_LIBINTL@' = yes; then \ if test '@USE_INCLUDED_LIBINTL@' = yes; then \
$(mkinstalldirs) $(DESTDIR)$(libdir); \ test @GLIBC21@ != no || $(mkinstalldirs) $(DESTDIR)$(libdir); \
temp=$(DESTDIR)$(libdir)/t-charset.alias; \ temp=$(DESTDIR)$(libdir)/t-charset.alias; \
dest=$(DESTDIR)$(libdir)/charset.alias; \ dest=$(DESTDIR)$(libdir)/charset.alias; \
if test -f $(DESTDIR)$(libdir)/charset.alias; then \ if test -f $(DESTDIR)$(libdir)/charset.alias; then \
@ -181,11 +312,11 @@ install-exec: all
: ; \ : ; \
fi fi
install-data: all install-data: all
if test "$(PACKAGE)" = "gettext"; then \ if test "$(PACKAGE)" = "gettext-tools"; then \
$(mkinstalldirs) $(DESTDIR)$(gettextsrcdir); \ $(mkinstalldirs) $(DESTDIR)$(gettextsrcdir); \
$(INSTALL_DATA) VERSION $(DESTDIR)$(gettextsrcdir)/VERSION; \ $(INSTALL_DATA) VERSION $(DESTDIR)$(gettextsrcdir)/VERSION; \
$(INSTALL_DATA) ChangeLog.inst $(DESTDIR)$(gettextsrcdir)/ChangeLog; \ $(INSTALL_DATA) ChangeLog.inst $(DESTDIR)$(gettextsrcdir)/ChangeLog; \
dists="COPYING.LIB-2 COPYING.LIB-2.1 $(DISTFILES.common)"; \ dists="COPYING.LIB-2.0 COPYING.LIB-2.1 $(DISTFILES.common)"; \
for file in $$dists; do \ for file in $$dists; do \
$(INSTALL_DATA) $(srcdir)/$$file \ $(INSTALL_DATA) $(srcdir)/$$file \
$(DESTDIR)$(gettextsrcdir)/$$file; \ $(DESTDIR)$(gettextsrcdir)/$$file; \
@ -205,18 +336,51 @@ install-data: all
: ; \ : ; \
fi fi
install-strip: install
installdirs:
if { test "$(PACKAGE)" = "gettext-runtime" || test "$(PACKAGE)" = "gettext-tools"; } \
&& test '@USE_INCLUDED_LIBINTL@' = yes; then \
$(mkinstalldirs) $(DESTDIR)$(libdir) $(DESTDIR)$(includedir); \
else \
: ; \
fi
if test "$(PACKAGE)" = "gettext-tools" \
&& test '@USE_INCLUDED_LIBINTL@' = no; then \
$(mkinstalldirs) $(DESTDIR)$(libdir); \
else \
: ; \
fi
if test '@USE_INCLUDED_LIBINTL@' = yes; then \
test @GLIBC21@ != no || $(mkinstalldirs) $(DESTDIR)$(libdir); \
$(mkinstalldirs) $(DESTDIR)$(localedir); \
else \
: ; \
fi
if test "$(PACKAGE)" = "gettext-tools"; then \
$(mkinstalldirs) $(DESTDIR)$(gettextsrcdir); \
else \
: ; \
fi
# Define this as empty until I found a useful application. # Define this as empty until I found a useful application.
installcheck: installcheck:
uninstall: uninstall:
if test "$(PACKAGE)" = "gettext" \ if { test "$(PACKAGE)" = "gettext-runtime" || test "$(PACKAGE)" = "gettext-tools"; } \
&& test '@INTLOBJS@' = '$(GETTOBJS)'; then \ && test '@USE_INCLUDED_LIBINTL@' = yes; then \
rm -f $(DESTDIR)$(includedir)/libintl.h; \ rm -f $(DESTDIR)$(includedir)/libintl.h; \
$(LIBTOOL) --mode=uninstall \ $(LIBTOOL) --mode=uninstall \
rm -f $(DESTDIR)$(libdir)/libintl.$la; \ rm -f $(DESTDIR)$(libdir)/libintl.$la; \
else \ else \
: ; \ : ; \
fi fi
if test "$(PACKAGE)" = "gettext-tools" \
&& test '@USE_INCLUDED_LIBINTL@' = no; then \
rm -f $(DESTDIR)$(libdir)/preloadable_libintl.so; \
else \
: ; \
fi
if test '@USE_INCLUDED_LIBINTL@' = yes; then \ if test '@USE_INCLUDED_LIBINTL@' = yes; then \
if test -f $(DESTDIR)$(libdir)/charset.alias; then \ if test -f $(DESTDIR)$(libdir)/charset.alias; then \
temp=$(DESTDIR)$(libdir)/t-charset.alias; \ temp=$(DESTDIR)$(libdir)/t-charset.alias; \
@ -243,25 +407,36 @@ uninstall:
else \ else \
: ; \ : ; \
fi fi
if test "$(PACKAGE)" = "gettext"; then \ if test "$(PACKAGE)" = "gettext-tools"; then \
for file in VERSION ChangeLog COPYING.LIB-2 COPYING.LIB-2.1 $(DISTFILES.common) $(DISTFILES.generated); do \ for file in VERSION ChangeLog COPYING.LIB-2.0 COPYING.LIB-2.1 $(DISTFILES.common) $(DISTFILES.generated); do \
rm -f $(DESTDIR)$(gettextsrcdir)/$$file; \ rm -f $(DESTDIR)$(gettextsrcdir)/$$file; \
done; \ done; \
else \ else \
: ; \ : ; \
fi fi
info dvi: info dvi ps pdf html:
$(OBJECTS): ../config.h libgnuintl.h $(OBJECTS): ../config.h libgnuintl.h
bindtextdom.$lo finddomain.$lo loadmsgcat.$lo: gettextP.h gettext.h loadinfo.h 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
dcgettext.$lo: gettextP.h gettext.h hash-string.h loadinfo.h dcigettext.$lo loadmsgcat.$lo: $(srcdir)/hash-string.h
explodename.$lo l10nflist.$lo: $(srcdir)/loadinfo.h
dcigettext.$lo loadmsgcat.$lo plural.$lo plural-exp.$lo: $(srcdir)/plural-exp.h
dcigettext.$lo: $(srcdir)/eval-plural.h
localcharset.$lo: $(srcdir)/localcharset.h
localealias.$lo localcharset.$lo relocatable.$lo: $(srcdir)/relocatable.h
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
tags: TAGS tags: TAGS
TAGS: $(HEADERS) $(SOURCES) TAGS: $(HEADERS) $(SOURCES)
here=`pwd`; cd $(srcdir) && etags -o $$here/TAGS $(HEADERS) $(SOURCES) here=`pwd`; cd $(srcdir) && etags -o $$here/TAGS $(HEADERS) $(SOURCES)
ctags: CTAGS
CTAGS: $(HEADERS) $(SOURCES)
here=`pwd`; cd $(srcdir) && ctags -o $$here/CTAGS $(HEADERS) $(SOURCES)
id: ID id: ID
ID: $(HEADERS) $(SOURCES) ID: $(HEADERS) $(SOURCES)
@ -269,15 +444,15 @@ ID: $(HEADERS) $(SOURCES)
mostlyclean: mostlyclean:
rm -f *.a *.la *.o *.lo core core.* rm -f *.a *.la *.o *.obj *.lo core core.*
rm -f libintl.h charset.alias ref-add.sed ref-del.sed rm -f libgnuintl.h libintl.h charset.alias ref-add.sed ref-del.sed
rm -f -r .libs _libs rm -f -r .libs _libs
clean: mostlyclean clean: mostlyclean
distclean: clean distclean: clean
rm -f Makefile ID TAGS rm -f Makefile ID TAGS
if test "$(PACKAGE)" = gettext; then \ if test "$(PACKAGE)" = "gettext-runtime" || test "$(PACKAGE)" = "gettext-tools"; then \
rm -f ChangeLog.inst $(DISTFILES.normal); \ rm -f ChangeLog.inst $(DISTFILES.normal); \
else \ else \
: ; \ : ; \
@ -292,7 +467,10 @@ maintainer-clean: distclean
# other files which should not be distributed in other packages. # other files which should not be distributed in other packages.
distdir = ../$(PACKAGE)-$(VERSION)/$(subdir) distdir = ../$(PACKAGE)-$(VERSION)/$(subdir)
dist distdir: Makefile dist distdir: Makefile
if test "$(PACKAGE)" = gettext; then \ if test "$(PACKAGE)" = "gettext-tools"; then \
: ; \
else \
if test "$(PACKAGE)" = "gettext-runtime"; then \
additional="$(DISTFILES.gettext)"; \ additional="$(DISTFILES.gettext)"; \
else \ else \
additional="$(DISTFILES.normal)"; \ additional="$(DISTFILES.normal)"; \
@ -300,13 +478,15 @@ dist distdir: Makefile
$(MAKE) $(DISTFILES.common) $(DISTFILES.generated) $$additional; \ $(MAKE) $(DISTFILES.common) $(DISTFILES.generated) $$additional; \
for file in ChangeLog $(DISTFILES.common) $(DISTFILES.generated) $$additional; do \ for file in ChangeLog $(DISTFILES.common) $(DISTFILES.generated) $$additional; do \
if test -f $$file; then dir=.; else dir=$(srcdir); fi; \ if test -f $$file; then dir=.; else dir=$(srcdir); fi; \
ln $$dir/$$file $(distdir) 2> /dev/null \ cp -p $$dir/$$file $(distdir); \
|| cp -p $$dir/$$file $(distdir); \ done; \
done fi
Makefile: Makefile.in ../config.status Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
cd .. \ cd $(top_builddir) && $(SHELL) ./config.status
&& CONFIG_FILES=$(subdir)/$@ CONFIG_HEADERS= $(SHELL) ./config.status # This would be more efficient, but doesn't work any more with autoconf-2.57,
# when AC_CONFIG_FILES([intl/Makefile:somedir/Makefile.in]) is used.
# cd $(top_builddir) && CONFIG_FILES=$(subdir)/$@ CONFIG_HEADERS= $(SHELL) ./config.status
# Tell versions [3.59,3.63) of GNU make not to export all variables. # Tell versions [3.59,3.63) of GNU make not to export all variables.
# Otherwise a system limit (for SysV at least) may be exceeded. # Otherwise a system limit (for SysV at least) may be exceeded.

View File

@ -1 +1 @@
GNU gettext library from gettext-0.10.40 GNU gettext library from gettext-0.14.1

View File

@ -1,5 +1,5 @@
/* Implementation of the bindtextdomain(3) function /* Implementation of the bindtextdomain(3) function
Copyright (C) 1995-1998, 2000, 2001 Free Software Foundation, Inc. Copyright (C) 1995-1998, 2000-2003 Free Software Foundation, Inc.
This program is free software; you can redistribute it and/or modify it This program is free software; you can redistribute it and/or modify it
under the terms of the GNU Library General Public License as published under the terms of the GNU Library General Public License as published
@ -45,8 +45,8 @@
names than the internal variables in GNU libc, otherwise programs names than the internal variables in GNU libc, otherwise programs
using libintl.a cannot be linked statically. */ using libintl.a cannot be linked statically. */
#if !defined _LIBC #if !defined _LIBC
# define _nl_default_dirname _nl_default_dirname__ # define _nl_default_dirname libintl_nl_default_dirname
# define _nl_domain_bindings _nl_domain_bindings__ # define _nl_domain_bindings libintl_nl_domain_bindings
#endif #endif
/* Some compilers, like SunOS4 cc, don't have offsetof in <stddef.h>. */ /* Some compilers, like SunOS4 cc, don't have offsetof in <stddef.h>. */
@ -58,12 +58,17 @@
/* Contains the default location of the message catalogs. */ /* Contains the default location of the message catalogs. */
extern const char _nl_default_dirname[]; extern const char _nl_default_dirname[];
#ifdef _LIBC
extern const char _nl_default_dirname_internal[] attribute_hidden;
#else
# define INTUSE(name) name
#endif
/* List with bindings of specific domains. */ /* List with bindings of specific domains. */
extern struct binding *_nl_domain_bindings; extern struct binding *_nl_domain_bindings;
/* Lock variable to protect the global data in the gettext implementation. */ /* Lock variable to protect the global data in the gettext implementation. */
__libc_rwlock_define (extern, _nl_state_lock) __libc_rwlock_define (extern, _nl_state_lock attribute_hidden)
/* Names for the libintl functions are a problem. They must not clash /* Names for the libintl functions are a problem. They must not clash
@ -77,15 +82,10 @@ __libc_rwlock_define (extern, _nl_state_lock)
# define strdup(str) __strdup (str) # define strdup(str) __strdup (str)
# endif # endif
#else #else
# define BINDTEXTDOMAIN bindtextdomain__ # define BINDTEXTDOMAIN libintl_bindtextdomain
# define BIND_TEXTDOMAIN_CODESET bind_textdomain_codeset__ # define BIND_TEXTDOMAIN_CODESET libintl_bind_textdomain_codeset
#endif #endif
/* Prototypes for local functions. */
static void set_binding_values PARAMS ((const char *domainname,
const char **dirnamep,
const char **codesetp));
/* Specifies the directory name *DIRNAMEP and the output codeset *CODESETP /* Specifies the directory name *DIRNAMEP and the output codeset *CODESETP
to be used for the DOMAINNAME message catalog. to be used for the DOMAINNAME message catalog.
If *DIRNAMEP or *CODESETP is NULL, the corresponding attribute is not If *DIRNAMEP or *CODESETP is NULL, the corresponding attribute is not
@ -93,10 +93,8 @@ static void set_binding_values PARAMS ((const char *domainname,
If DIRNAMEP or CODESETP is NULL, the corresponding attribute is neither If DIRNAMEP or CODESETP is NULL, the corresponding attribute is neither
modified nor returned. */ modified nor returned. */
static void static void
set_binding_values (domainname, dirnamep, codesetp) set_binding_values (const char *domainname,
const char *domainname; const char **dirnamep, const char **codesetp)
const char **dirnamep;
const char **codesetp;
{ {
struct binding *binding; struct binding *binding;
int modified; int modified;
@ -146,8 +144,8 @@ set_binding_values (domainname, dirnamep, codesetp)
char *result = binding->dirname; char *result = binding->dirname;
if (strcmp (dirname, result) != 0) if (strcmp (dirname, result) != 0)
{ {
if (strcmp (dirname, _nl_default_dirname) == 0) if (strcmp (dirname, INTUSE(_nl_default_dirname)) == 0)
result = (char *) _nl_default_dirname; result = (char *) INTUSE(_nl_default_dirname);
else else
{ {
#if defined _LIBC || defined HAVE_STRDUP #if defined _LIBC || defined HAVE_STRDUP
@ -162,7 +160,7 @@ set_binding_values (domainname, dirnamep, codesetp)
if (__builtin_expect (result != NULL, 1)) if (__builtin_expect (result != NULL, 1))
{ {
if (binding->dirname != _nl_default_dirname) if (binding->dirname != INTUSE(_nl_default_dirname))
free (binding->dirname); free (binding->dirname);
binding->dirname = result; binding->dirname = result;
@ -216,7 +214,7 @@ set_binding_values (domainname, dirnamep, codesetp)
{ {
/* Simply return the default values. */ /* Simply return the default values. */
if (dirnamep) if (dirnamep)
*dirnamep = _nl_default_dirname; *dirnamep = INTUSE(_nl_default_dirname);
if (codesetp) if (codesetp)
*codesetp = NULL; *codesetp = NULL;
} }
@ -238,11 +236,11 @@ set_binding_values (domainname, dirnamep, codesetp)
if (dirname == NULL) if (dirname == NULL)
/* The default value. */ /* The default value. */
dirname = _nl_default_dirname; dirname = INTUSE(_nl_default_dirname);
else else
{ {
if (strcmp (dirname, _nl_default_dirname) == 0) if (strcmp (dirname, INTUSE(_nl_default_dirname)) == 0)
dirname = _nl_default_dirname; dirname = INTUSE(_nl_default_dirname);
else else
{ {
char *result; char *result;
@ -265,7 +263,7 @@ set_binding_values (domainname, dirnamep, codesetp)
} }
else else
/* The default value. */ /* The default value. */
new_binding->dirname = (char *) _nl_default_dirname; new_binding->dirname = (char *) INTUSE(_nl_default_dirname);
new_binding->codeset_cntr = 0; new_binding->codeset_cntr = 0;
@ -321,7 +319,7 @@ set_binding_values (domainname, dirnamep, codesetp)
if (0) if (0)
{ {
failed_codeset: failed_codeset:
if (new_binding->dirname != _nl_default_dirname) if (new_binding->dirname != INTUSE(_nl_default_dirname))
free (new_binding->dirname); free (new_binding->dirname);
failed_dirname: failed_dirname:
free (new_binding); free (new_binding);
@ -343,9 +341,7 @@ set_binding_values (domainname, dirnamep, codesetp)
/* Specify that the DOMAINNAME message catalog will be found /* Specify that the DOMAINNAME message catalog will be found
in DIRNAME rather than in the system locale data base. */ in DIRNAME rather than in the system locale data base. */
char * char *
BINDTEXTDOMAIN (domainname, dirname) BINDTEXTDOMAIN (const char *domainname, const char *dirname)
const char *domainname;
const char *dirname;
{ {
set_binding_values (domainname, &dirname, NULL); set_binding_values (domainname, &dirname, NULL);
return (char *) dirname; return (char *) dirname;
@ -354,9 +350,7 @@ BINDTEXTDOMAIN (domainname, dirname)
/* Specify the character encoding in which the messages from the /* Specify the character encoding in which the messages from the
DOMAINNAME message catalog will be returned. */ DOMAINNAME message catalog will be returned. */
char * char *
BIND_TEXTDOMAIN_CODESET (domainname, codeset) BIND_TEXTDOMAIN_CODESET (const char *domainname, const char *codeset)
const char *domainname;
const char *codeset;
{ {
set_binding_values (domainname, NULL, &codeset); set_binding_values (domainname, NULL, &codeset);
return (char *) codeset; return (char *) codeset;

View File

@ -1,7 +1,7 @@
#! /bin/sh #! /bin/sh
# Output a system dependent table of character encoding aliases. # Output a system dependent table of character encoding aliases.
# #
# Copyright (C) 2000-2001 Free Software Foundation, Inc. # Copyright (C) 2000-2004 Free Software Foundation, Inc.
# #
# This program is free software; you can redistribute it and/or modify it # This program is free software; you can redistribute it and/or modify it
# under the terms of the GNU Library General Public License as published # under the terms of the GNU Library General Public License as published
@ -30,21 +30,23 @@
# MIME charset name is preferred. # MIME charset name is preferred.
# The current list of GNU canonical charset names is as follows. # The current list of GNU canonical charset names is as follows.
# #
# name used by which systems a MIME name? # name MIME? used by which systems
# ASCII, ANSI_X3.4-1968 glibc solaris freebsd # ASCII, ANSI_X3.4-1968 glibc solaris freebsd darwin
# ISO-8859-1 glibc aix hpux irix osf solaris freebsd yes # ISO-8859-1 Y glibc aix hpux irix osf solaris freebsd darwin
# ISO-8859-2 glibc aix hpux irix osf solaris freebsd yes # ISO-8859-2 Y glibc aix hpux irix osf solaris freebsd darwin
# ISO-8859-3 glibc yes # ISO-8859-3 Y glibc solaris
# ISO-8859-4 osf solaris freebsd yes # ISO-8859-4 Y osf solaris freebsd darwin
# ISO-8859-5 glibc aix hpux irix osf solaris freebsd yes # ISO-8859-5 Y glibc aix hpux irix osf solaris freebsd darwin
# ISO-8859-6 glibc aix hpux solaris yes # ISO-8859-6 Y glibc aix hpux solaris
# ISO-8859-7 glibc aix hpux irix osf solaris yes # ISO-8859-7 Y glibc aix hpux irix osf solaris
# ISO-8859-8 glibc aix hpux osf solaris yes # ISO-8859-8 Y glibc aix hpux osf solaris
# ISO-8859-9 glibc aix hpux irix osf solaris yes # ISO-8859-9 Y glibc aix hpux irix osf solaris
# ISO-8859-13 glibc # ISO-8859-13 glibc
# ISO-8859-14 glibc
# ISO-8859-15 glibc aix osf solaris freebsd # ISO-8859-15 glibc aix osf solaris freebsd
# KOI8-R glibc solaris freebsd yes # KOI8-R Y glibc solaris freebsd darwin
# KOI8-U glibc freebsd yes # KOI8-U Y glibc freebsd darwin
# KOI8-T glibc
# CP437 dos # CP437 dos
# CP775 dos # CP775 dos
# CP850 aix osf dos # CP850 aix osf dos
@ -56,37 +58,40 @@
# CP862 dos # CP862 dos
# CP864 dos # CP864 dos
# CP865 dos # CP865 dos
# CP866 freebsd dos # CP866 freebsd darwin dos
# CP869 dos # CP869 dos
# CP874 win32 dos # CP874 woe32 dos
# CP922 aix # CP922 aix
# CP932 aix win32 dos # CP932 aix woe32 dos
# CP943 aix # CP943 aix
# CP949 osf win32 dos # CP949 osf woe32 dos
# CP950 win32 dos # CP950 woe32 dos
# CP1046 aix # CP1046 aix
# CP1124 aix # CP1124 aix
# CP1125 dos
# CP1129 aix # CP1129 aix
# CP1250 win32 # CP1250 woe32
# CP1251 glibc win32 # CP1251 glibc solaris darwin woe32
# CP1252 aix win32 # CP1252 aix woe32
# CP1253 win32 # CP1253 woe32
# CP1254 win32 # CP1254 woe32
# CP1255 win32 # CP1255 glibc woe32
# CP1256 win32 # CP1256 woe32
# CP1257 win32 # CP1257 woe32
# GB2312 glibc aix hpux irix solaris freebsd yes # GB2312 Y glibc aix hpux irix solaris freebsd darwin
# EUC-JP glibc aix hpux irix osf solaris freebsd yes # EUC-JP Y glibc aix hpux irix osf solaris freebsd darwin
# EUC-KR glibc aix hpux irix osf solaris freebsd yes # EUC-KR Y glibc aix hpux irix osf solaris freebsd darwin
# EUC-TW glibc aix hpux irix osf solaris # EUC-TW glibc aix hpux irix osf solaris
# BIG5 glibc aix hpux osf solaris freebsd yes # BIG5 Y glibc aix hpux osf solaris freebsd darwin
# BIG5-HKSCS glibc # BIG5-HKSCS glibc solaris
# GBK aix osf win32 dos # GBK glibc aix osf solaris woe32 dos
# GB18030 glibc # GB18030 glibc solaris
# SHIFT_JIS hpux osf solaris freebsd yes # SHIFT_JIS Y hpux osf solaris freebsd darwin
# JOHAB glibc win32 # JOHAB glibc solaris woe32
# TIS-620 glibc aix hpux osf solaris # TIS-620 glibc aix hpux osf solaris
# VISCII glibc yes # VISCII Y glibc
# TCVN5712-1 glibc
# GEORGIAN-PS glibc
# HP-ROMAN8 hpux # HP-ROMAN8 hpux
# HP-ARABIC8 hpux # HP-ARABIC8 hpux
# HP-GREEK8 hpux # HP-GREEK8 hpux
@ -95,7 +100,7 @@
# HP-KANA8 hpux # HP-KANA8 hpux
# DEC-KANJI osf # DEC-KANJI osf
# DEC-HANYU osf # DEC-HANYU osf
# UTF-8 glibc aix hpux osf solaris yes # UTF-8 Y glibc aix hpux osf solaris
# #
# Note: Names which are not marked as being a MIME name should not be used in # Note: Names which are not marked as being a MIME name should not be used in
# Internet protocols for information interchange (mail, news, etc.). # Internet protocols for information interchange (mail, news, etc.).
@ -116,6 +121,105 @@ echo "# It was automatically generated from config.charset."
# List of references, updated during installation: # List of references, updated during installation:
echo "# Packages using this file: " echo "# Packages using this file: "
case "$os" in case "$os" in
linux-gnulibc1*)
# Linux libc5 doesn't have nl_langinfo(CODESET); therefore
# localcharset.c falls back to using the full locale name
# from the environment variables.
echo "C ASCII"
echo "POSIX ASCII"
for l in af af_ZA ca ca_ES da da_DK de de_AT de_BE de_CH de_DE de_LU \
en en_AU en_BW en_CA en_DK en_GB en_IE en_NZ en_US en_ZA \
en_ZW es es_AR es_BO es_CL es_CO es_DO es_EC es_ES es_GT \
es_HN es_MX es_PA es_PE es_PY es_SV es_US es_UY es_VE et \
et_EE eu eu_ES fi fi_FI fo fo_FO fr fr_BE fr_CA fr_CH fr_FR \
fr_LU ga ga_IE gl gl_ES id id_ID in in_ID is is_IS it it_CH \
it_IT kl kl_GL nl nl_BE nl_NL no no_NO pt pt_BR pt_PT sv \
sv_FI sv_SE; do
echo "$l ISO-8859-1"
echo "$l.iso-8859-1 ISO-8859-1"
echo "$l.iso-8859-15 ISO-8859-15"
echo "$l.iso-8859-15@euro ISO-8859-15"
echo "$l@euro ISO-8859-15"
echo "$l.cp-437 CP437"
echo "$l.cp-850 CP850"
echo "$l.cp-1252 CP1252"
echo "$l.cp-1252@euro CP1252"
#echo "$l.atari-st ATARI-ST" # not a commonly used encoding
echo "$l.utf-8 UTF-8"
echo "$l.utf-8@euro UTF-8"
done
for l in cs cs_CZ hr hr_HR hu hu_HU pl pl_PL ro ro_RO sk sk_SK sl \
sl_SI sr sr_CS sr_YU; do
echo "$l ISO-8859-2"
echo "$l.iso-8859-2 ISO-8859-2"
echo "$l.cp-852 CP852"
echo "$l.cp-1250 CP1250"
echo "$l.utf-8 UTF-8"
done
for l in mk mk_MK ru ru_RU; do
echo "$l ISO-8859-5"
echo "$l.iso-8859-5 ISO-8859-5"
echo "$l.koi8-r KOI8-R"
echo "$l.cp-866 CP866"
echo "$l.cp-1251 CP1251"
echo "$l.utf-8 UTF-8"
done
for l in ar ar_SA; do
echo "$l ISO-8859-6"
echo "$l.iso-8859-6 ISO-8859-6"
echo "$l.cp-864 CP864"
#echo "$l.cp-868 CP868" # not a commonly used encoding
echo "$l.cp-1256 CP1256"
echo "$l.utf-8 UTF-8"
done
for l in el el_GR gr gr_GR; do
echo "$l ISO-8859-7"
echo "$l.iso-8859-7 ISO-8859-7"
echo "$l.cp-869 CP869"
echo "$l.cp-1253 CP1253"
echo "$l.cp-1253@euro CP1253"
echo "$l.utf-8 UTF-8"
echo "$l.utf-8@euro UTF-8"
done
for l in he he_IL iw iw_IL; do
echo "$l ISO-8859-8"
echo "$l.iso-8859-8 ISO-8859-8"
echo "$l.cp-862 CP862"
echo "$l.cp-1255 CP1255"
echo "$l.utf-8 UTF-8"
done
for l in tr tr_TR; do
echo "$l ISO-8859-9"
echo "$l.iso-8859-9 ISO-8859-9"
echo "$l.cp-857 CP857"
echo "$l.cp-1254 CP1254"
echo "$l.utf-8 UTF-8"
done
for l in lt lt_LT lv lv_LV; do
#echo "$l BALTIC" # not a commonly used encoding, wrong encoding name
echo "$l ISO-8859-13"
done
for l in ru_UA uk uk_UA; do
echo "$l KOI8-U"
done
for l in zh zh_CN; do
#echo "$l GB_2312-80" # not a commonly used encoding, wrong encoding name
echo "$l GB2312"
done
for l in ja ja_JP ja_JP.EUC; do
echo "$l EUC-JP"
done
for l in ko ko_KR; do
echo "$l EUC-KR"
done
for l in th th_TH; do
echo "$l TIS-620"
done
for l in fa fa_IR; do
#echo "$l ISIRI-3342" # a broken encoding
echo "$l.utf-8 UTF-8"
done
;;
linux* | *-gnu*) linux* | *-gnu*)
# With glibc-2.1 or newer, we don't need any canonicalization, # With glibc-2.1 or newer, we don't need any canonicalization,
# because glibc has iconv and both glibc and libiconv support all # because glibc has iconv and both glibc and libiconv support all
@ -217,6 +321,7 @@ case "$os" in
echo "646 ASCII" echo "646 ASCII"
echo "ISO8859-1 ISO-8859-1" echo "ISO8859-1 ISO-8859-1"
echo "ISO8859-2 ISO-8859-2" echo "ISO8859-2 ISO-8859-2"
echo "ISO8859-3 ISO-8859-3"
echo "ISO8859-4 ISO-8859-4" echo "ISO8859-4 ISO-8859-4"
echo "ISO8859-5 ISO-8859-5" echo "ISO8859-5 ISO-8859-5"
echo "ISO8859-6 ISO-8859-6" echo "ISO8859-6 ISO-8859-6"
@ -225,20 +330,27 @@ case "$os" in
echo "ISO8859-9 ISO-8859-9" echo "ISO8859-9 ISO-8859-9"
echo "ISO8859-15 ISO-8859-15" echo "ISO8859-15 ISO-8859-15"
echo "koi8-r KOI8-R" echo "koi8-r KOI8-R"
echo "ansi-1251 CP1251"
echo "BIG5 BIG5" echo "BIG5 BIG5"
echo "Big5-HKSCS BIG5-HKSCS"
echo "gb2312 GB2312" echo "gb2312 GB2312"
echo "GBK GBK"
echo "GB18030 GB18030"
echo "cns11643 EUC-TW" echo "cns11643 EUC-TW"
echo "5601 EUC-KR" echo "5601 EUC-KR"
echo "ko_KR.johap92 JOHAB"
echo "eucJP EUC-JP" echo "eucJP EUC-JP"
echo "PCK SHIFT_JIS" echo "PCK SHIFT_JIS"
echo "TIS620.2533 TIS-620" echo "TIS620.2533 TIS-620"
#echo "sun_eu_greek ?" # what is this? #echo "sun_eu_greek ?" # what is this?
echo "UTF-8 UTF-8" echo "UTF-8 UTF-8"
;; ;;
freebsd*) freebsd* | os2*)
# FreeBSD 4.2 doesn't have nl_langinfo(CODESET); therefore # FreeBSD 4.2 doesn't have nl_langinfo(CODESET); therefore
# localcharset.c falls back to using the full locale name # localcharset.c falls back to using the full locale name
# from the environment variables. # from the environment variables.
# Likewise for OS/2. OS/2 has XFree86 just like FreeBSD. Just
# reuse FreeBSD's locale data for OS/2.
echo "C ASCII" echo "C ASCII"
echo "US-ASCII ASCII" echo "US-ASCII ASCII"
for l in la_LN lt_LN; do for l in la_LN lt_LN; do
@ -270,6 +382,61 @@ case "$os" in
echo "ja_JP.Shift_JIS SHIFT_JIS" echo "ja_JP.Shift_JIS SHIFT_JIS"
echo "ko_KR.EUC EUC-KR" echo "ko_KR.EUC EUC-KR"
;; ;;
netbsd*)
echo "646 ASCII"
echo "ISO8859-1 ISO-8859-1"
echo "ISO8859-2 ISO-8859-2"
echo "ISO8859-4 ISO-8859-4"
echo "ISO8859-5 ISO-8859-5"
echo "ISO8859-15 ISO-8859-15"
echo "eucCN GB2312"
echo "eucJP EUC-JP"
echo "eucKR EUC-KR"
echo "eucTW EUC-TW"
echo "BIG5 BIG5"
echo "SJIS SHIFT_JIS"
;;
darwin*)
# Darwin 6.8 doesn't have nl_langinfo(CODESET); therefore
# localcharset.c falls back to using the full locale name
# from the environment variables.
echo "C ASCII"
for l in en_AU en_CA en_GB en_US la_LN; do
echo "$l.US-ASCII ASCII"
done
for l in da_DK de_AT de_CH de_DE en_AU en_CA en_GB en_US es_ES \
fi_FI fr_BE fr_CA fr_CH fr_FR is_IS it_CH it_IT nl_BE \
nl_NL no_NO pt_PT sv_SE; do
echo "$l ISO-8859-1"
echo "$l.ISO8859-1 ISO-8859-1"
echo "$l.ISO8859-15 ISO-8859-15"
done
for l in la_LN; do
echo "$l.ISO8859-1 ISO-8859-1"
echo "$l.ISO8859-15 ISO-8859-15"
done
for l in cs_CZ hr_HR hu_HU la_LN pl_PL sl_SI; do
echo "$l.ISO8859-2 ISO-8859-2"
done
for l in la_LN lt_LT; do
echo "$l.ISO8859-4 ISO-8859-4"
done
for l in ru_RU; do
echo "$l.KOI8-R KOI8-R"
echo "$l.ISO8859-5 ISO-8859-5"
echo "$l.CP866 CP866"
done
for l in bg_BG; do
echo "$l.CP1251 CP1251"
done
echo "uk_UA.KOI8-U KOI8-U"
echo "zh_TW.BIG5 BIG5"
echo "zh_TW.Big5 BIG5"
echo "zh_CN.EUC GB2312"
echo "ja_JP.EUC EUC-JP"
echo "ja_JP.SJIS SHIFT_JIS"
echo "ko_KR.EUC EUC-KR"
;;
beos*) beos*)
# BeOS has a single locale, and it has UTF-8 encoding. # BeOS has a single locale, and it has UTF-8 encoding.
echo "* UTF-8" echo "* UTF-8"
@ -284,7 +451,7 @@ case "$os" in
echo "# country is not the one your DOS machine actually uses, just" echo "# country is not the one your DOS machine actually uses, just"
echo "# correct it in this file, and send a mail to" echo "# correct it in this file, and send a mail to"
echo "# Juan Manuel Guerrero <st001906@hrz1.hrz.tu-darmstadt.de>" echo "# Juan Manuel Guerrero <st001906@hrz1.hrz.tu-darmstadt.de>"
echo "# and Bruno Haible <haible@clisp.cons.org>." echo "# and Bruno Haible <bruno@clisp.org>."
echo "#" echo "#"
echo "C ASCII" echo "C ASCII"
# ISO-8859-1 languages # ISO-8859-1 languages
@ -383,6 +550,7 @@ case "$os" in
echo "sq CP852" echo "sq CP852"
echo "sq_AL CP852" echo "sq_AL CP852"
echo "sr CP852" # CP852 or CP866 or CP855 ?? echo "sr CP852" # CP852 or CP866 or CP855 ??
echo "sr_CS CP852" # CP852 or CP866 or CP855 ??
echo "sr_YU CP852" # CP852 or CP866 or CP855 ?? echo "sr_YU CP852" # CP852 or CP866 or CP855 ??
# ISO-8859-3 languages # ISO-8859-3 languages
echo "mt CP850" echo "mt CP850"
@ -394,8 +562,10 @@ case "$os" in
echo "bg_BG CP866" # not CP855 ?? echo "bg_BG CP866" # not CP855 ??
echo "mk CP866" # not CP855 ?? echo "mk CP866" # not CP855 ??
echo "mk_MK CP866" # not CP855 ?? echo "mk_MK CP866" # not CP855 ??
echo "ru KOI8-R" # not CP866 ?? echo "ru CP866"
echo "ru_RU KOI8-R" # not CP866 ?? echo "ru_RU CP866"
echo "uk CP1125"
echo "uk_UA CP1125"
# ISO-8859-6 languages # ISO-8859-6 languages
echo "ar CP864" echo "ar CP864"
echo "ar_AE CP864" echo "ar_AE CP864"

View File

@ -1,5 +1,5 @@
/* Implementation of the dcgettext(3) function. /* Implementation of the dcgettext(3) function.
Copyright (C) 1995-1999, 2000, 2001 Free Software Foundation, Inc. Copyright (C) 1995-1999, 2000-2003 Free Software Foundation, Inc.
This program is free software; you can redistribute it and/or modify it This program is free software; you can redistribute it and/or modify it
under the terms of the GNU Library General Public License as published under the terms of the GNU Library General Public License as published
@ -37,22 +37,20 @@
# define DCGETTEXT __dcgettext # define DCGETTEXT __dcgettext
# define DCIGETTEXT __dcigettext # define DCIGETTEXT __dcigettext
#else #else
# define DCGETTEXT dcgettext__ # define DCGETTEXT libintl_dcgettext
# define DCIGETTEXT dcigettext__ # define DCIGETTEXT libintl_dcigettext
#endif #endif
/* Look up MSGID in the DOMAINNAME message catalog for the current CATEGORY /* Look up MSGID in the DOMAINNAME message catalog for the current CATEGORY
locale. */ locale. */
char * char *
DCGETTEXT (domainname, msgid, category) DCGETTEXT (const char *domainname, const char *msgid, int category)
const char *domainname;
const char *msgid;
int category;
{ {
return DCIGETTEXT (domainname, msgid, NULL, 0, 0, category); return DCIGETTEXT (domainname, msgid, NULL, 0, 0, category);
} }
#ifdef _LIBC #ifdef _LIBC
/* Alias for function name in GNU C Library. */ /* Alias for function name in GNU C Library. */
INTDEF(__dcgettext)
weak_alias (__dcgettext, dcgettext); weak_alias (__dcgettext, dcgettext);
#endif #endif

View File

@ -1,5 +1,5 @@
/* Implementation of the internal dcigettext function. /* Implementation of the internal dcigettext function.
Copyright (C) 1995-1999, 2000, 2001 Free Software Foundation, Inc. Copyright (C) 1995-1999, 2000-2003 Free Software Foundation, Inc.
This program is free software; you can redistribute it and/or modify it This program is free software; you can redistribute it and/or modify it
under the terms of the GNU Library General Public License as published under the terms of the GNU Library General Public License as published
@ -33,6 +33,10 @@
# define alloca __builtin_alloca # define alloca __builtin_alloca
# define HAVE_ALLOCA 1 # define HAVE_ALLOCA 1
#else #else
# ifdef _MSC_VER
# include <malloc.h>
# define alloca _alloca
# else
# if defined HAVE_ALLOCA_H || defined _LIBC # if defined HAVE_ALLOCA_H || defined _LIBC
# include <alloca.h> # include <alloca.h>
# else # else
@ -45,6 +49,7 @@ char *alloca ();
# endif # endif
# endif # endif
# endif # endif
#endif
#include <errno.h> #include <errno.h>
#ifndef errno #ifndef errno
@ -56,13 +61,7 @@ extern int errno;
#include <stddef.h> #include <stddef.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#if !HAVE_STRCHR && !defined _LIBC
# ifndef strchr
# define strchr index
# endif
#endif
#if defined HAVE_UNISTD_H || defined _LIBC #if defined HAVE_UNISTD_H || defined _LIBC
# include <unistd.h> # include <unistd.h>
@ -70,11 +69,26 @@ extern int errno;
#include <locale.h> #include <locale.h>
#ifdef _LIBC
/* Guess whether integer division by zero raises signal SIGFPE.
Set to 1 only if you know for sure. In case of doubt, set to 0. */
# if defined __alpha__ || defined __arm__ || defined __i386__ \
|| defined __m68k__ || defined __s390__
# define INTDIV0_RAISES_SIGFPE 1
# else
# define INTDIV0_RAISES_SIGFPE 0
# endif
#endif
#if !INTDIV0_RAISES_SIGFPE
# include <signal.h>
#endif
#if defined HAVE_SYS_PARAM_H || defined _LIBC #if defined HAVE_SYS_PARAM_H || defined _LIBC
# include <sys/param.h> # include <sys/param.h>
#endif #endif
#include "gettextP.h" #include "gettextP.h"
#include "plural-exp.h"
#ifdef _LIBC #ifdef _LIBC
# include <libintl.h> # include <libintl.h>
#else #else
@ -107,10 +121,10 @@ extern int errno;
names than the internal variables in GNU libc, otherwise programs names than the internal variables in GNU libc, otherwise programs
using libintl.a cannot be linked statically. */ using libintl.a cannot be linked statically. */
#if !defined _LIBC #if !defined _LIBC
# define _nl_default_default_domain _nl_default_default_domain__ # define _nl_default_default_domain libintl_nl_default_default_domain
# define _nl_current_default_domain _nl_current_default_domain__ # define _nl_current_default_domain libintl_nl_current_default_domain
# define _nl_default_dirname _nl_default_dirname__ # define _nl_default_dirname libintl_nl_default_dirname
# define _nl_domain_bindings _nl_domain_bindings__ # define _nl_domain_bindings libintl_nl_domain_bindings
#endif #endif
/* Some compilers, like SunOS4 cc, don't have offsetof in <stddef.h>. */ /* Some compilers, like SunOS4 cc, don't have offsetof in <stddef.h>. */
@ -134,13 +148,17 @@ extern int errno;
char *getwd (); char *getwd ();
# define getcwd(buf, max) getwd (buf) # define getcwd(buf, max) getwd (buf)
# else # else
# if VMS
# define getcwd(buf, max) (getcwd) (buf, max, 0)
# else
char *getcwd (); char *getcwd ();
# endif # endif
# endif
# ifndef HAVE_STPCPY # ifndef HAVE_STPCPY
static char *stpcpy PARAMS ((char *dest, const char *src)); static char *stpcpy (char *dest, const char *src);
# endif # endif
# ifndef HAVE_MEMPCPY # ifndef HAVE_MEMPCPY
static void *mempcpy PARAMS ((void *dest, const void *src, size_t n)); static void *mempcpy (void *dest, const void *src, size_t n);
# endif # endif
#endif #endif
@ -198,16 +216,6 @@ static void *mempcpy PARAMS ((void *dest, const void *src, size_t n));
# define IS_PATH_WITH_DIR(P) (strchr (P, '/') != NULL) # define IS_PATH_WITH_DIR(P) (strchr (P, '/') != NULL)
#endif #endif
/* XPG3 defines the result of `setlocale (category, NULL)' as:
``Directs `setlocale()' to query `category' and return the current
setting of `local'.''
However it does not specify the exact format. Neither do SUSV2 and
ISO C 99. So we can use this feature only on selected systems (e.g.
those using GNU C Library). */
#if defined _LIBC || (defined __GNU_LIBRARY__ && __GNU_LIBRARY__ >= 2)
# define HAVE_LOCALE_NULL
#endif
/* This is the type used for the search tree where known translations /* This is the type used for the search tree where known translations
are stored. */ are stored. */
struct known_translation_t struct known_translation_t
@ -244,11 +252,8 @@ static void *root;
# endif # endif
/* Function to compare two entries in the table of known translations. */ /* Function to compare two entries in the table of known translations. */
static int transcmp PARAMS ((const void *p1, const void *p2));
static int static int
transcmp (p1, p2) transcmp (const void *p1, const void *p2)
const void *p1;
const void *p2;
{ {
const struct known_translation_t *s1; const struct known_translation_t *s1;
const struct known_translation_t *s2; const struct known_translation_t *s2;
@ -272,39 +277,54 @@ transcmp (p1, p2)
} }
#endif #endif
#ifndef INTVARDEF
# define INTVARDEF(name)
#endif
#ifndef INTUSE
# define INTUSE(name) name
#endif
/* Name of the default domain used for gettext(3) prior any call to /* Name of the default domain used for gettext(3) prior any call to
textdomain(3). The default value for this is "messages". */ textdomain(3). The default value for this is "messages". */
const char _nl_default_default_domain[] = "messages"; const char _nl_default_default_domain[] attribute_hidden = "messages";
/* Value used as the default domain for gettext(3). */ /* Value used as the default domain for gettext(3). */
const char *_nl_current_default_domain = _nl_default_default_domain; const char *_nl_current_default_domain attribute_hidden
= _nl_default_default_domain;
/* Contains the default location of the message catalogs. */ /* Contains the default location of the message catalogs. */
#if defined __EMX__
extern const char _nl_default_dirname[];
#else
const char _nl_default_dirname[] = LOCALEDIR; const char _nl_default_dirname[] = LOCALEDIR;
INTVARDEF (_nl_default_dirname)
#endif
/* List with bindings of specific domains created by bindtextdomain() /* List with bindings of specific domains created by bindtextdomain()
calls. */ calls. */
struct binding *_nl_domain_bindings; struct binding *_nl_domain_bindings;
/* Prototypes for local functions. */ /* Prototypes for local functions. */
static char *plural_lookup PARAMS ((struct loaded_l10nfile *domain, static char *plural_lookup (struct loaded_l10nfile *domain,
unsigned long int n, unsigned long int n,
const char *translation, const char *translation, size_t translation_len)
size_t translation_len))
internal_function; internal_function;
static unsigned long int plural_eval PARAMS ((struct expression *pexp, static const char *guess_category_value (int category,
unsigned long int n)) const char *categoryname)
internal_function;
static const char *category_to_name PARAMS ((int category)) internal_function;
static const char *guess_category_value PARAMS ((int category,
const char *categoryname))
internal_function; internal_function;
#ifdef _LIBC
# include "../locale/localeinfo.h"
# define category_to_name(category) _nl_category_names[category]
#else
static const char *category_to_name (int category) internal_function;
#endif
/* For those loosing systems which don't have `alloca' we have to add /* For those loosing systems which don't have `alloca' we have to add
some additional code emulating it. */ some additional code emulating it. */
#ifdef HAVE_ALLOCA #ifdef HAVE_ALLOCA
/* Nothing has to be done. */ /* Nothing has to be done. */
# define freea(p) /* nothing */
# define ADD_BLOCK(list, address) /* nothing */ # define ADD_BLOCK(list, address) /* nothing */
# define FREE_BLOCKS(list) /* nothing */ # define FREE_BLOCKS(list) /* nothing */
#else #else
@ -329,11 +349,13 @@ struct block_list
while (list != NULL) { \ while (list != NULL) { \
struct block_list *old = list; \ struct block_list *old = list; \
list = list->next; \ list = list->next; \
free (old->address); \
free (old); \ free (old); \
} \ } \
} while (0) } while (0)
# undef alloca # undef alloca
# define alloca(size) (malloc (size)) # define alloca(size) (malloc (size))
# define freea(p) free (p)
#endif /* have alloca */ #endif /* have alloca */
@ -357,12 +379,12 @@ typedef unsigned char transmem_block_t;
#ifdef _LIBC #ifdef _LIBC
# define DCIGETTEXT __dcigettext # define DCIGETTEXT __dcigettext
#else #else
# define DCIGETTEXT dcigettext__ # define DCIGETTEXT libintl_dcigettext
#endif #endif
/* Lock variable to protect the global data in the gettext implementation. */ /* Lock variable to protect the global data in the gettext implementation. */
#ifdef _LIBC #ifdef _LIBC
__libc_rwlock_define_initialized (, _nl_state_lock) __libc_rwlock_define_initialized (, _nl_state_lock attribute_hidden)
#endif #endif
/* Checking whether the binaries runs SUID must be done and glibc provides /* Checking whether the binaries runs SUID must be done and glibc provides
@ -395,17 +417,15 @@ static int enable_secure;
} }
#endif #endif
/* Get the function to evaluate the plural expression. */
#include "eval-plural.h"
/* Look up MSGID in the DOMAINNAME message catalog for the current /* Look up MSGID in the DOMAINNAME message catalog for the current
CATEGORY locale and, if PLURAL is nonzero, search over string CATEGORY locale and, if PLURAL is nonzero, search over string
depending on the plural form determined by N. */ depending on the plural form determined by N. */
char * char *
DCIGETTEXT (domainname, msgid1, msgid2, plural, n, category) DCIGETTEXT (const char *domainname, const char *msgid1, const char *msgid2,
const char *domainname; int plural, unsigned long int n, int category)
const char *msgid1;
const char *msgid2;
int plural;
unsigned long int n;
int category;
{ {
#ifndef HAVE_ALLOCA #ifndef HAVE_ALLOCA
struct block_list *block_list = NULL; struct block_list *block_list = NULL;
@ -430,6 +450,15 @@ DCIGETTEXT (domainname, msgid1, msgid2, plural, n, category)
if (msgid1 == NULL) if (msgid1 == NULL)
return NULL; return NULL;
#ifdef _LIBC
if (category < 0 || category >= __LC_LAST || category == LC_ALL)
/* Bogus. */
return (plural == 0
? (char *) msgid1
/* Use the Germanic plural rule. */
: n == 1 ? (char *) msgid1 : (char *) msgid2);
#endif
__libc_rwlock_rdlock (_nl_state_lock); __libc_rwlock_rdlock (_nl_state_lock);
/* If DOMAINNAME is NULL, we are interested in the default domain. If /* If DOMAINNAME is NULL, we are interested in the default domain. If
@ -438,6 +467,12 @@ DCIGETTEXT (domainname, msgid1, msgid2, plural, n, category)
if (domainname == NULL) if (domainname == NULL)
domainname = _nl_current_default_domain; domainname = _nl_current_default_domain;
/* OS/2 specific: backward compatibility with older libintl versions */
#ifdef LC_MESSAGES_COMPAT
if (category == LC_MESSAGES_COMPAT)
category = LC_MESSAGES;
#endif
#if defined HAVE_TSEARCH || defined _LIBC #if defined HAVE_TSEARCH || defined _LIBC
msgid_len = strlen (msgid1) + 1; msgid_len = strlen (msgid1) + 1;
@ -450,6 +485,7 @@ DCIGETTEXT (domainname, msgid1, msgid2, plural, n, category)
search->category = category; search->category = category;
foundp = (struct known_translation_t **) tfind (search, &root, transcmp); foundp = (struct known_translation_t **) tfind (search, &root, transcmp);
freea (search);
if (foundp != NULL && (*foundp)->counter == _nl_msg_cat_cntr) if (foundp != NULL && (*foundp)->counter == _nl_msg_cat_cntr)
{ {
/* Now deal with plural. */ /* Now deal with plural. */
@ -486,7 +522,7 @@ DCIGETTEXT (domainname, msgid1, msgid2, plural, n, category)
} }
if (binding == NULL) if (binding == NULL)
dirname = (char *) _nl_default_dirname; dirname = (char *) INTUSE(_nl_default_dirname);
else if (IS_ABSOLUTE_PATH (binding->dirname)) else if (IS_ABSOLUTE_PATH (binding->dirname))
dirname = binding->dirname; dirname = binding->dirname;
else else
@ -514,17 +550,9 @@ DCIGETTEXT (domainname, msgid1, msgid2, plural, n, category)
} }
if (ret == NULL) if (ret == NULL)
{
/* We cannot get the current working directory. Don't signal an /* We cannot get the current working directory. Don't signal an
error but simply return the default string. */ error but simply return the default string. */
FREE_BLOCKS (block_list); goto return_untranslated;
__libc_rwlock_unlock (_nl_state_lock);
__set_errno (saved_errno);
return (plural == 0
? (char *) msgid1
/* Use the Germanic plural rule. */
: n == 1 ? (char *) msgid1 : (char *) msgid2);
}
stpcpy (stpcpy (strchr (dirname, '\0'), "/"), binding->dirname); stpcpy (stpcpy (strchr (dirname, '\0'), "/"), binding->dirname);
} }
@ -581,16 +609,7 @@ DCIGETTEXT (domainname, msgid1, msgid2, plural, n, category)
domain. Return the MSGID. */ domain. Return the MSGID. */
if (strcmp (single_locale, "C") == 0 if (strcmp (single_locale, "C") == 0
|| strcmp (single_locale, "POSIX") == 0) || strcmp (single_locale, "POSIX") == 0)
{ break;
FREE_BLOCKS (block_list);
__libc_rwlock_unlock (_nl_state_lock);
__set_errno (saved_errno);
return (plural == 0
? (char *) msgid1
/* Use the Germanic plural rule. */
: n == 1 ? (char *) msgid1 : (char *) msgid2);
}
/* Find structure describing the message catalog matching the /* Find structure describing the message catalog matching the
DOMAINNAME and CATEGORY. */ DOMAINNAME and CATEGORY. */
@ -622,7 +641,6 @@ DCIGETTEXT (domainname, msgid1, msgid2, plural, n, category)
/* Found the translation of MSGID1 in domain DOMAIN: /* Found the translation of MSGID1 in domain DOMAIN:
starting at RETVAL, RETLEN bytes. */ starting at RETVAL, RETLEN bytes. */
FREE_BLOCKS (block_list); FREE_BLOCKS (block_list);
__set_errno (saved_errno);
#if defined HAVE_TSEARCH || defined _LIBC #if defined HAVE_TSEARCH || defined _LIBC
if (foundp == NULL) if (foundp == NULL)
{ {
@ -661,6 +679,8 @@ DCIGETTEXT (domainname, msgid1, msgid2, plural, n, category)
(*foundp)->translation_length = retlen; (*foundp)->translation_length = retlen;
} }
#endif #endif
__set_errno (saved_errno);
/* Now deal with plural. */ /* Now deal with plural. */
if (plural) if (plural)
retval = plural_lookup (domain, n, retval, retlen); retval = plural_lookup (domain, n, retval, retlen);
@ -670,19 +690,40 @@ DCIGETTEXT (domainname, msgid1, msgid2, plural, n, category)
} }
} }
} }
/* NOTREACHED */
return_untranslated:
/* Return the untranslated MSGID. */
FREE_BLOCKS (block_list);
__libc_rwlock_unlock (_nl_state_lock);
#ifndef _LIBC
if (!ENABLE_SECURE)
{
extern void _nl_log_untranslated (const char *logfilename,
const char *domainname,
const char *msgid1, const char *msgid2,
int plural);
const char *logfilename = getenv ("GETTEXT_LOG_UNTRANSLATED");
if (logfilename != NULL && logfilename[0] != '\0')
_nl_log_untranslated (logfilename, domainname, msgid1, msgid2, plural);
}
#endif
__set_errno (saved_errno);
return (plural == 0
? (char *) msgid1
/* Use the Germanic plural rule. */
: n == 1 ? (char *) msgid1 : (char *) msgid2);
} }
char * char *
internal_function internal_function
_nl_find_msg (domain_file, domainbinding, msgid, lengthp) _nl_find_msg (struct loaded_l10nfile *domain_file,
struct loaded_l10nfile *domain_file; struct binding *domainbinding, const char *msgid,
struct binding *domainbinding; size_t *lengthp)
const char *msgid;
size_t *lengthp;
{ {
struct loaded_domain *domain; struct loaded_domain *domain;
nls_uint32 nstrings;
size_t act; size_t act;
char *result; char *result;
size_t resultlen; size_t resultlen;
@ -695,8 +736,10 @@ _nl_find_msg (domain_file, domainbinding, msgid, lengthp)
domain = (struct loaded_domain *) domain_file->data; domain = (struct loaded_domain *) domain_file->data;
nstrings = domain->nstrings;
/* Locate the MSGID and its translation. */ /* Locate the MSGID and its translation. */
if (domain->hash_size > 2 && domain->hash_tab != NULL) if (domain->hash_tab != NULL)
{ {
/* Use the hashing table. */ /* Use the hashing table. */
nls_uint32 len = strlen (msgid); nls_uint32 len = strlen (msgid);
@ -706,22 +749,30 @@ _nl_find_msg (domain_file, domainbinding, msgid, lengthp)
while (1) while (1)
{ {
nls_uint32 nstr = W (domain->must_swap, domain->hash_tab[idx]); nls_uint32 nstr =
W (domain->must_swap_hash_tab, domain->hash_tab[idx]);
if (nstr == 0) if (nstr == 0)
/* Hash table entry is empty. */ /* Hash table entry is empty. */
return NULL; return NULL;
/* Compare msgid with the original string at index nstr-1. nstr--;
/* Compare msgid with the original string at index nstr.
We compare the lengths with >=, not ==, because plural entries We compare the lengths with >=, not ==, because plural entries
are represented by strings with an embedded NUL. */ are represented by strings with an embedded NUL. */
if (W (domain->must_swap, domain->orig_tab[nstr - 1].length) >= len if (nstr < nstrings
? W (domain->must_swap, domain->orig_tab[nstr].length) >= len
&& (strcmp (msgid, && (strcmp (msgid,
domain->data + W (domain->must_swap, domain->data + W (domain->must_swap,
domain->orig_tab[nstr - 1].offset)) domain->orig_tab[nstr].offset))
== 0)
: domain->orig_sysdep_tab[nstr - nstrings].length > len
&& (strcmp (msgid,
domain->orig_sysdep_tab[nstr - nstrings].pointer)
== 0)) == 0))
{ {
act = nstr - 1; act = nstr;
goto found; goto found;
} }
@ -739,7 +790,7 @@ _nl_find_msg (domain_file, domainbinding, msgid, lengthp)
size_t top, bottom; size_t top, bottom;
bottom = 0; bottom = 0;
top = domain->nstrings; top = nstrings;
while (bottom < top) while (bottom < top)
{ {
int cmp_val; int cmp_val;
@ -762,9 +813,17 @@ _nl_find_msg (domain_file, domainbinding, msgid, lengthp)
found: found:
/* The translation was found at index ACT. If we have to convert the /* The translation was found at index ACT. If we have to convert the
string to use a different character set, this is the time. */ string to use a different character set, this is the time. */
result = ((char *) domain->data if (act < nstrings)
+ W (domain->must_swap, domain->trans_tab[act].offset)); {
result = (char *)
(domain->data + W (domain->must_swap, domain->trans_tab[act].offset));
resultlen = W (domain->must_swap, domain->trans_tab[act].length) + 1; resultlen = W (domain->must_swap, domain->trans_tab[act].length) + 1;
}
else
{
result = (char *) domain->trans_sysdep_tab[act - nstrings].pointer;
resultlen = domain->trans_sysdep_tab[act - nstrings].length;
}
#if defined _LIBC || HAVE_ICONV #if defined _LIBC || HAVE_ICONV
if (domain->codeset_cntr if (domain->codeset_cntr
@ -797,7 +856,8 @@ _nl_find_msg (domain_file, domainbinding, msgid, lengthp)
NULs. */ NULs. */
if (domain->conv_tab == NULL if (domain->conv_tab == NULL
&& ((domain->conv_tab = (char **) calloc (domain->nstrings, && ((domain->conv_tab =
(char **) calloc (nstrings + domain->n_sysdep_strings,
sizeof (char *))) sizeof (char *)))
== NULL)) == NULL))
/* Mark that we didn't succeed allocating a table. */ /* Mark that we didn't succeed allocating a table. */
@ -967,25 +1027,22 @@ _nl_find_msg (domain_file, domainbinding, msgid, lengthp)
/* Look up a plural variant. */ /* Look up a plural variant. */
static char * static char *
internal_function internal_function
plural_lookup (domain, n, translation, translation_len) plural_lookup (struct loaded_l10nfile *domain, unsigned long int n,
struct loaded_l10nfile *domain; const char *translation, size_t translation_len)
unsigned long int n;
const char *translation;
size_t translation_len;
{ {
struct loaded_domain *domaindata = (struct loaded_domain *) domain->data; struct loaded_domain *domaindata = (struct loaded_domain *) domain->data;
unsigned long int ind; /* gnupg */ unsigned long int index;
const char *p; const char *p;
ind = plural_eval (domaindata->plural, n); /* gnupg */ index = plural_eval (domaindata->plural, n);
if (ind >= domaindata->nplurals) /* gnupg */ if (index >= domaindata->nplurals)
/* This should never happen. It means the plural expression and the /* This should never happen. It means the plural expression and the
given maximum value do not match. */ given maximum value do not match. */
ind = 0; /* gnupg */ index = 0;
/* Skip INDEX strings at TRANSLATION. */ /* Skip INDEX strings at TRANSLATION. */
p = translation; p = translation;
while (ind-- > 0) /* gnupg */ while (index-- > 0)
{ {
#ifdef _LIBC #ifdef _LIBC
p = __rawmemchr (p, '\0'); p = __rawmemchr (p, '\0');
@ -1004,93 +1061,11 @@ plural_lookup (domain, n, translation, translation_len)
return (char *) p; return (char *) p;
} }
#ifndef _LIBC
/* Function to evaluate the plural expression and return an index value. */
static unsigned long int
internal_function
plural_eval (pexp, n)
struct expression *pexp;
unsigned long int n;
{
switch (pexp->nargs)
{
case 0:
switch (pexp->operation)
{
case var:
return n;
case num:
return pexp->val.num;
default:
break;
}
/* NOTREACHED */
break;
case 1:
{
/* pexp->operation must be lnot. */
unsigned long int arg = plural_eval (pexp->val.args[0], n);
return ! arg;
}
case 2:
{
unsigned long int leftarg = plural_eval (pexp->val.args[0], n);
if (pexp->operation == lor)
return leftarg || plural_eval (pexp->val.args[1], n);
else if (pexp->operation == land)
return leftarg && plural_eval (pexp->val.args[1], n);
else
{
unsigned long int rightarg = plural_eval (pexp->val.args[1], n);
switch (pexp->operation)
{
case mult:
return leftarg * rightarg;
case divide:
return leftarg / rightarg;
case module:
return leftarg % rightarg;
case plus:
return leftarg + rightarg;
case minus:
return leftarg - rightarg;
case less_than:
return leftarg < rightarg;
case greater_than:
return leftarg > rightarg;
case less_or_equal:
return leftarg <= rightarg;
case greater_or_equal:
return leftarg >= rightarg;
case equal:
return leftarg == rightarg;
case not_equal:
return leftarg != rightarg;
default:
break;
}
}
/* NOTREACHED */
break;
}
case 3:
{
/* pexp->operation must be qmop. */
unsigned long int boolarg = plural_eval (pexp->val.args[0], n);
return plural_eval (pexp->val.args[boolarg ? 1 : 2], n);
}
}
/* NOTREACHED */
return 0;
}
/* Return string representation of locale CATEGORY. */ /* Return string representation of locale CATEGORY. */
static const char * static const char *
internal_function internal_function
category_to_name (category) category_to_name (int category)
int category;
{ {
const char *retval; const char *retval;
@ -1145,13 +1120,12 @@ category_to_name (category)
return retval; return retval;
} }
#endif
/* Guess value of current locale from value of the environment variables. */ /* Guess value of current locale from value of the environment variables. */
static const char * static const char *
internal_function internal_function
guess_category_value (category, categoryname) guess_category_value (int category, const char *categoryname)
int category;
const char *categoryname;
{ {
const char *language; const char *language;
const char *retval; const char *retval;
@ -1166,27 +1140,21 @@ guess_category_value (category, categoryname)
/* We have to proceed with the POSIX methods of looking to `LC_ALL', /* We have to proceed with the POSIX methods of looking to `LC_ALL',
`LC_xxx', and `LANG'. On some systems this can be done by the `LC_xxx', and `LANG'. On some systems this can be done by the
`setlocale' function itself. */ `setlocale' function itself. */
#if defined _LIBC || (defined HAVE_SETLOCALE && defined HAVE_LC_MESSAGES && defined HAVE_LOCALE_NULL) #ifdef _LIBC
retval = setlocale (category, NULL); retval = __current_locale_name (category);
#else #else
/* Setting of LC_ALL overwrites all other. */ retval = _nl_locale_name (category, categoryname);
retval = getenv ("LC_ALL");
if (retval == NULL || retval[0] == '\0')
{
/* Next comes the name of the desired category. */
retval = getenv (categoryname);
if (retval == NULL || retval[0] == '\0')
{
/* Last possibility is the LANG environment variable. */
retval = getenv ("LANG");
if (retval == NULL || retval[0] == '\0')
/* We use C as the default domain. POSIX says this is
implementation defined. */
return "C";
}
}
#endif #endif
/* Ignore LANGUAGE if the locale is set to "C" because
1. "C" locale usually uses the ASCII encoding, and most international
messages use non-ASCII characters. These characters get displayed
as question marks (if using glibc's iconv()) or as invalid 8-bit
characters (because other iconv()s refuse to convert most non-ASCII
characters to ASCII). In any case, the output is ugly.
2. The precise output of some programs in the "C" locale is specified
by POSIX and should not depend on environment variables like
"LANGUAGE". We allow such programs to use gettext(). */
return language != NULL && strcmp (retval, "C") != 0 ? language : retval; return language != NULL && strcmp (retval, "C") != 0 ? language : retval;
} }
@ -1198,9 +1166,7 @@ guess_category_value (category, categoryname)
to be defined. */ to be defined. */
#if !_LIBC && !HAVE_STPCPY #if !_LIBC && !HAVE_STPCPY
static char * static char *
stpcpy (dest, src) stpcpy (char *dest, const char *src)
char *dest;
const char *src;
{ {
while ((*dest++ = *src++) != '\0') while ((*dest++ = *src++) != '\0')
/* Do nothing. */ ; /* Do nothing. */ ;
@ -1210,10 +1176,7 @@ stpcpy (dest, src)
#if !_LIBC && !HAVE_MEMPCPY #if !_LIBC && !HAVE_MEMPCPY
static void * static void *
mempcpy (dest, src, n) mempcpy (void *dest, const void *src, size_t n)
void *dest;
const void *src;
size_t n;
{ {
return (void *) ((char *) memcpy (dest, src, n) + n); return (void *) ((char *) memcpy (dest, src, n) + n);
} }
@ -1223,8 +1186,7 @@ mempcpy (dest, src, n)
#ifdef _LIBC #ifdef _LIBC
/* If we want to free all resources we have to do some work at /* If we want to free all resources we have to do some work at
program's end. */ program's end. */
static void __attribute__ ((unused)) libc_freeres_fn (free_mem)
free_mem (void)
{ {
void *old; void *old;
@ -1232,7 +1194,7 @@ free_mem (void)
{ {
struct binding *oldp = _nl_domain_bindings; struct binding *oldp = _nl_domain_bindings;
_nl_domain_bindings = _nl_domain_bindings->next; _nl_domain_bindings = _nl_domain_bindings->next;
if (oldp->dirname != _nl_default_dirname) if (oldp->dirname != INTUSE(_nl_default_dirname))
/* Yes, this is a pointer comparison. */ /* Yes, this is a pointer comparison. */
free (oldp->dirname); free (oldp->dirname);
free (oldp->codeset); free (oldp->codeset);
@ -1254,6 +1216,4 @@ free_mem (void)
free (old); free (old);
} }
} }
text_set_element (__libc_subfreeres, free_mem);
#endif #endif

View File

@ -1,5 +1,5 @@
/* Implementation of the dcngettext(3) function. /* Implementation of the dcngettext(3) function.
Copyright (C) 1995-1999, 2000, 2001 Free Software Foundation, Inc. Copyright (C) 1995-1999, 2000-2003 Free Software Foundation, Inc.
This program is free software; you can redistribute it and/or modify it This program is free software; you can redistribute it and/or modify it
under the terms of the GNU Library General Public License as published under the terms of the GNU Library General Public License as published
@ -37,19 +37,16 @@
# define DCNGETTEXT __dcngettext # define DCNGETTEXT __dcngettext
# define DCIGETTEXT __dcigettext # define DCIGETTEXT __dcigettext
#else #else
# define DCNGETTEXT dcngettext__ # define DCNGETTEXT libintl_dcngettext
# define DCIGETTEXT dcigettext__ # define DCIGETTEXT libintl_dcigettext
#endif #endif
/* Look up MSGID in the DOMAINNAME message catalog for the current CATEGORY /* Look up MSGID in the DOMAINNAME message catalog for the current CATEGORY
locale. */ locale. */
char * char *
DCNGETTEXT (domainname, msgid1, msgid2, n, category) DCNGETTEXT (const char *domainname,
const char *domainname; const char *msgid1, const char *msgid2, unsigned long int n,
const char *msgid1; int category)
const char *msgid2;
unsigned long int n;
int category;
{ {
return DCIGETTEXT (domainname, msgid1, msgid2, 1, n, category); return DCIGETTEXT (domainname, msgid1, msgid2, 1, n, category);
} }

View File

@ -1,5 +1,5 @@
/* Implementation of the dgettext(3) function. /* Implementation of the dgettext(3) function.
Copyright (C) 1995-1997, 2000, 2001 Free Software Foundation, Inc. Copyright (C) 1995-1997, 2000-2003 Free Software Foundation, Inc.
This program is free software; you can redistribute it and/or modify it This program is free software; you can redistribute it and/or modify it
under the terms of the GNU Library General Public License as published under the terms of the GNU Library General Public License as published
@ -20,9 +20,10 @@
# include <config.h> # include <config.h>
#endif #endif
#include "gettextP.h"
#include <locale.h> #include <locale.h>
#include "gettextP.h"
#ifdef _LIBC #ifdef _LIBC
# include <libintl.h> # include <libintl.h>
#else #else
@ -37,18 +38,16 @@
prefix. So we have to make a difference here. */ prefix. So we have to make a difference here. */
#ifdef _LIBC #ifdef _LIBC
# define DGETTEXT __dgettext # define DGETTEXT __dgettext
# define DCGETTEXT __dcgettext # define DCGETTEXT INTUSE(__dcgettext)
#else #else
# define DGETTEXT dgettext__ # define DGETTEXT libintl_dgettext
# define DCGETTEXT dcgettext__ # define DCGETTEXT libintl_dcgettext
#endif #endif
/* Look up MSGID in the DOMAINNAME message catalog of the current /* Look up MSGID in the DOMAINNAME message catalog of the current
LC_MESSAGES locale. */ LC_MESSAGES locale. */
char * char *
DGETTEXT (domainname, msgid) DGETTEXT (const char *domainname, const char *msgid)
const char *domainname;
const char *msgid;
{ {
return DCGETTEXT (domainname, msgid, LC_MESSAGES); return DCGETTEXT (domainname, msgid, LC_MESSAGES);
} }

View File

@ -1,5 +1,5 @@
/* Implementation of the dngettext(3) function. /* Implementation of the dngettext(3) function.
Copyright (C) 1995-1997, 2000, 2001 Free Software Foundation, Inc. Copyright (C) 1995-1997, 2000-2003 Free Software Foundation, Inc.
This program is free software; you can redistribute it and/or modify it This program is free software; you can redistribute it and/or modify it
under the terms of the GNU Library General Public License as published under the terms of the GNU Library General Public License as published
@ -20,9 +20,10 @@
# include <config.h> # include <config.h>
#endif #endif
#include "gettextP.h"
#include <locale.h> #include <locale.h>
#include "gettextP.h"
#ifdef _LIBC #ifdef _LIBC
# include <libintl.h> # include <libintl.h>
#else #else
@ -39,18 +40,15 @@
# define DNGETTEXT __dngettext # define DNGETTEXT __dngettext
# define DCNGETTEXT __dcngettext # define DCNGETTEXT __dcngettext
#else #else
# define DNGETTEXT dngettext__ # define DNGETTEXT libintl_dngettext
# define DCNGETTEXT dcngettext__ # define DCNGETTEXT libintl_dcngettext
#endif #endif
/* Look up MSGID in the DOMAINNAME message catalog of the current /* Look up MSGID in the DOMAINNAME message catalog of the current
LC_MESSAGES locale and skip message according to the plural form. */ LC_MESSAGES locale and skip message according to the plural form. */
char * char *
DNGETTEXT (domainname, msgid1, msgid2, n) DNGETTEXT (const char *domainname,
const char *domainname; const char *msgid1, const char *msgid2, unsigned long int n)
const char *msgid1;
const char *msgid2;
unsigned long int n;
{ {
return DCNGETTEXT (domainname, msgid1, msgid2, n, LC_MESSAGES); return DCNGETTEXT (domainname, msgid1, msgid2, n, LC_MESSAGES);
} }

View File

@ -1,4 +1,4 @@
/* Copyright (C) 1995-1998, 2000, 2001 Free Software Foundation, Inc. /* Copyright (C) 1995-1998, 2000-2001, 2003 Free Software Foundation, Inc.
Contributed by Ulrich Drepper <drepper@gnu.ai.mit.edu>, 1995. Contributed by Ulrich Drepper <drepper@gnu.ai.mit.edu>, 1995.
This program is free software; you can redistribute it and/or modify it This program is free software; you can redistribute it and/or modify it
@ -38,8 +38,7 @@
/* @@ end of prolog @@ */ /* @@ end of prolog @@ */
char * char *
_nl_find_language (name) _nl_find_language (const char *name)
const char *name;
{ {
while (name[0] != '\0' && name[0] != '_' && name[0] != '@' while (name[0] != '\0' && name[0] != '_' && name[0] != '@'
&& name[0] != '+' && name[0] != ',') && name[0] != '+' && name[0] != ',')
@ -50,17 +49,11 @@ _nl_find_language (name)
int int
_nl_explode_name (name, language, modifier, territory, codeset, _nl_explode_name (char *name,
normalized_codeset, special, sponsor, revision) const char **language, const char **modifier,
char *name; const char **territory, const char **codeset,
const char **language; const char **normalized_codeset, const char **special,
const char **modifier; const char **sponsor, const char **revision)
const char **territory;
const char **codeset;
const char **normalized_codeset;
const char **special;
const char **sponsor;
const char **revision;
{ {
enum { undecided, xpg, cen } syntax; enum { undecided, xpg, cen } syntax;
char *cp; char *cp;

View File

@ -1,5 +1,5 @@
/* Handle list of needed message catalogs /* Handle list of needed message catalogs
Copyright (C) 1995-1999, 2000, 2001 Free Software Foundation, Inc. Copyright (C) 1995-1999, 2000-2001, 2003 Free Software Foundation, Inc.
Written by Ulrich Drepper <drepper@gnu.org>, 1995. Written by Ulrich Drepper <drepper@gnu.org>, 1995.
This program is free software; you can redistribute it and/or modify it This program is free software; you can redistribute it and/or modify it
@ -47,11 +47,8 @@ static struct loaded_l10nfile *_nl_loaded_domains;
established bindings. */ established bindings. */
struct loaded_l10nfile * struct loaded_l10nfile *
internal_function internal_function
_nl_find_domain (dirname, locale, domainname, domainbinding) _nl_find_domain (const char *dirname, char *locale,
const char *dirname; const char *domainname, struct binding *domainbinding)
char *locale;
const char *domainname;
struct binding *domainbinding;
{ {
struct loaded_l10nfile *retval; struct loaded_l10nfile *retval;
const char *language; const char *language;
@ -178,8 +175,7 @@ _nl_find_domain (dirname, locale, domainname, domainbinding)
#ifdef _LIBC #ifdef _LIBC
static void __attribute__ ((unused)) libc_freeres_fn (free_mem)
free_mem (void)
{ {
struct loaded_l10nfile *runp = _nl_loaded_domains; struct loaded_l10nfile *runp = _nl_loaded_domains;
@ -193,6 +189,4 @@ free_mem (void)
free (here); free (here);
} }
} }
text_set_element (__libc_subfreeres, free_mem);
#endif #endif

View File

@ -1,5 +1,5 @@
/* Implementation of gettext(3) function. /* Implementation of gettext(3) function.
Copyright (C) 1995, 1997, 2000, 2001 Free Software Foundation, Inc. Copyright (C) 1995, 1997, 2000-2003 Free Software Foundation, Inc.
This program is free software; you can redistribute it and/or modify it This program is free software; you can redistribute it and/or modify it
under the terms of the GNU Library General Public License as published under the terms of the GNU Library General Public License as published
@ -42,18 +42,17 @@
prefix. So we have to make a difference here. */ prefix. So we have to make a difference here. */
#ifdef _LIBC #ifdef _LIBC
# define GETTEXT __gettext # define GETTEXT __gettext
# define DCGETTEXT __dcgettext # define DCGETTEXT INTUSE(__dcgettext)
#else #else
# define GETTEXT gettext__ # define GETTEXT libintl_gettext
# define DCGETTEXT dcgettext__ # define DCGETTEXT libintl_dcgettext
#endif #endif
/* Look up MSGID in the current default message catalog for the current /* Look up MSGID in the current default message catalog for the current
LC_MESSAGES locale. If not found, returns MSGID itself (the default LC_MESSAGES locale. If not found, returns MSGID itself (the default
text). */ text). */
char * char *
GETTEXT (msgid) GETTEXT (const char *msgid)
const char *msgid;
{ {
return DCGETTEXT (NULL, msgid, LC_MESSAGES); return DCGETTEXT (NULL, msgid, LC_MESSAGES);
} }

View File

@ -1,5 +1,5 @@
/* Header describing internals of libintl library. /* Header describing internals of libintl library.
Copyright (C) 1995-1999, 2000, 2001 Free Software Foundation, Inc. Copyright (C) 1995-1999, 2000-2003 Free Software Foundation, Inc.
Written by Ulrich Drepper <drepper@cygnus.com>, 1995. Written by Ulrich Drepper <drepper@cygnus.com>, 1995.
This program is free software; you can redistribute it and/or modify it This program is free software; you can redistribute it and/or modify it
@ -20,12 +20,6 @@
#ifndef _GETTEXTP_H #ifndef _GETTEXTP_H
#define _GETTEXTP_H #define _GETTEXTP_H
/* HP/UX users - if you get errors line "Unexpected symbol: SWAP" when
building with HP's C compiler, you will need to uncomment the
following line. This is a GnuPG-specific change. */
/* #define inline */
#include <stddef.h> /* Get size_t. */ #include <stddef.h> /* Get size_t. */
#ifdef _LIBC #ifdef _LIBC
@ -38,22 +32,18 @@
#include "loadinfo.h" #include "loadinfo.h"
#include "gettext.h" /* Get nls_uint32. */ #include "gmo.h" /* Get nls_uint32. */
/* @@ end of prolog @@ */ /* @@ end of prolog @@ */
#ifndef PARAMS
# if __STDC__
# define PARAMS(args) args
# else
# define PARAMS(args) ()
# endif
#endif
#ifndef internal_function #ifndef internal_function
# define internal_function # define internal_function
#endif #endif
#ifndef attribute_hidden
# define attribute_hidden
#endif
/* Tell the compiler when a conditional or integer expression is /* Tell the compiler when a conditional or integer expression is
almost always true or almost always false. */ almost always true or almost always false. */
#ifndef HAVE_BUILTIN_EXPECT #ifndef HAVE_BUILTIN_EXPECT
@ -78,63 +68,50 @@ SWAP (i)
#endif #endif
/* This is the representation of the expressions to determine the /* In-memory representation of system dependent string. */
plural form. */ struct sysdep_string_desc
struct expression
{ {
int nargs; /* Number of arguments. */ /* Length of addressed string, including the trailing NUL. */
enum operator size_t length;
{ /* Pointer to addressed string. */
/* Without arguments: */ const char *pointer;
var, /* The variable "n". */
num, /* Decimal number. */
/* Unary operators: */
lnot, /* Logical NOT. */
/* Binary operators: */
mult, /* Multiplication. */
divide, /* Division. */
module, /* Module operation. */
plus, /* Addition. */
minus, /* Subtraction. */
less_than, /* Comparison. */
greater_than, /* Comparison. */
less_or_equal, /* Comparison. */
greater_or_equal, /* Comparison. */
equal, /* Comparision for equality. */
not_equal, /* Comparision for inequality. */
land, /* Logical AND. */
lor, /* Logical OR. */
/* Ternary operators: */
qmop /* Question mark operator. */
} operation;
union
{
unsigned long int num; /* Number value for `num'. */
struct expression *args[3]; /* Up to three arguments. */
} val;
}; };
/* This is the data structure to pass information to the parser and get
the result in a thread-safe way. */
struct parse_args
{
const char *cp;
struct expression *res;
};
/* The representation of an opened message catalog. */ /* The representation of an opened message catalog. */
struct loaded_domain struct loaded_domain
{ {
/* Pointer to memory containing the .mo file. */
const char *data; const char *data;
/* 1 if the memory is mmap()ed, 0 if the memory is malloc()ed. */
int use_mmap; int use_mmap;
/* Size of mmap()ed memory. */
size_t mmap_size; size_t mmap_size;
/* 1 if the .mo file uses a different endianness than this machine. */
int must_swap; int must_swap;
/* Pointer to additional malloc()ed memory. */
void *malloced;
/* Number of static strings pairs. */
nls_uint32 nstrings; nls_uint32 nstrings;
struct string_desc *orig_tab; /* Pointer to descriptors of original strings in the file. */
struct string_desc *trans_tab; const struct string_desc *orig_tab;
/* Pointer to descriptors of translated strings in the file. */
const struct string_desc *trans_tab;
/* Number of system dependent strings pairs. */
nls_uint32 n_sysdep_strings;
/* Pointer to descriptors of original sysdep strings. */
const struct sysdep_string_desc *orig_sysdep_tab;
/* Pointer to descriptors of translated sysdep strings. */
const struct sysdep_string_desc *trans_sysdep_tab;
/* Size of hash table. */
nls_uint32 hash_size; nls_uint32 hash_size;
nls_uint32 *hash_tab; /* Pointer to hash table. */
const nls_uint32 *hash_tab;
/* 1 if the hash table uses a different endianness than this machine. */
int must_swap_hash_tab;
int codeset_cntr; int codeset_cntr;
#ifdef _LIBC #ifdef _LIBC
__gconv_t conv; __gconv_t conv;
@ -173,84 +150,64 @@ struct binding
This variable is part of the external ABI of the GNU libintl. */ This variable is part of the external ABI of the GNU libintl. */
extern int _nl_msg_cat_cntr; extern int _nl_msg_cat_cntr;
struct loaded_l10nfile *_nl_find_domain PARAMS ((const char *__dirname, #ifndef _LIBC
char *__locale, const char *_nl_locale_name (int category, const char *categoryname);
const char *__domainname,
struct binding *__domainbinding))
internal_function;
void _nl_load_domain PARAMS ((struct loaded_l10nfile *__domain,
struct binding *__domainbinding))
internal_function;
void _nl_unload_domain PARAMS ((struct loaded_domain *__domain))
internal_function;
const char *_nl_init_domain_conv PARAMS ((struct loaded_l10nfile *__domain_file,
struct loaded_domain *__domain,
struct binding *__domainbinding))
internal_function;
void _nl_free_domain_conv PARAMS ((struct loaded_domain *__domain))
internal_function;
char *_nl_find_msg PARAMS ((struct loaded_l10nfile *domain_file,
struct binding *domainbinding,
const char *msgid, size_t *lengthp))
internal_function;
#ifdef _LIBC
extern char *__gettext PARAMS ((const char *__msgid));
extern char *__dgettext PARAMS ((const char *__domainname,
const char *__msgid));
extern char *__dcgettext PARAMS ((const char *__domainname,
const char *__msgid, int __category));
extern char *__ngettext PARAMS ((const char *__msgid1, const char *__msgid2,
unsigned long int __n));
extern char *__dngettext PARAMS ((const char *__domainname,
const char *__msgid1, const char *__msgid2,
unsigned long int n));
extern char *__dcngettext PARAMS ((const char *__domainname,
const char *__msgid1, const char *__msgid2,
unsigned long int __n, int __category));
extern char *__dcigettext PARAMS ((const char *__domainname,
const char *__msgid1, const char *__msgid2,
int __plural, unsigned long int __n,
int __category));
extern char *__textdomain PARAMS ((const char *__domainname));
extern char *__bindtextdomain PARAMS ((const char *__domainname,
const char *__dirname));
extern char *__bind_textdomain_codeset PARAMS ((const char *__domainname,
const char *__codeset));
#else
extern char *gettext__ PARAMS ((const char *__msgid));
extern char *dgettext__ PARAMS ((const char *__domainname,
const char *__msgid));
extern char *dcgettext__ PARAMS ((const char *__domainname,
const char *__msgid, int __category));
extern char *ngettext__ PARAMS ((const char *__msgid1, const char *__msgid2,
unsigned long int __n));
extern char *dngettext__ PARAMS ((const char *__domainname,
const char *__msgid1, const char *__msgid2,
unsigned long int __n));
extern char *dcngettext__ PARAMS ((const char *__domainname,
const char *__msgid1, const char *__msgid2,
unsigned long int __n, int __category));
extern char *dcigettext__ PARAMS ((const char *__domainname,
const char *__msgid1, const char *__msgid2,
int __plural, unsigned long int __n,
int __category));
extern char *textdomain__ PARAMS ((const char *__domainname));
extern char *bindtextdomain__ PARAMS ((const char *__domainname,
const char *__dirname));
extern char *bind_textdomain_codeset__ PARAMS ((const char *__domainname,
const char *__codeset));
#endif #endif
struct loaded_l10nfile *_nl_find_domain (const char *__dirname, char *__locale,
const char *__domainname,
struct binding *__domainbinding)
internal_function;
void _nl_load_domain (struct loaded_l10nfile *__domain,
struct binding *__domainbinding)
internal_function;
void _nl_unload_domain (struct loaded_domain *__domain)
internal_function;
const char *_nl_init_domain_conv (struct loaded_l10nfile *__domain_file,
struct loaded_domain *__domain,
struct binding *__domainbinding)
internal_function;
void _nl_free_domain_conv (struct loaded_domain *__domain)
internal_function;
char *_nl_find_msg (struct loaded_l10nfile *domain_file,
struct binding *domainbinding, const char *msgid,
size_t *lengthp)
internal_function;
#ifdef _LIBC #ifdef _LIBC
extern void __gettext_free_exp PARAMS ((struct expression *exp)) extern char *__gettext (const char *__msgid);
internal_function; extern char *__dgettext (const char *__domainname, const char *__msgid);
extern int __gettextparse PARAMS ((void *arg)); extern char *__dcgettext (const char *__domainname, const char *__msgid,
int __category);
extern char *__ngettext (const char *__msgid1, const char *__msgid2,
unsigned long int __n);
extern char *__dngettext (const char *__domainname,
const char *__msgid1, const char *__msgid2,
unsigned long int n);
extern char *__dcngettext (const char *__domainname,
const char *__msgid1, const char *__msgid2,
unsigned long int __n, int __category);
extern char *__dcigettext (const char *__domainname,
const char *__msgid1, const char *__msgid2,
int __plural, unsigned long int __n,
int __category);
extern char *__textdomain (const char *__domainname);
extern char *__bindtextdomain (const char *__domainname,
const char *__dirname);
extern char *__bind_textdomain_codeset (const char *__domainname,
const char *__codeset);
#else #else
extern void gettext_free_exp__ PARAMS ((struct expression *exp)) /* Declare the exported libintl_* functions, in a way that allows us to
internal_function; call them under their real name. */
extern int gettextparse__ PARAMS ((void *arg)); # undef _INTL_REDIRECT_INLINE
# undef _INTL_REDIRECT_MACROS
# define _INTL_REDIRECT_MACROS
# include "libgnuintl.h"
extern char *libintl_dcigettext (const char *__domainname,
const char *__msgid1, const char *__msgid2,
int __plural, unsigned long int __n,
int __category);
#endif #endif
/* @@ begin of epilog @@ */ /* @@ begin of epilog @@ */

View File

@ -1,5 +1,5 @@
/* Description of GNU message catalog format: string hashing function. /* Description of GNU message catalog format: string hashing function.
Copyright (C) 1995, 1997, 1998, 2000, 2001 Free Software Foundation, Inc. Copyright (C) 1995, 1997-1998, 2000-2003 Free Software Foundation, Inc.
This program is free software; you can redistribute it and/or modify it This program is free software; you can redistribute it and/or modify it
under the terms of the GNU Library General Public License as published under the terms of the GNU Library General Public License as published
@ -18,14 +18,6 @@
/* @@ end of prolog @@ */ /* @@ end of prolog @@ */
#ifndef PARAMS
# if __STDC__
# define PARAMS(Args) Args
# else
# define PARAMS(Args) ()
# endif
#endif
/* We assume to have `unsigned long int' value with at least 32 bits. */ /* We assume to have `unsigned long int' value with at least 32 bits. */
#define HASHWORDBITS 32 #define HASHWORDBITS 32
@ -33,11 +25,8 @@
/* Defines the so called `hashpjw' function by P.J. Weinberger /* Defines the so called `hashpjw' function by P.J. Weinberger
[see Aho/Sethi/Ullman, COMPILERS: Principles, Techniques and Tools, [see Aho/Sethi/Ullman, COMPILERS: Principles, Techniques and Tools,
1986, 1987 Bell Telephone Laboratories, Inc.] */ 1986, 1987 Bell Telephone Laboratories, Inc.] */
static unsigned long int hash_string PARAMS ((const char *__str_param));
static inline unsigned long int static inline unsigned long int
hash_string (str_param) hash_string (const char *str_param)
const char *str_param;
{ {
unsigned long int hval, g; unsigned long int hval, g;
const char *str = str_param; const char *str = str_param;
@ -47,7 +36,7 @@ hash_string (str_param)
while (*str != '\0') while (*str != '\0')
{ {
hval <<= 4; hval <<= 4;
hval += (unsigned long int) *str++; hval += (unsigned char) *str++;
g = hval & ((unsigned long int) 0xf << (HASHWORDBITS - 4)); g = hval & ((unsigned long int) 0xf << (HASHWORDBITS - 4));
if (g != 0) if (g != 0)
{ {

View File

@ -1,6 +1,6 @@
/* intl-compat.c - Stub functions to call gettext functions from GNU gettext /* intl-compat.c - Stub functions to call gettext functions from GNU gettext
Library. Library.
Copyright (C) 1995, 2000, 2001 Software Foundation, Inc. Copyright (C) 1995, 2000-2003 Software Foundation, Inc.
This program is free software; you can redistribute it and/or modify it This program is free software; you can redistribute it and/or modify it
under the terms of the GNU Library General Public License as published under the terms of the GNU Library General Public License as published
@ -21,52 +21,18 @@
# include <config.h> # include <config.h>
#endif #endif
#include "libgnuintl.h"
#include "gettextP.h" #include "gettextP.h"
/* @@ end of prolog @@ */ /* @@ end of prolog @@ */
/* This file redirects the gettext functions (without prefix or suffix) to /* This file redirects the gettext functions (without prefix) to those
those defined in the included GNU gettext library (with "__" suffix). defined in the included GNU libintl library (with "libintl_" prefix).
It is compiled into libintl when the included GNU gettext library is It is compiled into libintl in order to make the AM_GNU_GETTEXT test
configured --with-included-gettext. of gettext <= 0.11.2 work with the libintl library >= 0.11.3 which
has the redirections primarily in the <libintl.h> include file.
This redirection works also in the case that the system C library or It is also compiled into libgnuintl so that libgnuintl.so can be used
the system libintl library contain gettext/textdomain/... functions. as LD_PRELOADable library on glibc systems, to provide the extra
If it didn't, we would need to add preprocessor level redirections to features that the functions in the libc don't have (namely, logging). */
libgnuintl.h of the following form:
# define gettext gettext__
# define dgettext dgettext__
# define dcgettext dcgettext__
# define ngettext ngettext__
# define dngettext dngettext__
# define dcngettext dcngettext__
# define textdomain textdomain__
# define bindtextdomain bindtextdomain__
# define bind_textdomain_codeset bind_textdomain_codeset__
How does this redirection work? There are two cases.
A. When libintl.a is linked into an executable, it works because
functions defined in the executable always override functions in
the shared libraries.
B. When libintl.so is used, it works because
1. those systems defining gettext/textdomain/... in the C library
(namely, Solaris 2.4 and newer, and GNU libc 2.0 and newer) are
ELF systems and define these symbols as weak, thus explicitly
letting other shared libraries override it.
2. those systems defining gettext/textdomain/... in a standalone
libintl.so library (namely, Solaris 2.3 and newer) have this
shared library in /usr/lib, and the linker will search /usr/lib
*after* the directory where the GNU gettext library is installed.
A third case, namely when libintl.a is linked into a shared library
whose name is not libintl.so, is not supported. In this case, on
Solaris, when -lintl precedes the linker option for the shared library
containing GNU gettext, the system's gettext would indeed override
the GNU gettext. Anyone doing this kind of stuff must be clever enough
to 1. compile libintl.a with -fPIC, 2. remove -lintl from his linker
command line. */
#undef gettext #undef gettext
@ -80,87 +46,86 @@
#undef bind_textdomain_codeset #undef bind_textdomain_codeset
/* When building a DLL, we must export some functions. Note that because
the functions are only defined for binary backward compatibility, we
don't need to use __declspec(dllimport) in any case. */
#if defined _MSC_VER && BUILDING_DLL
# define DLL_EXPORTED __declspec(dllexport)
#else
# define DLL_EXPORTED
#endif
DLL_EXPORTED
char * char *
gettext (msgid) gettext (const char *msgid)
const char *msgid;
{ {
return gettext__ (msgid); return libintl_gettext (msgid);
} }
DLL_EXPORTED
char * char *
dgettext (domainname, msgid) dgettext (const char *domainname, const char *msgid)
const char *domainname;
const char *msgid;
{ {
return dgettext__ (domainname, msgid); return libintl_dgettext (domainname, msgid);
} }
DLL_EXPORTED
char * char *
dcgettext (domainname, msgid, category) dcgettext (const char *domainname, const char *msgid, int category)
const char *domainname;
const char *msgid;
int category;
{ {
return dcgettext__ (domainname, msgid, category); return libintl_dcgettext (domainname, msgid, category);
} }
DLL_EXPORTED
char * char *
ngettext (msgid1, msgid2, n) ngettext (const char *msgid1, const char *msgid2, unsigned long int n)
const char *msgid1;
const char *msgid2;
unsigned long int n;
{ {
return ngettext__ (msgid1, msgid2, n); return libintl_ngettext (msgid1, msgid2, n);
} }
DLL_EXPORTED
char * char *
dngettext (domainname, msgid1, msgid2, n) dngettext (const char *domainname,
const char *domainname; const char *msgid1, const char *msgid2, unsigned long int n)
const char *msgid1;
const char *msgid2;
unsigned long int n;
{ {
return dngettext__ (domainname, msgid1, msgid2, n); return libintl_dngettext (domainname, msgid1, msgid2, n);
} }
DLL_EXPORTED
char * char *
dcngettext (domainname, msgid1, msgid2, n, category) dcngettext (const char *domainname,
const char *domainname; const char *msgid1, const char *msgid2, unsigned long int n,
const char *msgid1; int category)
const char *msgid2;
unsigned long int n;
int category;
{ {
return dcngettext__ (domainname, msgid1, msgid2, n, category); return libintl_dcngettext (domainname, msgid1, msgid2, n, category);
} }
DLL_EXPORTED
char * char *
textdomain (domainname) textdomain (const char *domainname)
const char *domainname;
{ {
return textdomain__ (domainname); return libintl_textdomain (domainname);
} }
DLL_EXPORTED
char * char *
bindtextdomain (domainname, dirname) bindtextdomain (const char *domainname, const char *dirname)
const char *domainname;
const char *dirname;
{ {
return bindtextdomain__ (domainname, dirname); return libintl_bindtextdomain (domainname, dirname);
} }
DLL_EXPORTED
char * char *
bind_textdomain_codeset (domainname, codeset) bind_textdomain_codeset (const char *domainname, const char *codeset)
const char *domainname;
const char *codeset;
{ {
return bind_textdomain_codeset__ (domainname, codeset); return libintl_bind_textdomain_codeset (domainname, codeset);
} }

View File

@ -1,4 +1,4 @@
/* Copyright (C) 1995-1999, 2000, 2001 Free Software Foundation, Inc. /* Copyright (C) 1995-1999, 2000-2003 Free Software Foundation, Inc.
Contributed by Ulrich Drepper <drepper@gnu.ai.mit.edu>, 1995. Contributed by Ulrich Drepper <drepper@gnu.ai.mit.edu>, 1995.
This program is free software; you can redistribute it and/or modify it This program is free software; you can redistribute it and/or modify it
@ -28,11 +28,6 @@
#endif #endif
#include <string.h> #include <string.h>
#if !HAVE_STRCHR && !defined _LIBC
# ifndef strchr
# define strchr index
# endif
#endif
#if defined _LIBC || defined HAVE_ARGZ_H #if defined _LIBC || defined HAVE_ARGZ_H
# include <argz.h> # include <argz.h>
@ -63,20 +58,34 @@
# endif # endif
#else #else
# ifndef HAVE_STPCPY # ifndef HAVE_STPCPY
static char *stpcpy PARAMS ((char *dest, const char *src)); static char *stpcpy (char *dest, const char *src);
# endif # endif
#endif #endif
/* Pathname support.
ISSLASH(C) tests whether C is a directory separator character.
IS_ABSOLUTE_PATH(P) tests whether P is an absolute path. If it is not,
it may be concatenated to a directory pathname.
*/
#if defined _WIN32 || defined __WIN32__ || defined __EMX__ || defined __DJGPP__
/* Win32, OS/2, DOS */
# define ISSLASH(C) ((C) == '/' || (C) == '\\')
# define HAS_DEVICE(P) \
((((P)[0] >= 'A' && (P)[0] <= 'Z') || ((P)[0] >= 'a' && (P)[0] <= 'z')) \
&& (P)[1] == ':')
# define IS_ABSOLUTE_PATH(P) (ISSLASH ((P)[0]) || HAS_DEVICE (P))
#else
/* Unix */
# define ISSLASH(C) ((C) == '/')
# define IS_ABSOLUTE_PATH(P) ISSLASH ((P)[0])
#endif
/* Define function which are usually not available. */ /* Define function which are usually not available. */
#if !defined _LIBC && !defined HAVE___ARGZ_COUNT #if !defined _LIBC && !defined HAVE___ARGZ_COUNT
/* Returns the number of strings in ARGZ. */ /* Returns the number of strings in ARGZ. */
static size_t argz_count__ PARAMS ((const char *argz, size_t len));
static size_t static size_t
argz_count__ (argz, len) argz_count__ (const char *argz, size_t len)
const char *argz;
size_t len;
{ {
size_t count = 0; size_t count = 0;
while (len > 0) while (len > 0)
@ -90,18 +99,17 @@ argz_count__ (argz, len)
} }
# undef __argz_count # undef __argz_count
# define __argz_count(argz, len) argz_count__ (argz, len) # define __argz_count(argz, len) argz_count__ (argz, len)
#else
# ifdef _LIBC
# define __argz_count(argz, len) INTUSE(__argz_count) (argz, len)
# endif
#endif /* !_LIBC && !HAVE___ARGZ_COUNT */ #endif /* !_LIBC && !HAVE___ARGZ_COUNT */
#if !defined _LIBC && !defined HAVE___ARGZ_STRINGIFY #if !defined _LIBC && !defined HAVE___ARGZ_STRINGIFY
/* Make '\0' separated arg vector ARGZ printable by converting all the '\0's /* Make '\0' separated arg vector ARGZ printable by converting all the '\0's
except the last into the character SEP. */ except the last into the character SEP. */
static void argz_stringify__ PARAMS ((char *argz, size_t len, int sep));
static void static void
argz_stringify__ (argz, len, sep) argz_stringify__ (char *argz, size_t len, int sep)
char *argz;
size_t len;
int sep;
{ {
while (len > 0) while (len > 0)
{ {
@ -114,17 +122,16 @@ argz_stringify__ (argz, len, sep)
} }
# undef __argz_stringify # undef __argz_stringify
# define __argz_stringify(argz, len, sep) argz_stringify__ (argz, len, sep) # define __argz_stringify(argz, len, sep) argz_stringify__ (argz, len, sep)
#else
# ifdef _LIBC
# define __argz_stringify(argz, len, sep) \
INTUSE(__argz_stringify) (argz, len, sep)
# endif
#endif /* !_LIBC && !HAVE___ARGZ_STRINGIFY */ #endif /* !_LIBC && !HAVE___ARGZ_STRINGIFY */
#if !defined _LIBC && !defined HAVE___ARGZ_NEXT #if !defined _LIBC && !defined HAVE___ARGZ_NEXT
static char *argz_next__ PARAMS ((char *argz, size_t argz_len,
const char *entry));
static char * static char *
argz_next__ (argz, argz_len, entry) argz_next__ (char *argz, size_t argz_len, const char *entry)
char *argz;
size_t argz_len;
const char *entry;
{ {
if (entry) if (entry)
{ {
@ -145,11 +152,8 @@ argz_next__ (argz, argz_len, entry)
/* Return number of bits set in X. */ /* Return number of bits set in X. */
static int pop PARAMS ((int x));
static inline int static inline int
pop (x) pop (int x)
int x;
{ {
/* We assume that no more than 16 bits are used. */ /* We assume that no more than 16 bits are used. */
x = ((x & ~0x5555) >> 1) + (x & 0x5555); x = ((x & ~0x5555) >> 1) + (x & 0x5555);
@ -162,31 +166,27 @@ pop (x)
struct loaded_l10nfile * struct loaded_l10nfile *
_nl_make_l10nflist (l10nfile_list, dirlist, dirlist_len, mask, language, _nl_make_l10nflist (struct loaded_l10nfile **l10nfile_list,
territory, codeset, normalized_codeset, modifier, special, const char *dirlist, size_t dirlist_len,
sponsor, revision, filename, do_allocate) int mask, const char *language, const char *territory,
struct loaded_l10nfile **l10nfile_list; const char *codeset, const char *normalized_codeset,
const char *dirlist; const char *modifier, const char *special,
size_t dirlist_len; const char *sponsor, const char *revision,
int mask; const char *filename, int do_allocate)
const char *language;
const char *territory;
const char *codeset;
const char *normalized_codeset;
const char *modifier;
const char *special;
const char *sponsor;
const char *revision;
const char *filename;
int do_allocate;
{ {
char *abs_filename; char *abs_filename;
struct loaded_l10nfile *last = NULL; struct loaded_l10nfile **lastp;
struct loaded_l10nfile *retval; struct loaded_l10nfile *retval;
char *cp; char *cp;
size_t dirlist_count;
size_t entries; size_t entries;
int cnt; int cnt;
/* If LANGUAGE contains an absolute directory specification, we ignore
DIRLIST. */
if (IS_ABSOLUTE_PATH (language))
dirlist_len = 0;
/* Allocate room for the full file name. */ /* Allocate room for the full file name. */
abs_filename = (char *) malloc (dirlist_len abs_filename = (char *) malloc (dirlist_len
+ strlen (language) + strlen (language)
@ -204,7 +204,7 @@ _nl_make_l10nflist (l10nfile_list, dirlist, dirlist_len, mask, language,
+ (((mask & CEN_SPONSOR) != 0 + (((mask & CEN_SPONSOR) != 0
|| (mask & CEN_REVISION) != 0) || (mask & CEN_REVISION) != 0)
? (1 + ((mask & CEN_SPONSOR) != 0 ? (1 + ((mask & CEN_SPONSOR) != 0
? strlen (sponsor) + 1 : 0) ? strlen (sponsor) : 0)
+ ((mask & CEN_REVISION) != 0 + ((mask & CEN_REVISION) != 0
? strlen (revision) + 1 : 0)) : 0) ? strlen (revision) + 1 : 0)) : 0)
+ 1 + strlen (filename) + 1); + 1 + strlen (filename) + 1);
@ -212,14 +212,16 @@ _nl_make_l10nflist (l10nfile_list, dirlist, dirlist_len, mask, language,
if (abs_filename == NULL) if (abs_filename == NULL)
return NULL; return NULL;
retval = NULL;
last = NULL;
/* Construct file name. */ /* Construct file name. */
memcpy (abs_filename, dirlist, dirlist_len); cp = abs_filename;
__argz_stringify (abs_filename, dirlist_len, PATH_SEPARATOR); if (dirlist_len > 0)
cp = abs_filename + (dirlist_len - 1); {
*cp++ = '/'; memcpy (cp, dirlist, dirlist_len);
__argz_stringify (cp, dirlist_len, PATH_SEPARATOR);
cp += dirlist_len;
cp[-1] = '/';
}
cp = stpcpy (cp, language); cp = stpcpy (cp, language);
if ((mask & TERRITORY) != 0) if ((mask & TERRITORY) != 0)
@ -266,7 +268,7 @@ _nl_make_l10nflist (l10nfile_list, dirlist, dirlist_len, mask, language,
/* Look in list of already loaded domains whether it is already /* Look in list of already loaded domains whether it is already
available. */ available. */
last = NULL; lastp = l10nfile_list;
for (retval = *l10nfile_list; retval != NULL; retval = retval->next) for (retval = *l10nfile_list; retval != NULL; retval = retval->next)
if (retval->filename != NULL) if (retval->filename != NULL)
{ {
@ -281,7 +283,7 @@ _nl_make_l10nflist (l10nfile_list, dirlist, dirlist_len, mask, language,
break; break;
} }
last = retval; lastp = &retval->next;
} }
if (retval != NULL || do_allocate == 0) if (retval != NULL || do_allocate == 0)
@ -290,39 +292,50 @@ _nl_make_l10nflist (l10nfile_list, dirlist, dirlist_len, mask, language,
return retval; return retval;
} }
retval = (struct loaded_l10nfile *) dirlist_count = (dirlist_len > 0 ? __argz_count (dirlist, dirlist_len) : 1);
malloc (sizeof (*retval) + (__argz_count (dirlist, dirlist_len)
* (1 << pop (mask)) /* Allocate a new loaded_l10nfile. */
retval =
(struct loaded_l10nfile *)
malloc (sizeof (*retval)
+ (((dirlist_count << pop (mask)) + (dirlist_count > 1 ? 1 : 0))
* sizeof (struct loaded_l10nfile *))); * sizeof (struct loaded_l10nfile *)));
if (retval == NULL) if (retval == NULL)
return NULL; return NULL;
retval->filename = abs_filename; retval->filename = abs_filename;
retval->decided = (__argz_count (dirlist, dirlist_len) != 1
/* We set retval->data to NULL here; it is filled in later.
Setting retval->decided to 1 here means that retval does not
correspond to a real file (dirlist_count > 1) or is not worth
looking up (if an unnormalized codeset was specified). */
retval->decided = (dirlist_count > 1
|| ((mask & XPG_CODESET) != 0 || ((mask & XPG_CODESET) != 0
&& (mask & XPG_NORM_CODESET) != 0)); && (mask & XPG_NORM_CODESET) != 0));
retval->data = NULL; retval->data = NULL;
if (last == NULL) retval->next = *lastp;
{ *lastp = retval;
retval->next = *l10nfile_list;
*l10nfile_list = retval;
}
else
{
retval->next = last->next;
last->next = retval;
}
entries = 0; entries = 0;
/* If the DIRLIST is a real list the RETVAL entry corresponds not to /* Recurse to fill the inheritance list of RETVAL.
a real file. So we have to use the DIRLIST separation mechanism If the DIRLIST is a real list (i.e. DIRLIST_COUNT > 1), the RETVAL
of the inner loop. */ entry does not correspond to a real file; retval->filename contains
cnt = __argz_count (dirlist, dirlist_len) == 1 ? mask - 1 : mask; colons. In this case we loop across all elements of DIRLIST and
for (; cnt >= 0; --cnt) across all bit patterns dominated by MASK.
If the DIRLIST is a single directory or entirely redundant (i.e.
DIRLIST_COUNT == 1), we loop across all bit patterns dominated by
MASK, excluding MASK itself.
In either case, we loop down from MASK to 0. This has the effect
that the extra bits in the locale name are dropped in this order:
first the modifier, then the territory, then the codeset, then the
normalized_codeset. */
for (cnt = dirlist_count > 1 ? mask : mask - 1; cnt >= 0; --cnt)
if ((cnt & ~mask) == 0 if ((cnt & ~mask) == 0
&& ((cnt & CEN_SPECIFIC) == 0 || (cnt & XPG_SPECIFIC) == 0) && ((cnt & CEN_SPECIFIC) == 0 || (cnt & XPG_SPECIFIC) == 0)
&& ((cnt & XPG_CODESET) == 0 || (cnt & XPG_NORM_CODESET) == 0)) && ((cnt & XPG_CODESET) == 0 || (cnt & XPG_NORM_CODESET) == 0))
{
if (dirlist_count > 1)
{ {
/* Iterate over all elements of the DIRLIST. */ /* Iterate over all elements of the DIRLIST. */
char *dir = NULL; char *dir = NULL;
@ -330,8 +343,15 @@ _nl_make_l10nflist (l10nfile_list, dirlist, dirlist_len, mask, language,
while ((dir = __argz_next ((char *) dirlist, dirlist_len, dir)) while ((dir = __argz_next ((char *) dirlist, dirlist_len, dir))
!= NULL) != NULL)
retval->successor[entries++] retval->successor[entries++]
= _nl_make_l10nflist (l10nfile_list, dir, strlen (dir) + 1, cnt, = _nl_make_l10nflist (l10nfile_list, dir, strlen (dir) + 1,
language, territory, codeset, cnt, language, territory, codeset,
normalized_codeset, modifier, special,
sponsor, revision, filename, 1);
}
else
retval->successor[entries++]
= _nl_make_l10nflist (l10nfile_list, dirlist, dirlist_len,
cnt, language, territory, codeset,
normalized_codeset, modifier, special, normalized_codeset, modifier, special,
sponsor, revision, filename, 1); sponsor, revision, filename, 1);
} }
@ -345,9 +365,7 @@ _nl_make_l10nflist (l10nfile_list, dirlist, dirlist_len, mask, language,
names. The return value is dynamically allocated and has to be names. The return value is dynamically allocated and has to be
freed by the caller. */ freed by the caller. */
const char * const char *
_nl_normalize_codeset (codeset, name_len) _nl_normalize_codeset (const char *codeset, size_t name_len)
const char *codeset;
size_t name_len;
{ {
int len = 0; int len = 0;
int only_digit = 1; int only_digit = 1;
@ -356,11 +374,11 @@ _nl_normalize_codeset (codeset, name_len)
size_t cnt; size_t cnt;
for (cnt = 0; cnt < name_len; ++cnt) for (cnt = 0; cnt < name_len; ++cnt)
if (isalnum (codeset[cnt])) if (isalnum ((unsigned char) codeset[cnt]))
{ {
++len; ++len;
if (isalpha (codeset[cnt])) if (isalpha ((unsigned char) codeset[cnt]))
only_digit = 0; only_digit = 0;
} }
@ -374,9 +392,9 @@ _nl_normalize_codeset (codeset, name_len)
wp = retval; wp = retval;
for (cnt = 0; cnt < name_len; ++cnt) for (cnt = 0; cnt < name_len; ++cnt)
if (isalpha (codeset[cnt])) if (isalpha ((unsigned char) codeset[cnt]))
*wp++ = tolower (codeset[cnt]); *wp++ = tolower ((unsigned char) codeset[cnt]);
else if (isdigit (codeset[cnt])) else if (isdigit ((unsigned char) codeset[cnt]))
*wp++ = codeset[cnt]; *wp++ = codeset[cnt];
*wp = '\0'; *wp = '\0';
@ -394,9 +412,7 @@ _nl_normalize_codeset (codeset, name_len)
to be defined. */ to be defined. */
#if !_LIBC && !HAVE_STPCPY #if !_LIBC && !HAVE_STPCPY
static char * static char *
stpcpy (dest, src) stpcpy (char *dest, const char *src)
char *dest;
const char *src;
{ {
while ((*dest++ = *src++) != '\0') while ((*dest++ = *src++) != '\0')
/* Do nothing. */ ; /* Do nothing. */ ;

View File

@ -1,4 +1,4 @@
/* Copyright (C) 1996-1999, 2000, 2001 Free Software Foundation, Inc. /* Copyright (C) 1996-1999, 2000-2003 Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@cygnus.com>, 1996. Contributed by Ulrich Drepper <drepper@cygnus.com>, 1996.
@ -20,13 +20,17 @@
#ifndef _LOADINFO_H #ifndef _LOADINFO_H
#define _LOADINFO_H 1 #define _LOADINFO_H 1
#ifndef PARAMS /* Declarations of locale dependent catalog lookup functions.
# if __STDC__ Implemented in
# define PARAMS(args) args
# else localealias.c Possibly replace a locale name by another.
# define PARAMS(args) () explodename.c Split a locale name into its various fields.
# endif l10nflist.c Generate a list of filenames of possible message catalogs.
#endif finddomain.c Find and open the relevant message catalogs.
The main function _nl_find_domain() in finddomain.c is declared
in gettextP.h.
*/
#ifndef internal_function #ifndef internal_function
# define internal_function # define internal_function
@ -77,33 +81,65 @@ struct loaded_l10nfile
names. Normalization allows the user to use any of the common names. Normalization allows the user to use any of the common
names. The return value is dynamically allocated and has to be names. The return value is dynamically allocated and has to be
freed by the caller. */ freed by the caller. */
extern const char *_nl_normalize_codeset PARAMS ((const char *codeset, extern const char *_nl_normalize_codeset (const char *codeset,
size_t name_len)); size_t name_len);
/* Lookup a locale dependent file.
*L10NFILE_LIST denotes a pool of lookup results of locale dependent
files of the same kind, sorted in decreasing order of ->filename.
DIRLIST and DIRLIST_LEN are an argz list of directories in which to
look, containing at least one directory (i.e. DIRLIST_LEN > 0).
MASK, LANGUAGE, TERRITORY, CODESET, NORMALIZED_CODESET, MODIFIER,
SPECIAL, SPONSOR, REVISION are the pieces of the locale name, as
produced by _nl_explode_name(). FILENAME is the filename suffix.
The return value is the lookup result, either found in *L10NFILE_LIST,
or - if DO_ALLOCATE is nonzero - freshly allocated, or possibly NULL.
If the return value is non-NULL, it is added to *L10NFILE_LIST, and
its ->next field denotes the chaining inside *L10NFILE_LIST, and
furthermore its ->successor[] field contains a list of other lookup
results from which this lookup result inherits. */
extern struct loaded_l10nfile * extern struct loaded_l10nfile *
_nl_make_l10nflist PARAMS ((struct loaded_l10nfile **l10nfile_list, _nl_make_l10nflist (struct loaded_l10nfile **l10nfile_list,
const char *dirlist, size_t dirlist_len, int mask, const char *dirlist, size_t dirlist_len, int mask,
const char *language, const char *territory, const char *language, const char *territory,
const char *codeset, const char *codeset, const char *normalized_codeset,
const char *normalized_codeset,
const char *modifier, const char *special, const char *modifier, const char *special,
const char *sponsor, const char *revision, const char *sponsor, const char *revision,
const char *filename, int do_allocate)); const char *filename, int do_allocate);
/* Lookup the real locale name for a locale alias NAME, or NULL if
NAME is not a locale alias (but possibly a real locale name).
The return value is statically allocated and must not be freed. */
extern const char *_nl_expand_alias (const char *name);
extern const char *_nl_expand_alias PARAMS ((const char *name)); /* Split a locale name NAME into its pieces: language, modifier,
territory, codeset, special, sponsor, revision.
/* normalized_codeset is dynamically allocated and has to be freed by NAME gets destructively modified: NUL bytes are inserted here and
the caller. */ there. *LANGUAGE gets assigned NAME. Each of *MODIFIER, *TERRITORY,
extern int _nl_explode_name PARAMS ((char *name, const char **language, *CODESET, *SPECIAL, *SPONSOR, *REVISION gets assigned either a
const char **modifier, pointer into the old NAME string, or NULL. *NORMALIZED_CODESET
const char **territory, gets assigned the expanded *CODESET, if it is different from *CODESET;
this one is dynamically allocated and has to be freed by the caller.
The return value is a bitmask, where each bit corresponds to one
filled-in value:
XPG_MODIFIER, CEN_AUDIENCE for *MODIFIER,
TERRITORY for *TERRITORY,
XPG_CODESET for *CODESET,
XPG_NORM_CODESET for *NORMALIZED_CODESET,
CEN_SPECIAL for *SPECIAL,
CEN_SPONSOR for *SPONSOR,
CEN_REVISION for *REVISION.
*/
extern int _nl_explode_name (char *name, const char **language,
const char **modifier, const char **territory,
const char **codeset, const char **codeset,
const char **normalized_codeset, const char **normalized_codeset,
const char **special, const char **special, const char **sponsor,
const char **sponsor, const char **revision);
const char **revision));
extern char *_nl_find_language PARAMS ((const char *name)); /* Split a locale name NAME into a leading language part and all the
rest. Return a pointer to the first character after the language,
i.e. to the first byte of the rest. */
extern char *_nl_find_language (const char *name);
#endif /* loadinfo.h */ #endif /* loadinfo.h */

File diff suppressed because it is too large Load Diff

View File

@ -1,6 +1,6 @@
/* Determine a canonical name for the current locale's character encoding. /* Determine a canonical name for the current locale's character encoding.
Copyright (C) 2000-2001 Free Software Foundation, Inc. Copyright (C) 2000-2003 Free Software Foundation, Inc.
This program is free software; you can redistribute it and/or modify it This program is free software; you can redistribute it and/or modify it
under the terms of the GNU Library General Public License as published under the terms of the GNU Library General Public License as published
@ -17,12 +17,15 @@
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
USA. */ USA. */
/* Written by Bruno Haible <haible@clisp.cons.org>. */ /* Written by Bruno Haible <bruno@clisp.org>. */
#ifdef HAVE_CONFIG_H #ifdef HAVE_CONFIG_H
# include <config.h> # include <config.h>
#endif #endif
/* Specification. */
#include "localcharset.h"
#if HAVE_STDDEF_H #if HAVE_STDDEF_H
# include <stddef.h> # include <stddef.h>
#endif #endif
@ -42,7 +45,12 @@
# define WIN32 # define WIN32
#endif #endif
#ifndef WIN32 #if defined __EMX__
/* Assume EMX program runs on OS/2, even if compiled under DOS. */
# define OS2
#endif
#if !defined WIN32
# if HAVE_LANGINFO_CODESET # if HAVE_LANGINFO_CODESET
# include <langinfo.h> # include <langinfo.h>
# else # else
@ -50,10 +58,25 @@
# include <locale.h> # include <locale.h>
# endif # endif
# endif # endif
#else /* WIN32 */ #elif defined WIN32
# define WIN32_LEAN_AND_MEAN # define WIN32_LEAN_AND_MEAN
# include <windows.h> # include <windows.h>
#endif #endif
#if defined OS2
# define INCL_DOS
# include <os2.h>
#endif
#if ENABLE_RELOCATABLE
# include "relocatable.h"
#else
# define relocate(pathname) (pathname)
#endif
#if defined _WIN32 || defined __WIN32__ || defined __EMX__ || defined __DJGPP__
/* Win32, OS/2, DOS */
# define ISSLASH(C) ((C) == '/' || (C) == '\\')
#endif
#ifndef DIRECTORY_SEPARATOR #ifndef DIRECTORY_SEPARATOR
# define DIRECTORY_SEPARATOR '/' # define DIRECTORY_SEPARATOR '/'
@ -63,6 +86,11 @@
# define ISSLASH(C) ((C) == DIRECTORY_SEPARATOR) # define ISSLASH(C) ((C) == DIRECTORY_SEPARATOR)
#endif #endif
#if HAVE_DECL_GETC_UNLOCKED
# undef getc
# define getc getc_unlocked
#endif
/* The following static variable is declared 'volatile' to avoid a /* The following static variable is declared 'volatile' to avoid a
possible multithread problem in the function get_charset_aliases. If we possible multithread problem in the function get_charset_aliases. If we
are running in a threaded environment, and if two threads initialize are running in a threaded environment, and if two threads initialize
@ -86,9 +114,9 @@ get_charset_aliases ()
cp = charset_aliases; cp = charset_aliases;
if (cp == NULL) if (cp == NULL)
{ {
#ifndef WIN32 #if !(defined VMS || defined WIN32)
FILE *fp; FILE *fp;
const char *dir = LIBDIR; const char *dir = relocate (LIBDIR);
const char *base = "charset.alias"; const char *base = "charset.alias";
char *file_name; char *file_name;
@ -145,12 +173,12 @@ get_charset_aliases ()
if (res_size == 0) if (res_size == 0)
{ {
res_size = l1 + 1 + l2 + 1; res_size = l1 + 1 + l2 + 1;
res_ptr = malloc (res_size + 1); res_ptr = (char *) malloc (res_size + 1);
} }
else else
{ {
res_size += l1 + 1 + l2 + 1; res_size += l1 + 1 + l2 + 1;
res_ptr = realloc (res_ptr, res_size + 1); res_ptr = (char *) realloc (res_ptr, res_size + 1);
} }
if (res_ptr == NULL) if (res_ptr == NULL)
{ {
@ -174,14 +202,54 @@ get_charset_aliases ()
if (file_name != NULL) if (file_name != NULL)
free (file_name); free (file_name);
#else /* WIN32 */ #else
# if defined VMS
/* To avoid the troubles of an extra file charset.alias_vms in the
sources of many GNU packages, simply inline the aliases here. */
/* The list of encodings is taken from the OpenVMS 7.3-1 documentation
"Compaq C Run-Time Library Reference Manual for OpenVMS systems"
section 10.7 "Handling Different Character Sets". */
cp = "ISO8859-1" "\0" "ISO-8859-1" "\0"
"ISO8859-2" "\0" "ISO-8859-2" "\0"
"ISO8859-5" "\0" "ISO-8859-5" "\0"
"ISO8859-7" "\0" "ISO-8859-7" "\0"
"ISO8859-8" "\0" "ISO-8859-8" "\0"
"ISO8859-9" "\0" "ISO-8859-9" "\0"
/* Japanese */
"eucJP" "\0" "EUC-JP" "\0"
"SJIS" "\0" "SHIFT_JIS" "\0"
"DECKANJI" "\0" "DEC-KANJI" "\0"
"SDECKANJI" "\0" "EUC-JP" "\0"
/* Chinese */
"eucTW" "\0" "EUC-TW" "\0"
"DECHANYU" "\0" "DEC-HANYU" "\0"
"DECHANZI" "\0" "GB2312" "\0"
/* Korean */
"DECKOREAN" "\0" "EUC-KR" "\0";
# endif
# if defined WIN32
/* To avoid the troubles of installing a separate file in the same /* To avoid the troubles of installing a separate file in the same
directory as the DLL and of retrieving the DLL's directory at directory as the DLL and of retrieving the DLL's directory at
runtime, simply inline the aliases here. */ runtime, simply inline the aliases here. */
cp = "CP936" "\0" "GBK" "\0" cp = "CP936" "\0" "GBK" "\0"
"CP1361" "\0" "JOHAB" "\0"; "CP1361" "\0" "JOHAB" "\0"
"CP20127" "\0" "ASCII" "\0"
"CP20866" "\0" "KOI8-R" "\0"
"CP21866" "\0" "KOI8-RU" "\0"
"CP28591" "\0" "ISO-8859-1" "\0"
"CP28592" "\0" "ISO-8859-2" "\0"
"CP28593" "\0" "ISO-8859-3" "\0"
"CP28594" "\0" "ISO-8859-4" "\0"
"CP28595" "\0" "ISO-8859-5" "\0"
"CP28596" "\0" "ISO-8859-6" "\0"
"CP28597" "\0" "ISO-8859-7" "\0"
"CP28598" "\0" "ISO-8859-8" "\0"
"CP28599" "\0" "ISO-8859-9" "\0"
"CP28605" "\0" "ISO-8859-15" "\0";
# endif
#endif #endif
charset_aliases = cp; charset_aliases = cp;
@ -205,7 +273,7 @@ locale_charset ()
const char *codeset; const char *codeset;
const char *aliases; const char *aliases;
#ifndef WIN32 #if !(defined WIN32 || defined OS2)
# if HAVE_LANGINFO_CODESET # if HAVE_LANGINFO_CODESET
@ -242,14 +310,67 @@ locale_charset ()
# endif # endif
#else /* WIN32 */ #elif defined WIN32
static char buf[2 + 10 + 1]; static char buf[2 + 10 + 1];
/* Win32 has a function returning the locale's codepage as a number. */ /* Woe32 has a function returning the locale's codepage as a number. */
sprintf (buf, "CP%u", GetACP ()); sprintf (buf, "CP%u", GetACP ());
codeset = buf; codeset = buf;
#elif defined OS2
const char *locale;
static char buf[2 + 10 + 1];
ULONG cp[3];
ULONG cplen;
/* Allow user to override the codeset, as set in the operating system,
with standard language environment variables. */
locale = getenv ("LC_ALL");
if (locale == NULL || locale[0] == '\0')
{
locale = getenv ("LC_CTYPE");
if (locale == NULL || locale[0] == '\0')
locale = getenv ("LANG");
}
if (locale != NULL && locale[0] != '\0')
{
/* If the locale name contains an encoding after the dot, return it. */
const char *dot = strchr (locale, '.');
if (dot != NULL)
{
const char *modifier;
dot++;
/* Look for the possible @... trailer and remove it, if any. */
modifier = strchr (dot, '@');
if (modifier == NULL)
return dot;
if (modifier - dot < sizeof (buf))
{
memcpy (buf, dot, modifier - dot);
buf [modifier - dot] = '\0';
return buf;
}
}
/* Resolve through the charset.alias file. */
codeset = locale;
}
else
{
/* OS/2 has a function returning the locale's codepage as a number. */
if (DosQueryCp (sizeof (cp), cp, &cplen))
codeset = "";
else
{
sprintf (buf, "CP%u", cp[0]);
codeset = buf;
}
}
#endif #endif
if (codeset == NULL) if (codeset == NULL)
@ -267,5 +388,11 @@ locale_charset ()
break; break;
} }
/* Don't return an empty string. GNU libc and GNU libiconv interpret
the empty string as denoting "the locale's character encoding",
thus GNU libiconv would call this function a second time. */
if (codeset[0] == '\0')
codeset = "ASCII";
return codeset; return codeset;
} }

View File

@ -1,5 +1,5 @@
# Locale name alias data base. # Locale name alias data base.
# Copyright (C) 1996,1997,1998,1999,2000,2001 Free Software Foundation, Inc. # Copyright (C) 1996-2001,2003 Free Software Foundation, Inc.
# #
# This program is free software; you can redistribute it and/or modify it # This program is free software; you can redistribute it and/or modify it
# under the terms of the GNU Library General Public License as published # under the terms of the GNU Library General Public License as published
@ -29,8 +29,8 @@
# Packages using this file: # Packages using this file:
bokmal no_NO.ISO-8859-1 bokmal nb_NO.ISO-8859-1
bokmål no_NO.ISO-8859-1 bokmål nb_NO.ISO-8859-1
catalan ca_ES.ISO-8859-1 catalan ca_ES.ISO-8859-1
croatian hr_HR.ISO-8859-2 croatian hr_HR.ISO-8859-2
czech cs_CZ.ISO-8859-2 czech cs_CZ.ISO-8859-2
@ -61,9 +61,9 @@ korean ko_KR.eucKR
korean.euc ko_KR.eucKR korean.euc ko_KR.eucKR
ko_KR ko_KR.eucKR ko_KR ko_KR.eucKR
lithuanian lt_LT.ISO-8859-13 lithuanian lt_LT.ISO-8859-13
nb_NO no_NO.ISO-8859-1 no_NO nb_NO.ISO-8859-1
nb_NO.ISO-8859-1 no_NO.ISO-8859-1 no_NO.ISO-8859-1 nb_NO.ISO-8859-1
norwegian no_NO.ISO-8859-1 norwegian nb_NO.ISO-8859-1
nynorsk nn_NO.ISO-8859-1 nynorsk nn_NO.ISO-8859-1
polish pl_PL.ISO-8859-2 polish pl_PL.ISO-8859-2
portuguese pt_PT.ISO-8859-1 portuguese pt_PT.ISO-8859-1

View File

@ -1,5 +1,5 @@
/* Handle aliases for locale names. /* Handle aliases for locale names.
Copyright (C) 1995-1999, 2000, 2001 Free Software Foundation, Inc. Copyright (C) 1995-1999, 2000-2001, 2003 Free Software Foundation, Inc.
This program is free software; you can redistribute it and/or modify it This program is free software; you can redistribute it and/or modify it
under the terms of the GNU Library General Public License as published under the terms of the GNU Library General Public License as published
@ -29,12 +29,20 @@
#include <ctype.h> #include <ctype.h>
#include <stdio.h> #include <stdio.h>
#if defined _LIBC || defined HAVE___FSETLOCKING
# include <stdio_ext.h>
#endif
#include <sys/types.h> #include <sys/types.h>
#ifdef __GNUC__ #ifdef __GNUC__
# undef alloca
# define alloca __builtin_alloca # define alloca __builtin_alloca
# define HAVE_ALLOCA 1 # define HAVE_ALLOCA 1
#else #else
# ifdef _MSC_VER
# include <malloc.h>
# define alloca _alloca
# else
# if defined HAVE_ALLOCA_H || defined _LIBC # if defined HAVE_ALLOCA_H || defined _LIBC
# include <alloca.h> # include <alloca.h>
# else # else
@ -47,18 +55,19 @@ char *alloca ();
# endif # endif
# endif # endif
# endif # endif
#endif
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#if !HAVE_STRCHR && !defined _LIBC
# ifndef strchr
# define strchr index
# endif
#endif
#include "gettextP.h" #include "gettextP.h"
#if ENABLE_RELOCATABLE
# include "relocatable.h"
#else
# define relocate(pathname) (pathname)
#endif
/* @@ end of prolog @@ */ /* @@ end of prolog @@ */
#ifdef _LIBC #ifdef _LIBC
@ -71,6 +80,7 @@ char *alloca ();
# define mempcpy __mempcpy # define mempcpy __mempcpy
# endif # endif
# define HAVE_MEMPCPY 1 # define HAVE_MEMPCPY 1
# define HAVE___FSETLOCKING 1
/* We need locking here since we can be called from different places. */ /* We need locking here since we can be called from different places. */
# include <bits/libc-lock.h> # include <bits/libc-lock.h>
@ -82,6 +92,15 @@ __libc_lock_define_initialized (static, lock);
# define internal_function # define internal_function
#endif #endif
/* Some optimizations for glibc. */
#ifdef _LIBC
# define FEOF(fp) feof_unlocked (fp)
# define FGETS(buf, n, fp) fgets_unlocked (buf, n, fp)
#else
# define FEOF(fp) feof (fp)
# define FGETS(buf, n, fp) fgets (buf, n, fp)
#endif
/* For those losing systems which don't have `alloca' we have to add /* For those losing systems which don't have `alloca' we have to add
some additional code emulating it. */ some additional code emulating it. */
#ifdef HAVE_ALLOCA #ifdef HAVE_ALLOCA
@ -91,11 +110,11 @@ __libc_lock_define_initialized (static, lock);
# define freea(p) free (p) # define freea(p) free (p)
#endif #endif
#if defined _LIBC_REENTRANT || defined HAVE_FGETS_UNLOCKED #if defined _LIBC_REENTRANT || HAVE_DECL_FGETS_UNLOCKED
# undef fgets # undef fgets
# define fgets(buf, len, s) fgets_unlocked (buf, len, s) # define fgets(buf, len, s) fgets_unlocked (buf, len, s)
#endif #endif
#if defined _LIBC_REENTRANT || defined HAVE_FEOF_UNLOCKED #if defined _LIBC_REENTRANT || HAVE_DECL_FEOF_UNLOCKED
# undef feof # undef feof
# define feof(s) feof_unlocked (s) # define feof(s) feof_unlocked (s)
#endif #endif
@ -108,27 +127,30 @@ struct alias_map
}; };
static char *string_space; #ifndef _LIBC
# define libc_freeres_ptr(decl) decl
#endif
libc_freeres_ptr (static char *string_space);
static size_t string_space_act; static size_t string_space_act;
static size_t string_space_max; static size_t string_space_max;
static struct alias_map *map; libc_freeres_ptr (static struct alias_map *map);
static size_t nmap; static size_t nmap;
static size_t maxmap; static size_t maxmap;
/* Prototypes for local functions. */ /* Prototypes for local functions. */
static size_t read_alias_file PARAMS ((const char *fname, int fname_len)) static size_t read_alias_file (const char *fname, int fname_len)
internal_function; internal_function;
static int extend_alias_table PARAMS ((void)); static int extend_alias_table (void);
static int alias_compare PARAMS ((const struct alias_map *map1, static int alias_compare (const struct alias_map *map1,
const struct alias_map *map2)); const struct alias_map *map2);
const char * const char *
_nl_expand_alias (name) _nl_expand_alias (const char *name)
const char *name;
{ {
static const char *locale_alias_path = LOCALE_ALIAS_PATH; static const char *locale_alias_path;
struct alias_map *retval; struct alias_map *retval;
const char *result = NULL; const char *result = NULL;
size_t added; size_t added;
@ -137,6 +159,9 @@ _nl_expand_alias (name)
__libc_lock_lock (lock); __libc_lock_lock (lock);
#endif #endif
if (locale_alias_path == NULL)
locale_alias_path = LOCALE_ALIAS_PATH;
do do
{ {
struct alias_map item; struct alias_map item;
@ -146,8 +171,8 @@ _nl_expand_alias (name)
if (nmap > 0) if (nmap > 0)
retval = (struct alias_map *) bsearch (&item, map, nmap, retval = (struct alias_map *) bsearch (&item, map, nmap,
sizeof (struct alias_map), sizeof (struct alias_map),
(int (*) PARAMS ((const void *, (int (*) (const void *,
const void *)) const void *)
) alias_compare); ) alias_compare);
else else
retval = NULL; retval = NULL;
@ -189,9 +214,7 @@ _nl_expand_alias (name)
static size_t static size_t
internal_function internal_function
read_alias_file (fname, fname_len) read_alias_file (const char *fname, int fname_len)
const char *fname;
int fname_len;
{ {
FILE *fp; FILE *fp;
char *full_fname; char *full_fname;
@ -207,58 +230,52 @@ read_alias_file (fname, fname_len)
memcpy (&full_fname[fname_len], aliasfile, sizeof aliasfile); memcpy (&full_fname[fname_len], aliasfile, sizeof aliasfile);
#endif #endif
fp = fopen (full_fname, "r"); fp = fopen (relocate (full_fname), "r");
freea (full_fname); freea (full_fname);
if (fp == NULL) if (fp == NULL)
return 0; return 0;
#ifdef HAVE___FSETLOCKING
/* No threads present. */
__fsetlocking (fp, FSETLOCKING_BYCALLER);
#endif
added = 0; added = 0;
while (!feof (fp)) while (!FEOF (fp))
{ {
/* It is a reasonable approach to use a fix buffer here because /* It is a reasonable approach to use a fix buffer here because
a) we are only interested in the first two fields a) we are only interested in the first two fields
b) these fields must be usable as file names and so must not b) these fields must be usable as file names and so must not
be that long be that long
*/ We avoid a multi-kilobyte buffer here since this would use up
char buf[BUFSIZ]; stack space which we might not have if the program ran out of
memory. */
char buf[400];
char *alias; char *alias;
char *value; char *value;
char *cp; char *cp;
if (fgets (buf, sizeof buf, fp) == NULL) if (FGETS (buf, sizeof buf, fp) == NULL)
/* EOF reached. */ /* EOF reached. */
break; break;
/* Possibly not the whole line fits into the buffer. Ignore
the rest of the line. */
if (strchr (buf, '\n') == NULL)
{
char altbuf[BUFSIZ];
do
if (fgets (altbuf, sizeof altbuf, fp) == NULL)
/* Make sure the inner loop will be left. The outer loop
will exit at the `feof' test. */
break;
while (strchr (altbuf, '\n') == NULL);
}
cp = buf; cp = buf;
/* Ignore leading white space. */ /* Ignore leading white space. */
while (isspace (cp[0])) while (isspace ((unsigned char) cp[0]))
++cp; ++cp;
/* A leading '#' signals a comment line. */ /* A leading '#' signals a comment line. */
if (cp[0] != '\0' && cp[0] != '#') if (cp[0] != '\0' && cp[0] != '#')
{ {
alias = cp++; alias = cp++;
while (cp[0] != '\0' && !isspace (cp[0])) while (cp[0] != '\0' && !isspace ((unsigned char) cp[0]))
++cp; ++cp;
/* Terminate alias name. */ /* Terminate alias name. */
if (cp[0] != '\0') if (cp[0] != '\0')
*cp++ = '\0'; *cp++ = '\0';
/* Now look for the beginning of the value. */ /* Now look for the beginning of the value. */
while (isspace (cp[0])) while (isspace ((unsigned char) cp[0]))
++cp; ++cp;
if (cp[0] != '\0') if (cp[0] != '\0')
@ -267,7 +284,7 @@ read_alias_file (fname, fname_len)
size_t value_len; size_t value_len;
value = cp++; value = cp++;
while (cp[0] != '\0' && !isspace (cp[0])) while (cp[0] != '\0' && !isspace ((unsigned char) cp[0]))
++cp; ++cp;
/* Terminate value. */ /* Terminate value. */
if (cp[0] == '\n') if (cp[0] == '\n')
@ -325,6 +342,14 @@ read_alias_file (fname, fname_len)
++added; ++added;
} }
} }
/* Possibly not the whole line fits into the buffer. Ignore
the rest of the line. */
while (strchr (buf, '\n') == NULL)
if (FGETS (buf, sizeof buf, fp) == NULL)
/* Make sure the inner loop will be left. The outer loop
will exit at the `feof' test. */
break;
} }
/* Should we test for ferror()? I think we have to silently ignore /* Should we test for ferror()? I think we have to silently ignore
@ -333,7 +358,7 @@ read_alias_file (fname, fname_len)
if (added > 0) if (added > 0)
qsort (map, nmap, sizeof (struct alias_map), qsort (map, nmap, sizeof (struct alias_map),
(int (*) PARAMS ((const void *, const void *))) alias_compare); (int (*) (const void *, const void *)) alias_compare);
return added; return added;
} }
@ -358,23 +383,8 @@ extend_alias_table ()
} }
#ifdef _LIBC
static void __attribute__ ((unused))
free_mem (void)
{
if (string_space != NULL)
free (string_space);
if (map != NULL)
free (map);
}
text_set_element (__libc_subfreeres, free_mem);
#endif
static int static int
alias_compare (map1, map2) alias_compare (const struct alias_map *map1, const struct alias_map *map2)
const struct alias_map *map1;
const struct alias_map *map2;
{ {
#if defined _LIBC || defined HAVE_STRCASECMP #if defined _LIBC || defined HAVE_STRCASECMP
return strcasecmp (map1->alias, map2->alias); return strcasecmp (map1->alias, map2->alias);

View File

@ -1,5 +1,5 @@
/* Implementation of ngettext(3) function. /* Implementation of ngettext(3) function.
Copyright (C) 1995, 1997, 2000, 2001 Free Software Foundation, Inc. Copyright (C) 1995, 1997, 2000-2003 Free Software Foundation, Inc.
This program is free software; you can redistribute it and/or modify it This program is free software; you can redistribute it and/or modify it
under the terms of the GNU Library General Public License as published under the terms of the GNU Library General Public License as published
@ -46,18 +46,15 @@
# define NGETTEXT __ngettext # define NGETTEXT __ngettext
# define DCNGETTEXT __dcngettext # define DCNGETTEXT __dcngettext
#else #else
# define NGETTEXT ngettext__ # define NGETTEXT libintl_ngettext
# define DCNGETTEXT dcngettext__ # define DCNGETTEXT libintl_dcngettext
#endif #endif
/* Look up MSGID in the current default message catalog for the current /* Look up MSGID in the current default message catalog for the current
LC_MESSAGES locale. If not found, returns MSGID itself (the default LC_MESSAGES locale. If not found, returns MSGID itself (the default
text). */ text). */
char * char *
NGETTEXT (msgid1, msgid2, n) NGETTEXT (const char *msgid1, const char *msgid2, unsigned long int n)
const char *msgid1;
const char *msgid2;
unsigned long int n;
{ {
return DCNGETTEXT (NULL, msgid1, msgid2, n, LC_MESSAGES); return DCNGETTEXT (NULL, msgid1, msgid2, n, LC_MESSAGES);
} }

File diff suppressed because it is too large Load Diff

View File

@ -1,6 +1,6 @@
%{ %{
/* Expression parsing for plural form selection. /* Expression parsing for plural form selection.
Copyright (C) 2000, 2001 Free Software Foundation, Inc. Copyright (C) 2000-2001, 2003 Free Software Foundation, Inc.
Written by Ulrich Drepper <drepper@cygnus.com>, 2000. Written by Ulrich Drepper <drepper@cygnus.com>, 2000.
This program is free software; you can redistribute it and/or modify it This program is free software; you can redistribute it and/or modify it
@ -30,25 +30,21 @@
# include <config.h> # include <config.h>
#endif #endif
#include <stddef.h>
#include <stdlib.h> #include <stdlib.h>
#include "gettextP.h" #include "plural-exp.h"
/* Names for the libintl functions are a problem. They must not clash /* The main function generated by the parser is called __gettextparse,
with existing names and they should follow ANSI C. But this source but we want it to be called PLURAL_PARSE. */
code is also used in GNU C Library where the names have a __ #ifndef _LIBC
prefix. So we have to make a difference here. */ # define __gettextparse PLURAL_PARSE
#ifdef _LIBC
# define FREE_EXPRESSION __gettext_free_exp
#else
# define FREE_EXPRESSION gettext_free_exp__
# define __gettextparse gettextparse__
#endif #endif
#define YYLEX_PARAM &((struct parse_args *) arg)->cp #define YYLEX_PARAM &((struct parse_args *) arg)->cp
#define YYPARSE_PARAM arg #define YYPARSE_PARAM arg
%} %}
%pure_parser %pure_parser
%expect 10 %expect 7
%union { %union {
unsigned long int num; unsigned long int num;
@ -58,28 +54,13 @@
%{ %{
/* Prototypes for local functions. */ /* Prototypes for local functions. */
static struct expression *new_exp PARAMS ((int nargs, enum operator op, static int yylex (YYSTYPE *lval, const char **pexp);
struct expression * const *args)); static void yyerror (const char *str);
static inline struct expression *new_exp_0 PARAMS ((enum operator op));
static inline struct expression *new_exp_1 PARAMS ((enum operator op,
struct expression *right));
static struct expression *new_exp_2 PARAMS ((enum operator op,
struct expression *left,
struct expression *right));
static inline struct expression *new_exp_3 PARAMS ((enum operator op,
struct expression *bexp,
struct expression *tbranch,
struct expression *fbranch));
static int yylex PARAMS ((YYSTYPE *lval, const char **pexp));
static void yyerror PARAMS ((const char *str));
/* Allocation of expressions. */ /* Allocation of expressions. */
static struct expression * static struct expression *
new_exp (nargs, op, args) new_exp (int nargs, enum operator op, struct expression * const *args)
int nargs;
enum operator op;
struct expression * const *args;
{ {
int i; int i;
struct expression *newp; struct expression *newp;
@ -108,16 +89,13 @@ new_exp (nargs, op, args)
} }
static inline struct expression * static inline struct expression *
new_exp_0 (op) new_exp_0 (enum operator op)
enum operator op;
{ {
return new_exp (0, op, NULL); return new_exp (0, op, NULL);
} }
static inline struct expression * static inline struct expression *
new_exp_1 (op, right) new_exp_1 (enum operator op, struct expression *right)
enum operator op;
struct expression *right;
{ {
struct expression *args[1]; struct expression *args[1];
@ -126,10 +104,7 @@ new_exp_1 (op, right)
} }
static struct expression * static struct expression *
new_exp_2 (op, left, right) new_exp_2 (enum operator op, struct expression *left, struct expression *right)
enum operator op;
struct expression *left;
struct expression *right;
{ {
struct expression *args[2]; struct expression *args[2];
@ -139,11 +114,8 @@ new_exp_2 (op, left, right)
} }
static inline struct expression * static inline struct expression *
new_exp_3 (op, bexp, tbranch, fbranch) new_exp_3 (enum operator op, struct expression *bexp,
enum operator op; struct expression *tbranch, struct expression *fbranch)
struct expression *bexp;
struct expression *tbranch;
struct expression *fbranch;
{ {
struct expression *args[3]; struct expression *args[3];
@ -234,8 +206,7 @@ exp: exp '?' exp ':' exp
void void
internal_function internal_function
FREE_EXPRESSION (exp) FREE_EXPRESSION (struct expression *exp)
struct expression *exp;
{ {
if (exp == NULL) if (exp == NULL)
return; return;
@ -261,9 +232,7 @@ FREE_EXPRESSION (exp)
static int static int
yylex (lval, pexp) yylex (YYSTYPE *lval, const char **pexp)
YYSTYPE *lval;
const char **pexp;
{ {
const char *exp = *pexp; const char *exp = *pexp;
int result; int result;
@ -406,8 +375,7 @@ yylex (lval, pexp)
static void static void
yyerror (str) yyerror (const char *str)
const char *str;
{ {
/* Do nothing. We don't print error messages here. */ /* Do nothing. We don't print error messages here. */
} }

View File

@ -1,5 +1,5 @@
/* Implementation of the textdomain(3) function. /* Implementation of the textdomain(3) function.
Copyright (C) 1995-1998, 2000, 2001 Free Software Foundation, Inc. Copyright (C) 1995-1998, 2000-2003 Free Software Foundation, Inc.
This program is free software; you can redistribute it and/or modify it This program is free software; you can redistribute it and/or modify it
under the terms of the GNU Library General Public License as published under the terms of the GNU Library General Public License as published
@ -44,17 +44,17 @@
names than the internal variables in GNU libc, otherwise programs names than the internal variables in GNU libc, otherwise programs
using libintl.a cannot be linked statically. */ using libintl.a cannot be linked statically. */
#if !defined _LIBC #if !defined _LIBC
# define _nl_default_default_domain _nl_default_default_domain__ # define _nl_default_default_domain libintl_nl_default_default_domain
# define _nl_current_default_domain _nl_current_default_domain__ # define _nl_current_default_domain libintl_nl_current_default_domain
#endif #endif
/* @@ end of prolog @@ */ /* @@ end of prolog @@ */
/* Name of the default text domain. */ /* Name of the default text domain. */
extern const char _nl_default_default_domain[]; extern const char _nl_default_default_domain[] attribute_hidden;
/* Default text domain in which entries for gettext(3) are to be found. */ /* Default text domain in which entries for gettext(3) are to be found. */
extern const char *_nl_current_default_domain; extern const char *_nl_current_default_domain attribute_hidden;
/* Names for the libintl functions are a problem. They must not clash /* Names for the libintl functions are a problem. They must not clash
@ -67,18 +67,17 @@ extern const char *_nl_current_default_domain;
# define strdup(str) __strdup (str) # define strdup(str) __strdup (str)
# endif # endif
#else #else
# define TEXTDOMAIN textdomain__ # define TEXTDOMAIN libintl_textdomain
#endif #endif
/* Lock variable to protect the global data in the gettext implementation. */ /* Lock variable to protect the global data in the gettext implementation. */
__libc_rwlock_define (extern, _nl_state_lock) __libc_rwlock_define (extern, _nl_state_lock attribute_hidden)
/* Set the current default message catalog to DOMAINNAME. /* Set the current default message catalog to DOMAINNAME.
If DOMAINNAME is null, return the current default. If DOMAINNAME is null, return the current default.
If DOMAINNAME is "", reset to the default of "messages". */ If DOMAINNAME is "", reset to the default of "messages". */
char * char *
TEXTDOMAIN (domainname) TEXTDOMAIN (const char *domainname)
const char *domainname;
{ {
char *new_domain; char *new_domain;
char *old_domain; char *old_domain;

View File

@ -1,18 +1,18 @@
# Makefile for program source directory in GNU NLS utilities package. # Makefile for PO directory in any package using GNU gettext.
# Copyright (C) 1995-1997, 2000, 2001 by Ulrich Drepper <drepper@gnu.ai.mit.edu> # Copyright (C) 1995-1997, 2000-2004 by Ulrich Drepper <drepper@gnu.ai.mit.edu>
# #
# This file file be copied and used freely without restrictions. It can # This file can be copied and used freely without restrictions. It can
# be used in projects which are not available under the GNU General Public License # be used in projects which are not available under the GNU General Public
# but which still want to provide support for the GNU gettext functionality. # License but which still want to provide support for the GNU gettext
# Please note that the actual code is *not* freely available. # functionality.
# Please note that the actual code of GNU gettext is covered by the GNU
# General Public License and is *not* in the public domain.
#
# Origin: gettext-0.14
PACKAGE = @PACKAGE@ PACKAGE = @PACKAGE@
VERSION = @VERSION@ VERSION = @VERSION@
# These two variables depend on the location of this directory.
subdir = po
top_builddir = ..
SHELL = /bin/sh SHELL = /bin/sh
@SET_MAKE@ @SET_MAKE@
@ -29,74 +29,128 @@ gettextsrcdir = $(datadir)/gettext/po
INSTALL = @INSTALL@ INSTALL = @INSTALL@
INSTALL_DATA = @INSTALL_DATA@ INSTALL_DATA = @INSTALL_DATA@
MKINSTALLDIRS = @MKINSTALLDIRS@ MKINSTALLDIRS = @MKINSTALLDIRS@
mkinstalldirs = $(SHELL) `case "$(MKINSTALLDIRS)" in /*) echo "$(MKINSTALLDIRS)" ;; *) echo "$(top_builddir)/$(MKINSTALLDIRS)" ;; esac` mkinstalldirs = $(SHELL) $(MKINSTALLDIRS)
CC = @CC@
GMSGFMT = @GMSGFMT@ GMSGFMT = @GMSGFMT@
MSGFMT = @MSGFMT@ MSGFMT = @MSGFMT@
XGETTEXT = @XGETTEXT@ XGETTEXT = @XGETTEXT@
MSGMERGE = msgmerge MSGMERGE = msgmerge
MSGMERGE_UPDATE = @MSGMERGE@ --update
DEFS = @DEFS@ MSGINIT = msginit
CFLAGS = @CFLAGS@ MSGCONV = msgconv
CPPFLAGS = @CPPFLAGS@ MSGFILTER = msgfilter
INCLUDES = -I.. -I$(top_srcdir)/intl
COMPILE = $(CC) -c $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) $(XCFLAGS)
POFILES = @POFILES@ POFILES = @POFILES@
GMOFILES = @GMOFILES@ GMOFILES = @GMOFILES@
DISTFILES = ChangeLog Makefile.in.in POTFILES.in $(PACKAGE).pot \ UPDATEPOFILES = @UPDATEPOFILES@
$(POFILES) $(GMOFILES) DUMMYPOFILES = @DUMMYPOFILES@
DISTFILES.common = Makefile.in.in remove-potcdate.sin \
$(DISTFILES.common.extra1) $(DISTFILES.common.extra2) $(DISTFILES.common.extra3)
DISTFILES = $(DISTFILES.common) Makevars POTFILES.in $(DOMAIN).pot stamp-po \
$(POFILES) $(GMOFILES) \
$(DISTFILES.extra1) $(DISTFILES.extra2) $(DISTFILES.extra3)
POTFILES = \ POTFILES = \
CATALOGS = @CATALOGS@ CATALOGS = @CATALOGS@
# Makevars gets inserted here. (Don't remove this line!)
.SUFFIXES: .SUFFIXES:
.SUFFIXES: .c .o .po .pox .gmo .mo .SUFFIXES: .po .gmo .mo .sed .sin .nop .po-create .po-update
.c.o:
$(COMPILE) $<
.po.pox:
$(MAKE) $(PACKAGE).pot
$(MSGMERGE) $< $(srcdir)/$(PACKAGE).pot -o $*.pox
.po.mo: .po.mo:
$(MSGFMT) -o $@ $< @echo "$(MSGFMT) -c -o $@ $<"; \
$(MSGFMT) -c -o t-$@ $< && mv t-$@ $@
.po.gmo: .po.gmo:
file=$(srcdir)/`echo $* | sed 's,.*/,,'`.gmo \ @lang=`echo $* | sed -e 's,.*/,,'`; \
&& rm -f $$file && $(GMSGFMT) --statistics -o $$file $< test "$(srcdir)" = . && cdcmd="" || cdcmd="cd $(srcdir) && "; \
echo "$${cdcmd}rm -f $${lang}.gmo && $(GMSGFMT) -c --statistics -o $${lang}.gmo $${lang}.po"; \
cd $(srcdir) && rm -f $${lang}.gmo && $(GMSGFMT) -c --statistics -o t-$${lang}.gmo $${lang}.po && mv t-$${lang}.gmo $${lang}.gmo
.sin.sed:
sed -e '/^#/d' $< > t-$@
mv t-$@ $@
all: all-@USE_NLS@ all: all-@USE_NLS@
all-yes: $(CATALOGS) all-yes: stamp-po
all-no: all-no:
# Note: Target 'all' must not depend on target '$(srcdir)/$(PACKAGE).pot', # stamp-po is a timestamp denoting the last time at which the CATALOGS have
# been loosely updated. Its purpose is that when a developer or translator
# checks out the package via CVS, and the $(DOMAIN).pot file is not in CVS,
# "make" will update the $(DOMAIN).pot and the $(CATALOGS), but subsequent
# invocations of "make" will do nothing. This timestamp would not be necessary
# if updating the $(CATALOGS) would always touch them; however, the rule for
# $(POFILES) has been designed to not touch files that don't need to be
# changed.
stamp-po: $(srcdir)/$(DOMAIN).pot
test -z "$(GMOFILES)" || $(MAKE) $(GMOFILES)
@echo "touch stamp-po"
@echo timestamp > stamp-poT
@mv stamp-poT stamp-po
# Note: Target 'all' must not depend on target '$(DOMAIN).pot-update',
# otherwise packages like GCC can not be built if only parts of the source # otherwise packages like GCC can not be built if only parts of the source
# have been downloaded. # have been downloaded.
$(srcdir)/$(PACKAGE).pot: $(POTFILES) $(srcdir)/POTFILES.in # This target rebuilds $(DOMAIN).pot; it is an expensive operation.
$(XGETTEXT) --default-domain=$(PACKAGE) --directory=$(top_srcdir) \ # Note that $(DOMAIN).pot is not touched if it doesn't need to be changed.
--add-comments --keyword=_ --keyword=N_ \ $(DOMAIN).pot-update: $(POTFILES) $(srcdir)/POTFILES.in remove-potcdate.sed
$(XGETTEXT) --default-domain=$(DOMAIN) --directory=$(top_srcdir) \
--add-comments=TRANSLATORS: $(XGETTEXT_OPTIONS) \
--files-from=$(srcdir)/POTFILES.in \ --files-from=$(srcdir)/POTFILES.in \
&& test ! -f $(PACKAGE).po \ --copyright-holder='$(COPYRIGHT_HOLDER)' \
|| ( rm -f $(srcdir)/$(PACKAGE).pot \ --msgid-bugs-address='$(MSGID_BUGS_ADDRESS)'
&& mv $(PACKAGE).po $(srcdir)/$(PACKAGE).pot ) test ! -f $(DOMAIN).po || { \
if test -f $(srcdir)/$(DOMAIN).pot; then \
sed -f remove-potcdate.sed < $(srcdir)/$(DOMAIN).pot > $(DOMAIN).1po && \
sed -f remove-potcdate.sed < $(DOMAIN).po > $(DOMAIN).2po && \
if cmp $(DOMAIN).1po $(DOMAIN).2po >/dev/null 2>&1; then \
rm -f $(DOMAIN).1po $(DOMAIN).2po $(DOMAIN).po; \
else \
rm -f $(DOMAIN).1po $(DOMAIN).2po $(srcdir)/$(DOMAIN).pot && \
mv $(DOMAIN).po $(srcdir)/$(DOMAIN).pot; \
fi; \
else \
mv $(DOMAIN).po $(srcdir)/$(DOMAIN).pot; \
fi; \
}
# This rule has no dependencies: we don't need to update $(DOMAIN).pot at
# every "make" invocation, only create it when it is missing.
# Only "make $(DOMAIN).pot-update" or "make dist" will force an update.
$(srcdir)/$(DOMAIN).pot:
$(MAKE) $(DOMAIN).pot-update
# This target rebuilds a PO file if $(DOMAIN).pot has changed.
# Note that a PO file is not touched if it doesn't need to be changed.
$(POFILES): $(srcdir)/$(DOMAIN).pot
@lang=`echo $@ | sed -e 's,.*/,,' -e 's/\.po$$//'`; \
if test -f "$(srcdir)/$${lang}.po"; then \
test "$(srcdir)" = . && cdcmd="" || cdcmd="cd $(srcdir) && "; \
echo "$${cdcmd}$(MSGMERGE_UPDATE) $${lang}.po $(DOMAIN).pot"; \
cd $(srcdir) && $(MSGMERGE_UPDATE) $${lang}.po $(DOMAIN).pot; \
else \
$(MAKE) $${lang}.po-create; \
fi
install: install-exec install-data install: install-exec install-data
install-exec: install-exec:
install-data: install-data-@USE_NLS@ install-data: install-data-@USE_NLS@
if test "$(PACKAGE)" = "gettext"; then \ if test "$(PACKAGE)" = "gettext-tools"; then \
$(mkinstalldirs) $(DESTDIR)$(gettextsrcdir); \ $(mkinstalldirs) $(DESTDIR)$(gettextsrcdir); \
$(INSTALL_DATA) $(srcdir)/Makefile.in.in \ for file in $(DISTFILES.common) Makevars.template; do \
$(DESTDIR)$(gettextsrcdir)/Makefile.in.in; \ $(INSTALL_DATA) $(srcdir)/$$file \
$(DESTDIR)$(gettextsrcdir)/$$file; \
done; \
for file in Makevars; do \
rm -f $(DESTDIR)$(gettextsrcdir)/$$file; \
done; \
else \ else \
: ; \ : ; \
fi fi
@ -106,41 +160,118 @@ install-data-yes: all
@catalogs='$(CATALOGS)'; \ @catalogs='$(CATALOGS)'; \
for cat in $$catalogs; do \ for cat in $$catalogs; do \
cat=`basename $$cat`; \ cat=`basename $$cat`; \
lang=`echo $$cat | sed 's/\.gmo$$//'`; \ lang=`echo $$cat | sed -e 's/\.gmo$$//'`; \
dir=$(localedir)/$$lang/LC_MESSAGES; \ dir=$(localedir)/$$lang/LC_MESSAGES; \
$(mkinstalldirs) $(DESTDIR)$$dir; \ $(mkinstalldirs) $(DESTDIR)$$dir; \
if test -r $$cat; then \ if test -r $$cat; then realcat=$$cat; else realcat=$(srcdir)/$$cat; fi; \
$(INSTALL_DATA) $$cat $(DESTDIR)$$dir/$(PACKAGE).mo; \ $(INSTALL_DATA) $$realcat $(DESTDIR)$$dir/$(DOMAIN).mo; \
echo "installing $$cat as $(DESTDIR)$$dir/$(PACKAGE).mo"; \ echo "installing $$realcat as $(DESTDIR)$$dir/$(DOMAIN).mo"; \
else \ for lc in '' $(EXTRA_LOCALE_CATEGORIES); do \
$(INSTALL_DATA) $(srcdir)/$$cat $(DESTDIR)$$dir/$(PACKAGE).mo; \ if test -n "$$lc"; then \
echo "installing $(srcdir)/$$cat as" \ if (cd $(DESTDIR)$(localedir)/$$lang && LC_ALL=C ls -l -d $$lc 2>/dev/null) | grep ' -> ' >/dev/null; then \
"$(DESTDIR)$$dir/$(PACKAGE).mo"; \ link=`cd $(DESTDIR)$(localedir)/$$lang && LC_ALL=C ls -l -d $$lc | sed -e 's/^.* -> //'`; \
mv $(DESTDIR)$(localedir)/$$lang/$$lc $(DESTDIR)$(localedir)/$$lang/$$lc.old; \
mkdir $(DESTDIR)$(localedir)/$$lang/$$lc; \
(cd $(DESTDIR)$(localedir)/$$lang/$$lc.old && \
for file in *; do \
if test -f $$file; then \
ln -s ../$$link/$$file $(DESTDIR)$(localedir)/$$lang/$$lc/$$file; \
fi; \ fi; \
done); \
rm -f $(DESTDIR)$(localedir)/$$lang/$$lc.old; \
else \
if test -d $(DESTDIR)$(localedir)/$$lang/$$lc; then \
:; \
else \
rm -f $(DESTDIR)$(localedir)/$$lang/$$lc; \
mkdir $(DESTDIR)$(localedir)/$$lang/$$lc; \
fi; \
fi; \
rm -f $(DESTDIR)$(localedir)/$$lang/$$lc/$(DOMAIN).mo; \
ln -s ../LC_MESSAGES/$(DOMAIN).mo $(DESTDIR)$(localedir)/$$lang/$$lc/$(DOMAIN).mo 2>/dev/null || \
ln $(DESTDIR)$(localedir)/$$lang/LC_MESSAGES/$(DOMAIN).mo $(DESTDIR)$(localedir)/$$lang/$$lc/$(DOMAIN).mo 2>/dev/null || \
cp -p $(DESTDIR)$(localedir)/$$lang/LC_MESSAGES/$(DOMAIN).mo $(DESTDIR)$(localedir)/$$lang/$$lc/$(DOMAIN).mo; \
echo "installing $$realcat link as $(DESTDIR)$(localedir)/$$lang/$$lc/$(DOMAIN).mo"; \
fi; \
done; \
done
install-strip: install
installdirs: installdirs-exec installdirs-data
installdirs-exec:
installdirs-data: installdirs-data-@USE_NLS@
if test "$(PACKAGE)" = "gettext-tools"; then \
$(mkinstalldirs) $(DESTDIR)$(gettextsrcdir); \
else \
: ; \
fi
installdirs-data-no:
installdirs-data-yes:
$(mkinstalldirs) $(DESTDIR)$(datadir)
@catalogs='$(CATALOGS)'; \
for cat in $$catalogs; do \
cat=`basename $$cat`; \
lang=`echo $$cat | sed -e 's/\.gmo$$//'`; \
dir=$(localedir)/$$lang/LC_MESSAGES; \
$(mkinstalldirs) $(DESTDIR)$$dir; \
for lc in '' $(EXTRA_LOCALE_CATEGORIES); do \
if test -n "$$lc"; then \
if (cd $(DESTDIR)$(localedir)/$$lang && LC_ALL=C ls -l -d $$lc 2>/dev/null) | grep ' -> ' >/dev/null; then \
link=`cd $(DESTDIR)$(localedir)/$$lang && LC_ALL=C ls -l -d $$lc | sed -e 's/^.* -> //'`; \
mv $(DESTDIR)$(localedir)/$$lang/$$lc $(DESTDIR)$(localedir)/$$lang/$$lc.old; \
mkdir $(DESTDIR)$(localedir)/$$lang/$$lc; \
(cd $(DESTDIR)$(localedir)/$$lang/$$lc.old && \
for file in *; do \
if test -f $$file; then \
ln -s ../$$link/$$file $(DESTDIR)$(localedir)/$$lang/$$lc/$$file; \
fi; \
done); \
rm -f $(DESTDIR)$(localedir)/$$lang/$$lc.old; \
else \
if test -d $(DESTDIR)$(localedir)/$$lang/$$lc; then \
:; \
else \
rm -f $(DESTDIR)$(localedir)/$$lang/$$lc; \
mkdir $(DESTDIR)$(localedir)/$$lang/$$lc; \
fi; \
fi; \
fi; \
done; \
done done
# Define this as empty until I found a useful application. # Define this as empty until I found a useful application.
installcheck: installcheck:
uninstall: uninstall: uninstall-exec uninstall-data
catalogs='$(CATALOGS)'; \ uninstall-exec:
for cat in $$catalogs; do \ uninstall-data: uninstall-data-@USE_NLS@
cat=`basename $$cat`; \ if test "$(PACKAGE)" = "gettext-tools"; then \
lang=`echo $$cat | sed 's/\.gmo$$//'`; \ for file in $(DISTFILES.common) Makevars.template; do \
rm -f $(DESTDIR)$(localedir)/$$lang/LC_MESSAGES/$(PACKAGE).mo; \ rm -f $(DESTDIR)$(gettextsrcdir)/$$file; \
done done; \
if test "$(PACKAGE)" = "gettext"; then \
rm -f $(DESTDIR)$(gettextsrcdir)/Makefile.in.in; \
else \ else \
: ; \ : ; \
fi fi
uninstall-data-no:
uninstall-data-yes:
catalogs='$(CATALOGS)'; \
for cat in $$catalogs; do \
cat=`basename $$cat`; \
lang=`echo $$cat | sed -e 's/\.gmo$$//'`; \
for lc in LC_MESSAGES $(EXTRA_LOCALE_CATEGORIES); do \
rm -f $(DESTDIR)$(localedir)/$$lang/$$lc/$(DOMAIN).mo; \
done; \
done
check: all check: all
dvi info tags TAGS ID: info dvi ps pdf html tags TAGS ctags CTAGS ID:
mostlyclean: mostlyclean:
rm -f core core.* *.pox $(PACKAGE).po *.new.po rm -f remove-potcdate.sed
rm -f stamp-poT
rm -f core core.* $(DOMAIN).po $(DOMAIN).1po $(DOMAIN).2po *.new.po
rm -fr *.o rm -fr *.o
clean: mostlyclean clean: mostlyclean
@ -151,7 +282,7 @@ distclean: clean
maintainer-clean: distclean maintainer-clean: distclean
@echo "This command is intended for maintainers to use;" @echo "This command is intended for maintainers to use;"
@echo "it deletes files that may require special tools to rebuild." @echo "it deletes files that may require special tools to rebuild."
rm -f $(GMOFILES) rm -f stamp-po $(GMOFILES)
distdir = $(top_builddir)/$(PACKAGE)-$(VERSION)/$(subdir) distdir = $(top_builddir)/$(PACKAGE)-$(VERSION)/$(subdir)
dist distdir: dist distdir:
@ -160,37 +291,76 @@ dist distdir:
# This is a separate target because 'update-po' must be executed before. # This is a separate target because 'update-po' must be executed before.
dist2: $(DISTFILES) dist2: $(DISTFILES)
dists="$(DISTFILES)"; \ dists="$(DISTFILES)"; \
if test "$(PACKAGE)" = "gettext-tools"; then \
dists="$$dists Makevars.template"; \
fi; \
if test -f $(srcdir)/ChangeLog; then \
dists="$$dists ChangeLog"; \
fi; \
for i in 0 1 2 3 4 5 6 7 8 9; do \
if test -f $(srcdir)/ChangeLog.$$i; then \
dists="$$dists ChangeLog.$$i"; \
fi; \
done; \
if test -f $(srcdir)/LINGUAS; then dists="$$dists LINGUAS"; fi; \
for file in $$dists; do \ for file in $$dists; do \
if test -f $$file; then dir=.; else dir=$(srcdir); fi; \ if test -f $$file; then \
cp -p $$dir/$$file $(distdir); \ cp -p $$file $(distdir); \
else \
cp -p $(srcdir)/$$file $(distdir); \
fi; \
done done
update-po: Makefile update-po: Makefile
$(MAKE) $(PACKAGE).pot $(MAKE) $(DOMAIN).pot-update
if test "$(PACKAGE)" = "gettext"; then PATH=`pwd`/../src:$$PATH; fi; \ test -z "$(UPDATEPOFILES)" || $(MAKE) $(UPDATEPOFILES)
cd $(srcdir); \
catalogs='$(GMOFILES)'; \
for cat in $$catalogs; do \
cat=`basename $$cat`; \
lang=`echo $$cat | sed 's/\.gmo$$//'`; \
echo "$$lang:"; \
if $(MSGMERGE) $$lang.po $(PACKAGE).pot -o $$lang.new.po; then \
mv -f $$lang.new.po $$lang.po; \
else \
echo "msgmerge for $$cat failed!"; \
rm -f $$lang.new.po; \
fi; \
done
$(MAKE) update-gmo $(MAKE) update-gmo
# General rule for creating PO files.
.nop.po-create:
@lang=`echo $@ | sed -e 's/\.po-create$$//'`; \
echo "File $$lang.po does not exist. If you are a translator, you can create it through 'msginit'." 1>&2; \
exit 1
# General rule for updating PO files.
.nop.po-update:
@lang=`echo $@ | sed -e 's/\.po-update$$//'`; \
if test "$(PACKAGE)" = "gettext-tools"; then PATH=`pwd`/../src:$$PATH; fi; \
tmpdir=`pwd`; \
echo "$$lang:"; \
test "$(srcdir)" = . && cdcmd="" || cdcmd="cd $(srcdir) && "; \
echo "$${cdcmd}$(MSGMERGE) $$lang.po $(DOMAIN).pot -o $$lang.new.po"; \
cd $(srcdir); \
if $(MSGMERGE) $$lang.po $(DOMAIN).pot -o $$tmpdir/$$lang.new.po; then \
if cmp $$lang.po $$tmpdir/$$lang.new.po >/dev/null 2>&1; then \
rm -f $$tmpdir/$$lang.new.po; \
else \
if mv -f $$tmpdir/$$lang.new.po $$lang.po; then \
:; \
else \
echo "msgmerge for $$lang.po failed: cannot move $$tmpdir/$$lang.new.po to $$lang.po" 1>&2; \
exit 1; \
fi; \
fi; \
else \
echo "msgmerge for $$lang.po failed!" 1>&2; \
rm -f $$tmpdir/$$lang.new.po; \
fi
$(DUMMYPOFILES):
update-gmo: Makefile $(GMOFILES) update-gmo: Makefile $(GMOFILES)
@: @:
Makefile: Makefile.in.in $(top_builddir)/config.status POTFILES.in Makefile: Makefile.in.in $(top_builddir)/config.status @POMAKEFILEDEPS@
cd $(top_builddir) \ cd $(top_builddir) \
&& CONFIG_FILES=$(subdir)/$@.in CONFIG_HEADERS= \ && CONFIG_FILES=$(subdir)/$@.in CONFIG_HEADERS= \
$(SHELL) ./config.status $(SHELL) ./config.status
force:
# Tell versions [3.59,3.63) of GNU make not to export all variables. # Tell versions [3.59,3.63) of GNU make not to export all variables.
# Otherwise a system limit (for SysV at least) may be exceeded. # Otherwise a system limit (for SysV at least) may be exceeded.
.NOEXPORT: .NOEXPORT:

View File

@ -4,8 +4,6 @@
# Created: 1993-05-16 # Created: 1993-05-16
# Public domain # Public domain
# $Id$
errstatus=0 errstatus=0
dirmode="" dirmode=""
@ -14,17 +12,28 @@ Usage: mkinstalldirs [-h] [--help] [-m mode] dir ..."
# process command line arguments # process command line arguments
while test $# -gt 0 ; do while test $# -gt 0 ; do
case "${1}" in case $1 in
-h | --help | --h*) # -h for help -h | --help | --h*) # -h for help
echo "${usage}" 1>&2; exit 0 ;; echo "$usage" 1>&2
exit 0
;;
-m) # -m PERM arg -m) # -m PERM arg
shift shift
test $# -eq 0 && { echo "${usage}" 1>&2; exit 1; } test $# -eq 0 && { echo "$usage" 1>&2; exit 1; }
dirmode="${1}" dirmode=$1
shift ;; shift
-- ) shift; break ;; # stop option processing ;;
-* ) echo "${usage}" 1>&2; exit 1 ;; # unknown option --) # stop option processing
* ) break ;; # first non-opt arg shift
break
;;
-*) # unknown option
echo "$usage" 1>&2
exit 1
;;
*) # first non-opt arg
break
;;
esac esac
done done
@ -46,12 +55,14 @@ case $dirmode in
if mkdir -p -- . 2>/dev/null; then if mkdir -p -- . 2>/dev/null; then
echo "mkdir -p -- $*" echo "mkdir -p -- $*"
exec mkdir -p -- "$@" exec mkdir -p -- "$@"
fi ;; fi
;;
*) *)
if mkdir -m "$dirmode" -p -- . 2>/dev/null; then if mkdir -m "$dirmode" -p -- . 2>/dev/null; then
echo "mkdir -m $dirmode -p -- $*" echo "mkdir -m $dirmode -p -- $*"
exec mkdir -m "$dirmode" -p -- "$@" exec mkdir -m "$dirmode" -p -- "$@"
fi ;; fi
;;
esac esac
for file for file
@ -63,7 +74,7 @@ do
for d for d
do do
pathcomp="$pathcomp$d" pathcomp="$pathcomp$d"
case "$pathcomp" in case $pathcomp in
-*) pathcomp=./$pathcomp ;; -*) pathcomp=./$pathcomp ;;
esac esac
@ -77,7 +88,6 @@ do
else else
if test ! -z "$dirmode"; then if test ! -z "$dirmode"; then
echo "chmod $dirmode $pathcomp" echo "chmod $dirmode $pathcomp"
lasterr="" lasterr=""
chmod "$dirmode" "$pathcomp" || lasterr=$? chmod "$dirmode" "$pathcomp" || lasterr=$?
@ -96,6 +106,6 @@ exit $errstatus
# Local Variables: # Local Variables:
# mode: shell-script # mode: shell-script
# sh-indentation: 3 # sh-indentation: 2
# End: # End:
# mkinstalldirs ends here # mkinstalldirs ends here