diff --git a/newlib/configure b/newlib/configure index 7997b0076..2f3f7d005 100755 --- a/newlib/configure +++ b/newlib/configure @@ -3216,13 +3216,6 @@ EOF fi -if test "${newlib_iconv}" = "yes"; then -cat >> confdefs.h <> confdefs.h <> confdefs.h <&2; exit 1; } + fi + + builtin_converters=`echo "${builtin_converters}" | sed -e 's/,/ /g' -e 's/-/_/g' -e 'y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/'` + + available_converters=`cat "${srcdir}/libc/iconv/charset.aliases" | sed -e '/#/d' | sed -e 'N; s/\n //;'` + + builtin_converters1="${builtin_converters}" + builtin_converters="" + for converter in ${builtin_converters1}; do + result=`echo "${available_converters}" | grep -e "\(^\| \)${converter}\( \|\$\)"` + if test $? != "0"; then + { echo "configure: error: ${converter} is not supported - see ${srcdir}/libc/iconv/charset.aliases file for the list of available converters" 1>&2; exit 1; } + fi + converter1=`echo "${result}" | sed -e 's/\(^[^ ]*\).*$/\1/'` + builtin_converters="${builtin_converters} ${converter1}" + done + + for converter in ${builtin_converters}; do + opt=_ICONV_CONVERTER_`echo "${converter}" | sed -e 'y/abcdefghijklmnopqrstuvwxyz/ABCDEFGHIJKLMNOPQRSTUVWXYZ/'` + cat >> confdefs.h < confcache <<\EOF diff --git a/newlib/configure.in b/newlib/configure.in index a38d9b583..fe4a36fed 100644 --- a/newlib/configure.in +++ b/newlib/configure.in @@ -150,10 +150,6 @@ else AC_DEFINE_UNQUOTED(_MB_LEN_MAX,1) fi -if test "${newlib_iconv}" = "yes"; then -AC_DEFINE_UNQUOTED(_ICONV_ENABLED,1) -fi - AC_DEFINE_UNQUOTED(_NEWLIB_VERSION,"$VERSION") if test "${multilib}" = "yes"; then @@ -162,6 +158,44 @@ else multilib_arg= fi +if test "${newlib_iconv}" = "yes"; then +AC_DEFINE_UNQUOTED(_ICONV_ENABLED,1) +fi + +dnl Parse --enable-newlib-builtin-converters option argument +if test "x${builtin_converters}" != "x"; then + + dnl Check that --enable-newlib-iconv was enabled + if test x${newlib_iconv} = x; then + AC_MSG_ERROR(--enable-newlib-builtin-converters option can't be used if iconv library is disabled - use --enable-newlib-iconv to enable it) + fi + + dnl Normalize converter names and delete commas + builtin_converters=`echo "${builtin_converters}" | sed -e 's/,/ /g' -e 's/-/_/g' -e 'y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/'` + + dnl Get the list of available converters excluding comments + dnl Join line with previous if the first character is whitespace + available_converters=`cat "${srcdir}/libc/iconv/charset.aliases" | sed -e '/#/d' | sed -e 'N; s/\n //;'` + + dnl Check if required converters are supported + dnl Convert aliases to "official" names + builtin_converters1="${builtin_converters}" + builtin_converters="" + for converter in ${builtin_converters1}; do + result=`echo "${available_converters}" | grep -e "\(^\| \)${converter}\( \|\$\)"` + if test $? != "0"; then + AC_MSG_ERROR(${converter} is not supported - see ${srcdir}/libc/iconv/charset.aliases file for the list of available converters) + fi + converter1=`echo "${result}" | sed -e 's/\(^[[^ ]]*\).*$/\1/'` + builtin_converters="${builtin_converters} ${converter1}" + done + + dnl Enable appropriate option in newlib.h + for converter in ${builtin_converters}; do + opt=_ICONV_CONVERTER_`echo "${converter}" | sed -e 'y/abcdefghijklmnopqrstuvwxyz/ABCDEFGHIJKLMNOPQRSTUVWXYZ/'` + AC_DEFINE_UNQUOTED($opt,1) + done +fi; AC_OUTPUT(Makefile, [if test -n "$CONFIG_FILES"; then diff --git a/newlib/newlib.hin b/newlib/newlib.hin index 74bb81f29..6f5497c08 100644 --- a/newlib/newlib.hin +++ b/newlib/newlib.hin @@ -14,5 +14,34 @@ /* ICONV enabled */ #undef _ICONV_ENABLED +/* + * ICONV converters enabled + */ +#undef _ICONV_CONVERTER_US_ASCII +#undef _ICONV_CONVERTER_BIG5 +#undef _ICONV_CONVERTER_SHIFT_JIS +#undef _ICONV_CONVERTER_GB_2312_80 +#undef _ICONV_CONVERTER_CP866 +#undef _ICONV_CONVERTER_CP855 +#undef _ICONV_CONVERTER_CP852 +#undef _ICONV_CONVERTER_CP850 +#undef _ICONV_CONVERTER_CP775 +#undef _ICONV_CONVERTER_KOI8_U +#undef _ICONV_CONVERTER_KOI8_R +#undef _ICONV_CONVERTER_ISO_8859_1 +#undef _ICONV_CONVERTER_ISO_8859_2 +#undef _ICONV_CONVERTER_ISO_8859_4 +#undef _ICONV_CONVERTER_ISO_8859_5 +#undef _ICONV_CONVERTER_ISO_8859_15 +#undef _ICONV_CONVERTER_EUC_JP +#undef _ICONV_CONVERTER_EUC_KR +#undef _ICONV_CONVERTER_EUC_TW +#undef _ICONV_CONVERTER_ISO_10646_UCS_2 +#undef _ICONV_CONVERTER_ISO_10646_UCS_4 +#undef _ICONV_CONVERTER_UCS_2_INTERNAL +#undef _ICONV_CONVERTER_UCS_4_INTERNAL +#undef _ICONV_CONVERTER_UTF_16 +#undef _ICONV_CONVERTER_UTF_8 + #endif /* !__NEWLIB_H__ */