From 44d990198218146dd9a486e0055c7914f7407be9 Mon Sep 17 00:00:00 2001 From: "Peter S. Mazinger" Date: Fri, 25 Nov 2005 15:33:02 +0000 Subject: Integrate locales into new build system, move everything locale related to extra/locale, as download, unpack, locale_data.o --- Makefile.in | 18 +---------- extra/locale/Makefile.in | 71 +++++++++++++++++++++++++++----------------- libc/misc/locale/Makefile.in | 17 +---------- 3 files changed, 46 insertions(+), 60 deletions(-) diff --git a/Makefile.in b/Makefile.in index f8eaac343..046b88901 100644 --- a/Makefile.in +++ b/Makefile.in @@ -30,6 +30,7 @@ include $(top_srcdir)libresolv/Makefile.in include $(top_srcdir)librt/Makefile.in include $(top_srcdir)libutil/Makefile.in include $(top_srcdir)libpthread/Makefile.in +include $(top_srcdir)extra/locale/Makefile.in # last included to catch all the objects added by others (locales/threads) include $(top_srcdir)libc/Makefile.in @@ -94,24 +95,7 @@ headers: include/bits/uClibc_config.h mv -f include/bits/sysnum.h.new include/bits/sysnum.h; \ fi -# Command used to download source code -WGET:=wget --passive-ftp - -LOCALE_DATA_FILENAME:=uClibc-locale-030818.tgz - pregen: headers -ifeq ($(UCLIBC_DOWNLOAD_PREGENERATED_LOCALE_DATA),y) - (cd $(top_builddir)extra/locale; \ - if [ ! -f $(LOCALE_DATA_FILENAME) ] ; then \ - $(WGET) http://www.uclibc.org/downloads/$(LOCALE_DATA_FILENAME) ; \ - fi ) -endif -ifeq ($(UCLIBC_PREGENERATED_LOCALE_DATA),y) - (cd $(top_builddir)extra/locale; zcat $(LOCALE_DATA_FILENAME) | tar -xvf -) -endif -ifeq ($(UCLIBC_HAS_LOCALE),y) - $(MAKE) -C $(top_builddir)extra/locale locale_objs -endif install: install_runtime install_dev diff --git a/extra/locale/Makefile.in b/extra/locale/Makefile.in index e7ca2154f..0f1ad85dc 100644 --- a/extra/locale/Makefile.in +++ b/extra/locale/Makefile.in @@ -5,6 +5,11 @@ # Licensed under the LGPL v2.1, see the file COPYING.LIB in this tarball. # +# command used to download source code +WGET := wget --passive-ftp + +LOCALE_DATA_FILENAME := uClibc-locale-030818.tgz + HOSTCFLAGS-locale-common := -D__UCLIBC_GEN_LOCALE HOSTCFLAGS-gen_wc8bit := $(HOSTCFLAGS-locale-common) -DCTYPE_PACKED=1 @@ -24,17 +29,21 @@ DEPH-gen_ldc := c8tables.h wctables.h locale_tables.h locale_collate.h locale_DIR := $(top_srcdir)extra/locale locale_OUT := $(top_builddir)extra/locale -#locale_OBJ := gen_collate gen_ldc gen_locale gen_wc8bit gen_wctype -locale_OBJ := gen_collate gen_wc8bit gen_wctype -locale_OBJ := $(patsubst %,$(locale_OUT)/%,$(locale_OBJ)) +#locale_HOBJ := gen_collate gen_ldc gen_locale gen_wc8bit gen_wctype +locale_HOBJ := gen_collate gen_wc8bit gen_wctype +locale_HOBJ := $(patsubst %,$(locale_OUT)/%,$(locale_HOBJ)) -ifeq ($(UCLIBC_HAS_LOCALE),y) -locale_objs: locale_build -else -locale_objs: -endif +locale_SRC := $(locale_OUT)/locale_data.c +locale_OBJ := $(locale_OUT)/locale_data.o -objs: locale_objs +CFLAGS-locale_data.c := -D__WCHAR_ENABLED -I$(locale_OUT) -I$(locale_DIR) + +headers-$(UCLIBC_HAS_LOCALE) += locale_headers + +libc-a-$(UCLIBC_HAS_LOCALE) += $(locale_OBJ) +libc-so-$(UCLIBC_HAS_LOCALE) += $(locale_OBJ:.o=.os) + +locale_headers: $(top_builddir)include/bits/uClibc_locale_data.h # make sure that the host system has locales (this check is ok for uClibc/glibc) # we do not know though which locales were really enabled for libc at build time @@ -95,7 +104,7 @@ endif endif -$(locale_OBJ): $(locale_OUT)/% : $(locale_DIR)/%.c | $(DEPH-locale) +$(locale_HOBJ): $(locale_OUT)/% : $(locale_DIR)/%.c | $(DEPH-locale) $(hcompile.u) $(locale_OUT)/gen_locale : $(locale_DIR)/gen_locale.c | $(DEPH-locale) $(patsubst %,$(locale_OUT)/%,$(DEPH-gen_locale)) @@ -104,7 +113,7 @@ $(locale_OUT)/gen_locale : $(locale_DIR)/gen_locale.c | $(DEPH-locale) $(patsubs $(locale_OUT)/gen_ldc : $(locale_DIR)/gen_ldc.c | $(DEPH-locale) $(patsubst %,$(locale_OUT)/%,$(DEPH-gen_ldc)) $(hcompile.u) -# code needs to be modified to support top_builddir in almost all apps that right directly to a file +# code needs to be modified to support top_builddir in almost all apps that write directly to a file # grep fopen *.c $(locale_OUT)/c8tables.h: $(locale_OUT)/gen_wc8bit $(locale_OUT)/codesets.txt $< `cat $(word 2,$^)` @@ -124,33 +133,41 @@ $(locale_OUT)/locale_collate.h: $(locale_OUT)/gen_collate $(locale_OUT)/locale_t grep COL_IDX_ $(word 2,$^) | sed -e "s/^.*COL_IDX_\([^, ]*\).*$$/\1/" | \ sort | uniq | xargs $< -$(locale_OUT)/locale_data.c: $(locale_OUT)/gen_ldc - $< +$(locale_OUT)/$(LOCALE_DATA_FILENAME): +ifeq ($(UCLIBC_DOWNLOAD_PREGENERATED_LOCALE_DATA),y) + ( cd $(dir $@); $(WGET) http://www.uclibc.org/downloads/$(notdir $@) ) +endif ifeq ($(UCLIBC_PREGENERATED_LOCALE_DATA),y) -#$(locale_OUT)/uClibc_locale_data.h: -# cp $(locale_DIR)/full/common/*.h $(locale_OUT)/ -#ifeq ($(wildcard $(locale_DIR)/full/$(TARGET_ARCH)/*.c),) -# cp $(locale_DIR)/full/orig/*.{c,h} $(locale_OUT)/ -#else -# # we need here support for endian versions -# cp $(locale_DIR)/full/$(TARGET_ARCH)/*.{h,c} $(locale_OUT)/ -#endif +$(locale_SRC): $(locale_OUT)/$(LOCALE_DATA_FILENAME) + zcat $< | tar -xv -C $(dir $@) -f - + touch $@ + # we use the one in locale_DIR + #$(RM) $(locale_OUT)/locale_mmap.h + +# for arch specific versions we have to at least overwrite lt_defines.h/locale_data.c/uClibc_locale_data.h -locale_build: $(top_builddir)include/bits/uClibc_locale_data.h +$(locale_OUT)/uClibc_locale_data.h: $(locale_SRC) else -$(locale_OUT)/uClibc_locale_data.h: $(locale_OUT)/lt_defines.h $(locale_OUT)/c8tables.h $(locale_OUT)/wctables.h $(locale_OUT)/locale_mmap.h +$(locale_SRC): $(locale_OUT)/gen_ldc + $< + +$(locale_OUT)/uClibc_locale_data.h: $(locale_OUT)/lt_defines.h $(locale_OUT)/c8tables.h $(locale_OUT)/wctables.h $(locale_DIR)/locale_mmap.h | $(locale_OUT)/uClibc_locale_data.h grep -v "define __LC" $< > $@ cat $(wordlist 2,3,4,$^) >> $@ -locale_build: $(top_builddir)include/bits/uClibc_locale_data.h $(locale_OUT)/locale_data.c - endif -$(top_builddir)include/bits/uClibc_locale_data.h: $(locale_OUT)/uClibc_locale_data.h $(top_builddir)include/bits/sysnum.h +$(locale_OBJ): $(locale_SRC) | $(headers_dep) + $(compile.c) + +$(locale_OBJ:.o=.os): $(locale_SRC) | $(headers_dep) + $(compile.c) + +$(top_builddir)include/bits/uClibc_locale_data.h: $(locale_OUT)/uClibc_locale_data.h | $(top_builddir)include/bits/uClibc_config.h cat $< | awk 'BEGIN{i=1}{ if ( /WANT_/ ) i = /endif/ ; else if (i) print $0 }' > $@ # to be removed after included by top Makefile.in @@ -160,6 +177,6 @@ objclean-y += locale_clean # lmmtolso.c/gen_mmap.c/tst-*.c not used locale_clean: - $(RM) $(locale_OBJ) $(locale_OUT)/{*.txt,locale_data.c,gen_locale,gen_ldc} + $(RM) $(locale_HOBJ) $(locale_SRC) $(locale_OUT)/{*.{o,os,txt},gen_locale,gen_ldc} $(RM) $(locale_OUT)/{uClibc_locale_data,lt_defines,c8tables,wctables,locale_tables,locale_collate}.h $(RM) $(locale_OUT)/{lmmtolso,gen_mmap,locale.mmap} diff --git a/libc/misc/locale/Makefile.in b/libc/misc/locale/Makefile.in index 9d0074521..f4439cdf5 100644 --- a/libc/misc/locale/Makefile.in +++ b/libc/misc/locale/Makefile.in @@ -18,11 +18,6 @@ ifeq ($(UCLIBC_HAS_XLOCALE),y) MOBJx:=nl_langinfo_l.o duplocale.o freelocale.o uselocale.o __curlocale.o endif -DATA:= -ifeq ($(UCLIBC_HAS_LOCALE),y) -DATA:=locale_data.o -endif - MISC_LOCALE_NO_MULTI=localeconv.o MISC_LOCALE_DIR:=$(top_srcdir)libc/misc/locale @@ -31,7 +26,6 @@ MISC_LOCALE_OUT:=$(top_builddir)libc/misc/locale MISC_LOCALE_MSRC:=$(MISC_LOCALE_DIR)/$(MSRC) MISC_LOCALE_MOBJ:=$(patsubst %.o,$(MISC_LOCALE_OUT)/%.o,$(MOBJ)) MISC_LOCALE_MOBJx:=$(patsubst %.o,$(MISC_LOCALE_OUT)/%.o,$(MOBJx)) -MISC_LOCALE_DATA:=$(patsubst %.o,$(MISC_LOCALE_OUT)/%.o,$(DATA)) MISC_LOCALE_DEF:=$(patsubst %,-DL_%,$(subst .o,,$(filter-out $(MISC_LOCALE_NO_MULTI),$(notdir $(MISC_LOCALE_MOBJ))))) @@ -47,26 +41,17 @@ $(MISC_LOCALE_MOBJx): $(MISC_LOCALE_MSRC) $(MISC_LOCALE_MOBJx:.o=.os): $(MISC_LOCALE_MSRC) $(compile.m) -D__UCLIBC_DO_XLOCALE -$(MISC_LOCALE_DATA): $(top_builddir)extra/locale/$(notdir $(MISC_LOCALE_DATA:.o=.c)) - $(compile.c) -D__WCHAR_ENABLED -I$(dir $<) - -$(MISC_LOCALE_DATA:.o=.os): $(top_builddir)extra/locale/$(notdir $(MISC_LOCALE_DATA:.o=.c)) - $(compile.c) -D__WCHAR_ENABLED -I$(dir $<) - libc-a-y+=$(MISC_LOCALE_MOBJ) -libc-a-$(UCLIBC_HAS_LOCALE)+=$(MISC_LOCALE_DATA) libc-a-$(UCLIBC_HAS_XLOCALE)+=$(MISC_LOCALE_MOBJx) libc-so-y+=$(MISC_LOCALE_MOBJ:.o=.os) -libc-so-$(UCLIBC_HAS_LOCALE)+=$(MISC_LOCALE_DATA:.o=.os) libc-so-$(UCLIBC_HAS_XLOCALE)+=$(MISC_LOCALE_MOBJx:.o=.os) CFLAGS-multi-y+=$(MISC_LOCALE_DEF) libc-multi-y+=$(MISC_LOCALE_MSRC) libc-nomulti-y+=$(patsubst %.o,$(MISC_LOCALE_OUT)/%.o,$(MISC_LOCALE_NO_MULTI)) -libc-nomulti-$(UCLIBC_HAS_LOCALE)+=$(MISC_LOCALE_DATA) libc-nomulti-$(UCLIBC_HAS_XLOCALE)+=$(MISC_LOCALE_MOBJx) objclean-y+=misc_locale_objclean misc_locale_objclean: - $(RM) $(MISC_LOCALE_OUT)/{*.{o,os},locale_data.c} + $(RM) $(MISC_LOCALE_OUT)/{*.{o,os}} -- cgit v1.2.3