X-Git-Url: https://git.distorted.org.uk/~mdw/termux-packages/blobdiff_plain/6e1eae49c02c6686ef4f49d665723d4a44530e9a..768ce14ecc1048cdfc8fcf0d51baaba5c33a163b:/packages/clang/build.sh diff --git a/packages/clang/build.sh b/packages/clang/build.sh index b649d942..3d7b5e29 100644 --- a/packages/clang/build.sh +++ b/packages/clang/build.sh @@ -1,11 +1,15 @@ TERMUX_PKG_HOMEPAGE=http://clang.llvm.org/ TERMUX_PKG_DESCRIPTION="C and C++ frontend for the LLVM compiler" _PKG_MAJOR_VERSION=3.8 -TERMUX_PKG_VERSION=${_PKG_MAJOR_VERSION}.0 +TERMUX_PKG_VERSION=${_PKG_MAJOR_VERSION}.1 +TERMUX_PKG_BUILD_REVISION=1 TERMUX_PKG_SRCURL=http://llvm.org/releases/${TERMUX_PKG_VERSION}/llvm-${TERMUX_PKG_VERSION}.src.tar.xz TERMUX_PKG_HOSTBUILD=true TERMUX_PKG_RM_AFTER_INSTALL="bin/macho-dump bin/bugpoint bin/llvm-tblgen lib/BugpointPasses.so lib/LLVMHello.so" -TERMUX_PKG_DEPENDS="binutils, libgnustl, ncurses, ndk-sysroot" +TERMUX_PKG_DEPENDS="binutils, ncurses, ndk-sysroot, ndk-stl, libgcc" +# Replace gcc since gcc is deprecated by google on android and is not maintained upstream. +TERMUX_PKG_CONFLICTS=gcc +TERMUX_PKG_REPLACES=gcc termux_step_post_extract_package () { CLANG_SRC_TAR=cfe-${TERMUX_PKG_VERSION}.src.tar.xz @@ -33,17 +37,21 @@ termux_step_host_build () { termux_step_configure () { cd $TERMUX_PKG_BUILDDIR - LLVM_DEFAULT_TARGET_TRIPLE=$TERMUX_HOST_PLATFORM - LLVM_TARGET_ARCH=$TERMUX_ARCH - if [ $TERMUX_ARCH = "arm" ]; then - LLVM_TARGET_ARCH=ARM - LLVM_DEFAULT_TARGET_TRIPLE="armv7a-linux-androideabihf" - elif [ $TERMUX_ARCH = "i686" ]; then - LLVM_TARGET_ARCH=X86 + LLVM_DEFAULT_TARGET_TRIPLE=$TERMUX_HOST_PLATFORM + if [ $TERMUX_ARCH = "arm" ]; then + LLVM_TARGET_ARCH=ARM + # See https://github.com/termux/termux-packages/issues/282 + LLVM_DEFAULT_TARGET_TRIPLE="armv7a-linux-androideabi" elif [ $TERMUX_ARCH = "aarch64" ]; then LLVM_TARGET_ARCH=AArch64 - LLVM_DEFAULT_TARGET_TRIPLE="aarch64-linux-android" - fi + elif [ $TERMUX_ARCH = "i686" ]; then + LLVM_TARGET_ARCH=X86 + elif [ $TERMUX_ARCH = "x86_64" ]; then + LLVM_TARGET_ARCH=X86 + else + echo "Invalid arch: $TERMUX_ARCH" + exit 1 + fi # see CMakeLists.txt and tools/clang/CMakeLists.txt cmake -G "Unix Makefiles" .. \ -DCMAKE_AR=`which ${TERMUX_HOST_PLATFORM}-ar` \ @@ -68,5 +76,15 @@ termux_step_configure () { } termux_step_post_make_install () { - (cd $TERMUX_PREFIX/bin && rm -f clang clang++ && ln -s clang-${_PKG_MAJOR_VERSION} clang && ln -s clang-${_PKG_MAJOR_VERSION} clang++) + cd $TERMUX_PREFIX/bin + + ln -f -s clang-${_PKG_MAJOR_VERSION} clang + ln -f -s clang-${_PKG_MAJOR_VERSION} clang++ + ln -f -s clang-${_PKG_MAJOR_VERSION} cc + ln -f -s clang-${_PKG_MAJOR_VERSION} c++ + + ln -f -s clang-${_PKG_MAJOR_VERSION} gcc + ln -f -s clang-${_PKG_MAJOR_VERSION} g++ + ln -f -s clang-${_PKG_MAJOR_VERSION} ${TERMUX_HOST_PLATFORM}-gcc + ln -f -s clang-${_PKG_MAJOR_VERSION} ${TERMUX_HOST_PLATFORM}-g++ }