dev-libs/icu: Bump to version 65.1
authorLars Wendler <polynomial-c@gentoo.org>
Tue, 15 Oct 2019 12:01:41 +0000 (14:01 +0200)
committerLars Wendler <polynomial-c@gentoo.org>
Tue, 15 Oct 2019 12:04:45 +0000 (14:04 +0200)
Package-Manager: Portage-2.3.77, Repoman-2.3.17
Signed-off-by: Lars Wendler <polynomial-c@gentoo.org>
dev-libs/icu/Manifest
dev-libs/icu/files/icu-65.1-remove-bashisms.patch [new file with mode: 0644]
dev-libs/icu/icu-65.1.ebuild [new file with mode: 0644]

index 8e3d05e0d4d05c375fe879f5e598fd0da874b151..852d3209dce863e90b52946e68be05bb5aace860 100644 (file)
@@ -1 +1,2 @@
 DIST icu4c-64_2-src.tgz 24013250 BLAKE2B 4a286e7a952f5faa74d942f6b6a73147a46aa10fe6d54d024e2d18d1e01056444d56118ded04b4fe084d6a0f9058d7d9e76973960ac8fe5bd9ee105d9e214318 SHA512 5ecb4c230ba45918747a1cf9aef86f555aa07d5b29b1d07ab674e8013f46dfb907a0e9d6945db41155f9dc3012fd94e1152ffc19f61a68b6dfcbabdcb8ae9d78
+DIST icu4c-65_1-src.tgz 24267934 BLAKE2B 3c62781201c02a2b1027c9b6db4586f8ccdfb339c0765301a381242d5218f3503a1cdbdc1dc9a1a23ffa657096adc4bf7f0b7fe702461f14beba293a7e82e02c SHA512 8f1ef33e1f4abc9a8ee870331c59f01b473d6da1251a19ce403f822f3e3871096f0791855d39c8f20c612fc49cda2c62c06864aa32ddab2dbd186d2b21ce9139
diff --git a/dev-libs/icu/files/icu-65.1-remove-bashisms.patch b/dev-libs/icu/files/icu-65.1-remove-bashisms.patch
new file mode 100644 (file)
index 0000000..f052a06
--- /dev/null
@@ -0,0 +1,207 @@
+--- a/config/icu-config-bottom
++++ b/config/icu-config-bottom
+@@ -218,65 +218,65 @@
+           ;;
+       --cflags)
+-          echo $ECHO_N "${CFLAGS} ${ECHO_C}"
++          printf "%s" "${CFLAGS} "
+           ;;
+       --cc)
+-          echo $ECHO_N "${CC} ${ECHO_C}"
++          printf "%s" "${CC} "
+           ;;
+       --cxx)
+-          echo $ECHO_N "${CXX} ${ECHO_C}"
++          printf "%s" "${CXX} "
+           ;;
+       --cxxflags)
+-          echo $ECHO_N "${CXXFLAGS} ${ECHO_C}"
++          printf "%s" "${CXXFLAGS} "
+           ;;
+       --cppflags)
+           # Don't echo the -I. - it's unneeded.
+-          echo $ECHO_N "${CPPFLAGS} ${ECHO_C}" | sed -e 's/-I. //'
++          printf "%s" "${CPPFLAGS} " | sed -e 's/-I. //'
+           ;;
+       --cppflags-searchpath)
+-          echo $ECHO_N "-I${prefix}/include ${ECHO_C}"
++          printf "%s" "-I${prefix}/include "
+           ;;
+       --cppflags-dynamic)
+-          echo $ECHO_N "${SHAREDLIBCPPFLAGS} ${ECHO_C}"
++          printf "%s" "${SHAREDLIBCPPFLAGS} "
+           ;;
+       --cxxflags-dynamic)
+-          echo $ECHO_N "${SHAREDLIBCXXFLAGS} ${ECHO_C}"
++          printf "%s" "${SHAREDLIBCXXFLAGS} "
+           ;;
+       --cflags-dynamic)
+-          echo $ECHO_N "${SHAREDLIBCFLAGS} ${ECHO_C}"
++          printf "%s" "${SHAREDLIBCFLAGS} "
+           ;;
+       --ldflags-system)
+-          echo $ECHO_N "${LIBS} ${ECHO_C}"
++          printf "%s" "${LIBS} "
+           ;;
+       --ldflags)
+-          echo $ECHO_N "${LDFLAGS} ${ICULIBS} ${ECHO_C}"
++          printf "%s" "${LDFLAGS} ${ICULIBS} "
+ # $RPATH_LDFLAGS
+           ;;
+       --ldflags-libsonly)
+-          echo $ECHO_N "${ICULIBS_I18N} ${ICULIBS_COMMON} ${ICULIBS_DATA} ${ECHO_C}"
++          printf "%s" "${ICULIBS_I18N} ${ICULIBS_COMMON} ${ICULIBS_DATA} "
+           ;;
+       --ldflags-icuio)
+-          echo $ECHO_N " ${ICULIBS_ICUIO} ${ECHO_C}"
++          printf "%s" " ${ICULIBS_ICUIO} "
+           ;;
+       --ldflags-obsolete)
+-          echo $ECHO_N "${ICULIBS_OBSOLETE} ${ECHO_C}"
++          printf "%s" "${ICULIBS_OBSOLETE} "
+           ;;
+       --ldflags-toolutil)
+-          echo $ECHO_N " ${ICULIBS_TOOLUTIL} ${ECHO_C}"
++          printf "%s" " ${ICULIBS_TOOLUTIL} "
+           ;;
+       --ldflags-layout)
+@@ -285,7 +285,7 @@
+           ;;
+       --ldflags-searchpath)
+-          echo $ECHO_N "-L${libdir} ${ECHO_C}"
++          printf "%s" "-L${libdir} "
+           ;;
+       --detect-prefix)
+@@ -321,47 +321,47 @@
+           ;;
+       --shared-datadir)
+-          echo $ECHO_N "${datadir} ${ECHO_C}"
++          printf "%s" "${datadir} "
+           ;;
+         --incfile)
+-          echo $ECHO_N "${pkglibdir}/Makefile.inc ${ECHO_C}"
++          printf "%s" "${pkglibdir}/Makefile.inc "
+           ;;
+       --incpkgdatafile)
+-          echo $ECHO_N "${pkglibdir}/pkgdata.inc ${ECHO_C}"
++          printf "%s" "${pkglibdir}/pkgdata.inc "
+           ;;
+       --icudata)
+-          echo $ECHO_N "${ICUDATA_NAME} ${ECHO_C}"
++          printf "%s" "${ICUDATA_NAME} "
+           ;;
+       --icudata-mode)
+-          echo $ECHO_N "${PKGDATA_MODE} ${ECHO_C}"
++          printf "%s" "${PKGDATA_MODE} "
+           ;;
+       --icudata-install-dir)
+-        echo $ECHO_N "${ICUPKGDATA_DIR} ${ECHO_C}"
++        printf "%s" "${ICUPKGDATA_DIR} "
+           ;;
+       --icudatadir)
+-          echo $ECHO_N "${ICUDATA_DIR} ${ECHO_C}"
++          printf "%s" "${ICUDATA_DIR} "
+           ;;
+       --shlib-c)
+-          echo $ECHO_N "${SHLIB_c} ${ECHO_C}"
++          printf "%s" "${SHLIB_c} "
+           ;;
+       --shlib-cc)
+-          echo $ECHO_N "${SHLIB_cc} ${ECHO_C}"
++          printf "%s" "${SHLIB_cc} "
+           ;;
+       --version)
+-          echo $ECHO_N $VERSION
++          printf "%s" "$VERSION"
+           ;;
+       --unicode-version)
+-          echo $ECHO_N $UNICODE_VERSION
++          printf "%s" "$UNICODE_VERSION"
+           ;;
+       --host)
+--- a/config/Makefile.inc.in
++++ b/config/Makefile.inc.in
+@@ -124,12 +124,6 @@
+ # with usually. Many applications will want to add $(ICULIBS_I18N) as well. 
+ ICULIBS = $(ICULIBS_BASE) $(ICULIBS_I18N) $(ICULIBS_COMMON) $(ICULIBS_DATA) 
+-# Proper echo newline handling is needed in icu-config
+-ECHO_N=@ICU_ECHO_N@
+-ECHO_C=@ICU_ECHO_C@
+-# Not currently being used but good to have for proper tab handling
+-ECHO_T=@ICU_ECHO_T@
+-
+ ##################################################################
+ ##################################################################
+ #
+--- a/configure.ac
++++ b/configure.ac
+@@ -26,24 +26,6 @@
+ PACKAGE="icu"
+ AC_SUBST(PACKAGE)
+-# Use custom echo test for newline option
+-# Current autoconf (2.65) gives incorrect echo newline option
+-# for icu-config
+-# This may be removed later - mow (June 17, 2010)
+-ICU_ECHO_C= ICU_ECHO_N= ICU_ECHO_T=
+-case `/bin/sh -c "echo -n x"` in
+--n*)
+-  case `/bin/sh -c "echo 'x\c'"` in
+-  *c*) ICU_ECHO_T=' ';;     # ECHO_T is single tab character.
+-  *)   ICU_ECHO_C='\c';;
+-  esac;;
+-*)
+-  ICU_ECHO_N='-n';;
+-esac
+-AC_SUBST(ICU_ECHO_N)
+-AC_SUBST(ICU_ECHO_C)
+-AC_SUBST(ICU_ECHO_T)
+-
+ AC_MSG_CHECKING(for ICU version numbers)
+ # Get the ICU version from uversion.h or other headers
+--- a/icudefs.mk.in
++++ b/icudefs.mk.in
+@@ -161,11 +161,6 @@
+ ENABLE_STATIC = @ENABLE_STATIC@
+ ENABLE_SHARED = @ENABLE_SHARED@
+-# Echo w/o newline
+-
+-#ECHO_N = @ICU_ECHO_N@
+-#ECHO_C = @ICU_ECHO_C@
+-
+ # Commands to compile
+ COMPILE.c=    $(CC) $(CPPFLAGS) $(DEFS) $(CFLAGS) -c
+ COMPILE.cc=   $(CXX) $(CPPFLAGS) $(DEFS) $(CXXFLAGS) -c
diff --git a/dev-libs/icu/icu-65.1.ebuild b/dev-libs/icu/icu-65.1.ebuild
new file mode 100644 (file)
index 0000000..a8993d9
--- /dev/null
@@ -0,0 +1,142 @@
+# Copyright 1999-2019 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=7
+
+PYTHON_COMPAT=( python3_{5,6,7} )
+inherit autotools flag-o-matic multilib-minimal python-any-r1 toolchain-funcs
+
+DESCRIPTION="International Components for Unicode"
+HOMEPAGE="http://www.icu-project.org/"
+SRC_URI="https://github.com/unicode-org/icu/releases/download/release-${PV//./-}/icu4c-${PV//./_}-src.tgz"
+
+LICENSE="BSD"
+
+SLOT="0/${PV}"
+
+KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~m68k ~mips ~ppc ~ppc64 ~riscv ~s390 ~sh ~sparc ~x86 ~ppc-aix ~amd64-linux ~x86-linux ~ppc-macos ~x64-macos ~x86-macos ~sparc-solaris ~sparc64-solaris ~x64-solaris ~x86-solaris ~x86-winnt"
+IUSE="debug doc examples static-libs"
+
+BDEPEND="${PYTHON_DEPS}
+       virtual/pkgconfig
+       doc? ( app-doc/doxygen[dot] )
+"
+
+S="${WORKDIR}/${PN}/source"
+
+MULTILIB_CHOST_TOOLS=(
+       /usr/bin/icu-config
+)
+
+PATCHES=(
+       "${FILESDIR}/${PN}-65.1-remove-bashisms.patch"
+       "${FILESDIR}/${PN}-64.2-darwin.patch"
+       "${FILESDIR}/${PN}-64.1-data_archive_generation.patch"
+)
+
+src_prepare() {
+       default
+
+       local variable
+
+       # Disable renaming as it is stupid thing to do
+       sed -i \
+               -e "s/#define U_DISABLE_RENAMING 0/#define U_DISABLE_RENAMING 1/" \
+               common/unicode/uconfig.h || die
+
+       # Fix linking of icudata
+       sed -i \
+               -e "s:LDFLAGSICUDT=-nodefaultlibs -nostdlib:LDFLAGSICUDT=:" \
+               config/mh-linux || die
+
+       # Append doxygen configuration to configure
+       sed -i \
+               -e 's:icudefs.mk:icudefs.mk Doxyfile:' \
+               configure.ac || die
+
+       eautoreconf
+}
+
+src_configure() {
+       append-cxxflags -std=c++14
+
+       if tc-is-cross-compiler; then
+               mkdir "${WORKDIR}"/host || die
+               pushd "${WORKDIR}"/host >/dev/null || die
+
+               CFLAGS="" CXXFLAGS="" ASFLAGS="" LDFLAGS="" \
+               CC="$(tc-getBUILD_CC)" CXX="$(tc-getBUILD_CXX)" AR="$(tc-getBUILD_AR)" \
+               RANLIB="$(tc-getBUILD_RANLIB)" LD="$(tc-getBUILD_LD)" \
+               "${S}"/configure --disable-renaming --disable-debug \
+                       --disable-samples --enable-static || die
+               emake
+
+               popd >/dev/null || die
+       fi
+
+       multilib-minimal_src_configure
+}
+
+multilib_src_configure() {
+       local myeconfargs=(
+               --disable-renaming
+               --disable-samples
+               --disable-layoutex
+               $(use_enable debug)
+               $(use_enable static-libs static)
+               $(multilib_native_use_enable examples samples)
+       )
+
+       tc-is-cross-compiler && myeconfargs+=(
+               --with-cross-build="${WORKDIR}"/host
+       )
+
+       # icu tries to use clang by default
+       tc-export CC CXX
+
+       # make sure we configure with the same shell as we run icu-config
+       # with, or ECHO_N, ECHO_T and ECHO_C will be wrongly defined
+       export CONFIG_SHELL="${EPREFIX}/bin/sh"
+       # probably have no /bin/sh in prefix-chain
+       [[ -x ${CONFIG_SHELL} ]] || CONFIG_SHELL="${BASH}"
+
+       ECONF_SOURCE="${S}" econf "${myeconfargs[@]}"
+}
+
+multilib_src_compile() {
+       default
+
+       if multilib_is_native_abi && use doc; then
+               doxygen -u Doxyfile || die
+               doxygen Doxyfile || die
+       fi
+}
+
+multilib_src_test() {
+       # INTLTEST_OPTS: intltest options
+       #   -e: Exhaustive testing
+       #   -l: Reporting of memory leaks
+       #   -v: Increased verbosity
+       # IOTEST_OPTS: iotest options
+       #   -e: Exhaustive testing
+       #   -v: Increased verbosity
+       # CINTLTST_OPTS: cintltst options
+       #   -e: Exhaustive testing
+       #   -v: Increased verbosity
+       emake -j1 VERBOSE="1" check
+}
+
+multilib_src_install() {
+       default
+
+       if multilib_is_native_abi && use doc; then
+               docinto html
+               dodoc -r doc/html/*
+       fi
+}
+
+multilib_src_install_all() {
+       einstalldocs
+       docinto html
+       dodoc ../readme.html
+}