Compare commits

..

No commits in common. "f83bf386cddb981e4bcdc43d06acb436b784f58b" and "f817f61876bc8a4cb631665bded1218fd59ae734" have entirely different histories.

7 changed files with 67 additions and 129 deletions

6
.gitignore vendored
View file

@ -1,6 +1,8 @@
/Dockerfile
/app/result
/app/result/*
/app/obj
/app/obj/*
!/app/obj/.gitkeep
/app/bin
/app/bin/*
/app/app.apk
/app/Makefile.app-config

View file

@ -8,21 +8,31 @@ test -f app-config.sh && {
echo "package $APP_PACKAGE;"
cat << 'APPACTIVITYJAVA'
import android.provider.Settings ;
import android.content.Intent;
import android.util.Log;
import android.util.Base64;
import java.util.Objects;
import android.app.Activity;
import android.os.Bundle;
import android.os.CountDownTimer;
import android.os.Environment;
//import android.view.MenuItem;
import android.text.method.ScrollingMovementMethod;
import android.view.*;
// for WebView,WebMessage,WebMessagePort,
//import android.view.MenuItem;
import android.view.ViewGroup.*;
import android.widget.*;
//import android.widget.Toast;
//import android.widget.TextView;
import android.webkit.*;
import android.net.Uri;
import org.json.JSONObject;
//import android.webkit.WebView;
//import android.webkit.WebMessage;
//import android.webkit.WebMessagePort;
import java.io.InputStream;
import java.io.File;
import java.util.Objects;
@ -60,9 +70,6 @@ public class AppActivity extends Activity {
myWebSettings.setBuiltInZoomControls(true);
myWebSettings.setDisplayZoomControls(false);
myWebSettings.setJavaScriptEnabled(true);
myWebSettings.setDomStorageEnabled(true);
myWebSettings.setDatabaseEnabled(true);
myWebSettings.setDatabasePath("/data/data/" + myWebView.getContext().getPackageName() + "/databases/");
myWebView.addJavascriptInterface(this, "myJavaScriptInterface");
// load the html from assets file
String html = readFileFromAssets("index.html");
@ -78,3 +85,4 @@ public class AppActivity extends Activity {
return "this is good";
}
}
APPACTIVITYJAVA

View file

@ -13,21 +13,11 @@ test -n "$LINES" || {
test -n "$LINES" || {
read -r LINES COLUMNS < <(stty size)
}
test -z "$LINES" && {
test -n "$LINES" || {
LINES=25
}
test "$LINES" -lt "16" && {
LINES=16
COLUMS=80
}
test -z "$COLUMNS" && {
COLUMNS=80
}
test "$COLUMNS" -lt "36" && {
COLUMNS=36
}
type whiptail &>/dev/null && {
ECHO(){

View file

@ -1,64 +1,51 @@
.ONESHELL:
SHELL=/bin/makefile-bash-wrapper.sh
# the include of the Makefile.app-config defines the Makefile
# variables $(BUILDTOOLS), $(ANDROID_JAR) and $(PACKAGE)
# which depend on the configuration and are necessary to have the Makefile work
# the rule whose target is Makefile.app-config will trigger a reload of this include as ncessary
# (as explained https://make.mad-scientist.net/papers/advanced-auto-dependency-generation/#include)
include Makefile.app-config
SHELL=/bin/bash
# symlink
./app.apk: ./result/app.apk
ln -sfrv ./result/app.apk ./app.apk
# zipalign and sign again (second signing)
./result/app.apk : ./result/signed.apk app-config.sh ./keystore
$(BUILDTOOLS)/zipalign -v -f 4 $< $@
$(BUILDTOOLS)/apksigner sign --ks keystore --key-pass pass:armena --ks-pass pass:armena $@
./result/app.apk : ./result/signed.apk app-config.sh
source app-config.sh; $${ANDROID_SDK_ROOT}/$$(tr ';' '/' < android-sdk/.installed.buildtools.version.current)/zipalign -v -f 4 $< $@
source app-config.sh; $${ANDROID_SDK_ROOT}/$$(tr ';' '/' < android-sdk/.installed.buildtools.version.current)/apksigner sign \
--ks ToyKey.keystore --key-pass pass:armena --ks-pass pass:armena $@
# sign the apk file (first sign)
./result/signed.apk : ./result/unsigned.apk ./keystore
jarsigner -verbose -keystore ./keystore -storepass armena -keypass armena -signedjar $@ $< helljniKey
./result/signed.apk : ./result/unsigned.apk ./ToyKey.keystore ./result
jarsigner -verbose -keystore ./ToyKey.keystore -storepass armena -keypass armena -signedjar $@ $< helljniKey
# make a "keystore" for the cryptographic signing stuff
./keystore :
./ToyKey.keystore :
keytool -genkeypair -validity 1000 -dname "CN=alexander,O=Android,C=JPN" -keystore $@ \
-storepass armena -keypass armena -alias helljniKey -keyalg RSA -v
# aapt "package" together the dalvik/hex stuff (and "assets" and "res")
./result/unsigned.apk : ./result/bin/classes.dex ./assets ./AndroidManifest.xml
./result/unsigned.apk : ./bin/classes.dex ./result ./assets ./bin ./AndroidManifest.xml
rm -rvf "$@"
$(BUILDTOOLS)/aapt package \
source app-config.sh; $${ANDROID_SDK_ROOT}/$$(tr ';' '/' < android-sdk/.installed.buildtools.version.current)/aapt package \
-v -u -f -M ./AndroidManifest.xml -S ./res \
-I $(ANDROID_JAR) -A ./assets -F $@ ./result/bin
-I $${ANDROID_SDK_ROOT}/$$(tr ';' '/' < android-sdk/.installed.platforms.version.current)/android.jar -A ./assets -F $@ ./bin
# convert "java class"es files (i.e bytecode) to dalvic/d8 android thing
./result/bin/classes.dex : ./obj/$(PACKAGE)/AppActivity.class
mkdir -p ./result/bin
$(BUILDTOOLS)/d8 ./obj/$(PACKAGE)/*.class \
--lib $(ANDROID_JAR) --output ./result/bin
# convert "java class"es files (i.e bytecode to dalvic/d8 android thing
./bin/classes.dex : ./obj/package ./obj/package/AppActivity.class ./bin
ls ./obj/package/*.class
source app-config.sh; $${ANDROID_SDK_ROOT}/$$(tr ';' '/' < android-sdk/.installed.buildtools.version.current)/d8 $$(realpath --relative-to=. $<)/*.class \
--lib $${ANDROID_SDK_ROOT}/$$(tr ';' '/' < android-sdk/.installed.platforms.version.current)/android.jar --output bin
# compile (javac) the class from
./obj/$(PACKAGE)/AppActivity.class : ./src/$(PACKAGE)/AppActivity.java ./src/$(PACKAGE)/R.java
mkdir -p ./obj/$(PACKAGE)
javac -d ./obj -classpath $(ANDROID_JAR) -sourcepath ./src $<
./obj/package/AppActivity.class : ./src/package/AppActivity.java ./src/package/R.java ./obj/package
javac -d ./obj -classpath $${ANDROID_SDK_ROOT}/$$(tr ';' '/' < android-sdk/.installed.platforms.version.current)/android.jar \
-sourcepath ./src $$(realpath --relative-to=/src $<)
# make the resources "R.java" thing
./src/$(PACKAGE)/R.java : $(shell find ./res -type f) app-config.sh ./AndroidManifest.xml ./android-sdk/installed | ./src/$(PACKAGE)
$(BUILDTOOLS)/aapt package \
-v -f -m -S ./res -J ./src -M ./AndroidManifest.xml \
-I $(ANDROID_JAR)
# generate the AppActivity.java (template
# the "|" denotes an "order-only" prerequiste (as in https://stackoverflow.com/a/58040049/1711186)
./src/$(PACKAGE)/AppActivity.java: app-config.sh | ./src/$(PACKAGE)
# generate teh AppActivity.java (template)
./src/package/AppActivity.java: ./src/package app-config.sh
./.Makefile.scripts/make--AppActivity.java.sh > $@
./src/$(PACKAGE):
mkdir -p $@
# make the resources "R.java" thing
./src/package/R.java : $(shell find ./res -type f) app-config.sh ./src/package ./AndroidManifest.xml ./android-sdk/installed
source app-config.sh; $${ANDROID_SDK_ROOT}/$$(tr ';' '/' < android-sdk/.installed.buildtools.version.current)/aapt package \
-v -f -m -S ./res -J ./src -M ./AndroidManifest.xml \
-I $${ANDROID_SDK_ROOT}/$$(tr ';' '/' < android-sdk/.installed.platforms.version.current)/android.jar
# install the necessary android sdks
./android-sdk/installed: app-config.sh
@ -68,24 +55,19 @@ include Makefile.app-config
./AndroidManifest.xml: app-config.sh
./.Makefile.scripts/make--AndroidManifest.xml
Makefile.app-config: app-config.sh Makefile
source app-config.sh; \
tee $@ << MAKEFILE_APP_CONFIG
BUILDTOOLS:=$${ANDROID_SDK_ROOT}/$$(tr ';' '/' < android-sdk/.installed.buildtools.version.current)
ANDROID_JAR:=$${ANDROID_SDK_ROOT}/$$(tr ';' '/' < android-sdk/.installed.platforms.version.current)/android.jar
PACKAGE:=$$(echo "$$APP_PACKAGE" | tr '.' '/')
MAKEFILE_APP_CONFIG
# recipe to make directories (if) needed
./result ./bin ./assets ./src/ ./obj:
mkdir -p "$@"
# make symlinksa and directories (to cater for the "helpful" java thing, to use folders for package names and yes we need a package name :( )
./src/package: app-config.sh
set -x; source app-config.sh; PKGDIR=$$(echo "$$APP_PACKAGE" | tr '.' '/'); mkdir -p src/$$PKGDIR; rm -rf $@ ; ln -sfrv src/$$PKGDIR $@
./obj/package: app-config.sh
source app-config.sh; PKGDIR=$$(echo "$$APP_PACKAGE" | tr '.' '/'); mkdir -p obj/$$PKGDIR; rm -rf $@; ln -sfrv obj/$$PKGDIR $@
# use whiptail textgui to make configuration (android API level, app-name, app-label etc...)
app-config.sh:
./.Makefile.scripts/make--app-config.sh
# rule to effectuate a cleanup
clean:
rm -rf obj/* result/*
# this rule's purpose is to run "by force" no matter what, doing nothing
# as listed prerequisite to another rule it causes that rule to be made/run
# unconditionally every time
FORCE:
@true

View file

@ -4,37 +4,7 @@
<meta charset="UTF-8">
<meta content="width=device-width,initial-scale=1.0" name="viewport">
</head>
<style>
@keyframes wobble {
0% {
transform: scale(0.1);
opacity:0.0
}
100% {
transform: scale(1.0);
opacity:1.0
}
}
</style>
<body>
<h1>Webview</h1>
<script>
window.addEventListener("error",(error)=>{
document.body.innerHTML = "<h1>error</h1><pre>" +
error.filename +
"\nline:" + error.lineno +
"\n"+error.message +"</pre>";
},false);
window.addEventListener("load",()=>{
var count = localStorage.getItem("app-opened-count")|| 0;
count++;
localStorage.setItem("app-opened-count",count);
var h2 = document.createElement("h2");
h2.textContent = "Javascript works! (app was opened " + count + " times)";
h2.style.animation="wobble 1s ease-in-out 0s 1 forwards normal running"
document.body.appendChild(h2);
},false);
</script>
<h1> SUPER</h1>
</body>
</html>

View file

View file

@ -1,11 +1,11 @@
#!/bin/sh
set -e
set -ex
CONTAINERRUNTIMES='docker podman nerdctl'
for CONTAINERRUNTIME in $CONTAINERRUNTIMES /
do
type $CONTAINERRUNTIME >/dev/null 2>/dev/null && break
type $CONTAINERRUNTIME 2>/dev/null && break
test "$CONTAINERRUNTIME" = / && {
echo "install a container runtime (e.g ${CONTAINERRUNTIMES//\ /\/})" >&2
exit 2
@ -15,7 +15,7 @@ done
HASHES='md5sum cksum sha1sum base64 uuencode'
for HASH in $HASHES /
do
type $HASH >/dev/null 2>/dev/null && break
type $HASH 2>/dev/null && break
test "$HASH" = / && {
echo "install checksum (e.g ${HASHES//\ /\/})" >&2
exit 3
@ -26,46 +26,32 @@ DockerfileContent(){
cat << 'DOCKERFILEEOF'
FROM debian:latest
RUN apt-get update -y && apt-get install -y make openjdk-17-jdk-headless unzip zip wget curl whiptail
ENTRYPOINT ["/bin/bash","-c","make"]
ENV JAVA_HOME="/usr/lib/jvm/java-17-openjdk-amd64/"
ENV ANDROID_SDK_ROOT="/app/android-sdk"
ENV BUILD_TOOLS_LATEST="$ANDROID_SDK_ROOT/cmdline-tools/latest"
ENV PATH="$BUILD_TOOLS_LATEST/bin:$PATH"
ENV LIBRARY_PATH="$LIBRARY_PATH:$BUILD_TOOLS_LATEST/lib"
CMD ["make","--trace"]
RUN <<EOF
cat > /bin/makefile-bash-wrapper.sh << 'WRAPPER'
#!/bin/bash
printf $'\033[0;32m''#----------------------------------------\n'$'\033[0m' >&2
bash "$@"
printf '\n\n\n\n' >&2
WRAPPER
chmod u+x /bin/makefile-bash-wrapper.sh
EOF
DOCKERFILEEOF
}
diff Dockerfile <(DockerfileContent) 2>/dev/null > /dev/null || {
test -f Dockerfile && {
read -p 'reset/start Dockerfile[Y/n]' YES
test "$YES" = "n" && { echo "aborting..." >&2; exit 1; }
}
read -p 'reset/start Dockerfile[Y/n]' YES
test "$YES" = "n" && { echo "aborting..." >&2; exit 1; }
DockerfileContent > Dockerfile
}
IMAGE=build-android-app:"$($HASH Dockerfile | tr -cd '[a-zA-Z0-9]' | head -c 12)"
IMAGE=android-app:"$($HASH Dockerfile | tr -cd '[a-zA-Z0-9]' | head -c 12)"
docker image inspect "$IMAGE" >/dev/null 2>/dev/null || {
$CONTAINERRUNTIME build --tag "$IMAGE" .
}
#(optional) tag the latest image build
docker tag $IMAGE build-android-app:latest
time $CONTAINERRUNTIME run --name build-android-app-$(date +%F--%H-%M-%S) \
$CONTAINERRUNTIME run --name build-android-app-$(date +%F--%H-%M-%S) \
--workdir=/app \
--env LINES=10 \
--env COLUMNS=$COLUMNS \
--hostname build-android-app \
--volume ./app:/app \
-it \
--rm \
"$IMAGE" "$@"
"$IMAGE"