X-Git-Url: https://git.distorted.org.uk/~mdw/termux-packages/blobdiff_plain/1986232751c7f8c679e8a0f8a5e56612b96389be..179329f864d48a6a1e97e720278a88ba1d74dde7:/packages/ldc/build.sh diff --git a/packages/ldc/build.sh b/packages/ldc/build.sh index 9a097520..fdf0f43b 100644 --- a/packages/ldc/build.sh +++ b/packages/ldc/build.sh @@ -1,9 +1,9 @@ TERMUX_PKG_HOMEPAGE=https://github.com/ldc-developers/ldc TERMUX_PKG_DESCRIPTION="D programming language compiler, built with LLVM" -_PKG_MAJOR_VERSION=1.3 +_PKG_MAJOR_VERSION=1.5 TERMUX_PKG_VERSION=${_PKG_MAJOR_VERSION}.0 TERMUX_PKG_SRCURL=https://github.com/ldc-developers/ldc/releases/download/v${TERMUX_PKG_VERSION}/ldc-${TERMUX_PKG_VERSION}-src.tar.gz -TERMUX_PKG_SHA256=efe31a639bcb44e1f5b752da21713376d9410a01279fecc8aab8572065a3050b +TERMUX_PKG_SHA256=03659a4b9cafff0cf8d537469dd15579f097c7748a342ea2a5770fa0edd3a084 TERMUX_PKG_DEPENDS="clang" TERMUX_PKG_HOSTBUILD=true TERMUX_PKG_BLACKLISTED_ARCHES="aarch64,i686,x86_64" @@ -13,57 +13,85 @@ TERMUX_PKG_EXTRA_CONFIGURE_ARGS=" -DLLVM_ENABLE_PIC=ON -DLLVM_BUILD_TOOLS=OFF -DLLVM_BUILD_UTILS=OFF --DLLVM_TABLEGEN=$TERMUX_PKG_HOSTBUILD_DIR/bin/llvm-tblgen" +-DLLVM_TABLEGEN=$TERMUX_PKG_HOSTBUILD_DIR/bin/llvm-tblgen +-DPYTHON_EXECUTABLE=`which python` +" TERMUX_PKG_KEEP_STATIC_LIBRARIES=true TERMUX_PKG_NO_DEVELSPLIT=yes TERMUX_PKG_MAINTAINER="Joakim @joakim-noah" termux_step_post_extract_package () { - local LLVM_SRC_VERSION=4.0.1 + local LLVM_SRC_VERSION=5.0.0-2 termux_download \ https://github.com/ldc-developers/llvm/releases/download/ldc-v${LLVM_SRC_VERSION}/llvm-${LLVM_SRC_VERSION}.src.tar.xz \ $TERMUX_PKG_CACHEDIR/llvm-${LLVM_SRC_VERSION}.src.tar.xz \ - 53dee2054a4da0a292fc55830119ae167812cc0eed5cc670223adc5a8731f71b + 7bb7621ecb05ad9a9a2165bae69c0548c179fdaf7e12e8458897c5e8bc1a6dae tar xf $TERMUX_PKG_CACHEDIR/llvm-${LLVM_SRC_VERSION}.src.tar.xz mv llvm-${LLVM_SRC_VERSION}.src llvm - DMD_COMPILER_VERSION=2.075.1 + DMD_COMPILER_VERSION=2.076.1 termux_download \ http://downloads.dlang.org/releases/2.x/${DMD_COMPILER_VERSION}/dmd.${DMD_COMPILER_VERSION}.linux.tar.xz \ $TERMUX_PKG_CACHEDIR/dmd.${DMD_COMPILER_VERSION}.linux.tar.xz \ - 6531c098020cf321b5e71c420a10db729566006b72e0af873b15b506a1583c57 + 1d0b8fb6aadc80f6c5dfe7acf46fc17d2b3de24a0bf46e947352094bb21fef04 + + termux_download \ + https://github.com/dlang/tools/archive/v${DMD_COMPILER_VERSION}.tar.gz \ + $TERMUX_PKG_CACHEDIR/tools-v${DMD_COMPILER_VERSION}.tar.gz \ + cf42d4e5f9ceb5acfb5bd3000dd9c1ed7120b136f252b33b07fb026f36970e77 + + tar xf $TERMUX_PKG_CACHEDIR/tools-v${DMD_COMPILER_VERSION}.tar.gz + mv tools-${DMD_COMPILER_VERSION} rdmd + + local DUB_VERSION=1.5.0 + termux_download \ + https://github.com/dlang/dub/archive/v${DUB_VERSION}.tar.gz \ + $TERMUX_PKG_CACHEDIR/dub-v${DUB_VERSION}.tar.gz \ + 3509f959cc5b34e44adaae586b62ded387ac10031f6c1aaf1cfbb4aae5af37dd + + tar xf $TERMUX_PKG_CACHEDIR/dub-v${DUB_VERSION}.tar.gz + mv dub-${DUB_VERSION} dub sed "s#\@TERMUX_C_COMPILER\@#$TERMUX_STANDALONE_TOOLCHAIN/bin/$TERMUX_HOST_PLATFORM-clang#" \ $TERMUX_PKG_BUILDER_DIR/ldc-config-stdlib.patch.beforehostbuild.in > \ $TERMUX_PKG_BUILDER_DIR/ldc-config-stdlib.patch.beforehostbuild - sed -i "s#\@TERMUX_C_FLAGS\@#-march=armv7-a -mfpu=neon -mfloat-abi=softfp -mthumb -Os -I$TERMUX_PREFIX/include#" \ - $TERMUX_PKG_BUILDER_DIR/ldc-config-stdlib.patch.beforehostbuild + sed "s#\@TERMUX_PKG_HOSTBUILD\@#$TERMUX_PKG_HOSTBUILD_DIR#" $TERMUX_PKG_BUILDER_DIR/ldc-linker-flags.patch.in > \ $TERMUX_PKG_BUILDER_DIR/ldc-linker-flags.patch - sed "s#\@TERMUX_PKG_BUILD\@#$TERMUX_PKG_BUILDDIR#" $TERMUX_PKG_BUILDER_DIR/ldc-llvm-config.patch.in > \ - $TERMUX_PKG_BUILDER_DIR/ldc-llvm-config.patch - sed -i "s#\@TERMUX_PKG_SRC\@#$TERMUX_PKG_SRCDIR#" $TERMUX_PKG_BUILDER_DIR/ldc-llvm-config.patch + + sed $TERMUX_PKG_BUILDER_DIR/llvm-config.in \ + -e "s|@LLVM_VERSION@|$LLVM_SRC_VERSION|g" \ + -e "s|@LLVM_BUILD_DIR@|$TERMUX_PKG_BUILDDIR/llvm|g" \ + -e "s|@TERMUX_PKG_SRCDIR@|$TERMUX_PKG_SRCDIR|g" \ + -e "s|@LLVM_TARGETS@|ARM AArch64 X86|g" \ + -e "s|@LLVM_DEFAULT_TARGET_TRIPLE@|armv7-none-linux-android|g" \ + -e "s|@TERMUX_ARCH@|$TERMUX_ARCH|g" > $TERMUX_PKG_BUILDDIR/llvm-config + chmod 755 $TERMUX_PKG_BUILDDIR/llvm-config } termux_step_host_build () { tar xf $TERMUX_PKG_CACHEDIR/dmd.${DMD_COMPILER_VERSION}.linux.tar.xz termux_setup_cmake - cmake -G "Unix Makefiles" $TERMUX_PKG_SRCDIR/llvm \ + termux_setup_ninja + cmake -GNinja $TERMUX_PKG_SRCDIR/llvm \ -DCMAKE_BUILD_TYPE=Release \ -DLLVM_TARGETS_TO_BUILD=ARM \ -DLLVM_DEFAULT_TARGET_TRIPLE=armv7-none-linux-android \ -DLLVM_BUILD_TOOLS=OFF \ -DLLVM_BUILD_UTILS=OFF - make -j $TERMUX_MAKE_PROCESSES all llvm-config + ninja -j $TERMUX_MAKE_PROCESSES all llvm-config mkdir ldc-bootstrap cd ldc-bootstrap export DMD="$TERMUX_PKG_HOSTBUILD_DIR/dmd2/linux/bin64/dmd" - cmake -G "Unix Makefiles" $TERMUX_PKG_SRCDIR \ + + cmake -GNinja $TERMUX_PKG_SRCDIR \ + -DD_FLAGS="-w;-mcpu=cortex-a8" \ + -DRT_CFLAGS="-march=armv7-a -mfpu=neon -mfloat-abi=softfp -mthumb -Oz -I$TERMUX_PREFIX/include" \ -DLLVM_CONFIG="$TERMUX_PKG_HOSTBUILD_DIR/bin/llvm-config" - make -j $TERMUX_MAKE_PROCESSES druntime-ldc phobos2-ldc \ + ninja -j $TERMUX_MAKE_PROCESSES druntime-ldc phobos2-ldc \ druntime-ldc-debug phobos2-ldc-debug ldmd2 cd .. } @@ -71,7 +99,6 @@ termux_step_host_build () { termux_step_pre_configure () { rm $TERMUX_PKG_BUILDER_DIR/ldc-config-stdlib.patch.beforehostbuild rm $TERMUX_PKG_BUILDER_DIR/ldc-linker-flags.patch - rm $TERMUX_PKG_BUILDER_DIR/ldc-llvm-config.patch TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" -DLLVM_DEFAULT_TARGET_TRIPLE=armv7a-linux-androideabi" TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" -DLLVM_TARGET_ARCH=ARM -DLLVM_TARGETS_TO_BUILD=AArch64;ARM;X86" @@ -93,7 +120,8 @@ termux_step_post_configure () { TERMUX_PKG_BUILDDIR=$OLD_TERMUX_PKG_BUILDDIR cd "$TERMUX_PKG_BUILDDIR" - TERMUX_PKG_EXTRA_CONFIGURE_ARGS="" + mv llvm-config llvm/bin + TERMUX_PKG_EXTRA_CONFIGURE_ARGS="-DLLVM_CONFIG=$TERMUX_PKG_BUILDDIR/llvm/bin/llvm-config" export DMD="$TERMUX_PKG_HOSTBUILD_DIR/ldc-bootstrap/bin/ldmd2" termux_step_configure_cmake @@ -110,12 +138,23 @@ termux_step_make () { cd .. if ls ./*akefile &> /dev/null; then - make -j $TERMUX_MAKE_PROCESSES ldc2 ldmd2 + make -j $TERMUX_MAKE_PROCESSES ldc2 ldmd2 ldc-build-runtime fi + + # Build the rdmd scripting wrapper and the dub package manager + D_FLAGS="-w -de -O -inline -release -mcpu=cortex-a8" + $DMD $D_FLAGS -c $TERMUX_PKG_SRCDIR/rdmd/rdmd.d -of=$TERMUX_PKG_BUILDDIR/bin/rdmd.o + D_LDFLAGS="-fuse-ld=bfd -L${TERMUX_PKG_HOSTBUILD_DIR}/ldc-bootstrap/lib -lphobos2-ldc -ldruntime-ldc -Wl,--gc-sections -ldl -lm -Wl,--fix-cortex-a8 -fPIE -pie -Wl,-z,nocopyreloc ${LDFLAGS}" + $CC $TERMUX_PKG_BUILDDIR/bin/rdmd.o $D_LDFLAGS -o $TERMUX_PKG_BUILDDIR/bin/rdmd + + cd $TERMUX_PKG_SRCDIR/dub + $DMD $D_FLAGS -version=DubUseCurl -Isource -c @build-files.txt -of=$TERMUX_PKG_BUILDDIR/bin/dub.o + cd $TERMUX_PKG_BUILDDIR + $CC $TERMUX_PKG_BUILDDIR/bin/dub.o $D_LDFLAGS -o $TERMUX_PKG_BUILDDIR/bin/dub } termux_step_make_install () { - cp bin/{ldc2,ldmd2} $TERMUX_PREFIX/bin + cp bin/{dub,ldc-build-runtime,ldc2,ldmd2,rdmd} $TERMUX_PREFIX/bin cp $TERMUX_PKG_HOSTBUILD_DIR/ldc-bootstrap/lib/lib{druntime,phobos2}*.a $TERMUX_PREFIX/lib sed -i "/runtime\/druntime\/src/d" bin/ldc2.conf sed -i "/runtime\/profile-rt\/d/d" bin/ldc2.conf