ldc: add dub and rdmd, plus bump host dmd to latest version 2.076.0 (#1377)
authorjoakim-noah <gh@joakim.fea.st>
Wed, 6 Sep 2017 19:16:04 +0000 (00:46 +0530)
committerFredrik Fornwall <fredrik@fornwall.net>
Wed, 6 Sep 2017 19:16:04 +0000 (21:16 +0200)
packages/ldc/build.sh
packages/ldc/rdmd-tempDir.patch [new file with mode: 0644]

index 9a09752..0346f84 100644 (file)
@@ -2,6 +2,7 @@ TERMUX_PKG_HOMEPAGE=https://github.com/ldc-developers/ldc
 TERMUX_PKG_DESCRIPTION="D programming language compiler, built with LLVM"
 _PKG_MAJOR_VERSION=1.3
 TERMUX_PKG_VERSION=${_PKG_MAJOR_VERSION}.0
+TERMUX_PKG_REVISION=1
 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_DEPENDS="clang"
@@ -28,11 +29,28 @@ termux_step_post_extract_package () {
        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.0
        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
+               3e3fc9fbdc61681edea837e9d095a341dda6c325ab4dbc437017239d576ba433
+
+       termux_download \
+               https://github.com/dlang/tools/archive/v${DMD_COMPILER_VERSION}.tar.gz \
+               $TERMUX_PKG_CACHEDIR/tools-v${DMD_COMPILER_VERSION}.tar.gz \
+               5f58dc6492e1abb539291a5fbf2bfb06eed818bd158912f090b55cd712c2a34a
+
+       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 > \
@@ -112,10 +130,21 @@ termux_step_make () {
        if ls ./*akefile &> /dev/null; then
                make -j $TERMUX_MAKE_PROCESSES ldc2 ldmd2
        fi
+
+       # Build the rdmd scripting wrapper and the dub package manager
+       D_FLAGS="-w -de -O -inline -release"
+       $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,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
diff --git a/packages/ldc/rdmd-tempDir.patch b/packages/ldc/rdmd-tempDir.patch
new file mode 100644 (file)
index 0000000..a786c1d
--- /dev/null
@@ -0,0 +1,19 @@
+diff --git a/rdmd/rdmd.d b/rdmd/rdmd.d
+index 06f46d7..af22c35 100755
+--- a/rdmd/rdmd.d
++++ b/rdmd/rdmd.d
+@@ -386,7 +386,13 @@ bool inALibrary(string source, string object)
+ private @property string myOwnTmpDir()
+ {
+-    auto tmpRoot = userTempDir ? userTempDir : tempDir();
++    import std.file : empty, exists;
++    import std.process : environment;
++
++    string shellTemp = environment.get("TMPDIR");
++    string defaultTemp = !shellTemp.empty && shellTemp.exists ? shellTemp
++                                                              : tempDir();
++    auto tmpRoot = userTempDir ? userTempDir : defaultTemp;
+     version (Posix)
+     {
+         import core.sys.posix.unistd;