commit:     45b26f4c5ef1ccb8968d31dd6144845516dfdad4
Author:     Aric Belsito <lluixhi <AT> gmail <DOT> com>
AuthorDate: Wed Nov  9 01:24:00 2016 +0000
Commit:     Aric Belsito <lluixhi <AT> gmail <DOT> com>
CommitDate: Wed Nov  9 01:25:10 2016 +0000
URL:        https://gitweb.gentoo.org/proj/musl.git/commit/?id=45b26f4c

dev-libs/icu: Add 58.1

The most recent version assumes that we use xlocale.h on all operating systems
that aren't windows -- but musl doesn't have xlocale.h

 dev-libs/icu/Manifest                             |   5 +
 dev-libs/icu/files/icu-58.1-no-xlocale.patch      |  18 ++
 dev-libs/icu/files/icu-58.1-remove-bashisms.patch | 224 ++++++++++++++++++++++
 dev-libs/icu/icu-58.1.ebuild                      | 142 ++++++++++++++
 dev-libs/icu/metadata.xml                         |   8 +
 5 files changed, 397 insertions(+)

diff --git a/dev-libs/icu/Manifest b/dev-libs/icu/Manifest
new file mode 100644
index 0000000..9c6edc3
--- /dev/null
+++ b/dev-libs/icu/Manifest
@@ -0,0 +1,5 @@
+AUX icu-58.1-no-xlocale.patch 493 SHA256 
31fa67910ebb691f70d1edfc685a5cd735f0df2cced92f3a9ccdc79ae172883f SHA512 
e56576c527049f1fd32185e32b5bbc23d2c861fb1da8491a6f957c8b2919637a795a36e9616bd433bc8aed2e78c06be6108162640838644194e7a79448b72701
 WHIRLPOOL 
ec0eb13c54b6e58469d0095a34f58d8689344215175b4e850be459e99f9c3c1209e4e913e3185e9666436f1d668d1d6d8acdb38c5bbba36fbb04ddf2443e686c
+AUX icu-58.1-remove-bashisms.patch 5888 SHA256 
8a2177d5f549168d5680d6477381a9f6f5ca0bd8f6bd23cc30d7f953e10907bc SHA512 
54835db4db5bca704aed015a911a1f5285fbd3f6d09493cdcf98493d87a03851c9ee79cc9cbcb45da409513ad5b3af38b302aa5d164992d94af1f80c6349aeb8
 WHIRLPOOL 
8f0d95fe666a3de52ebf4511b0792add819e4dbf3e5e259e2f80bd1fce28e21bd046084a18c3130dc16ad1bc3c73cb912c8bb1d0d8bb387b0587d8748c656824
+DIST icu4c-58_1-src.tgz 23366443 SHA256 
0eb46ba3746a9c2092c8ad347a29b1a1b4941144772d13a88667a7b11ea30309 SHA512 
59b2a76834192a35125fda326587e613ef4486152cf0278c6f22568d4ae02c4b2d897efcea2654ef2b11bd1c3154aecd38cb68a70f69430736f343689f94c155
 WHIRLPOOL 
faf2624a83f0d6f874166b328522dc9c89088db2690433ab05e96371722b635b81fd5210c7e87fe8e5df6681e881cf10204832925b448552affe8c2f6c851e37
+EBUILD icu-58.1.ebuild 2982 SHA256 
560c2036409990a493667bd3f320b6013a798c8088ecfb63f9bf423ff25093a2 SHA512 
1e7d9ccc2c8a40c1f87c3f035563314a30727b186051bc25263bf89a17c8e36dbaddf777b45203454970dff58712709481dce4921a3b205e0fe17a366ed38dde
 WHIRLPOOL 
122602a8a986bd04c0e734314e3814399b86e41f72e0b97a0644c836e31fdd7f30b292d0d31e12048ea2a852ac3b19ca174e8a6255973b0dcb9f6b514c3c047a
+MISC metadata.xml 255 SHA256 
34d028c790cfe86c47c5c3dcf8655fcefc3e23ff52fed38a400ce42d678c8c5e SHA512 
ac646e8ac676faf0aac283e4be31c5f2b29e98ccf07327073ed05e688ce696caf639bdfea63e4aed141a90e84c0a86892bc717a52b95cdf1739aaa15240013c3
 WHIRLPOOL 
87f7199996948fe95e5417f8da0c4c90cd51a68f246ac8ae87a2e2a31c11c709f220d664eb893b34692577415e5f5eb351dd7e310dbc59f508fa40c7edb8ceeb

diff --git a/dev-libs/icu/files/icu-58.1-no-xlocale.patch 
b/dev-libs/icu/files/icu-58.1-no-xlocale.patch
new file mode 100644
index 0000000..0bf4e69
--- /dev/null
+++ b/dev-libs/icu/files/icu-58.1-no-xlocale.patch
@@ -0,0 +1,18 @@
+diff -Naur a/i18n/digitlst.cpp b/i18n/digitlst.cpp
+--- a/i18n/digitlst.cpp        2016-10-16 22:10:38.000000000 -0700
++++ b/i18n/digitlst.cpp        2016-11-07 02:46:13.155828312 -0800
+@@ -60,13 +60,7 @@
+ # endif
+ #endif
+ 
+-#if U_USE_STRTOD_L && !U_PLATFORM_USES_ONLY_WIN32_API
+-# if U_PLATFORM == U_PF_CYGWIN
+-#   include <locale.h>
+-# else
+-#   include <xlocale.h>
+-# endif
+-#endif
++#include <locale.h>
+ 
+ // ***************************************************************************
+ // class DigitList

diff --git a/dev-libs/icu/files/icu-58.1-remove-bashisms.patch 
b/dev-libs/icu/files/icu-58.1-remove-bashisms.patch
new file mode 100644
index 0000000..ef60ce4
--- /dev/null
+++ b/dev-libs/icu/files/icu-58.1-remove-bashisms.patch
@@ -0,0 +1,224 @@
+diff -ruN a/config/Makefile.inc.in b/config/Makefile.inc.in
+--- a/config/Makefile.inc.in   2016-09-09 23:28:18.000000000 +0200
++++ b/config/Makefile.inc.in   2016-11-05 19:43:07.688466668 +0100
+@@ -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@
+-
+ ##################################################################
+ ##################################################################
+ #
+diff -ruN a/config/icu-config-bottom b/config/icu-config-bottom
+--- a/config/icu-config-bottom 2016-09-09 23:28:18.000000000 +0200
++++ b/config/icu-config-bottom 2016-11-05 19:49:00.854481361 +0100
+@@ -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)
+diff -ruN a/configure.ac b/configure.ac
+--- a/configure.ac     2016-10-04 21:30:20.000000000 +0200
++++ b/configure.ac     2016-11-05 19:43:07.688466668 +0100
+@@ -22,24 +22,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
+diff -ruN a/icudefs.mk.in b/icudefs.mk.in
+--- a/icudefs.mk.in    2016-09-09 23:28:18.000000000 +0200
++++ b/icudefs.mk.in    2016-11-05 19:43:07.688466668 +0100
+@@ -157,11 +157,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 -ruN a/test/hdrtst/Makefile.in b/test/hdrtst/Makefile.in
+--- a/test/hdrtst/Makefile.in  2016-09-28 06:17:24.000000000 +0200
++++ b/test/hdrtst/Makefile.in  2016-11-05 19:43:07.688466668 +0100
+@@ -35,9 +35,6 @@
+ include $(shell icu-config --incfile)
+ DIRS=$(prefix)/include/unicode
+ LDIRS=$(prefix)/include/layout
+-ECHO_T=@ECHO_T@
+-ECHO_C=@ECHO_C@
+-ECHO_N=@ECHO_N@
+ 
+ all: 
+       @echo Please read this Makefile for more information.

diff --git a/dev-libs/icu/icu-58.1.ebuild b/dev-libs/icu/icu-58.1.ebuild
new file mode 100644
index 0000000..efa3bab
--- /dev/null
+++ b/dev-libs/icu/icu-58.1.ebuild
@@ -0,0 +1,142 @@
+# Copyright 1999-2016 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Id$
+
+EAPI=6
+
+inherit eutils flag-o-matic toolchain-funcs autotools multilib-minimal
+
+DESCRIPTION="International Components for Unicode"
+HOMEPAGE="http://www.icu-project.org/";
+SRC_URI="http://download.icu-project.org/files/icu4c/${PV/_/}/icu4c-${PV//./_}-src.tgz";
+
+LICENSE="BSD"
+
+SLOT="0/${PV}"
+
+KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~m68k ~mips ~ppc ~ppc64 ~s390 
~sh ~sparc ~x86 ~amd64-fbsd ~x86-fbsd"
+IUSE="debug doc examples static-libs"
+
+DEPEND="
+       virtual/pkgconfig
+       doc? (
+               app-doc/doxygen[dot]
+       )
+"
+
+S="${WORKDIR}/${PN}/source"
+
+MULTILIB_CHOST_TOOLS=(
+       /usr/bin/icu-config
+)
+
+PATCHES=(
+       "${FILESDIR}/${PN}-58.1-remove-bashisms.patch"
+       "${FILESDIR}/${PN}-58.1-no-xlocale.patch"
+)
+
+src_prepare() {
+       # apply patches
+       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() {
+       # Use C++14
+       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-layoutex
+               --disable-renaming
+               --disable-samples
+               $(use_enable debug)
+               $(use_enable static-libs static)
+       )
+
+       multilib_is_native_abi && myeconfargs+=(
+               $(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
+
+       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
+}

diff --git a/dev-libs/icu/metadata.xml b/dev-libs/icu/metadata.xml
new file mode 100644
index 0000000..13ce236
--- /dev/null
+++ b/dev-libs/icu/metadata.xml
@@ -0,0 +1,8 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE pkgmetadata SYSTEM "http://www.gentoo.org/dtd/metadata.dtd";>
+<pkgmetadata>
+       <maintainer type="project">
+               <email>off...@gentoo.org</email>
+               <name>Gentoo Office project</name>
+       </maintainer>
+</pkgmetadata>

Reply via email to