From 29a9c96ee51263876021301350d9334c60f4094a Mon Sep 17 00:00:00 2001 From: Joey Hess Date: Wed, 7 Jan 2015 14:14:37 -0400 Subject: android binary compatability is so bad we have to build all utilities twice --- standalone/android/Makefile | 116 +++++------------------------------ standalone/android/buildapk | 146 ++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 161 insertions(+), 101 deletions(-) create mode 100755 standalone/android/buildapk (limited to 'standalone') diff --git a/standalone/android/Makefile b/standalone/android/Makefile index 020303374..f6ae8fdba 100644 --- a/standalone/android/Makefile +++ b/standalone/android/Makefile @@ -1,91 +1,24 @@ # Cross-compiles utilities needed for git-annex on Android, # and builds the Android app. -# Add Android cross-compiler to PATH (as installed by ghc-android) -ANDROID_CROSS_COMPILER?=$(HOME)/.ghc/$(shell cat abiversion)/bin -PATH:=$(ANDROID_CROSS_COMPILER):$(PATH) +build: + ./buildapk 4 + ./buildapk 5 -# Paths to the Android SDK and NDK. -export ANDROID_SDK_ROOT?=$(HOME)/.android/adt-bundle-linux-x86/sdk -export ANDROID_NDK_ROOT?=$(HOME)/.android/android-ndk +# Targets below are used by buildapk, which sets +# GIT_ANNEX_ANDROID_SOURCETREE -# Where to store the source tree used to build utilities. This -# directory will be created by `make source`. -GIT_ANNEX_ANDROID_SOURCETREE?=$(HOME)/.android/git-annex-sourcetree - -GITTREE=$(GIT_ANNEX_ANDROID_SOURCETREE)/git/installed-tree - -VER=$(shell perl -e '$$_=<>;print m/\((.*?)\)/'<../../CHANGELOG) - -build: start - if [ ! -e "$(GIT_ANNEX_ANDROID_SOURCETREE)" ]; then $(MAKE) source; fi - $(MAKE) $(GIT_ANNEX_ANDROID_SOURCETREE)/openssl/build-stamp - $(MAKE) $(GIT_ANNEX_ANDROID_SOURCETREE)/openssh/build-stamp - $(MAKE) $(GIT_ANNEX_ANDROID_SOURCETREE)/busybox/build-stamp - $(MAKE) $(GIT_ANNEX_ANDROID_SOURCETREE)/rsync/build-stamp - $(MAKE) $(GIT_ANNEX_ANDROID_SOURCETREE)/gnupg/build-stamp - $(MAKE) $(GIT_ANNEX_ANDROID_SOURCETREE)/git/build-stamp - $(MAKE) $(GIT_ANNEX_ANDROID_SOURCETREE)/term/build-stamp - - perl -i -pe 's/(android:versionName=)"[^"]+"/$$1"'$(VER)'"/' $(GIT_ANNEX_ANDROID_SOURCETREE)/term/AndroidManifest.xml - - # Debug build because it does not need signing keys. - cd $(GIT_ANNEX_ANDROID_SOURCETREE)/term && tools/build-debug - - # Install executables as pseudo-libraries so they will be - # unpacked from the .apk. - mkdir -p $(GIT_ANNEX_ANDROID_SOURCETREE)/term/libs/armeabi - cp $(GIT_ANNEX_ANDROID_SOURCETREE)/busybox/busybox $(GIT_ANNEX_ANDROID_SOURCETREE)/term/libs/armeabi/lib.busybox.so - cp $(GIT_ANNEX_ANDROID_SOURCETREE)/openssh/ssh $(GIT_ANNEX_ANDROID_SOURCETREE)/term/libs/armeabi/lib.ssh.so - cp $(GIT_ANNEX_ANDROID_SOURCETREE)/openssh/ssh-keygen $(GIT_ANNEX_ANDROID_SOURCETREE)/term/libs/armeabi/lib.ssh-keygen.so - cp $(GIT_ANNEX_ANDROID_SOURCETREE)/rsync/rsync $(GIT_ANNEX_ANDROID_SOURCETREE)/term/libs/armeabi/lib.rsync.so - cp $(GIT_ANNEX_ANDROID_SOURCETREE)/gnupg/g10/gpg $(GIT_ANNEX_ANDROID_SOURCETREE)/term/libs/armeabi/lib.gpg.so - cp $(GIT_ANNEX_ANDROID_SOURCETREE)/git/git $(GIT_ANNEX_ANDROID_SOURCETREE)/term/libs/armeabi/lib.git.so - cp $(GIT_ANNEX_ANDROID_SOURCETREE)/git/git-shell $(GIT_ANNEX_ANDROID_SOURCETREE)/term/libs/armeabi/lib.git-shell.so - cp $(GIT_ANNEX_ANDROID_SOURCETREE)/git/git-upload-pack $(GIT_ANNEX_ANDROID_SOURCETREE)/term/libs/armeabi/lib.git-upload-pack.so - arm-linux-androideabi-strip --strip-unneeded --remove-section=.comment --remove-section=.note $(GIT_ANNEX_ANDROID_SOURCETREE)/term/libs/armeabi/* - cp runshell $(GIT_ANNEX_ANDROID_SOURCETREE)/term/libs/armeabi/lib.runshell.so - cp start $(GIT_ANNEX_ANDROID_SOURCETREE)/term/libs/armeabi/lib.start.so - - # remove git stuff we don't need to save space - rm -rf $(GITTREE)/bin/git-cvsserver \ - $(GITTREE)/libexec/git-core/git-daemon \ - $(GITTREE)/libexec/git-core/git-show-index \ - $(GITTREE)/libexec/git-core/mergetools \ - $(GITTREE)/libexec/git-core/git-credential-* \ - $(GITTREE)/libexec/git-core/git-cvsserver \ - $(GITTREE)/libexec/git-core/git-cvsimport \ - $(GITTREE)/libexec/git-core/git-fast-import \ - $(GITTREE)/libexec/git-core/git-http-backend \ - $(GITTREE)/libexec/git-core/git-imap-send \ - $(GITTREE)/libexec/git-core/git-instaweb \ - $(GITTREE)/libexec/git-core/git-p4 \ - $(GITTREE)/libexec/git-core/git-remote-test* \ - $(GITTREE)/libexec/git-core/git-submodule \ - $(GITTREE)/libexec/git-core/git-svn \ - $(GITTREE)/libexec/git-core/git-web--browse - # Most of git is in one multicall binary, but a few important - # commands are still shell scripts. Those are put into - # a tarball, along with a list of all the links that should be - # set up. - cd $(GITTREE) && mkdir -p links - cd $(GITTREE) && find -samefile bin/git -not -wholename ./bin/git > links/git - cd $(GITTREE) && find -samefile bin/git-shell -not -wholename ./bin/git-shell > links/git-shell - cd $(GITTREE) && find -samefile bin/git-upload-pack -not -wholename ./bin/git-upload-pack > links/git-upload-pack - cd $(GITTREE) && find -type f -not -samefile bin/git -not -samefile bin/git-shell -not -samefile bin/git-upload-pack|tar czf ../git.tar.gz -T - - cp $(GIT_ANNEX_ANDROID_SOURCETREE)/git/git.tar.gz $(GIT_ANNEX_ANDROID_SOURCETREE)/term/libs/armeabi/lib.git.tar.gz.so - - git rev-parse HEAD > $(GIT_ANNEX_ANDROID_SOURCETREE)/term/libs/armeabi/lib.version.so - cp ../trustedkeys.gpg $(GIT_ANNEX_ANDROID_SOURCETREE)/term/libs/armeabi/lib.trustedkeys.so +source: $(GIT_ANNEX_ANDROID_SOURCETREE) - set -e; \ - for v in 4.0 4.3 5.0; do \ - mkdir -p ../../tmp/$$v; \ - cp ../../tmp/androidtree/dist/build/git-annex/$$v/git-annex $(GIT_ANNEX_ANDROID_SOURCETREE)/term/libs/armeabi/lib.git-annex.so; \ - arm-linux-androideabi-strip --strip-unneeded --remove-section=.comment --remove-section=.note $(GIT_ANNEX_ANDROID_SOURCETREE)/term/libs/armeabi/lib.git-annex.so; \ - (cd $(GIT_ANNEX_ANDROID_SOURCETREE)/term && ant debug); \ - cp $(GIT_ANNEX_ANDROID_SOURCETREE)/term/bin/Term-debug.apk ../../tmp/$$v/git-annex.apk; \ - done +$(GIT_ANNEX_ANDROID_SOURCETREE): + mkdir -p $(GIT_ANNEX_ANDROID_SOURCETREE) + git clone git://git.debian.org/git/d-i/busybox $(GIT_ANNEX_ANDROID_SOURCETREE)/busybox + git clone git://git.kernel.org/pub/scm/git/git.git $(GIT_ANNEX_ANDROID_SOURCETREE)/git + git clone git://git.samba.org/rsync.git $(GIT_ANNEX_ANDROID_SOURCETREE)/rsync + git clone git://git.gnupg.org/gnupg.git $(GIT_ANNEX_ANDROID_SOURCETREE)/gnupg + git clone git://git.openssl.org/openssl $(GIT_ANNEX_ANDROID_SOURCETREE)/openssl + git clone git://github.com/CyanogenMod/android_external_openssh.git $(GIT_ANNEX_ANDROID_SOURCETREE)/openssh + git clone git://github.com/jackpal/Android-Terminal-Emulator.git $(GIT_ANNEX_ANDROID_SOURCETREE)/term $(GIT_ANNEX_ANDROID_SOURCETREE)/openssl/build-stamp: cd $(GIT_ANNEX_ANDROID_SOURCETREE)/openssl && CC=$$(which cc) ./Configure android @@ -146,22 +79,3 @@ $(GIT_ANNEX_ANDROID_SOURCETREE)/term/build-stamp: term.patch icons cd $(GIT_ANNEX_ANDROID_SOURCETREE)/term && perl -pi -e 's/Terminal Emulator/Git Annex/g' res/*/strings.xml cd $(GIT_ANNEX_ANDROID_SOURCETREE)/term && echo y | tools/update.sh || true touch $@ - -source: $(GIT_ANNEX_ANDROID_SOURCETREE) - -$(GIT_ANNEX_ANDROID_SOURCETREE): - mkdir -p $(GIT_ANNEX_ANDROID_SOURCETREE) - git clone git://git.debian.org/git/d-i/busybox $(GIT_ANNEX_ANDROID_SOURCETREE)/busybox - git clone git://git.kernel.org/pub/scm/git/git.git $(GIT_ANNEX_ANDROID_SOURCETREE)/git - git clone git://git.samba.org/rsync.git $(GIT_ANNEX_ANDROID_SOURCETREE)/rsync - git clone git://git.gnupg.org/gnupg.git $(GIT_ANNEX_ANDROID_SOURCETREE)/gnupg - git clone git://git.openssl.org/openssl $(GIT_ANNEX_ANDROID_SOURCETREE)/openssl - git clone git://github.com/CyanogenMod/android_external_openssh.git $(GIT_ANNEX_ANDROID_SOURCETREE)/openssh - git clone git://github.com/jackpal/Android-Terminal-Emulator.git $(GIT_ANNEX_ANDROID_SOURCETREE)/term - -clean: - rm -rf $(GITTREE) - rm -f start - -reallyclean: clean - rm -rf $(GIT_ANNEX_ANDROID_SOURCETREE) diff --git a/standalone/android/buildapk b/standalone/android/buildapk new file mode 100755 index 000000000..3a073d474 --- /dev/null +++ b/standalone/android/buildapk @@ -0,0 +1,146 @@ +#!/bin/sh +# +# Cross-compiles utilities needed for git-annex on Android, +# and builds the Android app. + +set -e + +androidversion=$1 +if [ -z "$androidversion" ]; then + echo "need android version (4 or 5) as parameter" >&2 + exit 1 +fi + +VER="$(perl -e '$_=<>;print m/\((.*?)\)/'<../../CHANGELOG)" + +wrap () { + echo "#!/bin/sh -e" > "$2" + echo "$1 $3" >> "$2" + chmod +x "$2" +} + +# Add Android cross-compiler to PATH (as installed by ghc-android) +androidtoolchain="$HOME/.ghc/$(cat abiversion)/bin" +# For Android 5, use a wrapped version of the C compiler, +# which sets PIE build flags. +if [ "$androidversion" = 5 ]; then + rm -rf "$androidtoolchain/5.0" + mkdir -p "$androidtoolchain/5.0" + for f in $(find "$androidtoolchain" -maxdepth 1 -not -type d -printf '%f\n'); do + src="$androidtoolchain/$f" + dest="$androidtoolchain/5.0/$f" + case "$f" of + *-ld*) + wrap "$src" "$dest" "-pie" + ;; + *-gcc) + wrap "$src" "$dest" "-pie" "-fPIE" + ;; + *'-g++') + wrap "$src" "$dest" "-pie" "-fPIE" + ;; + *) + cp -a "$src" "$dest" + ;; + esac + done + PATH="$androidtoolchain:$PATH/5.0" +else + PATH="$androidtoolchain:$PATH" +fi +export PATH + +# Paths to the Android SDK and NDK. +export ANDROID_SDK_ROOT="$HOME/.android/adt-bundle-linux-x86/sdk" +export ANDROID_NDK_ROOT="$HOME/.android/android-ndk" + +GIT_ANNEX_ANDROID_SOURCETREE="$HOME/.android/git-annex-sourcetree" +export GIT_ANNEX_ANDROID_SOURCETREE +if [ ! -e "$GIT_ANNEX_ANDROID_SOURCETREE" ]; then + make source +fi +src="$GIT_ANNEX_ANDROID_SOURCETREE/$androidversion" +if [ ! -e "$src" ] ; then + cp -a "$GIT_ANNEX_ANDROID_SOURCETREE" "$src" +fi +GIT_ANNEX_ANDROID_SOURCETREE="$src" +export "$GIT_ANNEX_ANDROID_SOURCETREE" + +gittree="$GIT_ANNEX_ANDROID_SOURCETREE/git/installed-tree" + +make "$GIT_ANNEX_ANDROID_SOURCETREE/openssl/build-stamp" +make "$GIT_ANNEX_ANDROID_SOURCETREE/openssh/build-stamp" +make "$GIT_ANNEX_ANDROID_SOURCETREE/busybox/build-stamp" +make "$GIT_ANNEX_ANDROID_SOURCETREE/rsync/build-stamp" +make "$GIT_ANNEX_ANDROID_SOURCETREE/gnupg/build-stamp" +make "$GIT_ANNEX_ANDROID_SOURCETREE/git/build-stamp" +make "$GIT_ANNEX_ANDROID_SOURCETREE/term/build-stamp" + +perl -i -pe 's/(android:versionName=)"[^"]+"/$1"'"$VER"'"/' \ + "$GIT_ANNEX_ANDROID_SOURCETREE/term/AndroidManifest.xml" + +# Debug build because it does not need signing keys. +cd "$GIT_ANNEX_ANDROID_SOURCETREE/term" && tools/build-debug + +# Install executables as pseudo-libraries so they will be +# unpacked from the .apk. +mkdir -p "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi" +cp "$GIT_ANNEX_ANDROID_SOURCETREE/busybox/busybox" "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.busybox.so" +cp "$GIT_ANNEX_ANDROID_SOURCETREE/openssh/ssh" "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.ssh.so" +cp "$GIT_ANNEX_ANDROID_SOURCETREE/openssh/ssh-keygen" "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.ssh-keygen.so" +cp "$GIT_ANNEX_ANDROID_SOURCETREE/rsync/rsync" "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.rsync.so" +cp "$GIT_ANNEX_ANDROID_SOURCETREE/gnupg/g10/gpg "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.gpg.so" +cp "$GIT_ANNEX_ANDROID_SOURCETREE/git/git" "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.git.so" +cp "$GIT_ANNEX_ANDROID_SOURCETREE/git/git-shell" "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.git-shell.so" +cp "$GIT_ANNEX_ANDROID_SOURCETREE/git/git-upload-pack "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.git-upload-pack.so" +arm-linux-androideabi-strip --strip-unneeded --remove-section=.comment --remove-section=.note "$GIT_ANNEX_ANDROID_SOURCETREE"/term/libs/armeabi/* +cp runshell "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.runshell.so" +cc start.c -o "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.start.so" + +# remove git stuff we don't need to save space +rm -rf $gittree/bin/git-cvsserver \ + $gittree/libexec/git-core/git-daemon \ + $gittree/libexec/git-core/git-show-index \ + $gittree/libexec/git-core/mergetools \ + $gittree/libexec/git-core/git-credential-* \ + $gittree/libexec/git-core/git-cvsserver \ + $gittree/libexec/git-core/git-cvsimport \ + $gittree/libexec/git-core/git-fast-import \ + $gittree/libexec/git-core/git-http-backend \ + $gittree/libexec/git-core/git-imap-send \ + $gittree/libexec/git-core/git-instaweb \ + $gittree/libexec/git-core/git-p4 \ + $gittree/libexec/git-core/git-remote-test* \ + $gittree/libexec/git-core/git-submodule \ + $gittree/libexec/git-core/git-svn \ + $gittree/libexec/git-core/git-web--browse + +# Most of git is in one multicall binary, but a few important +# commands are still shell scripts. Those are put into +# a tarball, along with a list of all the links that should be +# set up. +cd $gittree && mkdir -p links +cd $gittree && find -samefile bin/git -not -wholename ./bin/git > links/git +cd $gittree && find -samefile bin/git-shell -not -wholename ./bin/git-shell > links/git-shell +cd $gittree && find -samefile bin/git-upload-pack -not -wholename ./bin/git-upload-pack > links/git-upload-pack +cd $gittree && find -type f -not -samefile bin/git -not -samefile bin/git-shell -not -samefile bin/git-upload-pack | tar czf ../git.tar.gz -T - +cp "$GIT_ANNEX_ANDROID_SOURCETREE/git/git.tar.gz" "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.git.tar.gz.so" + +git rev-parse HEAD > "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.version.so" +cp ../trustedkeys.gpg "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.trustedkeys.so" + +genapk () { + mkdir -p ../../tmp/$1; \ + cp ../../tmp/androidtree/dist/build/git-annex/$1/git-annex "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.git-annex.so" + arm-linux-androideabi-strip --strip-unneeded --remove-section=.comment --remove-section=.note "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.git-annex.so" + cd "$GIT_ANNEX_ANDROID_SOURCETREE/term" && ant debug + cp "$GIT_ANNEX_ANDROID_SOURCETREE/term/bin/Term-debug.apk" ../../tmp/$1/git-annex.apk +} + +if [ "$androidversion" = 4 ]; then + for v in 4.0 4.3; do + genapk $v + done +else + genapk 5.0 +fi -- cgit v1.2.3 From 20160a6eebdcbf0fc7acea8940617ccc6c3023ce Mon Sep 17 00:00:00 2001 From: Joey Hess Date: Wed, 7 Jan 2015 14:17:36 -0400 Subject: typo --- standalone/android/buildapk | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'standalone') diff --git a/standalone/android/buildapk b/standalone/android/buildapk index 3a073d474..f751dda15 100755 --- a/standalone/android/buildapk +++ b/standalone/android/buildapk @@ -29,7 +29,7 @@ if [ "$androidversion" = 5 ]; then for f in $(find "$androidtoolchain" -maxdepth 1 -not -type d -printf '%f\n'); do src="$androidtoolchain/$f" dest="$androidtoolchain/5.0/$f" - case "$f" of + case "$f" in *-ld*) wrap "$src" "$dest" "-pie" ;; -- cgit v1.2.3 From 838b23cfc92e4ebf1af698c176d62283cc913503 Mon Sep 17 00:00:00 2001 From: Joey Hess Date: Wed, 7 Jan 2015 14:20:26 -0400 Subject: fix dir name --- standalone/android/buildapk | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'standalone') diff --git a/standalone/android/buildapk b/standalone/android/buildapk index f751dda15..ca5de9361 100755 --- a/standalone/android/buildapk +++ b/standalone/android/buildapk @@ -59,7 +59,7 @@ export GIT_ANNEX_ANDROID_SOURCETREE if [ ! -e "$GIT_ANNEX_ANDROID_SOURCETREE" ]; then make source fi -src="$GIT_ANNEX_ANDROID_SOURCETREE/$androidversion" +src="$GIT_ANNEX_ANDROID_SOURCETREE-$androidversion" if [ ! -e "$src" ] ; then cp -a "$GIT_ANNEX_ANDROID_SOURCETREE" "$src" fi -- cgit v1.2.3 From 1cbd583c70e1ff05b56356dbebeed2f6864d4f51 Mon Sep 17 00:00:00 2001 From: Joey Hess Date: Wed, 7 Jan 2015 14:22:02 -0400 Subject: typo --- standalone/android/buildapk | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'standalone') diff --git a/standalone/android/buildapk b/standalone/android/buildapk index ca5de9361..cbc8d36c9 100755 --- a/standalone/android/buildapk +++ b/standalone/android/buildapk @@ -64,7 +64,7 @@ if [ ! -e "$src" ] ; then cp -a "$GIT_ANNEX_ANDROID_SOURCETREE" "$src" fi GIT_ANNEX_ANDROID_SOURCETREE="$src" -export "$GIT_ANNEX_ANDROID_SOURCETREE" +export GIT_ANNEX_ANDROID_SOURCETREE gittree="$GIT_ANNEX_ANDROID_SOURCETREE/git/installed-tree" -- cgit v1.2.3 From a6548a48d0de97c3ee9836806eef3df634ef847c Mon Sep 17 00:00:00 2001 From: Joey Hess Date: Wed, 7 Jan 2015 14:49:04 -0400 Subject: fix BIGNUM related openssh build breakage --- standalone/android/Makefile | 3 +++ 1 file changed, 3 insertions(+) (limited to 'standalone') diff --git a/standalone/android/Makefile b/standalone/android/Makefile index f6ae8fdba..261259bf4 100644 --- a/standalone/android/Makefile +++ b/standalone/android/Makefile @@ -21,6 +21,9 @@ $(GIT_ANNEX_ANDROID_SOURCETREE): git clone git://github.com/jackpal/Android-Terminal-Emulator.git $(GIT_ANNEX_ANDROID_SOURCETREE)/term $(GIT_ANNEX_ANDROID_SOURCETREE)/openssl/build-stamp: + # This is a version which the openssh below can build with. + # Newer versions changed something to do with BIGNUM. + cd $(GIT_ANNEX_ANDROID_SOURCETREE)/openssl && git reset --hard 616f71e486d693991b594439c884ec624b32c2d4 cd $(GIT_ANNEX_ANDROID_SOURCETREE)/openssl && CC=$$(which cc) ./Configure android cd $(GIT_ANNEX_ANDROID_SOURCETREE)/openssl && $(MAKE) touch $@ -- cgit v1.2.3 From c10bf022f6c48549fad75164160820e7981b9c34 Mon Sep 17 00:00:00 2001 From: Joey Hess Date: Wed, 7 Jan 2015 15:08:52 -0400 Subject: typos --- standalone/android/buildapk | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) (limited to 'standalone') diff --git a/standalone/android/buildapk b/standalone/android/buildapk index cbc8d36c9..7b3d0c0be 100755 --- a/standalone/android/buildapk +++ b/standalone/android/buildapk @@ -89,10 +89,10 @@ cp "$GIT_ANNEX_ANDROID_SOURCETREE/busybox/busybox" "$GIT_ANNEX_ANDROID_SOURCETRE cp "$GIT_ANNEX_ANDROID_SOURCETREE/openssh/ssh" "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.ssh.so" cp "$GIT_ANNEX_ANDROID_SOURCETREE/openssh/ssh-keygen" "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.ssh-keygen.so" cp "$GIT_ANNEX_ANDROID_SOURCETREE/rsync/rsync" "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.rsync.so" -cp "$GIT_ANNEX_ANDROID_SOURCETREE/gnupg/g10/gpg "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.gpg.so" +cp "$GIT_ANNEX_ANDROID_SOURCETREE/gnupg/g10/gpg" "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.gpg.so" cp "$GIT_ANNEX_ANDROID_SOURCETREE/git/git" "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.git.so" cp "$GIT_ANNEX_ANDROID_SOURCETREE/git/git-shell" "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.git-shell.so" -cp "$GIT_ANNEX_ANDROID_SOURCETREE/git/git-upload-pack "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.git-upload-pack.so" +cp "$GIT_ANNEX_ANDROID_SOURCETREE/git/git-upload-pack" "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.git-upload-pack.so" arm-linux-androideabi-strip --strip-unneeded --remove-section=.comment --remove-section=.note "$GIT_ANNEX_ANDROID_SOURCETREE"/term/libs/armeabi/* cp runshell "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.runshell.so" cc start.c -o "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.start.so" -- cgit v1.2.3 From bc29af157a7ea69ff8e197a7d3134cbe33ae707e Mon Sep 17 00:00:00 2001 From: Joey Hess Date: Wed, 7 Jan 2015 15:11:10 -0400 Subject: subshells for cd && --- standalone/android/buildapk | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) (limited to 'standalone') diff --git a/standalone/android/buildapk b/standalone/android/buildapk index 7b3d0c0be..4c50cacf0 100755 --- a/standalone/android/buildapk +++ b/standalone/android/buildapk @@ -80,7 +80,7 @@ perl -i -pe 's/(android:versionName=)"[^"]+"/$1"'"$VER"'"/' \ "$GIT_ANNEX_ANDROID_SOURCETREE/term/AndroidManifest.xml" # Debug build because it does not need signing keys. -cd "$GIT_ANNEX_ANDROID_SOURCETREE/term" && tools/build-debug +(cd "$GIT_ANNEX_ANDROID_SOURCETREE/term" && tools/build-debug) # Install executables as pseudo-libraries so they will be # unpacked from the .apk. @@ -119,12 +119,12 @@ rm -rf $gittree/bin/git-cvsserver \ # commands are still shell scripts. Those are put into # a tarball, along with a list of all the links that should be # set up. -cd $gittree && mkdir -p links -cd $gittree && find -samefile bin/git -not -wholename ./bin/git > links/git -cd $gittree && find -samefile bin/git-shell -not -wholename ./bin/git-shell > links/git-shell -cd $gittree && find -samefile bin/git-upload-pack -not -wholename ./bin/git-upload-pack > links/git-upload-pack -cd $gittree && find -type f -not -samefile bin/git -not -samefile bin/git-shell -not -samefile bin/git-upload-pack | tar czf ../git.tar.gz -T - -cp "$GIT_ANNEX_ANDROID_SOURCETREE/git/git.tar.gz" "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.git.tar.gz.so" +(cd $gittree && mkdir -p links) +(cd $gittree && find -samefile bin/git -not -wholename ./bin/git > links/git) +(cd $gittree && find -samefile bin/git-shell -not -wholename ./bin/git-shell > links/git-shell) +(cd $gittree && find -samefile bin/git-upload-pack -not -wholename ./bin/git-upload-pack > links/git-upload-pack) +(cd $gittree && find -type f -not -samefile bin/git -not -samefile bin/git-shell -not -samefile bin/git-upload-pack | tar czf ../git.tar.gz -T -) +(cp "$GIT_ANNEX_ANDROID_SOURCETREE/git/git.tar.gz" "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.git.tar.gz.so") git rev-parse HEAD > "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.version.so" cp ../trustedkeys.gpg "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.trustedkeys.so" @@ -133,7 +133,7 @@ genapk () { mkdir -p ../../tmp/$1; \ cp ../../tmp/androidtree/dist/build/git-annex/$1/git-annex "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.git-annex.so" arm-linux-androideabi-strip --strip-unneeded --remove-section=.comment --remove-section=.note "$GIT_ANNEX_ANDROID_SOURCETREE/term/libs/armeabi/lib.git-annex.so" - cd "$GIT_ANNEX_ANDROID_SOURCETREE/term" && ant debug + (cd "$GIT_ANNEX_ANDROID_SOURCETREE/term" && ant debug) cp "$GIT_ANNEX_ANDROID_SOURCETREE/term/bin/Term-debug.apk" ../../tmp/$1/git-annex.apk } -- cgit v1.2.3 From f9f362ae2e0d52be4013556e6b91735cda7013d6 Mon Sep 17 00:00:00 2001 From: Joey Hess Date: Wed, 7 Jan 2015 15:30:50 -0400 Subject: fix -fPIE option --- standalone/android/buildapk | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) (limited to 'standalone') diff --git a/standalone/android/buildapk b/standalone/android/buildapk index 4c50cacf0..1d02ffc7d 100755 --- a/standalone/android/buildapk +++ b/standalone/android/buildapk @@ -15,6 +15,7 @@ VER="$(perl -e '$_=<>;print m/\((.*?)\)/'<../../CHANGELOG)" wrap () { echo "#!/bin/sh -e" > "$2" + echo "echo \"$1 added options: $2\" >&2" >> "$2" echo "$1 $3" >> "$2" chmod +x "$2" } @@ -34,10 +35,10 @@ if [ "$androidversion" = 5 ]; then wrap "$src" "$dest" "-pie" ;; *-gcc) - wrap "$src" "$dest" "-pie" "-fPIE" + wrap "$src" "$dest" "-pie -fPIE" ;; *'-g++') - wrap "$src" "$dest" "-pie" "-fPIE" + wrap "$src" "$dest" "-pie -fPIE" ;; *) cp -a "$src" "$dest" -- cgit v1.2.3 From 012d1318e6c128f45385420223e4888e0c9393a5 Mon Sep 17 00:00:00 2001 From: Joey Hess Date: Wed, 7 Jan 2015 15:33:12 -0400 Subject: fix path --- standalone/android/buildapk | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'standalone') diff --git a/standalone/android/buildapk b/standalone/android/buildapk index 1d02ffc7d..980803f71 100755 --- a/standalone/android/buildapk +++ b/standalone/android/buildapk @@ -45,7 +45,7 @@ if [ "$androidversion" = 5 ]; then ;; esac done - PATH="$androidtoolchain:$PATH/5.0" + PATH="$androidtoolchain:$PATH/5" else PATH="$androidtoolchain:$PATH" fi -- cgit v1.2.3 From 5e09ba1b2035ca72981d1f2dc6d33b9480dd5108 Mon Sep 17 00:00:00 2001 From: Joey Hess Date: Wed, 7 Jan 2015 15:35:08 -0400 Subject: more PATH typos --- standalone/android/buildapk | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) (limited to 'standalone') diff --git a/standalone/android/buildapk b/standalone/android/buildapk index 980803f71..34ddd9537 100755 --- a/standalone/android/buildapk +++ b/standalone/android/buildapk @@ -25,11 +25,11 @@ androidtoolchain="$HOME/.ghc/$(cat abiversion)/bin" # For Android 5, use a wrapped version of the C compiler, # which sets PIE build flags. if [ "$androidversion" = 5 ]; then - rm -rf "$androidtoolchain/5.0" - mkdir -p "$androidtoolchain/5.0" + rm -rf "$androidtoolchain/5" + mkdir -p "$androidtoolchain/5" for f in $(find "$androidtoolchain" -maxdepth 1 -not -type d -printf '%f\n'); do src="$androidtoolchain/$f" - dest="$androidtoolchain/5.0/$f" + dest="$androidtoolchain/5/$f" case "$f" in *-ld*) wrap "$src" "$dest" "-pie" @@ -45,7 +45,7 @@ if [ "$androidversion" = 5 ]; then ;; esac done - PATH="$androidtoolchain:$PATH/5" + PATH="$androidtoolchain/5:$PATH" else PATH="$androidtoolchain:$PATH" fi -- cgit v1.2.3 From 26725f59373aea86fc428f953127b281b3c4d3e5 Mon Sep 17 00:00:00 2001 From: Joey Hess Date: Wed, 7 Jan 2015 15:36:19 -0400 Subject: add $@ to wrapper --- standalone/android/buildapk | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'standalone') diff --git a/standalone/android/buildapk b/standalone/android/buildapk index 34ddd9537..b7f7d033b 100755 --- a/standalone/android/buildapk +++ b/standalone/android/buildapk @@ -16,7 +16,7 @@ VER="$(perl -e '$_=<>;print m/\((.*?)\)/'<../../CHANGELOG)" wrap () { echo "#!/bin/sh -e" > "$2" echo "echo \"$1 added options: $2\" >&2" >> "$2" - echo "$1 $3" >> "$2" + echo "$1 $3 "'"$@"' >> "$2" chmod +x "$2" } -- cgit v1.2.3 From 1721e743fac762dd14c66ff918a34011671f39a0 Mon Sep 17 00:00:00 2001 From: Joey Hess Date: Wed, 7 Jan 2015 15:37:22 -0400 Subject: minor typo --- standalone/android/buildapk | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'standalone') diff --git a/standalone/android/buildapk b/standalone/android/buildapk index b7f7d033b..e91dd28b4 100755 --- a/standalone/android/buildapk +++ b/standalone/android/buildapk @@ -15,7 +15,7 @@ VER="$(perl -e '$_=<>;print m/\((.*?)\)/'<../../CHANGELOG)" wrap () { echo "#!/bin/sh -e" > "$2" - echo "echo \"$1 added options: $2\" >&2" >> "$2" + echo "echo \"$1 added options: $3\" >&2" >> "$2" echo "$1 $3 "'"$@"' >> "$2" chmod +x "$2" } -- cgit v1.2.3 From 69b66353595285bd8617479457e51692758ef324 Mon Sep 17 00:00:00 2001 From: Joey Hess Date: Wed, 7 Jan 2015 15:48:11 -0400 Subject: smarter wrapper; detect -r link option /home/builder/.ghc/android-14/arm-linux-androideabi-4.8/bin/../lib/gcc/arm-linux-androideabi/4.8/../../../../arm-linux-androideabi/bin/ld: fatal error: -pie and -r are incompatible --- standalone/android/buildapk | 4 +--- standalone/android/wrapper.pl | 12 ++++++++++++ 2 files changed, 13 insertions(+), 3 deletions(-) create mode 100644 standalone/android/wrapper.pl (limited to 'standalone') diff --git a/standalone/android/buildapk b/standalone/android/buildapk index e91dd28b4..213ddcbb1 100755 --- a/standalone/android/buildapk +++ b/standalone/android/buildapk @@ -14,9 +14,7 @@ fi VER="$(perl -e '$_=<>;print m/\((.*?)\)/'<../../CHANGELOG)" wrap () { - echo "#!/bin/sh -e" > "$2" - echo "echo \"$1 added options: $3\" >&2" >> "$2" - echo "$1 $3 "'"$@"' >> "$2" + sed -e "s!PROG!$1!" -e "s!OPTS!$3! < wrapper.pl > "$2" chmod +x "$2" } diff --git a/standalone/android/wrapper.pl b/standalone/android/wrapper.pl new file mode 100644 index 000000000..ae484a6cf --- /dev/null +++ b/standalone/android/wrapper.pl @@ -0,0 +1,12 @@ +#!/usr/bin/perl +my $prog=q{PROG}; # replaced +my @opts=qw{OPTS}; # replaced + +if (grep { $_ eq "-r" || $_ eq "--relocatable" } @ARGV) { + print "running $prog withthout extra opts, as relocatable build detected\n"; + exec($prog,@ARGV) || die "failed to run $prog"; +} +else { + print "running $prog with extra opts @opts\n"; + exec($prog,@opts,@ARGV) || die "failed to run $prog"; +} -- cgit v1.2.3 From 42642f00ff3eee96ce3661ec3d0886ae0fbfffd8 Mon Sep 17 00:00:00 2001 From: Joey Hess Date: Wed, 7 Jan 2015 15:50:10 -0400 Subject: typo --- standalone/android/buildapk | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'standalone') diff --git a/standalone/android/buildapk b/standalone/android/buildapk index 213ddcbb1..063fe6c83 100755 --- a/standalone/android/buildapk +++ b/standalone/android/buildapk @@ -14,7 +14,7 @@ fi VER="$(perl -e '$_=<>;print m/\((.*?)\)/'<../../CHANGELOG)" wrap () { - sed -e "s!PROG!$1!" -e "s!OPTS!$3! < wrapper.pl > "$2" + sed -e "s!PROG!$1!" -e "s!OPTS!$3!" < wrapper.pl > "$2" chmod +x "$2" } -- cgit v1.2.3 From 4847d0039241e28a3b44163c91b64e1c42bf09b0 Mon Sep 17 00:00:00 2001 From: Joey Hess Date: Wed, 7 Jan 2015 16:00:31 -0400 Subject: remove debug prints; even going to stderr that breaks gnupg's configure script --- standalone/android/wrapper.pl | 2 -- 1 file changed, 2 deletions(-) (limited to 'standalone') diff --git a/standalone/android/wrapper.pl b/standalone/android/wrapper.pl index ae484a6cf..a7136a950 100644 --- a/standalone/android/wrapper.pl +++ b/standalone/android/wrapper.pl @@ -3,10 +3,8 @@ my $prog=q{PROG}; # replaced my @opts=qw{OPTS}; # replaced if (grep { $_ eq "-r" || $_ eq "--relocatable" } @ARGV) { - print "running $prog withthout extra opts, as relocatable build detected\n"; exec($prog,@ARGV) || die "failed to run $prog"; } else { - print "running $prog with extra opts @opts\n"; exec($prog,@opts,@ARGV) || die "failed to run $prog"; } -- cgit v1.2.3