# OpenBSD makefile for: egcs # Version required: recent enough snapshot, check below # Date created: 25 sep 98 # Whom: Marc Espie # # $OpenBSD: Makefile,v 1.20 1999/01/18 10:23:25 espie Exp $ # # This is a configuration file for egcs, snapshot flavor # PLEASE use the regular egcs-stable for serious work, resort to this one # for experimentations and testing. # we could remove this dependency by patching configure, but this is not # reasonable... BUILD_DEPENDS= autoconf:${PORTSDIR}/devel/autoconf CATEGORIES= lang MAINTAINER= Marc.Espie@openbsd.org MIRROR_DISTFILE=no # Testers for the new configurations: # Jason L.Wright & Marco S.Hyman for sparc, # Michael Shalayeff for hppa, # Wim Van Deputte for alpha. ONLY_FOR_ARCHS = i386 sparc m68k alpha pa mips # user configuration section # see files/tests for precise testing procedure # cygnus packaging scheme is now working, though it is weird. # namely, testsuite holds all the tests. g++-tests no longer exists, # and g77-tests only holds duplicates from the main testsuite archive. MAKE_TESTS=yes MAKE_GXX=yes MAKE_FORTRAN=yes MAKE_CHILL=yes MAKE_OBJC=yes MAKE_JAVA=yes .if defined(MAKE_TESTS) BUILD_DEPENDS+= runtest:${PORTSDIR}/devel/dejagnu .endif # if you want/need to use the mammoth archive ONE_ARCHIVE=yes LATEST_DATE=1999-01-12 #### fetch section # configuration is built so that you can test the next snapshot easily, # define NEXT_DATE to the next snapshot... you lose the ability to check # md5 sums, though. # You also may have to remove/add some patches, as these things ARE # usually passed along to the egcs ml. NEXT_DATE=1999-01-17 #PATCH_DEBUG=yes LATEST != echo ${LATEST_DATE} | sed -e s/-//g; DIRECTORY=egcs/snapshots/%SUBDIR%/ .if defined(NEXT_DATE) NEXT != echo ${NEXT_DATE} | sed -e s/-//g; DISTNAME= egcs-${NEXT} .else DISTNAME= egcs-${LATEST} .endif # getting the right archives where they should be MASTER_SITE_SUBDIR=${LATEST_DATE} PATCH_SITE_SUBDIR=${NEXT_DATE} DIST_SUBDIR=egcs PATCH_DIST_STRIP=-p1 .if defined(ONE_ARCHIVE) DISTFILES= egcs-${LATEST}${EXTRACT_SUFX} .else DISTFILES= egcs-core-${LATEST}${EXTRACT_SUFX} .if defined(MAKE_TESTS) DISTFILES+=egcs-tests-${LATEST}${EXTRACT_SUFX} .endif .if defined(MAKE_GXX) DISTFILES+= egcs-g++-${LATEST}${EXTRACT_SUFX} .endif .if defined(MAKE_FORTRAN) DISTFILES+= egcs-g77-${LATEST}${EXTRACT_SUFX} .endif .if defined(MAKE_JAVA) DISTFILES+=egcs-java-${LATEST}${EXTRACT_SUFX} .endif .if defined(MAKE_OBJC) DISTFILES+=egcs-objc-${LATEST}${EXTRACT_SUFX} .endif .if defined(MAKE_CHILL) DISTFILES+=egcs-chill-${LATEST}${EXTRACT_SUFX} .endif .endif MASTER_SITES= MASTER_SITES+= ftp://egcs.cygnus.com/pub/${DIRECTORY} MASTER_SITES+= ftp://ftp.lip6.fr/pub/${DIRECTORY} MASTER_SITES+= ftp://go.cygnus.com/pub/ftp.cygnus.com/${DIRECTORY} MASTER_SITES+= ftp://ftp.goof.com/pub/pcg/${DIRECTORY} #MASTER_SITES+= ftp://cambridge.cygnus.com/pub/${DIRECTORY} MASTER_SITES+= ftp://ftp.ninemoons.com/pub/mirrors/${DIRECTORY} MASTER_SITES+= ftp://sunsite.doc.ic.ac.uk/Mirrors/egcs.cygnus.com/pub/${DIRECTORY} MASTER_SITES+= ftp://gd.tuwien.ac.at/gnu/${DIRECTORY} #MASTER_SITES+= ftp://ftp.ilog.fr/pub/Mirrors/${DIRECTORY} #MASTER_SITES+= ftp://ftp.irisa.fr/pub/mirrors/${DIRECTORY} MASTER_SITES+= ftp://ftp.gts.cz/pub/MIRRORS/ftp.cygnus.com/pub/${DIRECTORY} MASTER_SITES+= ftp://sunsite.auc.dk/pub/${DIRECTORY} MASTER_SITES+= ftp://ftp.fu-berlin.de/unix/languages/${DIRECTORY} MASTER_SITES+= ftp://ftp.gwdg.de/pub/cygnus/${DIRECTORY} MASTER_SITES+= ftp://ftp.mpi-sb.mpg.de/pub/gnu/mirror/egcs.cygnus.com/${DIRECTORY} MASTER_SITES+= ftp://ftp.uni-trier.de/pub/languages/c/implementation/${DIRECTORY} MASTER_SITES+= ftp://ftp.sunet.se/pub/gnu/${DIRECTORY} #MASTER_SITES+= ftp://ftp.unicamp.br/pub/gnu/=EXTRA=/cygnus/${DIRECTORY} MASTER_SITES+= ftp://ftp.lbi.ro/mirrors/ftp.cygnus.com/pub/${DIRECTORY} MASTER_SITES+= ftp://ftp.ntua.gr/pub/gnu/${DIRECTORY} MASTER_SITES+= ftp://ftp.nluug.nl/pub/languages/${DIRECTORY} MASTER_SITES+= ftp://ftp.dti.ad.jp/pub/lang/${DIRECTORY} MASTER_SITES+= ftp://ftp.win.or.jp/pub/lang/${DIRECTORY} MASTER_SITES+= ftp://ftp.telewaynet.ad.jp/pub/lang/${DIRECTORY} MASTER_SITES+= ftp://ftp.lab.kdd.co.jp/lang/${DIRECTORY} #MASTER_SITES+= ftp://ftp.funet.fi/mirrors/ftp.cygnus.com/pub/${DIRECTORY} #MASTER_SITES+= ftp://ftp.crc.ca/pub/packages/${DIRECTORY} MASTER_SITES+= ftp://ftp.nc.orc.ru/pub/${DIRECTORY} #MASTER_SITES+= ftp://ftp.u-aizu.ac.jp/pub/lang/C/pcg/${DIRECTORY} MASTER_SITES+= ftp://ftp.maisel.int-evry.fr/pub/linux/pentium/${DIRECTORY} MASTER_SITES+= ftp://ftp.yggdrasil.com/mirrors/site/egcs.cygnus.com/pub/${DIRECTORY} MASTER_SITES+= ftp://unix.hensa.ac.uk/mirrors/egcs.cygnus.com/pub/${DIRECTORY} # couldn't contact those, maybe they work ? MASTER_SITES+= ftp://sunsite.mff.cuni.cz/pub/GNU/${DIRECTORY} MASTER_SITES+= ftp://sunsite.icm.edu.pl/pub/programming/${DIRECTORY} MASTER_SITES+= ftp://ftp.task.gda.pl/mirror/egcs.cygnus.com/pub/${DIRECTORY} MASTER_SITES+= ftp://ftp.lca.uevora.pt/pub/${DIRECTORY} MASTER_SITES+= ftp://cair-archive.kaist.ac.kr/pub/gnu/${DIRECTORY} MASTER_SITES+= ftp://linux.ihep.su/pub/cygnus/${DIRECTORY} MASTER_SITES+= ftp://linux.cis.nctu.edu.tw/pub/packages/pcg/${DIRECTORY} PATCH_SITES = ${MASTER_SITES} # add a possible next snapshot .if defined(NEXT) .if defined(ONE_ARCHIVE) PATCHFILES=egcs-${LATEST}-${NEXT}.diff.gz .else PATCHFILES=egcs-core-${LATEST}-${NEXT}.diff.gz .if defined(MAKE_TESTS) PATCHFILES+=egcs-tests-${LATEST}-${NEXT}.diff.gz .endif .if defined(MAKE_GXX) PATCHFILES+=egcs-g++-${LATEST}-${NEXT}.diff.gz .if defined(MAKE_TESTS) PATCHFILES+=egcs-g++-tests-${LATEST}-${NEXT}.diff.gz .endif .endif .if defined(MAKE_FORTRAN) PATCHFILES+=egcs-g77-${LATEST}-${NEXT}.diff.gz .if defined(MAKE_TESTS) PATCHFILES+=egcs-g77-testsuite-${LATEST}-${NEXT}.diff.gz .endif .endif .if defined(MAKE_JAVA) PATCHFILES+=egcs-java-${LATEST}-${NEXT}.diff.gz .endif .if defined(MAKE_OBJC) PATCHFILES+=egcs-objc-${LATEST}-${NEXT}.diff.gz .endif .if defined(MAKE_CHILL) PATCHFILES+=egcs-chill-${LATEST}-${NEXT}.diff.gz .endif .endif .endif # synch the date .if defined(NEXT) post-extract: ${MV} ${WRKDIR}/egcs-${LATEST} ${WRKSRC} .endif #### # Patch section PATCH_LIST=patch-core-* .if defined(MAKE_GXX) PATCH_LIST+=patch-g++-* .endif .if defined(MAKE_OBJC) PATCH_LIST+=patch-objc-* .endif .if defined(MAKE_CHILL) PATCH_LIST+=patch-chill-* .endif .if defined(MAKE_FORTRAN) PATCH_LIST+=patch-g77-* .endif .if defined(MAKE_JAVA) PATCH_LIST+=patch-java-* .endif # get openbsd configuration files where they should be post-patch: # avoid packaging include copies along... #find ${WRKSRC} -name \*.orig|xargs ${RM} ${CP} -R ${FILESDIR}/config/* ${WRKSRC} -${RM} -rf ${WRKSRC}/texinfo cd ${WRKSRC}; \ for f in `cat ${FILESDIR}/fixdepend`; \ do \ [ -f $$f ] && touch $$f; \ done #### # configure section # # define AS_PATH/LD_PATH is you don't want to use the default as/ld. # This should not be used for regular releases, but if you're using this # snapshot, you know what you're doing, don't you ? GNU_CONFIGURE= yes CONFIGURE_SCRIPT=../source/configure LANGS=c .if defined(MAKE_GXX) LANGS+=c++ .endif .if defined(MAKE_FORTRAN) LANGS+=f77 .endif .if defined(MAKE_CHILL) LANGS+=CHILL .endif .if defined(MAKE_OBJC) LANGS+=objc .endif .if defined(MAKE_JAVA) LANGS+=java .endif CONFIGURE_ENV=CFLAGS='-O2 -g' LANGUAGES='${LANGS}' CONFIGURE_ARGS= --prefix=${PREFIX} \ --verbose --program-transform-name=s,^,e, .if defined(AS_PATH) CONFIGURE_ARGS += --with-as=${AS_PATH} .else CONFIGURE_ARGS += --with-gnu-as .endif .if defined(LD_PATH) CONFIGURE_ARGS += --with-ld=${LD_PATH} .else CONFIGURE_ARGS += --with-gnu-ld .endif .if (${MACHINE_ARCH} != "alpha") CONFIGURE_ARGS+=--enable-shared .endif # rebuild configure files after patching, then move source around !!! # XXX: don't try to autoconf the main configure file, it's not autoconf. pre-configure: cd ${WRKSRC}/gcc && autoreconf cd ${WRKSRC}/libiberty && autoreconf -${MV} ${WRKSRC} ${WRKDIR}/source ${MKDIR} ${WRKSRC} #### # build section # should work without gmake. If it turns out to be needed, this must be # reported to the egcs folks #USE_GMAKE= yes # you shouldn't skip bootstrap unless you know what you're doing # use bootstrap-lean if you're pressed for space ALL_TARGET=bootstrap # ALL_TARGET=bootstrap-lean .if defined(MAKE_TESTS) ALL_TARGET+=check .endif # XXX we need to override do-build to get the warnings from within make do-build: @(cd ${WRKSRC}; \ ${MAKE_ENV} ${MAKE_PROGRAM} ${MAKE_FLAGS} ${MAKEFILE} ${ALL_TARGET} 2>warnings) || \ (echo "Make bootstrap failed."; \ echo "Don't forget to look at ${WRKSRC}/warnings"; ${FALSE}) #### # Install section PLIST=${WRKDIR}/PLIST M4FLAGS=-Uinclude -DDISTNAME=${DISTNAME} .if defined(MAKE_GXX) M4FLAGS+= -DGXX .endif .if defined(MAKE_FORTRAN) M4FLAGS+= -DFORTRAN .endif .if defined(MAKE_CHILL) M4FLAGS+= -DCHILL .endif .if defined(MAKE_OBJC) M4FLAGS+= -DOBJC .endif .if defined(MAKE_JAVA) M4FLAGS+= -DJAVA .endif .if (${MACHINE_ARCH}) != "alpha") M4FLAGS+= -DDYNAMIC .endif pre-install: ${M4} ${M4FLAGS} -DARCH=`${WRKDIR}/source/config.guess` \ -DVERSION=`${SED} -e 's/.*\(egcs-[0-9.]*\) .*/\1/' <${WRKDIR}/source/gcc/version.c` \ <${FILESDIR}/PLIST.template >${PLIST} .include