diff options
author | wtx | 2016-12-23 08:04:15 +0100 |
---|---|---|
committer | wtx | 2016-12-23 08:07:55 +0100 |
commit | d3cc8c1370d32f38f31368b608ffee2d1f973e45 (patch) | |
tree | 53663c5c1c3b88e420af57fff6445706a12f5d5c | |
download | aur-d3cc8c1370d32f38f31368b608ffee2d1f973e45.tar.gz |
Initial commit
-rw-r--r-- | .SRCINFO | 49 | ||||
-rw-r--r-- | PKGBUILD | 347 | ||||
-rw-r--r-- | cfns.h.diff | 15 | ||||
-rw-r--r-- | gcc.texi.48.patch | 11 | ||||
-rw-r--r-- | gcc48-alternative-libs.install | 16 | ||||
-rw-r--r-- | gcc48-alternative.install | 20 |
6 files changed, 458 insertions, 0 deletions
diff --git a/.SRCINFO b/.SRCINFO new file mode 100644 index 000000000000..4847c80be175 --- /dev/null +++ b/.SRCINFO @@ -0,0 +1,49 @@ +pkgbase = gcc48-alternative + pkgdesc = The GNU Compiler Collection 4.8 for multilib + pkgver = 4.8.5 + pkgrel = 2 + url = http://gcc.gnu.org + arch = x86_64 + license = GPL + license = LGPL + license = FDL + license = custom + checkdepends = dejagnu + checkdepends = inetutils + makedepends = binutils>=2.25 + makedepends = libmpc + makedepends = doxygen + makedepends = lib32-glibc>=2.20 + options = !emptydirs + source = ftp://gcc.gnu.org/pub/gcc/releases/gcc-4.8.5/gcc-4.8.5.tar.bz2 + source = http://isl.gforge.inria.fr/isl-0.12.2.tar.bz2 + source = http://www.bastoul.net/cloog/pages/download/cloog-0.18.1.tar.gz + md5sums = 80d2c2982a3392bb0b89673ff136e223 + md5sums = e039bfcfb6c2ab039b8ee69bf883e824 + md5sums = e34fca0540d840e5d0f6427e98c92252 + +pkgname = gcc48-alternative-multilib + pkgdesc = The GNU Compiler Collection 4.8 - C and C++ frontends for multilib + install = gcc48-alternative.install + groups = multilib-devel + depends = gcc48-alternative-libs-multilib=4.8.5-2 + depends = binutils>=2.25 + depends = libmpc + provides = gcc48=4.8.5-2 + options = staticlibs + +pkgname = gcc48-alternative-libs-multilib + pkgdesc = Runtime GCC 4.8 libraries for multilib + install = gcc48-alternative-libs.install + depends = glibc>=2.20 + depends = lib32-gcc48-alternative-libs=4.8.5-2 + provides = gcc48-alternative-libs=4.8.5-2 + options = !emptydirs + options = !strip + +pkgname = lib32-gcc48-alternative-libs + pkgdesc = Runtime GCC 4.8 libraries (32-bit) + depends = lib32-glibc>=2.20 + options = !emptydirs + options = !strip + diff --git a/PKGBUILD b/PKGBUILD new file mode 100644 index 000000000000..a566856a98c1 --- /dev/null +++ b/PKGBUILD @@ -0,0 +1,347 @@ +# Maintainer: Yurii Kolesnykov (yurikooles) <yurikoles@gmail.com> +# Maintainer: Jan Alexander Steffens (heftig) <jan.steffens@gmail.com> +# Contributor: Allan McRae <allan@archlinux.org> + +# toolchain build order: linux-api-headers->glibc->binutils->gcc->binutils->glibc +# NOTE: libtool requires rebuilt with each new gcc version + +pkgname=('gcc48-alternative-multilib' 'gcc48-alternative-libs-multilib' 'lib32-gcc48-alternative-libs') +pkgver=4.8.5 +_pkgver=4.8 +_islver=0.12.2 +_cloogver=0.18.1 +pkgrel=2 +#_snapshot=4.9-20150304 +pkgdesc="The GNU Compiler Collection 4.8 for multilib" +arch=('x86_64') +license=('GPL' 'LGPL' 'FDL' 'custom') +url="http://gcc.gnu.org" +makedepends=('binutils>=2.25' 'libmpc' 'doxygen' + 'lib32-glibc>=2.20') +checkdepends=('dejagnu' 'inetutils') +options=('!emptydirs') +source=(ftp://gcc.gnu.org/pub/gcc/releases/gcc-${pkgver}/gcc-${pkgver}.tar.bz2 + #ftp://gcc.gnu.org/pub/gcc/snapshots/${_snapshot}/gcc-${_snapshot}.tar.bz2 + http://isl.gforge.inria.fr/isl-${_islver}.tar.bz2 + http://www.bastoul.net/cloog/pages/download/cloog-${_cloogver}.tar.gz) +md5sums=('80d2c2982a3392bb0b89673ff136e223' + 'e039bfcfb6c2ab039b8ee69bf883e824' + 'e34fca0540d840e5d0f6427e98c92252') + +if [ -n "${_snapshot}" ]; then + _basedir=gcc-${_snapshot} +else + _basedir=gcc-${pkgver} +fi + +_libdir="usr/gcc48/lib/gcc/$CHOST/$pkgver" + + +prepare() { + cd ${srcdir}/${_basedir} + + # link isl/cloog for in-tree builds + ln -sf ../isl-${_islver} isl + ln -sf ../cloog-${_cloogver} cloog + + # Do not run fixincludes + sed -i 's@\./fixinc\.sh@-c true@' gcc/Makefile.in + + # Arch Linux installs x86_64 libraries /lib + [[ $CARCH == "x86_64" ]] && sed -i '/m64=/s/lib64/lib/' gcc/config/i386/t-linux64 + + echo ${pkgver} > gcc/BASE-VER + + # hack! - some configure tests for header files using "$CPP $CPPFLAGS" + sed -i "/ac_cpp=/s/\$CPPFLAGS/\$CPPFLAGS -O2/" {libiberty,gcc}/configure + + patch -p1 -i ${startdir}/cfns.h.diff +# patch -p0 -i ${startdir}/texinfo.patch + patch -p0 -i ${startdir}/gcc.texi.48.patch + + mkdir -p ${srcdir}/gcc-build +} + +build() { + cd ${srcdir}/gcc-build + + # using -pipe causes spurious test-suite failures + # http://gcc.gnu.org/bugzilla/show_bug.cgi?id=48565 + CFLAGS=${CFLAGS/-pipe/} + CXXFLAGS=${CXXFLAGS/-pipe/} + + CFLAGS=${CFLAGS/-fstack-protector-strong/} + CXXFLAGS=${CFLAGS/-fstack-protector-strong/} + + + export LD_PRELOAD=/usr/lib/libstdc++.so.6 + + + ${srcdir}/${_basedir}/configure --prefix=/usr/gcc48 --exec-prefix=/usr/gcc48 \ + --libdir=/usr/gcc48/lib --libexecdir=/usr/gcc48/lib \ + --mandir=/usr/gcc48/share/man --infodir=/usr/gcc48/share/info \ + --with-bugurl=https://bugs.archlinux.org/ \ + --enable-languages=c,c++,lto \ + --enable-shared --enable-threads=posix \ + --with-system-zlib --enable-__cxa_atexit \ + --disable-libunwind-exceptions --enable-clocale=gnu \ + --disable-libstdcxx-pch --disable-libssp \ + --enable-gnu-unique-object --enable-linker-build-id \ + --enable-cloog-backend=isl \ + --enable-lto --enable-plugin --enable-install-libiberty \ + --with-linker-hash-style=gnu \ + --enable-multilib --disable-werror \ + --enable-checking=release + + + make + + # make documentation + make -C $CHOST/libstdc++-v3/doc doc-man-doxygen +} + +check() { + cd ${srcdir}/gcc-build + + # increase stack size to prevent test failures + # http://gcc.gnu.org/bugzilla/show_bug.cgi?id=31827 + ulimit -s 32768 + + # do not abort on error as some are "expected" + make -k check || true + ${srcdir}/${_basedir}/contrib/test_summary +} + +package_lib32-gcc48-alternative-libs() +{ + pkgdesc="Runtime GCC 4.8 libraries (32-bit)" + depends=('lib32-glibc>=2.20') + options=('!emptydirs' '!strip') + + cd ${srcdir}/gcc-build + + make -C $CHOST/32/libgcc DESTDIR=${pkgdir} install-shared + rm ${pkgdir}/${_libdir}/32/libgcc_eh.a + + for lib in libatomic \ + libgomp \ + libitm \ + libquadmath \ + libsanitizer/asan \ + libstdc++-v3/src \ + ; do + make -C $CHOST/32/$lib DESTDIR=${pkgdir} install-toolexeclibLTLIBRARIES + done + + # make -C $CHOST/32/libobjc DESTDIR=${pkgdir} install-libs + + # remove stuff in gcc-libs-multilib + rm -r ${pkgdir}/usr/gcc48/lib +} + +package_gcc48-alternative-libs-multilib() +{ + pkgdesc="Runtime GCC 4.8 libraries for multilib" +# depends=('glibc>=2.20' "lib32-gcc-libs=$pkgver-$pkgrel") + depends=('glibc>=2.20' "lib32-gcc48-alternative-libs=$pkgver-$pkgrel") + provides=("gcc48-alternative-libs=$pkgver-$pkgrel") +# conflicts=('gcc-libs') + options=('!emptydirs' '!strip') + install=gcc48-alternative-libs.install + + cd ${srcdir}/gcc-build + + make -C $CHOST/libgcc DESTDIR=${pkgdir} install-shared + rm ${pkgdir}/${_libdir}/libgcc_eh.a + + for lib in libatomic \ + libgomp \ + libitm \ + libquadmath \ + libsanitizer/asan \ + libstdc++-v3/src \ + ; do + make -C $CHOST/$lib DESTDIR=${pkgdir} install-toolexeclibLTLIBRARIES + done + + [[ $CARCH == "x86_64" ]] && \ + make -C $CHOST/libsanitizer/tsan DESTDIR=${pkgdir} install-toolexeclibLTLIBRARIES + +# make -C $CHOST/libobjc DESTDIR=${pkgdir} install-libs + make -C $CHOST/libstdc++-v3/po DESTDIR=${pkgdir} install + + + + +# for lib in libgomp \ +# libitm \ +# libquadmath; do +# make -C $CHOST/$lib DESTDIR=${pkgdir} install-info +# done + +# rm ${pkgdir}/usr/gcc48/share/locale/de/LC_MESSAGES/libstdc++.mo +# rm ${pkgdir}/usr/gcc48/share/locale/fr/LC_MESSAGES/libstdc++.mo + + # remove stuff in lib32-gcc-libs + #rm -r ${pkgdir}/usr/lib32 + + # Install Runtime Library Exception + # install -Dm644 ${srcdir}/${_basedir}/COPYING.RUNTIME ${pkgdir}/usr/share/licenses/gcc-libs-multilib/RUNTIME.LIBRARY.EXCEPTION +} + +package_gcc48-alternative-multilib() +{ + pkgdesc="The GNU Compiler Collection 4.8 - C and C++ frontends for multilib" + depends=("gcc48-alternative-libs-multilib=$pkgver-$pkgrel" 'binutils>=2.25' 'libmpc') + groups=('multilib-devel') + options=('staticlibs') + provides=("gcc48=$pkgver-$pkgrel") +# conflicts=('gcc') + install=gcc48-alternative.install + + cd ${srcdir}/gcc-build + + make -C gcc DESTDIR=${pkgdir} install-driver install-cpp install-gcc-ar \ + c++.install-common install-headers install-plugin install-lto-wrapper + + install -m755 gcc/gcov $pkgdir/usr/gcc48/bin/ + install -m755 -t $pkgdir/${_libdir}/ gcc/{cc1,cc1plus,collect2,lto1} + + make -C $CHOST/libgcc DESTDIR=${pkgdir} install + make -C $CHOST/32/libgcc DESTDIR=${pkgdir} install + rm ${pkgdir}/usr/gcc48/lib{,32}/libgcc_s.so* + + make -C $CHOST/libstdc++-v3/src DESTDIR=${pkgdir} install + make -C $CHOST/libstdc++-v3/include DESTDIR=${pkgdir} install + make -C $CHOST/libstdc++-v3/libsupc++ DESTDIR=${pkgdir} install + make -C $CHOST/libstdc++-v3/python DESTDIR=${pkgdir} install + make -C $CHOST/32/libstdc++-v3/src DESTDIR=${pkgdir} install + make -C $CHOST/32/libstdc++-v3/include DESTDIR=${pkgdir} install + make -C $CHOST/32/libstdc++-v3/libsupc++ DESTDIR=${pkgdir} install + + install -d $pkgdir/usr/gcc48/share/gdb/auto-load/usr/lib + mv $pkgdir/usr/gcc48/lib/libstdc++.so.6.*-gdb.py $pkgdir/usr/gcc48/share/gdb/auto-load/usr/lib/ + + rm ${pkgdir}/usr/gcc48/lib{,32}/libstdc++.so* + + make DESTDIR=${pkgdir} install-fixincludes + make -C gcc DESTDIR=${pkgdir} install-mkheaders + make -C lto-plugin DESTDIR=${pkgdir} install + +# make -C $CHOST/libcilkrts DESTDIR=${pkgdir} install-nodist_toolexeclibHEADERS \ +# install-nodist_cilkincludeHEADERS + make -C $CHOST/libgomp DESTDIR=${pkgdir} install-nodist_toolexeclibHEADERS \ + install-nodist_libsubincludeHEADERS + make -C $CHOST/libitm DESTDIR=${pkgdir} install-nodist_toolexeclibHEADERS + make -C $CHOST/libquadmath DESTDIR=${pkgdir} install-nodist_libsubincludeHEADERS +# make -C $CHOST/libsanitizer DESTDIR=${pkgdir} install-nodist_toolexeclibHEADERS + make -C $CHOST/libsanitizer/asan DESTDIR=${pkgdir} install-nodist_toolexeclibHEADERS +# make -C $CHOST/32/libcilkrts DESTDIR=${pkgdir} install-nodist_toolexeclibHEADERS + make -C $CHOST/32/libgomp DESTDIR=${pkgdir} install-nodist_toolexeclibHEADERS + make -C $CHOST/32/libitm DESTDIR=${pkgdir} install-nodist_toolexeclibHEADERS +# make -C $CHOST/32/libsanitizer DESTDIR=${pkgdir} install-nodist_toolexeclibHEADERS + make -C $CHOST/32/libsanitizer/asan DESTDIR=${pkgdir} install-nodist_toolexeclibHEADERS + + make -C libiberty DESTDIR=${pkgdir} install + # install PIC version of libiberty +# install -m644 ${srcdir}/gcc-build/libiberty/pic/libiberty.a ${pkgdir}/usr/lib + install -m644 ${srcdir}/gcc-build/libiberty/pic/libiberty.a ${pkgdir}/usr/gcc48/lib + + + make -C gcc DESTDIR=${pkgdir} install-man install-info +# rm ${pkgdir}/usr/share/man/man1/{gccgo,gfortran}.1 +# rm ${pkgdir}/usr/share/info/{gccgo,gfortran,gnat-style,gnat_rm,gnat_ugn}.info + + make -C libcpp DESTDIR=${pkgdir} install + make -C gcc DESTDIR=${pkgdir} install-po + + # many packages expect this symlink + ln -s gcc ${pkgdir}/usr/gcc48/bin/cc + + # POSIX conformance launcher scripts for c89 and c99 + cat > $pkgdir/usr/gcc48/bin/c89 <<"EOF" +#!/bin/sh +fl="-std=c89" +for opt; do + case "$opt" in + -ansi|-std=c89|-std=iso9899:1990) fl="";; + -std=*) echo "`basename $0` called with non ANSI/ISO C option $opt" >&2 + exit 1;; + esac +done +exec gcc $fl ${1+"$@"} +EOF + + cat > $pkgdir/usr/gcc48/bin/c99 <<"EOF" +#!/bin/sh +fl="-std=c99" +for opt; do + case "$opt" in + -std=c99|-std=iso9899:1999) fl="";; + -std=*) echo "`basename $0` called with non ISO C99 option $opt" >&2 + exit 1;; + esac +done +exec gcc $fl ${1+"$@"} +EOF + + chmod 755 $pkgdir/usr/gcc48/bin/c{8,9}9 + + # install the libstdc++ man pages + make -C $CHOST/libstdc++-v3/doc DESTDIR=$pkgdir doc-install-man + + + + mv ${pkgdir}/usr/gcc48/share/man/man1/gcc.1 ${pkgdir}/usr/gcc48/share/man/man1/gcc-4.8.5 + mv ${pkgdir}/usr/gcc48/share/man/man1/g++.1 ${pkgdir}/usr/gcc48/share/man/man1/g++-4.8.5 + mv ${pkgdir}/usr/gcc48/share/man/man1/cpp.1 ${pkgdir}/usr/gcc48/share/man/man1/cpp-4.8.5 + mv ${pkgdir}/usr/gcc48/share/man/man1/gcov.1 ${pkgdir}/usr/gcc48/share/man/man1/gcov-4.8.5 + mv ${pkgdir}/usr/gcc48/share/info/cpp.info ${pkgdir}/usr/gcc48/share/man/man1/cpp-4.8.info + mv ${pkgdir}/usr/gcc48/share/info/gcc.info ${pkgdir}/usr/gcc48/share/man/man1/gcc-4.8.info + mv ${pkgdir}/usr/gcc48/share/info/cppinternals.info ${pkgdir}/usr/gcc48/share/man/man1/cppinternals-4.8.info + mv ${pkgdir}/usr/gcc48/share/info/gccinstall.info ${pkgdir}/usr/gcc48/share/man/man1/gccinstall-4.8.info + mv ${pkgdir}/usr/gcc48/share/info/gccint.info ${pkgdir}/usr/gcc48/share/man/man1/gccint-4.8.info + + rm -r ${pkgdir}/usr/gcc48/share/locale/ + + install -d ${pkgdir}/usr/bin + + cd ${pkgdir}/usr/bin/ + ln -s ../gcc48/bin/c++ c++-4.8 + ln -s ../gcc48/bin/c89 c89-4.8 + ln -s ../gcc48/bin/c99 c99-4.8 + ln -s ../gcc48/bin/cc cc-4.8 + ln -s ../gcc48/bin/cpp cpp-4.8 + ln -s ../gcc48/bin/g++ g++-4.8 + ln -s ../gcc48/bin/gcc gcc-4.8 + ln -s ../gcc48/bin/gcc-ar gcc-ar-4.8 + ln -s ../gcc48/bin/gcc-nm gcc-nm-4.8 + ln -s ../gcc48/bin/gcc-ranlib gcc-ranlib-4.8 + ln -s ../gcc48/bin/gcov gcov-4.8 + cd $owd + + + +# rm -r ${pkgdir}/usr/gcc48/include/libiberty +# rm ${pkgdir}/usr/gcc48/share/man/man3/Numeric_arrays.3 +# rm ${pkgdir}/usr/gcc48/share/man/man3/Pointer_abstractions.3 +# rm ${pkgdir}/usr/gcc48/share/man/man3/SGIextensions.3 +# rm ${pkgdir}/usr/gcc48/share/man/man3/__gnu_cxx.3 +# rm ${pkgdir}/usr/gcc48/share/man/man3/__gnu_debug.3 +# rm ${pkgdir}/usr/gcc48/share/man/man3/__gnu_internal.3 +# rm ${pkgdir}/usr/gcc48/share/man/man3/__gnu_parallel.3 +# rm ${pkgdir}/usr/gcc48/share/man/man3/__gnu_pbds.3 +# rm ${pkgdir}/usr/gcc48/share/man/man3/random.3 +# rm ${pkgdir}/usr/gcc48/share/man/man3/regex.3 +# rm ${pkgdir}/usr/gcc48/share/man/man7/fsf-funding.7 +# rm ${pkgdir}/usr/gcc48/share/man/man7/gfdl.7 +# rm ${pkgdir}/usr/gcc48/share/man/man7/gpl.7 + + # Install Runtime Library Exception + install -d ${pkgdir}/usr/gcc48/share/licenses/gcc-multilib/ +# ln -s ../gcc-libs-multilib/RUNTIME.LIBRARY.EXCEPTION ${pkgdir}/usr/gcc48/share/licenses/gcc-multilib/ +} + + + + diff --git a/cfns.h.diff b/cfns.h.diff new file mode 100644 index 000000000000..79b1924aa72c --- /dev/null +++ b/cfns.h.diff @@ -0,0 +1,15 @@ +--- gcc-5.3.0/gcc/cp/cfns.h 2016-05-07 19:39:04.976724823 +0200 ++++ gcc-5.3.0/gcc/cp/cfns.h 2016-05-07 19:37:59.000000000 +0200 +@@ -124,9 +124,9 @@ hash (register const char *str, register + + #ifdef __GNUC__ + __inline +-#ifdef __GNUC_STDC_INLINE__ +-__attribute__ ((__gnu_inline__)) +-#endif ++//#ifdef __GNUC_STDC_INLINE__ ++//__attribute__ ((__gnu_inline__)) ++//#endif + #endif + const char * + libc_name_p (register const char *str, register unsigned int len) diff --git a/gcc.texi.48.patch b/gcc.texi.48.patch new file mode 100644 index 000000000000..da22bc1666bd --- /dev/null +++ b/gcc.texi.48.patch @@ -0,0 +1,11 @@ +--- gcc/doc/gcc.texi 2015-06-23 09:35:08.000000000 +0200 ++++ gcc/doc/gcc.texi 2016-12-22 14:17:41.313844060 +0100 +@@ -205,4 +205,8 @@ form; it may sometimes be useful to look + @c Epilogue + @c --------------------------------------------------------------------- + ++@end tex ++@end multitable ++@end titlepage ++ + @bye diff --git a/gcc48-alternative-libs.install b/gcc48-alternative-libs.install new file mode 100644 index 000000000000..23553b8f0b10 --- /dev/null +++ b/gcc48-alternative-libs.install @@ -0,0 +1,16 @@ +infodir=usr/share/info +filelist=(libgomp.info libquadmath.info) + +post_upgrade() { + [ -x usr/bin/install-info ] || return 0 + for file in ${filelist[@]}; do + install-info $infodir/$file.gz $infodir/dir 2> /dev/null + done +} + +pre_remove() { + [ -x usr/bin/install-info ] || return 0 + for file in ${filelist[@]}; do + install-info --delete $infodir/$file.gz $infodir/dir 2> /dev/null + done +} diff --git a/gcc48-alternative.install b/gcc48-alternative.install new file mode 100644 index 000000000000..3407a5e1f37c --- /dev/null +++ b/gcc48-alternative.install @@ -0,0 +1,20 @@ +infodir=usr/share/info +filelist=(cpp.info cppinternals.info gcc.info gccinstall.info gccint.info) + +post_install() { + [ -x usr/bin/install-info ] || return 0 + for file in ${filelist[@]}; do + install-info $infodir/$file.gz $infodir/dir 2> /dev/null + done +} + +post_upgrade() { + post_install $1 +} + +pre_remove() { + [ -x usr/bin/install-info ] || return 0 + for file in ${filelist[@]}; do + install-info --delete $infodir/$file.gz $infodir/dir 2> /dev/null + done +} |