TOPDIR = ../../
+EXTRA_LOCALE_DIR:=${shell cd $(TOPDIR)/extra/locale && pwd}
include $(TOPDIR)Rules.mak
CFLAGS_wc8bit=-DCTYPE_PACKED=1
CFLAGS_mmap=
-ifeq ($(strip $(HAS_WCHAR)),true)
+ifeq ($(strip $(UCLIBC_HAS_WCHAR)),y)
CFLAGS_wc8bit += -DDO_WIDE_CHAR=1
CFLAGS_mmap += -D__WCHAR_ENABLED=1
endif
echo " "; \
echo "You do not have a codesets.txt file. Please create this "; \
echo "file in the extra/locale directory by running something like: "; \
- echo -e " find ./charmaps -name \"*.pairs\" > ./codesets.txt"; \
+ echo -e " find $(EXTRA_LOCALE_DIR)/charmaps -name \"*.pairs\" > \\"; \
+ echo -e " $(EXTRA_LOCALE_DIR)/codesets.txt"; \
echo "and then edit that file to disable/enable the codesets you wish to support. "; \
echo " "; \
- /bin/false; \
+ false; \
fi;
gen_wc8bit: gen_wc8bit.c
- gcc -Os -Wall $(CFLAGS_wc8bit) gen_wc8bit.c -o gen_wc8bit
+ $(HOSTCC) $(HOSTCFLAGS) $(NATIVE_LDFLAGS) $(CFLAGS_wc8bit) $^ -o $@
c8tables.h: gen_wc8bit codesets.txt
./gen_wc8bit `cat codesets.txt`
gen_wctype: gen_wctype.c
- gcc -Os -Wall gen_wctype.c -o gen_wctype
+ $(HOSTCC) $(HOSTCFLAGS) $(NATIVE_LDFLAGS) $^ -o $@
# Warning! Beware tr_TR toupper/tolower exceptions!
-# Warning! Ignore the width table. It will go away.
wctables.h: gen_wctype
./gen_wctype en_US
gen_locale: gen_locale.c c8tables.h
- gcc -Os -Wall gen_locale.c -o gen_locale
+ $(HOSTCC) $(HOSTCFLAGS) $(NATIVE_LDFLAGS) gen_locale.c -o $@
-# TODO: if no wide char support, we should auto-disable all UTF-8 locales
locale_tables.h: gen_locale locales.txt
./gen_locale locales.txt
-lt_defines.h: locale_tables.h
+lt_defines.h: locale_tables.h locale_collate.h
grep "^#define" locale_tables.h > lt_defines.h
+ grep "^#define __lc" locale_collate.h >> lt_defines.h
+
+gen_collate: gen_collate.c
+ $(HOSTCC) $(HOSTCFLAGS) $(NATIVE_LDFLAGS) gen_collate.c -o $@
+
+locale_collate.h: gen_collate locale_tables.h
+ grep COL_IDX_ locale_tables.h | sed -e "s/^.*COL_IDX_\([^, ]*\).*$$/\1/" | sort | uniq | xargs ./gen_collate
locales.txt:
@if [ ! -f locales.txt ] ; then \
set -e; \
echo " "; \
- echo "You do not have a locales.txt file. In the extra/locale "; \
- echo "directory, Please copy the LOCALES file to locales.txt and "; \
- echo "then edit that file to disable/enable the locales you wish "; \
+ echo "You do not have a locales.txt file in the extra/locale "; \
+ echo "directory, Please copy the LOCALES file to locales.txt by "; \
+ echo "running something like: "; \
+ echo " cp $(EXTRA_LOCALE_DIR)/LOCALES \\ "; \
+ echo " $(EXTRA_LOCALE_DIR)/locales.txt "; \
+ echo "then edit locales.txt to disable/enable the locales you wish "; \
echo "to support. "; \
echo " "; \
- /bin/false; \
+ false; \
fi;
-ifneq ($(TARGET_ARCH),$(NATIVE_ARCH))
-
-locale.mmap: gen_mmap
- echo Your locale.mmap file is either missing or out of date.
- echo The developmental code can only generate one for the
- echo target arch == native arch case. Sorry.
-else
-
-gen_mmap: gen_mmap.c c8tables.h wctables.h locale_tables.h
- gcc $(CFLAGS_mmap) -Os -Wall -static gen_mmap.c -o gen_mmap
-
-locale.mmap: gen_mmap
- ./gen_mmap
+gen_ldc: gen_ldc.c c8tables.h wctables.h locale_tables.h locale_collate.h
+ $(HOSTCC) $(HOSTCFLAGS) $(NATIVE_LDFLAGS) $(CFLAGS_mmap) gen_ldc.c -o $@
-endif
-
-lmmtolso: lmmtolso.c
- gcc -Os -Wall lmmtolso.c -o lmmtolso
-
-locale_data.c: lmmtolso locale.mmap
- ./lmmtolso
-
-locale_data.o: locale_data.c lt_defines.h
- $(CC) -c locale_data.c
- $(STRIPTOOL) -x -R .note -R .comment locale_data.o
+locale_data.c: gen_ldc
+ ./gen_ldc
uClibc_locale_data.h: c8tables.h wctables.h lt_defines.h locale_mmap.h
grep -v "define __LC" lt_defines.h > uClibc_locale_data.h
cat c8tables.h wctables.h locale_mmap.h >> uClibc_locale_data.h
-links-target: locale_data.o uClibc_locale_data.h
- ln -sf ../../../extra/locale/locale_data.o ../../libc/misc/locale
- cp uClibc_locale_data.h ../../libc/sysdeps/linux/common/bits/
+links-target: locale_data.c uClibc_locale_data.h
+ cat uClibc_locale_data.h | awk 'BEGIN{i=1}{ if ( /WANT_/ ) i = /endif/ ; else if (i) print $0 }' > ../../include/bits/uClibc_locale_data.h
+
+pregen:
+ cat uClibc_locale_data.h | awk 'BEGIN{i=1}{ if ( /WANT_/ ) i = /endif/ ; else if (i) print $0 }' > ../../include/bits/uClibc_locale_data.h
clean:
rm -f *.[oa] *~ core
- rm -f gen_wc8bit gen_wctype gen_locale
- rm -f c8tables.h wctables.h locale_tables.h lt_defines.h
+ rm -f gen_wc8bit gen_wctype gen_locale gen_ldc gen_collate
+ rm -f c8tables.h wctables.h locale_tables.h lt_defines.h locale_collate.h
rm -f gen_mmap locale.mmap lmmtolso
- rm -f locale_data.c locale_data.o uClibc_locale_data.h
+ rm -f locale_data.c uClibc_locale_data.h
+.PHONY: pregen links-target