termux-api: Update from 0.26 to 0.27
[termux-packages] / packages / dx / build.sh
index c70533a..b7af1b6 100755 (executable)
@@ -4,13 +4,26 @@ TERMUX_PKG_VERSION=$TERMUX_ANDROID_BUILD_TOOLS_VERSION
 TERMUX_PKG_PLATFORM_INDEPENDENT=true
 
 termux_step_make_install () {
-        mkdir -p $TERMUX_PREFIX/share/dex
-        $TERMUX_DX \
-                --dex \
-                --output=$TERMUX_PREFIX/share/dex/dx.jar \
-                $ANDROID_HOME/build-tools/${TERMUX_PKG_VERSION}/lib/dx.jar
+       # Rewrite packages to avoid using com.android.* classes which may clash with
+       # classes in the Android runtime on devices (see #1801):
+       local JARJAR=$TERMUX_PKG_CACHEDIR/jarjar.jar
+       local RULEFILE=$TERMUX_PKG_TMPDIR/jarjar-rule.txt
+       local REWRITTEN_DX=$TERMUX_PKG_TMPDIR/dx-rewritten.jar
+       termux_download \
+               http://central.maven.org/maven2/com/googlecode/jarjar/jarjar/1.3/jarjar-1.3.jar \
+               $JARJAR \
+               4225c8ee1bf3079c4b07c76fe03c3e28809a22204db6249c9417efa4f804b3a7
+       echo 'rule com.android.** dx.@1' > $RULEFILE
+       java -jar $JARJAR process $RULEFILE \
+               $ANDROID_HOME/build-tools/${TERMUX_PKG_VERSION}/lib/dx.jar \
+               $REWRITTEN_DX
+
+       # Dex the rewritten jar file:
+       mkdir -p $TERMUX_PREFIX/share/dex
+       $TERMUX_DX --dex \
+               --output $TERMUX_PREFIX/share/dex/dx.dex \
+               $REWRITTEN_DX
 
        install $TERMUX_PKG_BUILDER_DIR/dx $TERMUX_PREFIX/bin/dx
-       install $TERMUX_PKG_BUILDER_DIR/dalvikvm-wrapper $TERMUX_PREFIX/bin/dalvikvm-wrapper
-       perl -p -i -e "s%\@TERMUX_PREFIX\@%${TERMUX_PREFIX}%g" $TERMUX_PREFIX/bin/{dx,dalvikvm-wrapper}
+       perl -p -i -e "s%\@TERMUX_PREFIX\@%${TERMUX_PREFIX}%g" $TERMUX_PREFIX/bin/dx
 }