svn commit: trunk/uClibc: extra/locale libc/misc/locale

psm at uclibc.org psm at uclibc.org
Fri Nov 25 15:33:15 UTC 2005


Author: psm
Date: 2005-11-25 07:33:02 -0800 (Fri, 25 Nov 2005)
New Revision: 12525

Log:
Integrate locales into new build system, move everything locale related to extra/locale, as download, unpack, locale_data.o

Modified:
   trunk/uClibc/Makefile.in
   trunk/uClibc/extra/locale/Makefile.in
   trunk/uClibc/libc/misc/locale/Makefile.in


Changeset:
Modified: trunk/uClibc/Makefile.in
===================================================================
--- trunk/uClibc/Makefile.in	2005-11-25 15:19:27 UTC (rev 12524)
+++ trunk/uClibc/Makefile.in	2005-11-25 15:33:02 UTC (rev 12525)
@@ -30,6 +30,7 @@
 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 @@
 		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
 

Modified: trunk/uClibc/extra/locale/Makefile.in
===================================================================
--- trunk/uClibc/extra/locale/Makefile.in	2005-11-25 15:19:27 UTC (rev 12524)
+++ trunk/uClibc/extra/locale/Makefile.in	2005-11-25 15:33:02 UTC (rev 12525)
@@ -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,18 +29,22 @@
 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
 ifeq ($(wildcard /usr/include/iconv.h),)
@@ -95,7 +104,7 @@
 
 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_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 @@
 	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
 
-locale_build: $(top_builddir)include/bits/uClibc_locale_data.h
+# for arch specific versions we have to at least overwrite lt_defines.h/locale_data.c/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 @@
 
 # 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}

Modified: trunk/uClibc/libc/misc/locale/Makefile.in
===================================================================
--- trunk/uClibc/libc/misc/locale/Makefile.in	2005-11-25 15:19:27 UTC (rev 12524)
+++ trunk/uClibc/libc/misc/locale/Makefile.in	2005-11-25 15:33:02 UTC (rev 12525)
@@ -18,11 +18,6 @@
 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_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:.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}}




More information about the uClibc-cvs mailing list