diff options
| -rw-r--r-- | Makefile.in | 18 | ||||
| -rw-r--r-- | extra/locale/Makefile.in | 71 | ||||
| -rw-r--r-- | 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}}  | 
