diff options
author | Joey Hess <joeyh@joeyh.name> | 2015-01-07 17:26:05 -0400 |
---|---|---|
committer | Joey Hess <joeyh@joeyh.name> | 2015-01-07 17:26:05 -0400 |
commit | 2da860256a11db54cad7ff981fc4e9e000572564 (patch) | |
tree | b7d3f4c43e3888ce79f3b41c3668cb665ebc8348 /standalone | |
parent | 6d9eb8da566c410c7780e15625dfed3f76a3e8f8 (diff) | |
parent | 5cb4e8b3705db23d652e0a5f12ab2de88fe721e7 (diff) |
Merge branch 'master' of ssh://git-annex.branchable.com into relativepaths
Diffstat (limited to 'standalone')
-rw-r--r-- | standalone/android/Makefile | 119 | ||||
-rwxr-xr-x | standalone/android/buildapk | 145 | ||||
-rw-r--r-- | standalone/android/wrapper.pl | 10 |
3 files changed, 173 insertions, 101 deletions
diff --git a/standalone/android/Makefile b/standalone/android/Makefile index 020303374..261259bf4 100644 --- a/standalone/android/Makefile +++ b/standalone/android/Makefile @@ -1,93 +1,29 @@ # 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: + # 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 $@ @@ -146,22 +82,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..063fe6c83 --- /dev/null +++ b/standalone/android/buildapk @@ -0,0 +1,145 @@ +#!/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 () { + sed -e "s!PROG!$1!" -e "s!OPTS!$3!" < wrapper.pl > "$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" + mkdir -p "$androidtoolchain/5" + for f in $(find "$androidtoolchain" -maxdepth 1 -not -type d -printf '%f\n'); do + src="$androidtoolchain/$f" + dest="$androidtoolchain/5/$f" + case "$f" in + *-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/5:$PATH" +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 diff --git a/standalone/android/wrapper.pl b/standalone/android/wrapper.pl new file mode 100644 index 000000000..a7136a950 --- /dev/null +++ b/standalone/android/wrapper.pl @@ -0,0 +1,10 @@ +#!/usr/bin/perl +my $prog=q{PROG}; # replaced +my @opts=qw{OPTS}; # replaced + +if (grep { $_ eq "-r" || $_ eq "--relocatable" } @ARGV) { + exec($prog,@ARGV) || die "failed to run $prog"; +} +else { + exec($prog,@opts,@ARGV) || die "failed to run $prog"; +} |