diff options
author | Andres Loeh <kosmikus@gentoo.org> | 2004-03-11 12:43:23 +0000 |
---|---|---|
committer | Andres Loeh <kosmikus@gentoo.org> | 2004-03-11 12:43:23 +0000 |
commit | 8aa2fca7e3f5feffe0448ca3e4de1c69b2de74a7 (patch) | |
tree | 498be1dd5262a71314e9da6b21beb4842aff090c /dev-lang/ghc | |
parent | Added ppc support (Manifest recommit) (diff) | |
download | gentoo-2-8aa2fca7e3f5feffe0448ca3e4de1c69b2de74a7.tar.gz gentoo-2-8aa2fca7e3f5feffe0448ca3e4de1c69b2de74a7.tar.bz2 gentoo-2-8aa2fca7e3f5feffe0448ca3e4de1c69b2de74a7.zip |
disabling hardened-gcc features in resulting compiler, possible fix for #36154
Diffstat (limited to 'dev-lang/ghc')
-rw-r--r-- | dev-lang/ghc/ChangeLog | 9 | ||||
-rw-r--r-- | dev-lang/ghc/Manifest | 3 | ||||
-rw-r--r-- | dev-lang/ghc/files/digest-ghc-6.2-r1 | 1 | ||||
-rw-r--r-- | dev-lang/ghc/files/ghc-6.2.hardened-gcc.patch.bz2 | bin | 0 -> 471 bytes | |||
-rw-r--r-- | dev-lang/ghc/ghc-6.2-r1.ebuild | 163 |
5 files changed, 175 insertions, 1 deletions
diff --git a/dev-lang/ghc/ChangeLog b/dev-lang/ghc/ChangeLog index cb4fab9ff46e..e9c96facdfe2 100644 --- a/dev-lang/ghc/ChangeLog +++ b/dev-lang/ghc/ChangeLog @@ -1,6 +1,13 @@ # ChangeLog for dev-lang/ghc # Copyright 2002-2004 Gentoo Technologies, Inc.; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/dev-lang/ghc/ChangeLog,v 1.27 2004/02/20 13:10:56 kosmikus Exp $ +# $Header: /var/cvsroot/gentoo-x86/dev-lang/ghc/ChangeLog,v 1.28 2004/03/11 12:43:23 kosmikus Exp $ + +*ghc-6.2-r1 (11 Mar 2004) + + 11 Mar 2004; Andres Loeh <kosmikus@gentoo.org> ghc-6.2-r1.ebuild, + files/ghc-6.2.hardened-gcc.patch.bz2: + Disabling propolice in the resulting ghc when using gcc-hardened (cf. bug + #36154). 20 Feb 2004; Andres Loeh <kosmikus@gentoo.org> ghc-6.2.ebuild: Fixed a problem building libraries using recent binutils (#40128). diff --git a/dev-lang/ghc/Manifest b/dev-lang/ghc/Manifest index c63862253133..76b14f02fb90 100644 --- a/dev-lang/ghc/Manifest +++ b/dev-lang/ghc/Manifest @@ -4,11 +4,14 @@ MD5 802669d9b27965494cb6b7e4d8cece09 ghc-6.2.ebuild 5065 MD5 eb902d291c43516728dc3b4e00834029 ghc-6.0.1.ebuild 4878 MD5 67d53cfa8dfbe716719a583732a73987 ChangeLog 6244 MD5 a769ecfcd1cdd2d40986627df7dfb249 metadata.xml 224 +MD5 84f09f9587ccce767f78507a053b0ac4 ghc-6.2-r1.ebuild 5266 MD5 9da9270be8ac4d92d6a5c23fd519cc3c files/lndir.c 8050 MD5 9c184505ec441675c94d47a3110fa754 files/ghc-6.2.documentation.patch 721 MD5 d4a4184d5dcf525047332f9c68e522f7 files/ghc-5.04.3-r1.patch 2717 MD5 a20f2d9eabadd7ed4890784b905f857c files/digest-ghc-5.04.3-r1 68 MD5 d417c9e24a826959ad6d921247e43328 files/digest-ghc-6.0.1 67 +MD5 2e1bd1157c6d47093864b670d6b51a64 files/digest-ghc-6.2-r1 65 MD5 1b6997afc8940a5df3f780897d78ee0a files/digest-ghc-6.0 65 MD5 2e1bd1157c6d47093864b670d6b51a64 files/digest-ghc-6.2 65 MD5 9c15b50bf0b73b7d70a06fd47510a3ef files/ghc-6.0.1.haddock.patch 380 +MD5 18922ab5f2ede2af4eef5e3fde92aa68 files/ghc-6.2-hardened-gcc.patch 547 diff --git a/dev-lang/ghc/files/digest-ghc-6.2-r1 b/dev-lang/ghc/files/digest-ghc-6.2-r1 new file mode 100644 index 000000000000..a1a0bad1815c --- /dev/null +++ b/dev-lang/ghc/files/digest-ghc-6.2-r1 @@ -0,0 +1 @@ +MD5 cc495e263f4384e1d6b38e851bf6eca0 ghc-6.2-src.tar.bz2 5356656 diff --git a/dev-lang/ghc/files/ghc-6.2.hardened-gcc.patch.bz2 b/dev-lang/ghc/files/ghc-6.2.hardened-gcc.patch.bz2 Binary files differnew file mode 100644 index 000000000000..8e6bd56ef72e --- /dev/null +++ b/dev-lang/ghc/files/ghc-6.2.hardened-gcc.patch.bz2 diff --git a/dev-lang/ghc/ghc-6.2-r1.ebuild b/dev-lang/ghc/ghc-6.2-r1.ebuild new file mode 100644 index 000000000000..2f503a926074 --- /dev/null +++ b/dev-lang/ghc/ghc-6.2-r1.ebuild @@ -0,0 +1,163 @@ +# Copyright 1999-2004 Gentoo Technologies, Inc. +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/dev-lang/ghc/ghc-6.2-r1.ebuild,v 1.1 2004/03/11 12:43:23 kosmikus Exp $ + +#Some explanation of bootstrap logic: +# +#After thinking through the best way to bootstrap ghc I decided to split it into +#ghc and ghc-bin and make ghc depend on ghc-bin. +# The ebuild has been revamped and greatly simplified. Bootstrap off old 4x hc files no longer works on x86. +#Not sure what happens with old scheme on sparc, as I did not see any test reports. +# +#The considerations: +#Making ghc unpack binary build first (under ${WORKDIR}) and bootstrapping from that will effectively force +#ghc-bin reinstall every time ghc is rebuilt or upgraded. What is worse it will likely force download of binary image +#at upgrade, which is not nice (in fact quite bad for modem users - 16+ MB). +# +#The best results are achieved if ghc-bin is left alone after ghc installation - +#Both ebuilds install in the same place, thus space penalty is minimal. In fact only the docs exist in double +#(considering that ghc is not installing much docs at present this looks more like an advantage). +#When the upgrade time comes, if you still have ghc-bin around, portage will happily bootstrap off +#your existing ghc (or ghc-bin, whichever was merged last), without attempting to ruin anything... +# +#There is only one issue: ghci will be successfully built only if ghc is bootstrapped from the same version. +#Thus we need to detect presently installed one and bootstrap in one or two stages.. + +inherit base + +IUSE="doc tetex opengl" + +DESCRIPTION="The Glasgow Haskell Compiler" +HOMEPAGE="http://www.haskell.org/ghc/" + +SRC_URI="http://www.haskell.org/ghc/dist/${PV}/ghc-${PV}-src.tar.bz2" + +LICENSE="as-is" +SLOT="0" +KEYWORDS="~x86 -ppc -alpha" + + +PROVIDE="virtual/ghc" +# FIXME: Add USE support for parallel haskell (requires PVM) +# Get PVM from ftp://ftp.netlib.org/pvm3/ +DEPEND="virtual/ghc + >=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 + doc? ( >=app-text/openjade-1.3.1 + >=app-text/sgml-common-0.6.3 + =app-text/docbook-sgml-dtd-3.1-r1 + >=app-text/docbook-dsssl-stylesheets-1.64 + >=dev-haskell/haddock-0.6-r2 + tetex? ( >=app-text/tetex-1.0.7 + >=app-text/jadetex-3.12 ) ) + opengl? ( virtual/opengl + virtual/glu + virtual/glut )" + +RDEPEND="virtual/glibc + >=sys-devel/gcc-2.95.3 + >=dev-lang/perl-5.6.1 + >=dev-libs/gmp-4.1 + opengl? ( virtual/opengl virtual/glu virtual/glut )" + +# extend path to /opt/ghc/bin to guarantee that ghc-bin is found +GHCPATH="${PATH}:/opt/ghc/bin" + +src_unpack() { + base_src_unpack + + # for documentation generation the new ghc should be used, + # not the old one ... + patch -p0 < ${FILESDIR}/ghc-6.2.documentation.patch + # hardened-gcc needs to be disabled, because the + # mangler doesn't accept its output + bzcat ${FILESDIR}/ghc-6.2.hardened-gcc.patch.bz2 | patch -p0 +} + +src_compile() { + local myconf + if [ `use opengl` ]; then + myconf="--enable-hopengl" + fi + + # 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) + if has_version "sys-devel/hardened-gcc" + then + echo "SRC_CC_OPTS+=-yet_exec -yno_propolice" >> mk/build.mk + echo "SRC_HC_OPTS+=-optc-yet_exec -optc-yno_propolice" >> mk/build.mk + fi + + # 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 + + # unset SGML_CATALOG_FILES because documentation installation + # breaks otherwise ... + PATH="${GHCPATH}" SGML_CATALOG_FILES="" econf \ + --enable-threaded-rts ${myconf} || die "econf failed" + + # the build does not seem to work all that + # well with parallel make + make || die "make failed" + + # if documentation has been requested, build documentation ... + if use doc; then + make html || die "make html failed" + if use tetex; then + make ps || die "make ps failed" + fi + fi + +} + +src_install () { + local mydoc + local insttarget + + insttarget="install" + + # determine what to do with documentation + if [ `use doc` ]; then + mydoc="html" + insttarget="${insttarget} install-docs" + if [ `use tetex` ]; then + mydoc="${mydoc} ps" + fi + else + mydoc="" + # needed to prevent haddock from being called + echo NO_HADDOCK_DOCS=YES >> mk/build.mk + fi + echo SGMLDocWays="${mydoc}" >> mk/build.mk + + make ${insttarget} \ + prefix="${D}/usr" \ + datadir="${D}/usr/share/doc/${PF}" \ + infodir="${D}/usr/share/info" \ + mandir="${D}/usr/share/man" || die + + #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 +} + + +pkg_postinst () { + einfo "If you have dev-lang/ghc-bin installed, you might" + einfo "want to unmerge it again. It is no longer needed." +} |