]> git.ipfire.org Git - thirdparty/glibc.git/blobdiff - intl/Makefile
* intl/dcigettext.c (_nl_find_msg): Unlock the conversions_lock
[thirdparty/glibc.git] / intl / Makefile
index 7b40f2e432fde0b4f4a295079c5a04c69cf468e5..9da445aa38b1988c36e2c366ff6a3e5de99479fa 100644 (file)
@@ -1,20 +1,20 @@
-# Copyright (C) 1995-1999, 2000 Free Software Foundation, Inc.
+# Copyright (C) 1995-2003, 2005 Free Software Foundation, Inc.
 # This file is part of the GNU C Library.
 
 # The GNU C Library is free software; you can redistribute it and/or
-# modify it under the terms of the GNU Library General Public License
-# as published by the Free Software Foundation; either version 2 of
-# the License, or (at your option) any later version.
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
 
 # The GNU C Library is distributed in the hope that it will be useful,
 # but WITHOUT ANY WARRANTY; without even the implied warranty of
 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
-# Library General Public License for more details.
+# Lesser General Public License for more details.
 
-# You should have received a copy of the GNU Library General Public
-# License along with the GNU C Library; see the file COPYING.LIB.  If not,
-# write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
-# Boston, MA 02111-1307, USA.
+# You should have received a copy of the GNU Lesser General Public
+# License along with the GNU C Library; if not, write to the Free
+# Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
+# 02111-1307 USA.
 
 # Makefile for intl subdirectory: message handling code from GNU gettext.
 
@@ -22,70 +22,110 @@ subdir = intl
 headers = libintl.h
 routines = bindtextdom dcgettext dgettext gettext      \
           dcigettext dcngettext dngettext ngettext \
-          finddomain loadmsgcat localealias textdomain \
-          l10nflist explodename plural
-distribute = gettext.h gettextP.h hash-string.h loadinfo.h locale.alias \
-            plural.y po2test.sed tst-gettext.sh
-
-test-srcs := tst-gettext
+          finddomain loadmsgcat localealias textdomain
+aux =     l10nflist explodename plural plural-exp hash-string
+distribute = gmo.h gettextP.h hash-string.h loadinfo.h locale.alias \
+            plural.y plural-exp.h plural-eval.c po2test.sed \
+            tst-gettext.sh \
+            tst-translit.sh translit.po \
+            tst-gettext2.sh tstlang1.po tstlang2.po \
+            tst-codeset.sh tstcodeset.po \
+            tst-gettext3.sh \
+            tst-gettext4.sh tst-gettext4-de.po tst-gettext4-fr.po \
+            tst-gettext5.sh
+
+include ../Makeconfig
+
+multithread-test-srcs := tst-gettext4 tst-gettext5
+test-srcs := tst-gettext tst-translit tst-gettext2 tst-codeset tst-gettext3
+ifeq ($(have-thread-library),yes)
+test-srcs += $(multithread-test-srcs)
+endif
+tests = tst-ngettext
 
 before-compile = $(objpfx)msgs.h
 
 install-others = $(inst_msgcatdir)/locale.alias
 
-generated = msgs.h
+generated = msgs.h mtrace-tst-gettext tst-gettext.mtrace
+generated-dirs := domaindir localedir
 
+ifneq (no,$(BISON))
 plural.c: plural.y
-       $(YACC) $(YFLAGS) $@ $^
+       $(BISON) $(BISONFLAGS) $@ $^
 ifeq ($(with-cvs),yes)
-       test ! -d CVS || cvs $(CVSOPTS) commit -m'$(YACC) $(YFLAGS) $@ $^' $@
+       test ! -d CVS || cvs $(CVSOPTS) commit -m'$(BISON) $(BISONFLAGS) $@ $^' $@
+endif
 endif
 $(objpfx)plural.o: plural.c
 
 include ../Rules
 
-.PHONY: do-gettext-test
-tests: do-gettext-test
-do-gettext-test: tst-gettext.sh $(objpfx)tst-gettext
-       $(SHELL) -e $< $(common-objpfx) $(objpfx)
+ifeq (no,$(cross-compiling))
+ifeq (yes,$(build-shared))
+ifneq ($(strip $(MSGFMT)),:)
+tests: $(objpfx)tst-translit.out $(objpfx)tst-gettext2.out \
+       $(objpfx)tst-codeset.out $(objpfx)tst-gettext3.out
+ifeq ($(have-thread-library),yes)
+tests: $(objpfx)tst-gettext4.out $(objpfx)tst-gettext5.out
+endif
+ifneq (no,$(PERL))
+tests: $(objpfx)mtrace-tst-gettext
+endif
+endif
+$(objpfx)mtrace-tst-gettext: $(objpfx)tst-gettext.out
+       $(common-objpfx)malloc/mtrace $(objpfx)tst-gettext.mtrace > $@
+$(objpfx)tst-gettext.out: tst-gettext.sh $(objpfx)tst-gettext
+       $(SHELL) -e $< $(common-objpfx) $(common-objpfx)intl/ \
+         $(objpfx)tst-gettext.mtrace
+$(objpfx)tst-translit.out: tst-translit.sh $(objpfx)tst-translit
+       $(SHELL) -e $< $(common-objpfx) $(common-objpfx)intl/
+$(objpfx)tst-gettext2.out: tst-gettext2.sh $(objpfx)tst-gettext2
+       $(SHELL) -e $< $(common-objpfx) $(common-objpfx)intl/
+$(objpfx)tst-codeset.out: tst-codeset.sh $(objpfx)tst-codeset
+       $(SHELL) -e $< $(common-objpfx) $(common-objpfx)intl/
+$(objpfx)tst-gettext3.out: tst-gettext3.sh $(objpfx)tst-gettext3
+       $(SHELL) -e $< $(common-objpfx) $(common-objpfx)intl/
+$(objpfx)tst-gettext4.out: tst-gettext4.sh $(objpfx)tst-gettext4
+       $(SHELL) -e $< $(common-objpfx) '$(run-program-prefix)' $(common-objpfx)intl/
+$(objpfx)tst-gettext5.out: tst-gettext5.sh $(objpfx)tst-gettext5
+       $(SHELL) -e $< $(common-objpfx) '$(run-program-prefix)' $(common-objpfx)intl/
+endif
+endif
 
 $(objpfx)msgs.h: po2test.sed ../po/de.po
        $(make-target-directory)
-       sed -f $^ > $@
+       LC_ALL=C sed -f $^ > $@
 
 CFLAGS-tst-gettext.c = -DTESTSTRS_H=\"$(objpfx)msgs.h\"
-
-CPPFLAGS += -D'GNULOCALEDIR="$(msgcatdir)"' \
-           -D'LOCALE_ALIAS_PATH="$(msgcatdir):$(i18ndir)"'
-YFLAGS = --name-prefix=__gettext --output
-
-$(inst_msgcatdir)/locale.alias: locale.alias $(+force)
-       $(do-install)
-
-ifdef gettext-srcdir
-
-%.h:: ../gpl2lgpl.sed $(gettext-srcdir)/intl/%.glibc; $(copysrc)
-%.c:: ../gpl2lgpl.sed $(gettext-srcdir)/intl/%.c; $(copysrc)
-%.h:: ../gpl2lgpl.sed $(gettext-srcdir)/intl/%.h; $(copysrc)
-locale.alias:: ../gpl2lgpl.sed $(gettext-srcdir)/misc/locale.alias; $(copysrc)
-
-ifeq ($(with-cvs),yes)
-define copysrc
-sed -f $^ > $@.new
-chmod a-w $@.new
-mv -f $@.new $@
-test ! -d CVS || cvs $(CVSOPTS) commit -m'Updated from $<' $@
-endef
+CFLAGS-tst-translit.c = -DOBJPFX=\"$(objpfx)\"
+CFLAGS-tst-gettext2.c = -DOBJPFX=\"$(objpfx)\"
+CFLAGS-tst-codeset.c = -DOBJPFX=\"$(objpfx)\"
+CFLAGS-tst-gettext3.c = -DOBJPFX=\"$(objpfx)\"
+CFLAGS-tst-gettext4.c = -DOBJPFX=\"$(objpfx)\"
+CFLAGS-tst-gettext5.c = -DOBJPFX=\"$(objpfx)\"
+
+ifeq ($(have-thread-library),yes)
+ifeq (yes,$(build-shared))
+$(addprefix $(objpfx),$(multithread-test-srcs)): $(shared-thread-library)
 else
-define copysrc
-sed -f $^ > $@.new
-chmod a-w $@.new
-mv -f $@.new $@
-endef
+$(addprefix $(objpfx),$(multithread-test-srcs)): $(static-thread-library)
 endif
-
+ifeq (yes,$(build-bounded))
+$(multithread-test-srcs:%=$(objpfx)%-bp): $(bounded-thread-library)
 endif
+endif
+
+$(objpfx)tst-translit.out: $(objpfx)tst-gettext.out
+$(objpfx)tst-gettext2.out: $(objpfx)tst-gettext.out
+$(objpfx)tst-codeset.out: $(objpfx)tst-gettext.out
+$(objpfx)tst-gettext3.out: $(objpfx)tst-gettext.out
+$(objpfx)tst-gettext4.out: $(objpfx)tst-gettext.out
+$(objpfx)tst-gettext5.out: $(objpfx)tst-gettext.out
+
+CPPFLAGS += -D'LOCALEDIR="$(msgcatdir)"' \
+           -D'LOCALE_ALIAS_PATH="$(msgcatdir)"'
+BISONFLAGS = --yacc --name-prefix=__gettext --output
 
-CFLAGS-bindtextdom.c = -Wno-unused
-CFLAGS-finddomain.c = -Wno-unused
-CFLAGS-localealias.c = -Wno-unused
+$(inst_msgcatdir)/locale.alias: locale.alias $(+force)
+       $(do-install)