diff options
author | root <root@rshg054.dnsready.net> | 2013-08-26 01:41:32 -0700 |
---|---|---|
committer | root <root@rshg054.dnsready.net> | 2013-08-26 01:41:32 -0700 |
commit | 1d0d7aa1e250616385bce94b4d23f53b3d7b29e2 (patch) | |
tree | 1fe52c044982f2f66ae5b0045b7c5c5fae1f2f29 /community/gdc | |
parent | eed3b2a218be9aa9d9d8256f6b8ccd06d04b8804 (diff) |
Mon Aug 26 01:39:20 PDT 2013
Diffstat (limited to 'community/gdc')
-rw-r--r-- | community/gdc/PKGBUILD | 93 | ||||
-rw-r--r-- | community/gdc/folders.diff | 32 |
2 files changed, 125 insertions, 0 deletions
diff --git a/community/gdc/PKGBUILD b/community/gdc/PKGBUILD new file mode 100644 index 000000000..72fb3a5c6 --- /dev/null +++ b/community/gdc/PKGBUILD @@ -0,0 +1,93 @@ +# Maintainer: Mihails Strasuns <public@dicebot.lv> +# Contributor: Moritz Maxeiner <moritz@ucworks.org> +# Contributor: Jerome Berger <jeberger@free.fr> +# Contributor: Jesus Alvarez <jeezusjr@gmail.com> + +pkgname=('gdc' 'libgphobos-devel') +pkgver=4.8.1 +pkgrel=1 +arch=('i686' 'x86_64') +url="https://github.com/D-Programming-GDC/GDC" +license=('GPL') +makedepends=('binutils>=2.23' 'git' 'gcc' 'make' 'perl' 'cloog' 'automake') +options=('!libtool' '!emptydirs' '!buildflags') +_snapshot=4.8-20130725 +source=(ftp://gcc.gnu.org/pub/gcc/snapshots/${_snapshot}/gcc-${_snapshot}.tar.bz2 + gdc::git://github.com/D-Programming-GDC/GDC.git#branch=gdc-4.8 + folders.diff) +sha256sums=('e4e2202b15f8ba323f88c65de0e4190b0630a4b2e70b0653526b31e946877ead' + 'SKIP' + 'cd9df3c4129092f9a3ce6f608baa83e12935d7185d0ad3e273799264a21b031e') + +groups=('dlang' 'dlang-gdc') +conflicts=('gdc1-bin' 'gdc1-hg' 'gdc-git') + +prepare() +{ + cd $srcdir/gcc-$_snapshot + + # Do not run fixincludes + sed -i 's@\./fixinc\.sh@-c true@' gcc/Makefile.in + + 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 + + cd $srcdir/gdc + git apply $srcdir/folders.diff # fix gdc_include_path + ./setup-gcc.sh ../gcc-$_snapshot + + mkdir $srcdir/gcc-build +} + + +build() +{ + cd ${srcdir}/gcc-build + + ${srcdir}/gcc-$_snapshot/configure --prefix=/usr \ + --libdir=/usr/lib --libexecdir=/usr/lib \ + --mandir=/usr/share/man --infodir=/usr/share/info \ + --with-bugurl=https://bugs.archlinux.org/ \ + --enable-languages=d \ + --enable-shared --enable-threads=posix \ + --with-system-zlib --enable-__cxa_atexit \ + --disable-libunwind-exceptions --enable-clocale=gnu \ + --disable-libstdcxx-pch \ + --enable-gnu-unique-object --enable-linker-build-id \ + --enable-cloog-backend=isl --disable-cloog-version-check \ + --enable-lto --enable-gold --enable-ld=default \ + --enable-plugin --with-plugin-ld=ld.gold \ + --with-linker-hash-style=gnu --disable-install-libiberty \ + --disable-multilib --disable-libssp --disable-werror \ + --disable-nls --disable-bootstrap \ + --disable-libgomp --disable-libmudflap --disable-libquadmath + + make +} + +package_gdc() +{ + depends=('libmpc' 'zlib') + optdepends=('libgphobos-devel: D standard library, GDC version') + + install -D -m755 $srcdir/gcc-build/gcc/gdc $pkgdir/usr/bin/gdc + install -D -m755 $srcdir/gcc-build/gcc/cc1d $pkgdir/usr/lib/gcc/$CHOST/4.8.1/cc1d +} + +package_libgphobos-devel() +{ + # druntime + install -D $srcdir/gdc/libphobos/libdruntime/object.di $pkgdir/usr/include/dlang/gdc/$pkgver/object.di + cp -r $srcdir/gdc/libphobos/libdruntime/core $pkgdir/usr/include/dlang/gdc/$pkgver/core + cp -r $srcdir/gdc/libphobos/libdruntime/gcc $pkgdir/usr/include/dlang/gdc/$pkgver/gcc + + # phobos + cp $srcdir/gdc/libphobos/crc32.d ${pkgdir}/usr/include/dlang/gdc/$pkgver/crc32.d + cp -r $srcdir/gdc/libphobos/std ${pkgdir}/usr/include/dlang/gdc/$pkgver/std + cp -r $srcdir/gdc/libphobos/etc ${pkgdir}/usr/include/dlang/gdc/$pkgver/etc + + install -D -m644 $srcdir/gcc-build/$CHOST/libphobos/libgphobos2.a $pkgdir/usr/lib/libgphobos2.a + install -D -m644 $srcdir/gcc-build/$CHOST/libatomic/.libs/libatomic.a $pkgdir/usr/lib/libatomic.a +} diff --git a/community/gdc/folders.diff b/community/gdc/folders.diff new file mode 100644 index 000000000..738a7e6cd --- /dev/null +++ b/community/gdc/folders.diff @@ -0,0 +1,32 @@ +diff --git a/gcc/d/Make-lang.in b/gcc/d/Make-lang.in +index 5bdab1b..aa1122e 100644 +--- a/gcc/d/Make-lang.in ++++ b/gcc/d/Make-lang.in +@@ -25,9 +25,9 @@ D_TARGET_INSTALL_NAME = $(target_alias)-$(shell echo gdc|sed '$(program_transfor + + # This should be configured + ifeq ($(host), $(target)) +- gcc_d_include_dir = $(prefix)/include/d/$(version) ++ gcc_d_include_dir = $(prefix)/include/dlang/gdc/$(version) + else +- gcc_d_include_dir = $(libsubdir)/include/d ++ gcc_d_include_dir = $(libsubdir)/include/dlang/gdc + endif + + +diff --git a/libphobos/configure.in b/libphobos/configure.in +index f6b3660..7e88b23 100644 +--- a/libphobos/configure.in ++++ b/libphobos/configure.in +@@ -232,9 +232,9 @@ dnl (# Default case for install directory for include files.) and on + # will have to modify gcc/configure.ac .. + # For now, basic workaround for cross compilers .. + if test "${host}" != "${build}"; then +- gdc_include_dir='${libdir}/gcc/${host_alias}'/${d_gcc_ver}/include/d ++ gdc_include_dir='${libdir}/gcc/${host_alias}'/${d_gcc_ver}/include/dlang/gdc + else +- gdc_include_dir='${prefix}'/include/d/${d_gcc_ver} ++ gdc_include_dir='${prefix}'/include/dlang/gdc/${d_gcc_ver} + fi + AC_SUBST(gdc_include_dir) + AC_ARG_WITH([cross-host], |