X-Git-Url: http://git.cielonegro.org/gitweb.cgi?a=blobdiff_plain;f=Makefile;h=3e50ccd2c09bef1160749b3b946869ac1ba9ccdd;hb=f4afb39c623b1c077a5ffeddbad2b4f451f0d975;hp=e0e6201fcb5d02b2a17d1c59fb7c5fc7a97ec2fa;hpb=50d1db4f9e9c59e5dd04a4a58aca83fb8c6d6cb9;p=pkgsrc-ghc.git diff --git a/Makefile b/Makefile index e0e6201..3e50ccd 100644 --- a/Makefile +++ b/Makefile @@ -1,7 +1,7 @@ # $NetBSD: Makefile,v 1.42 2008/07/07 14:58:00 kristerw Exp $ DISTNAME= ghc-${VERSION} -VERSION= 6.12.1 +VERSION= 7.0.3 CATEGORIES= lang MASTER_SITES= http://www.haskell.org/ghc/dist/${VERSION}/ MAINTAINER= kristerw@NetBSD.org @@ -9,44 +9,49 @@ HOMEPAGE= http://www.haskell.org/ghc/ COMMENT= Compiler for the functional language Haskell LICENSE= modified-bsd -DISTFILES= ${DISTNAME}-src.tar.bz2 \ - ${DISTNAME}-boot-i386-unknown-netbsd.tar.bz2 \ - ${DISTNAME}-boot-i386-unknown-freebsd.tar.bz2 +DISTFILES= ${DISTNAME}-src.tar.bz2 +DISTFILES+= ${DISTNAME}-boot-i386-unknown-freebsd.tar.bz2 +DISTFILES+= ${DISTNAME}-boot-i386-unknown-netbsd.tar.bz2 +DISTFILES+= ${DISTNAME}-boot-powerpc-apple-darwin.tar.bz2 + -SITES.${DISTNAME}-src.tar.bz2 = http://www.haskell.org/ghc/dist/${VERSION}/ SITES.${DISTNAME}-boot-i386-unknown-netbsd.tar.bz2 = http://static.cielonegro.org/archive/ SITES.${DISTNAME}-boot-i386-unknown-freebsd.tar.bz2 = http://static.cielonegro.org/archive/ +SITES.${DISTNAME}-boot-powerpc-apple-darwin.tar.bz2 = http://static.cielonegro.org/archive/ PKG_DESTDIR_SUPPORT= user-destdir .include "../../mk/bsd.prefs.mk" # Unregisterised HC packages are architecture dependent. We have to -# create more HC packages to support more architectures. -ONLY_FOR_PLATFORM= NetBSD-*-i386 FreeBSD-*-i386 -# Note: Darwin-*-powerpc is temporarily disabled for now. It shall -# come back in the near future. Thanks for your patience. +# create more HC packages to support more architectures. Note that +# these packages are built with integer-simple, not integer-gmp, to +# reduce some complexity by not depending on the GMP. The resulting +# registerised GHC uses integer-gmp so this won't be a problem. +# +# If you want to build HC packages yourself, follow instructions in +# the ./TODO file. +ONLY_FOR_PLATFORM= NetBSD-*-i386 FreeBSD-*-i386 Darwin-*-powerpc # We must provide the real pass to gcc to the ./configure script, -# because GHC has a runtime dependency on it. Aren't there any better -# way than this? +# because GHC has a runtime dependency on it. Aren't there any ways +# better than this? .include "../../mk/compiler.mk" .if empty(CCPATH) -WARNINGS+= "This package depends on pkgsrc's undocumented variable CCPATH but it disappeared somehow." +WARNINGS+= "This package depends on pkgsrc's undocumented variable \ +CCPATH but it disappeared somehow." WARNINGS+= "Using hard-coded /usr/bin/gcc as the C compiler..." CONFIGURE_ARGS+= --with-gcc=/usr/bin/gcc .else CONFIGURE_ARGS+= --with-gcc=${CCPATH} .endif -USE_TOOLS+= gmake bsdtar perl:run +USE_TOOLS+= gmake gtar perl:run CONFIGURE_ENV+= PerlCmd=${PERL5:Q} # We don't want to extract all of the DISTFILEs. EXTRACT_ONLY= ${DISTNAME}-src.tar.bz2 -<<<<<<< Makefile -PLATFORM= ${LOWER_ARCH}-unknown-${LOWER_OPSYS} CONFIGURE_ARGS += \ --build=${PLATFORM} \ --host=${PLATFORM} \ @@ -57,15 +62,6 @@ CONFIGURE_ARGS += \ --with-gmp-libraries=${PREFIX}/lib \ --with-iconv-includes=${PREFIX}/include \ --with-iconv-libraries=${PREFIX}/lib -======= -CONFIGURE_ARGS += \ - --prefix=${PREFIX} \ - --mandir=${PREFIX}/${PKGMANDIR} \ - --with-gmp-includes=${PREFIX}/include \ - --with-gmp-libraries=${PREFIX}/lib \ - --with-iconv-includes=${PREFIX}/include \ - --with-iconv-libraries=${PREFIX}/lib ->>>>>>> 1.14 # Build an unregisterised bootstrap compiler and install it directly # into the .buildlink directory. But we can't use "make install" @@ -77,65 +73,96 @@ CONFIGURE_ARGS += \ # running "ghc-pkg recache". .if ${MACHINE_ARCH} == "i386" && ${OPSYS} == "NetBSD" -BOOTSTRAP_TARBALL = ${DISTNAME}-boot-i386-unknown-netbsd.tar.bz2 BOOTSTRAP_BUILD_MK = ${PKGDIR}/files/bootstrap-bsd.mk +PLATFORM = i386-unknown-netbsd .elif ${MACHINE_ARCH} == "i386" && ${OPSYS} == "FreeBSD" -BOOTSTRAP_TARBALL = ${DISTNAME}-boot-i386-unknown-freebsd.tar.bz2 BOOTSTRAP_BUILD_MK = ${PKGDIR}/files/bootstrap-bsd.mk +PLATFORM = i386-unknown-freebsd -#.elif ${MACHINE_ARCH} == "powerpc" && ${OPSYS} == "Darwin" -#BOOTSTRAP_TARBALL = ${DISTNAME}-boot-powerpc-apple-darwin.tar.bz2 -#BOOTSTRAP_BUILD_MK = ${PKGDIR}/files/bootstrap.mk +.elif ${MACHINE_ARCH} == "powerpc" && ${OPSYS} == "Darwin" +BOOTSTRAP_BUILD_MK = ${PKGDIR}/files/bootstrap.mk +PLATFORM = powerpc-apple-darwin +# Existence of libelf makes LeadingUnderscore being "NO", which is +# incorrect for this platform. See ghc-6.12.1/aclocal.m4 +# (FP_LEADING_UNDERSCORE) +CONFLICTS= libelf-[0-9]* .else PKG_FAIL_REASON+= "internal error: unsupported platform" .endif -pre-configure: +BOOTSTRAP_TARBALL = ${DISTNAME}-boot-${PLATFORM}.tar.bz2 + +pre-configure: ${WRKDIR}/stamp-bootstrap-ghc + +${WRKDIR}/stamp-prepare-bootstrap: ${RUN} cd ${WRKDIR} && \ - ${ECHO} "====> Preparing bootstrap compiler" && \ - ${MKDIR} bootstrap && \ - ${CP} -r ${DISTNAME} bootstrap && \ - cd bootstrap/${DISTNAME} && \ - ${LN} -sf ${PWD_CMD} utils/ghc-pwd/ghc-pwd && \ - ${ECHO} "====> Configuring for bootstrap compiler" && \ - ${ENV} ${CONFIGURE_ENV} ./configure --enable-hc-boot ${CONFIGURE_ARGS} && \ - ${ECHO} "====> Extracting bootstrap HC archive" && \ - (cd .. && bsdtar jxfm ${DISTDIR}/${BOOTSTRAP_TARBALL}) && \ - ${SH} mkfiles && \ - ${ECHO} "====> Building bootstrap compiler" && \ + ${PHASE_MSG} "Preparing bootstrap compiler for ${PKGNAME}" && \ + ${RM} -rf bootstrap && \ + ${MKDIR} -p bootstrap/${DISTNAME}/utils/ghc-pwd/dist-boot && \ + ${GTAR} -cf - ${DISTNAME} | ${GTAR} -C bootstrap -xf - && \ + ${LN} -sf ${PWD_CMD} bootstrap/${DISTNAME}/utils/ghc-pwd/dist-boot/ghc-pwd && \ + ${TOUCH} ${.TARGET} + +${WRKDIR}/stamp-configure-hc-boot: ${WRKDIR}/stamp-prepare-bootstrap + ${RUN} cd ${WRKDIR}/bootstrap/${DISTNAME} && \ + ${PHASE_MSG} "Configuring bootstrap compiler for ${PKGNAME}" && \ + ${SETENV} ${CONFIGURE_ENV} ./configure --enable-hc-boot --with-ghc="" ${CONFIGURE_ARGS} && \ + ${TOUCH} ${.TARGET} + +${WRKDIR}/stamp-extract-hc: ${WRKDIR}/stamp-configure-hc-boot + ${RUN} cd ${WRKDIR}/bootstrap && \ + ${PHASE_MSG} "Extracting bootstrap HC archive for ${PKGNAME}" && \ + ${FIND} ${DISTNAME} -type d -o -type f | ${XARGS} ${TOUCH} -t 200001010000 && \ + ${GTAR} -jxf ${DISTDIR}/${BOOTSTRAP_TARBALL} && \ + (cd ${DISTNAME} && ${SH} mkfiles) && \ + ${TOUCH} ${.TARGET} + +${WRKDIR}/stamp-rewrite-hc-paths: ${WRKDIR}/stamp-extract-hc + ${RUN} cd ${WRKDIR}/bootstrap/${DISTNAME} && \ + ${PHASE_MSG} "Rewriting source paths in bootstrap compiler for ${PKGNAME}" && \ ${SED} -e "s#\\[\\[PREFIX\\]\\]#${PREFIX}#g" ${BOOTSTRAP_BUILD_MK} > mk/build.mk && \ for c in libraries/*/configure; do \ - (cd `${DIRNAME} $$c` && ${ENV} ${CONFIGURE_ENV} ${SH} configure ${CONFIGURE_ARGS}); \ + (cd `${DIRNAME} $$c` && ${SETENV} ${CONFIGURE_ENV} ${SH} configure ${CONFIGURE_ARGS}); \ done && \ for i in inplace/lib/package.conf.d/*.conf */*/package-data.mk */*/*/package-data.mk; do \ - ${SED} -e "s#\\[\\[GHC_SOURCE_PATH\\]\\]#`${PWD_CMD}`#g" $$i > $$i.tmp; \ + ${SED} -e "s#\\[\\[PREFIX\\]\\]#${PREFIX}#g" \ + -e "s#\\[\\[GHC_SOURCE_PATH\\]\\]#`${PWD_CMD}`#g" $$i > $$i.tmp; \ ${MV} -f $$i.tmp $$i; \ done && \ - ${TOUCH} -r inplace/lib/package.conf.d */*/package-data.mk */*/*/package-data.mk && \ + ${TOUCH} -r inplace/lib/package.conf.d \ + */*/package-data.mk \ + */*/*/package-data.mk \ + compiler/stage?/build/Config.hs && \ + ${TOUCH} ${.TARGET} + +${WRKDIR}/stamp-bootstrap-ghc: ${WRKDIR}/stamp-rewrite-hc-paths + ${RUN} cd ${WRKDIR}/bootstrap/${DISTNAME} && \ + ${PHASE_MSG} "Building bootstrap compiler for ${PKGNAME}" && \ ${GMAKE} bootstrapping-files && \ ${GMAKE} all_ghc_stage2 && \ ${GMAKE} inplace/bin/ghc-pkg && \ ${GMAKE} inplace/lib/unlit && \ inplace/bin/ghc-pkg recache && \ - ${CP} inplace/bin/ghc-stage2 ${BUILDLINK_DIR}/bin/ghc && \ - ${CP} inplace/bin/ghc-pkg ${BUILDLINK_DIR}/bin/ghc-pkg + ${CP} -f inplace/bin/ghc-stage2 ${BUILDLINK_DIR}/bin/ghc && \ + ${CP} -f inplace/bin/ghc-pkg ${BUILDLINK_DIR}/bin/ghc-pkg && \ + ${TOUCH} ${.TARGET} -# We need to tell the libraries/integer-gmp/configure that libgmp is -# in a non-standard path. Without that, the resulting GHC tries to -# link programs by executing ld(1) without passing it -L${PREFIX}/lib. do-configure: +# Seemingly by mistake, ghc-7.0.3 has a prebuilt +# utils/ghc-pwd/dist-boot/ghc-pwd for amd64 GNU/Linux. ${RUN} cd ${WRKSRC} && \ - ${ENV} ${CONFIGURE_ENV} ./configure ${CONFIGURE_ARGS} - ${RUN} ${ECHO} "libraries/integer-gmp_CONFIGURE_OPTS += \ - --configure-option=--with-gmp-includes=${PREFIX}/include \ - --configure-option=--with-gmp-libraries=${PREFIX}/lib" > ${WRKSRC}/mk/build.mk + rm -rf utils/ghc-pwd/dist-boot + ${RUN} cd ${WRKSRC} && \ + ${SETENV} ${CONFIGURE_ENV} ./configure ${CONFIGURE_ARGS} +# We need to tell the libraries/terminfo/configure that our ncurses is +# in a non-standard path. Without that, the resulting GHC tries to +# link programs by executing ld(1) without passing it -L${PREFIX}/lib. ${RUN} ${ECHO} "libraries/terminfo_CONFIGURE_OPTS += \ --configure-option=--with-curses-includes=${PREFIX}/include \ --configure-option=--with-curses-libraries=${PREFIX}/lib" >> ${WRKSRC}/mk/build.mk - -# The ghc compiler does normally split the generated C files into small +# The ghc compiler does normally split the generated asm files into small # parts before sending them to gcc, to enable the linker to eliminate # unused parts. This does however not play nice with the pkgsrc # framework, and the result is that the build takes more than 5 times @@ -143,10 +170,21 @@ do-configure: # http://mail-index.netbsd.org/tech-pkg/2006/07/30/0005.html # for a description of the problem. # Disable file splitting until pkgsrc gets improved. -pre-build: ${RUN} ${ECHO} "SplitObjs = NO" >> ${WRKSRC}/mk/build.mk - -# Some unused scripts don't pass the portability test. +# If we don't explicitly disable HsColour, PLIST gets changed +# depending on whether we have installed it or not. + ${RUN} ${ECHO} "HSCOLOUR_SRCS = NO" >> ${WRKSRC}/mk/build.mk +# To avoid powerpc crash... +# See http://hackage.haskell.org/trac/ghc/ticket/4034 +#.if ${MACHINE_ARCH} == "powerpc" && ${OPSYS} == "Darwin" +# ${RUN} ${ECHO} "GhcRtsHcOpts = -optc-O0 -optc-g" >> ${WRKSRC}/mk/build.mk +# ${RUN} ${ECHO} "GhcRtsCcOpts = -O0 -g" >> ${WRKSRC}/mk/build.mk +#.endif + +# Substitutions for INSTALL and DEINSTALL. +FILES_SUBST+= DISTNAME=${DISTNAME} + +# There is an unused script which don't pass the portability test. CHECK_PORTABILITY_SKIP+= distrib/prep-bin-dist-mingw # GHC currently *requires* ${PREFIX}/lib to be in @@ -154,10 +192,14 @@ CHECK_PORTABILITY_SKIP+= distrib/prep-bin-dist-mingw # http://hackage.haskell.org/trac/ghc/ticket/2933 CHECK_SHLIBS_SUPPORTED= no +# I guess pdcurses works well but not tested. +USE_NCURSES= yes +.include "../../devel/ncurses/buildlink3.mk" + +BUILD_DEPENDS+= docbook-xsl-[0-9]*:../../textproc/docbook-xsl BUILDLINK_DEPMETHOD.libxslt = build .include "../../converters/libiconv/buildlink3.mk" .include "../../devel/gmp/buildlink3.mk" .include "../../textproc/libxslt/buildlink3.mk" -.include "../../mk/termcap.buildlink3.mk" .include "../../mk/pthread.buildlink3.mk" .include "../../mk/bsd.pkg.mk"