summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDuncan Coutts <dcoutts@gentoo.org>2005-10-21 11:25:42 +0000
committerDuncan Coutts <dcoutts@gentoo.org>2005-10-21 11:25:42 +0000
commit5727355794de096e96b0d4b16a39e72bf365051c (patch)
tree1fdec712fd6305f92406fe549c465175a0ac9a4c /dev-lang
parent* bump (diff)
downloadgentoo-2-5727355794de096e96b0d4b16a39e72bf365051c.tar.gz
gentoo-2-5727355794de096e96b0d4b16a39e72bf365051c.tar.bz2
gentoo-2-5727355794de096e96b0d4b16a39e72bf365051c.zip
Add new revision ghc-6.4.1-r1 which now PDEPENDs on cabal.
(Portage version: 2.0.51.22-r3)
Diffstat (limited to 'dev-lang')
-rw-r--r--dev-lang/ghc/ChangeLog7
-rw-r--r--dev-lang/ghc/Manifest32
-rw-r--r--dev-lang/ghc/files/digest-ghc-6.4.1-r11
-rw-r--r--dev-lang/ghc/ghc-6.4.1-r1.ebuild209
4 files changed, 228 insertions, 21 deletions
diff --git a/dev-lang/ghc/ChangeLog b/dev-lang/ghc/ChangeLog
index 8e9584db3292..75bb75df54da 100644
--- a/dev-lang/ghc/ChangeLog
+++ b/dev-lang/ghc/ChangeLog
@@ -1,6 +1,11 @@
# ChangeLog for dev-lang/ghc
# Copyright 2002-2005 Gentoo Foundation; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/dev-lang/ghc/ChangeLog,v 1.72 2005/10/06 18:11:25 dcoutts Exp $
+# $Header: /var/cvsroot/gentoo-x86/dev-lang/ghc/ChangeLog,v 1.73 2005/10/21 11:25:42 dcoutts Exp $
+
+*ghc-6.4.1-r1 (21 Oct 2005)
+
+ 21 Oct 2005; <duncan@gentoo.org> +ghc-6.4.1-r1.ebuild:
+ Add new revision ghc-6.4.1-r1 which now PDEPENDs on cabal.
06 Oct 2005; <duncan@gentoo.org> ghc-6.4.1.ebuild:
Revert to using virtual/ghc in DEPEND since the other method had no advantages.
diff --git a/dev-lang/ghc/Manifest b/dev-lang/ghc/Manifest
index 681260dce38c..aeafeeffaeaf 100644
--- a/dev-lang/ghc/Manifest
+++ b/dev-lang/ghc/Manifest
@@ -1,25 +1,17 @@
------BEGIN PGP SIGNED MESSAGE-----
-Hash: SHA1
-
-MD5 9dd2d4469df37616f8133d14b58a2ff7 ChangeLog 12935
+MD5 670ea0013a01dc7771a7ee918ae62187 ghc-6.4.1.ebuild 5943
+MD5 6b0575f665b30bd942f60a152f52dca8 ghc-6.0.1.ebuild 4709
+MD5 49113531ecf3c15247194f067ffe00bd ghc-6.2.2.ebuild 5582
+MD5 9620778937a1aff6ef88863c81222cfc ghc-6.4.ebuild 6109
+MD5 6d88f6f6a9fece2d5f381849f5c507ca ghc-6.4.1-r1.ebuild 5980
+MD5 f61be76a9ec71ba1363e96a8c6e94ab8 ChangeLog 13083
+MD5 a769ecfcd1cdd2d40986627df7dfb249 metadata.xml 224
+MD5 af174f2e566a288f0e2276883a866827 files/ghc-updater 9075
MD5 7e423c353b08a2c05693d13f21e067d0 files/depsort.py 1958
+MD5 1ae8c6b539b6706ba0e8b988a918a944 files/ghc-6.2.hardened.patch 525
+MD5 ffd472c0685cf2766ce6533265f9a3c9 files/ghc-6.4-powerpc.patch 908
+MD5 7c38a5e2d5ecf8446f38ff41fa4d4152 files/digest-ghc-6.4.1-r1 67
MD5 d417c9e24a826959ad6d921247e43328 files/digest-ghc-6.0.1 67
MD5 9e9c22452b545fd9ec1367155c15d8e2 files/digest-ghc-6.2.2 67
-MD5 75417bc4dea34cd08ea105457ccd3032 files/digest-ghc-6.4 65
MD5 7c38a5e2d5ecf8446f38ff41fa4d4152 files/digest-ghc-6.4.1 67
+MD5 75417bc4dea34cd08ea105457ccd3032 files/digest-ghc-6.4 65
MD5 9c15b50bf0b73b7d70a06fd47510a3ef files/ghc-6.0.1.haddock.patch 380
-MD5 1ae8c6b539b6706ba0e8b988a918a944 files/ghc-6.2.hardened.patch 525
-MD5 ffd472c0685cf2766ce6533265f9a3c9 files/ghc-6.4-powerpc.patch 908
-MD5 af174f2e566a288f0e2276883a866827 files/ghc-updater 9075
-MD5 6b0575f665b30bd942f60a152f52dca8 ghc-6.0.1.ebuild 4709
-MD5 49113531ecf3c15247194f067ffe00bd ghc-6.2.2.ebuild 5582
-MD5 670ea0013a01dc7771a7ee918ae62187 ghc-6.4.1.ebuild 5943
-MD5 9620778937a1aff6ef88863c81222cfc ghc-6.4.ebuild 6109
-MD5 a769ecfcd1cdd2d40986627df7dfb249 metadata.xml 224
------BEGIN PGP SIGNATURE-----
-Version: GnuPG v1.4.2 (GNU/Linux)
-
-iD8DBQFDRs29I1lqEGTUzyQRAqhmAJwKgc+7tGaHH0itu9sBiceOY95BbQCgj67+
-ElMSmjPwkk6eO9FGaKqP27o=
-=qDx7
------END PGP SIGNATURE-----
diff --git a/dev-lang/ghc/files/digest-ghc-6.4.1-r1 b/dev-lang/ghc/files/digest-ghc-6.4.1-r1
new file mode 100644
index 000000000000..1581d6c5629c
--- /dev/null
+++ b/dev-lang/ghc/files/digest-ghc-6.4.1-r1
@@ -0,0 +1 @@
+MD5 fd289bc7c3afa272ff831a71a50b5b00 ghc-6.4.1-src.tar.bz2 6826112
diff --git a/dev-lang/ghc/ghc-6.4.1-r1.ebuild b/dev-lang/ghc/ghc-6.4.1-r1.ebuild
new file mode 100644
index 000000000000..474d5c33f44d
--- /dev/null
+++ b/dev-lang/ghc/ghc-6.4.1-r1.ebuild
@@ -0,0 +1,209 @@
+# Copyright 1999-2005 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/dev-lang/ghc/ghc-6.4.1-r1.ebuild,v 1.1 2005/10/21 11:25:42 dcoutts Exp $
+
+# Brief explanation of the bootstrap logic:
+#
+# ghc requires ghc-bin to bootstrap.
+# Therefore,
+# (1) both ghc-bin and ghc provide virtual/ghc
+# (2) virtual/ghc *must* default to ghc-bin
+# (3) ghc depends on virtual/ghc
+#
+# This solution has the advantage that the binary distribution
+# can be removed once an forall after the first succesful install
+# of ghc.
+
+inherit base flag-o-matic eutils ghc-package
+
+IUSE="doc opengl"
+#java use flag disabled because of bug #106992
+
+DESCRIPTION="The Glasgow Haskell Compiler"
+HOMEPAGE="http://www.haskell.org/ghc/"
+
+# discover if this is a snapshot release
+IS_SNAPSHOT="${PV%%*pre*}" # zero if snapshot
+MY_PV="${PV/_pre/.}"
+MY_P="${PN}-${MY_PV}"
+EXTRA_SRC_URI="${MY_PV}"
+[[ -z "${IS_SNAPSHOT}" ]] && EXTRA_SRC_URI="stable/dist"
+
+SRC_URI="http://www.haskell.org/ghc/dist/${EXTRA_SRC_URI}/${MY_P}-src.tar.bz2"
+
+LICENSE="as-is"
+SLOT="0"
+# re-add ~ppc64 once dependencies are fulfilled
+KEYWORDS="-alpha ~amd64 ~x86 ~sparc ~ppc"
+
+S="${WORKDIR}/${MY_P}"
+
+PROVIDE="virtual/ghc"
+
+# ghc cannot usually be bootstrapped using later versions ...
+DEPEND="<virtual/ghc-6.5
+ !>=virtual/ghc-6.6
+ >=dev-lang/perl-5.6.1
+ >=sys-devel/gcc-2.95.3
+ >=sys-devel/make-3.79.1
+ >=sys-apps/sed-3.02.80
+ >=sys-devel/flex-2.5.4a
+ >=dev-libs/gmp-4.1
+ >=sys-libs/readline-4.2
+ doc? ( ~app-text/docbook-xml-dtd-4.2
+ app-text/docbook-xsl-stylesheets
+ >=dev-libs/libxslt-1.1.2
+ >=dev-haskell/haddock-0.6-r2 )
+ opengl? ( virtual/opengl
+ virtual/glu
+ virtual/glut )"
+# removed: java? ( >=dev-java/fop-0.20.5 )
+
+RDEPEND="virtual/libc
+ >=sys-devel/gcc-2.95.3
+ >=dev-lang/perl-5.6.1
+ >=dev-libs/gmp-4.1
+ >=sys-libs/readline-4.2
+ opengl? ( virtual/opengl virtual/glu virtual/glut )"
+
+PDEPEND=">=dev-haskell/cabal-1.1.3"
+
+SUPPORTED_CFLAGS=""
+
+# Setup supported CFLAGS.
+check_cflags() {
+ OLD_CFLAGS="${CFLAGS}"
+ CFLAGS="$1"
+ strip-unsupported-flags
+ SUPPORTED_CFLAGS="${SUPPORTED_CFLAGS} ${CFLAGS}"
+ CFLAGS="${OLD_CFLAGS}"
+}
+
+setup_cflags() {
+ check_cflags "-nopie -fno-stack-protector -fno-stack-protector-all"
+}
+
+# Portage's resolution of virtuals fails on virtual/ghc in some Portage releases,
+# the following function causes the build to fail with an informative error message
+# in such a case.
+# pkg_setup() {
+# if ! has_version virtual/ghc; then
+# eerror "This ebuild needs a version of GHC to bootstrap from."
+# eerror "Please emerge dev-lang/ghc-bin to get a binary version."
+# eerror "You can either use the binary version directly or emerge"
+# eerror "dev-lang/ghc afterwards."
+# die "virtual/ghc version required to build"
+# fi
+# }
+
+src_unpack() {
+ base_src_unpack
+
+ # TODO: test if ppc/ppc64 works without patch now ...
+
+ # hardened-gcc needs to be disabled, because the
+ # mangler doesn't accept its output; yes, the 6.2 version
+ # should do ...
+ cd "${S}/ghc/driver"
+ setup_cflags
+
+ epatch "${FILESDIR}/${PN}-6.2.hardened.patch"
+ sed -i -e "s|@GHC_CFLAGS@|${SUPPORTED_CFLAGS// -/ -optc-}|" ghc/ghc.sh
+ sed -i -e "s|@GHC_CFLAGS@|${SUPPORTED_CFLAGS// -/ -optc-}|" ghci/ghci.sh
+}
+
+src_compile() {
+ local myconf
+ local mydoc
+
+ if use opengl; then
+ myconf="--enable-hopengl"
+ fi
+
+ # initialize build.mk
+ echo '# Gentoo changes' > mk/build.mk
+
+ # determine what to do with documentation
+ if use doc; then
+ mydoc="html"
+# if use java; then
+# mydoc="${mydoc} ps"
+# fi
+ else
+ mydoc=""
+ # needed to prevent haddock from being called
+ echo NO_HADDOCK_DOCS=YES >> mk/build.mk
+ fi
+ echo XMLDocWays="${mydoc}" >> mk/build.mk
+
+ # disable the automatic PIC building which is considered as Prologue Junk by the Haskell Compiler
+ # thanks to Peter Simons for finding this and giving notice on bugs.gentoo.org
+ # (this is still necessary, even though we have the patch, because
+ # we might be bootstrapping from a version that didn't have the
+ # patch included)
+ setup_cflags
+ echo "SRC_CC_OPTS+=${SUPPORTED_CFLAGS}" >> mk/build.mk
+ echo "SRC_HC_OPTS+=${SUPPORTED_CFLAGS// -/ -optc-}" >> mk/build.mk
+
+ # force the config variable ArSupportsInput to be unset;
+ # ar in binutils >= 2.14.90.0.8-r1 seems to be classified
+ # incorrectly by the configure script
+ echo "ArSupportsInput:=" >> mk/build.mk
+
+ # Required for some architectures, because they don't support ghc fully ...
+ use ppc || use ppc64 || use sparc && echo "SplitObjs=NO" >> mk/build.mk
+ use ppc64 && echo "GhcWithInterpreter=NO" >> mk/build.mk
+
+ econf ${myconf} || die "econf failed"
+
+ # the build does not seem to work all that
+ # well with parallel make
+ emake -j1 all datadir="/usr/share/doc/${PF}" || die "make failed"
+ # the explicit datadir is required to make the haddock entries
+ # in the package.conf file point to the right place ...
+
+}
+
+src_install () {
+ local insttarget
+
+ insttarget="install"
+ use doc && insttarget="${insttarget} install-docs"
+
+ # the libdir0 setting is needed for amd64, and does not
+ # harm for other arches
+ emake -j1 ${insttarget} \
+ prefix="${D}/usr" \
+ datadir="${D}/usr/share/doc/${PF}" \
+ infodir="${D}/usr/share/info" \
+ mandir="${D}/usr/share/man" \
+ libdir0="${D}/usr/$(get_libdir)" \
+ || die "make ${insttarget} failed"
+
+ #need to remove ${D} from ghcprof script
+ cd "${D}/usr/bin"
+ mv ghcprof ghcprof-orig
+ sed -e 's:$FPTOOLS_TOP_ABS:#$FPTOOLS_TOP_ABS:' ghcprof-orig > ghcprof
+ chmod a+x ghcprof
+ rm -f ghcprof-orig
+
+ cd "${S}/ghc"
+ dodoc README ANNOUNCE LICENSE VERSION
+
+ dosbin ${FILESDIR}/ghc-updater
+}
+
+pkg_postinst () {
+ ebegin "Unregistering ghc's built-in cabal "
+ $(ghc-getghcpkg) unregister Cabal > /dev/null
+ eend $?
+ ghc-reregister
+ einfo "If you have dev-lang/ghc-bin installed, you might"
+ einfo "want to unmerge it. It is no longer needed."
+ einfo
+ ewarn "IMPORTANT:"
+ ewarn "If you upgrade from another ghc version, please run"
+ ewarn "/usr/sbin/ghc-updater to re-merge all ghc-based"
+ ewarn "Haskell libraries."
+}
+