clang: Some improvements
authorFredrik Fornwall <fredrik@fornwall.net>
Mon, 2 May 2016 18:46:39 +0000 (14:46 -0400)
committerFredrik Fornwall <fredrik@fornwall.net>
Mon, 2 May 2016 18:46:39 +0000 (14:46 -0400)
- Link to libgnustl_shared.so by default for C++.
- Setup 'cc' and 'c++' as symlinks to clang.
- Use hard-float ABI om arm by default.

packages/clang/build.sh
packages/clang/tools-clang-lib-Driver-ToolChain.cpp.patch [new file with mode: 0644]
packages/clang/tools-clang-lib-Driver-Tools.cpp.patch [new file with mode: 0644]

index d4dd316..e7fe3d2 100644 (file)
@@ -2,7 +2,7 @@ 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_BUILD_REVISION=1
+TERMUX_PKG_BUILD_REVISION=2
 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"
@@ -69,5 +69,6 @@ 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++)
+        (cd $TERMUX_PREFIX/bin && ln -f -s clang-${_PKG_MAJOR_VERSION} cc && ln -f -s clang-${_PKG_MAJOR_VERSION} c++)
 }
diff --git a/packages/clang/tools-clang-lib-Driver-ToolChain.cpp.patch b/packages/clang/tools-clang-lib-Driver-ToolChain.cpp.patch
new file mode 100644 (file)
index 0000000..da39a4f
--- /dev/null
@@ -0,0 +1,12 @@
+diff -u -r ../llvm-3.8.0.src/tools/clang/lib/Driver/ToolChain.cpp ./tools/clang/lib/Driver/ToolChain.cpp
+--- ../llvm-3.8.0.src/tools/clang/lib/Driver/ToolChain.cpp     2015-11-25 20:02:07.000000000 -0500
++++ ./tools/clang/lib/Driver/ToolChain.cpp     2016-05-02 08:50:35.526226962 -0400
+@@ -611,7 +611,7 @@
+     break;
+   case ToolChain::CST_Libstdcxx:
+-    CmdArgs.push_back("-lstdc++");
++    CmdArgs.push_back("-lgnustl_shared");
+     break;
+   }
+ }
diff --git a/packages/clang/tools-clang-lib-Driver-Tools.cpp.patch b/packages/clang/tools-clang-lib-Driver-Tools.cpp.patch
new file mode 100644 (file)
index 0000000..bc83924
--- /dev/null
@@ -0,0 +1,17 @@
+diff -u -r ../llvm-3.8.0.src/tools/clang/lib/Driver/Tools.cpp ./tools/clang/lib/Driver/Tools.cpp
+--- ../llvm-3.8.0.src/tools/clang/lib/Driver/Tools.cpp 2016-02-12 17:51:41.000000000 -0500
++++ ./tools/clang/lib/Driver/Tools.cpp 2016-05-01 23:01:30.148998957 -0400
+@@ -733,11 +733,11 @@
+         ABI = FloatABI::SoftFP;
+         break;
+       case llvm::Triple::Android:
+-        ABI = (SubArch == 7) ? FloatABI::SoftFP : FloatABI::Soft;
++        ABI = FloatABI::Hard;
+         break;
+       default:
+         // Assume "soft", but warn the user we are guessing.
+-        ABI = FloatABI::Soft;
++        ABI = FloatABI::Hard;
+         if (Triple.getOS() != llvm::Triple::UnknownOS ||
+             !Triple.isOSBinFormatMachO())
+           D.Diag(diag::warn_drv_assuming_mfloat_abi_is) << "soft";