commit:     62b5205e8441853746d90d11ca8c3fe2aa90873a
Author:     Alexis Ballier <aballier <AT> gentoo <DOT> org>
AuthorDate: Fri Apr 14 13:01:58 2017 +0000
Commit:     Alexis Ballier <aballier <AT> gentoo <DOT> org>
CommitDate: Sat Apr 15 10:27:46 2017 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=62b5205e

dev-lang/ocaml: Bump to 4.04.1

Package-Manager: Portage-2.3.5, Repoman-2.3.2

 dev-lang/ocaml/Manifest            |   1 +
 dev-lang/ocaml/ocaml-4.04.1.ebuild | 127 +++++++++++++++++++++++++++++++++++++
 2 files changed, 128 insertions(+)

diff --git a/dev-lang/ocaml/Manifest b/dev-lang/ocaml/Manifest
index c65cf2ee741..8e8baed18ba 100644
--- a/dev-lang/ocaml/Manifest
+++ b/dev-lang/ocaml/Manifest
@@ -1,4 +1,5 @@
 DIST ocaml-4.04.0.tar.gz 4057711 SHA256 
03e49d09d5a509216ca0cc8fccd10df3ad9dd441d7633e89974a74e149be3c51 SHA512 
288c514e7ccfe29fe9a65239d04f000b3b05df71f15bc05b3e5af50cb233544b4fec22baad69f60de587e8f0f8f65ee023a5b709896a1a68f9fd6fe30b81344d
 WHIRLPOOL 
91fea4195ed84fb97f2ae68e30f47ce60a2404bc47ca809f6e0d182dd755833ea16a2e033ee0a02fab008f5905a2a9b6fa8dc2194c75b8d9daa353eb6b1d70e9
+DIST ocaml-4.04.1.tar.gz 4061830 SHA256 
9aea1867848e370ae79f9aea4d48b04daf416478b0f43dfcb3a0f4d3ecf5f8e4 SHA512 
d1bb536cd4c596752fb9e508f6b37b2d23a41350ecda866b8a890e15e5248b16e08bb99c9d02ed6cab8eed73162ae555cf6ef250f498e27f7463e6a724a5c103
 WHIRLPOOL 
56d16ba29596fb3952580643b5103415a46231af30cb0e86a9c8d3d200aa689d1cdeeda260494435ee958abbc3caab70b34a42622e9e9a61f3ad8d3c4e146a7d
 DIST ocaml-4.05.0-beta3.tar.gz 4424084 SHA256 
3d82d5b32310d1c010981c12508e0ff63fb71b0c89457bcac813b7c291d4b61c SHA512 
4c31f2b1f43d2c81ea9e8a6b86439806ab3b4b1ab6c6ae35bc98bbd2a993d94b9e26744febebe1d2424c5ee2deb8b5c9c45ff6fbf96bc629758dec86877fff80
 WHIRLPOOL 
c2ecf0f8d4a9ee9fe92d1a0cbd3c16a4a341d6b8c1acd7077f8602aa730c88f7d58cf15f867da5f93c54de8c9f4984f5f12ae27ce3accedc0e4eeb0e0d73fc77
 DIST ocaml-patches-8.tar.bz2 1803 SHA256 
bce7ea483842f6e201cdf3de266928b39b5b45322315010291ed28f811720525 SHA512 
fc477fbb5bdec60a3c4d3dfa110119bb579560ac0e0e57e30e076da72643bda6359c06fd3745fd3436c5d611dbbd888ec2921e9d1920f4929df633c35a797411
 WHIRLPOOL 
ae73b5377744add3afce012b5745fafd70c0f92f75cd6cf91560e0f2ba359a91f7276afed13db145c307be9fdf79c339c2c69be6946565354c68d701fa61a4be
 DIST ocaml-patches-9.tar.bz2 1700 SHA256 
1709c257536e9a8fdd25bfa651c4fb1aaff4c97596dbaa70eb4d4afc7020ae92 SHA512 
cc19f9104fac69aecc5effa8cb772342e1fb61cdcd38ba0176efe04cf3d710b1c56d5178748f3bd29099af91fa684da432a8ef8d42de76dbd1b6954a255ea6c0
 WHIRLPOOL 
185406937ff0fdbfba3eed0e2e4267efac5aff1a15fc3cc5ea4434a57bf4a790bd21a801613d768328f3ab5046a0c85a0b73681c6711c348d0d0755a723c4857

diff --git a/dev-lang/ocaml/ocaml-4.04.1.ebuild 
b/dev-lang/ocaml/ocaml-4.04.1.ebuild
new file mode 100644
index 00000000000..7c0d656a3ef
--- /dev/null
+++ b/dev-lang/ocaml/ocaml-4.04.1.ebuild
@@ -0,0 +1,127 @@
+# Copyright 1999-2017 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI="5"
+
+inherit flag-o-matic eutils multilib versionator toolchain-funcs
+
+PATCHLEVEL="8"
+MY_P="${P/_/-}"
+DESCRIPTION="Type-inferring functional programming language descended from the 
ML family"
+HOMEPAGE="http://www.ocaml.org/";
+SRC_URI="https://github.com/ocaml/ocaml/archive/${PV/_/+}.tar.gz -> 
${MY_P}.tar.gz
+       mirror://gentoo/${PN}-patches-${PATCHLEVEL}.tar.bz2"
+
+LICENSE="QPL-1.0 LGPL-2"
+# Everytime ocaml is updated to a new version, everything ocaml must be 
rebuilt,
+# so here we go with the subslot.
+SLOT="0/${PV}"
+KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~mips ~ppc ~ppc64 ~sparc ~x86 
~amd64-fbsd ~x86-fbsd ~amd64-linux ~x86-linux"
+IUSE="emacs flambda latex ncurses +ocamlopt X xemacs"
+
+RDEPEND="
+       sys-libs/binutils-libs:=
+       ncurses? ( sys-libs/ncurses:0= )
+       X? ( x11-libs/libX11 x11-proto/xproto )"
+DEPEND="${RDEPEND}
+       virtual/pkgconfig"
+
+PDEPEND="emacs? ( app-emacs/ocaml-mode )
+       xemacs? ( app-xemacs/ocaml )"
+
+S="${WORKDIR}/${MY_P}"
+pkg_setup() {
+       # dev-lang/ocaml creates its own objects but calls gcc for linking, 
which will
+       # results in relocations if gcc wants to create a PIE executable
+       if gcc-specs-pie ; then
+               append-ldflags -nopie
+               ewarn "Ocaml generates its own native asm, you're using a PIE 
compiler"
+               ewarn "We have appended -nopie to ocaml build options"
+               ewarn "because linking an executable with pie while the objects 
are not pic will not work"
+       fi
+}
+
+src_prepare() {
+       EPATCH_SUFFIX="patch" epatch "${WORKDIR}/patches"
+}
+
+src_configure() {
+       export LC_ALL=C
+       local myconf=""
+
+       # Causes build failures because it builds some programs with -pg,
+       # bug #270920
+       filter-flags -fomit-frame-pointer
+       # Bug #285993
+       filter-mfpmath sse
+
+       # -ggdb3 & co makes it behave weirdly, breaks sexplib
+       replace-flags -ggdb* -ggdb
+
+       # It doesn't compile on alpha without this LDFLAGS
+       use alpha && append-ldflags "-Wl,--no-relax"
+
+       use ncurses || myconf="${myconf} -no-curses"
+       use X || myconf="${myconf} -no-graph"
+       use flambda && myconf="${myconf} -flambda"
+
+       # ocaml uses a home-brewn configure script, preventing it to use econf.
+       RAW_LDFLAGS="$(raw-ldflags)" ./configure \
+               --prefix "${EPREFIX}"/usr \
+               --bindir "${EPREFIX}"/usr/bin \
+               --target-bindir "${EPREFIX}"/usr/bin \
+               --libdir "${EPREFIX}"/usr/$(get_libdir)/ocaml \
+               --mandir "${EPREFIX}"/usr/share/man \
+               -target "${CHOST}" \
+               -host "${CBUILD}" \
+               -cc "$(tc-getCC)" \
+               -as "$(tc-getAS)" \
+               -aspp "$(tc-getCC) -c" \
+               -partialld "$(tc-getLD) -r" \
+               --with-pthread ${myconf} || die "configure failed!"
+
+       # http://caml.inria.fr/mantis/view.php?id=4698
+       export CCLINKFLAGS="${LDFLAGS}"
+}
+
+src_compile() {
+       emake world
+
+       # Native code generation can be disabled now
+       if use ocamlopt ; then
+               # bug #279968
+               emake opt
+               emake opt.opt
+       fi
+}
+
+src_test() {
+       if use ocamlopt ; then
+               emake -j1 tests
+       else
+               ewarn "${PN} testsuite requires ocamlopt useflag"
+       fi
+}
+
+src_install() {
+       emake BINDIR="${ED}"/usr/bin \
+               LIBDIR="${ED}"/usr/$(get_libdir)/ocaml \
+               MANDIR="${ED}"/usr/share/man \
+               install
+
+       # Symlink the headers to the right place
+       dodir /usr/include
+       dosym /usr/$(get_libdir)/ocaml/caml /usr/include/caml
+
+       dodoc Changes README.adoc
+
+       # Create and envd entry for latex input files
+       if use latex ; then
+               echo "TEXINPUTS=${EPREFIX}/usr/$(get_libdir)/ocaml/ocamldoc:" > 
"${T}"/99ocamldoc
+               doenvd "${T}"/99ocamldoc
+       fi
+
+       # Install ocaml-rebuild portage set
+       insinto /usr/share/portage/config/sets
+       doins "${FILESDIR}/ocaml.conf"
+}

Reply via email to