diff --git a/Dockerfile b/Dockerfile index add4df4..3f96935 100644 --- a/Dockerfile +++ b/Dockerfile @@ -3,50 +3,40 @@ FROM archlinux:latest ARG YESACCEPT=n RUN echo "this is $YESACCEPT" RUN pacman -Syu --noconfirm -RUN pacman -S --noconfirm coreutils bash shadow make unzip zip jdk11-openjdk wget xorg-xclock +RUN pacman -S --noconfirm coreutils bash shadow make unzip zip jdk17-openjdk wget ENV ANDROID_SDK_ROOT="/opt/android" ENV BUILD_TOOLS_LATEST="$ANDROID_SDK_ROOT/cmdline-tools/latest" RUN BUILD_TOOLS="$(realpath -m "$BUILD_TOOLS_LATEST/..")";\ mkdir -p "$BUILD_TOOLS";\ cd "$BUILD_TOOLS";\ pwd;\ - wget -O cmdline-tools.zip https://dl.google.com/android/repository/commandlinetools-linux-9477386_latest.zip;\ - unzip cmdline-tools.zip;\ + for LATESTTOOLS in \ + "$(curl https://developer.android.com/studio#command-line-tools-only | grep -e 'https://dl.google.com/android/repository/commandlinetools-linux-.*_latest.zip' | cut -f2 -d'"')" \ + 'https://dl.google.com/android/repository/commandlinetools-linux-11076708_latest.zip' ;\ + do \ + echo "testing to get '$LATESTTOOLS'";\ + echo test "${LATESTTOOLS:0:22}" = "https://dl.google.com/" -a "${LATESTTOOLS:(-11)}" = "_latest.zip" ;\ + test "${LATESTTOOLS:0:22}" = "https://dl.google.com/" -a "${LATESTTOOLS:(-11)}" = "_latest.zip" || { echo "unsure of URL $LATESTTOOLS correct, skipping it..." >&2; continue; }; \ + wget -O cmdline-tools.zip "$LATESTTOOLS" ;\ + unzip cmdline-tools.zip && break || { echo "error downloading working cmdline-tools.zip"; exit 1; };\ + done;\ ls ;\ ls cmdline-tools;\ rm cmdline-tools.zip;\ mv -v cmdline-tools "$BUILD_TOOLS_LATEST" || true ENV PATH="$PATH:$BUILD_TOOLS_LATEST/bin" -ENV JAVA_HOME="/usr/lib/jvm/java-11-openjdk/" -#ENTRYPOINT bash -c 'sleep 10000' +#TODO make this automatic +ENV JAVA_HOME="/usr/lib/jvm/java-17-openjdk/" ENV LIBRARY_PATH="$LIBRARY_PATH:$BUILD_TOOLS_LATEST/lib" RUN test "$YESACCEPT" = "y" || { printf "\033[31;1;4m%s\n%s\033[0m " "FAILED TO BUILD CONTAINER: You did not ACCEPT THE UPSTREAM LICENSE" " -> export YESACCEPT=y" >&2; exit 1; } -RUN echo you selected to accept the licenses/TOS +RUN echo you selected to accept the licenses/TOS RUN echo "$YESACCEPT" | sdkmanager --install "build-tools;33.0.2" RUN echo "$YESACCEPT" | sdkmanager --install "platforms;android-33" RUN echo "$YESACCEPT" | sdkmanager --install "ndk;28.0.12433566" -RUN echo "$YESACCEPT" | sdkmanager --install "system-images;android-33;aosp_atd;x86_64" -RUN echo "$YESACCEPT" | sdkmanager --install "emulator" -RUN echo "no" | avdmanager --verbose create avd --force --name "thedevice" --package 'system-images;android-33;aosp_atd;x86_64' --tag "aosp_atd" --abi "x86_64" -RUN echo "$YESACCEPT" | sdkmanager --install "platform-tools" -RUN pacman -S --noconfirm libpulse libdrm libbsd libxi -RUN mkdir /tmp/.X11-unix/ - -# 10 pacman -Ss pulse -# 11 pacman -Ss pulse | grpe lib -# 12 pacman -Ss pulse | grep lib -# 13 pacman -S libpulse -# 15 pacman -S libdrm -# 17 pacman -S libXi -# 18 pacman -Ss libXi -# 19 pacman -Ss libxi -# 20 pacman -S libxi -# 22 pacman -S libsd -# 23 pacman -S libbsd -# 24 pacman -S libbsd -# 26 history | grep pacman -# -#RUN apk add setpriv +#RUN echo "$YESACCEPT" | sdkmanager --install "system-images;android-33;aosp_atd;x86_64" +#RUN echo "$YESACCEPT" | sdkmanager --install "emulator" +#RUN echo "no" | avdmanager --verbose create avd --force --name "thedevice" --package 'system-images;android-33;aosp_atd;x86_64' --tag "aosp_atd" --abi "x86_64" +#RUN echo "$YESACCEPT" | sdkmanager --install "platform-tools" COPY entrypoint.sh /entrypoint.sh RUN chown 0:0 /entrypoint.sh RUN chmod 0700 /entrypoint.sh diff --git a/Makefile b/Makefile index 22a0173..91d2608 100644 --- a/Makefile +++ b/Makefile @@ -1,30 +1,8 @@ # this includes explicit rules - - include Makefile.apps Makefile.apps: Makefile apps - @(\ - cd apps;\ - for APP in */;\ - do \ - test -d "$$APP" || continue;\ - APP="$${APP%/}";\ - MFA="\ - apps/$$APP/app.apk: docker-compose-build.log\n\ - docker compose run --rm compile $$APP\n\ - build-$$APP: apps/$$APP/app.apk\n\ - true\n\ - apps/$$APP/app.apk.install-log: apps/$$APP/app.apk\n\ - adb install -r $$< > \$$@ || rm \$$@ \n\ - install-$$APP: apps/$$APP/app.apk.install-log\n\ - true\n\ - run-$$APP: apps/$$APP/app.apk.install-log\n\ - adb shell am start -n app.example/.ExampleApp\n\ - ";\ - done;\ - printf "$$MFA" \ - ) > "$@" + @./Makefile.make.Makefile.apps.sh apps: mkdir "$@" @@ -38,5 +16,3 @@ docker-compose-build.log: Dockerfile compose.yml docker-compose down --remove-orphans --rmi all BUILDKIT_PROGRESS=plain docker-compose build | tee docker-compose-build.log -some thing: - echo was $@ diff --git a/Makefile.make.Makefile.apps.sh b/Makefile.make.Makefile.apps.sh new file mode 100755 index 0000000..76115da --- /dev/null +++ b/Makefile.make.Makefile.apps.sh @@ -0,0 +1,22 @@ +#!/bin/bash +( +set -xe +cd apps +for APP in */ +do + test -d "$APP" || continue; + APP="${APP%/}"; + cat << MAKEFILE +apps/$APP/app.apk: docker-compose-build.log + docker compose run --rm compile $APP +build-$APP: apps/$APP/app.apk + true +apps/$APP/app.apk.install-log: apps/$APP/app.apk + adb install -r $< > \$@ || rm \$@ +install-$APP: apps/$APP/app.apk.install-log + true +run-$APP: apps/$APP/app.apk.install-log + adb shell am start -n app.example/.ExampleApp +MAKEFILE +done +) > Makefile.apps