]> Pileus Git - ~andy/spades/blobdiff - makefile
Update makefile for release build
[~andy/spades] / makefile
index 877113032df4f55f2944dae48e9bf7b24bff10fc..4491afd740b36d0904028920ebe7c7e61f16c7d7 100644 (file)
--- a/makefile
+++ b/makefile
@@ -1,10 +1,15 @@
+-include config.mk
+
 # Settings
-ANDROID := /opt/android-sdk-update-manager/platforms/android-10/android.jar
-PACKAGE := org.pileus.spades
-OUTPUT  := bin/Spades.apk
+PROGRAM ?= Spades
+PACKAGE ?= org.pileus.spades
+KEYFILE ?= ~/.android/android.p12
+KEYTYPE ?= pkcs12
+KEYNAME ?= android
+ANDROID ?= /opt/android-sdk-update-manager/platforms/android-10/android.jar
 
 # Sources
-RES     := $(shell find res -name '*.xml')
+RES     := $(shell find res -type f)
 SRC     := $(shell find src -name '*.java')
 
 # Objects
@@ -14,23 +19,25 @@ OBJ     := $(subst .java,.class,   \
                 $(GEN:gen/%=obj/%))
 
 # Targets
-default: run
+debug: bin/$(PROGRAM).dbg
 
-compile: $(OBJ)
+release: bin/$(PROGRAM).apk
 
-debug: $(OUTPUT)
+compile: $(OBJ)
 
 clean:
        rm -rf bin gen obj
 
+# ADB targets
 logcat:
-       adb logcat Spades:D AndroidRuntime:E '*:S'
+       adb logcat $(PROGRAM):D AndroidRuntime:E '*:S'
 
 run: bin/install.stamp
-       adb shell am start -W -a android.intent.action.MAIN -n $(PACKAGE)/.Main
-       
+       adb shell am start -W                 \
+               -a android.intent.action.MAIN \
+               -n $(PACKAGE)/.Main
 
-install bin/install.stamp: $(OUTPUT)
+install bin/install.stamp: bin/$(PROGRAM).dbg
        adb install -r $+
        touch bin/install.stamp
 
@@ -38,11 +45,46 @@ uninstall:
        adb uninstall $(PACKAGE)
        rm bin/install.stamp
 
+# Graphics targets
+graphics:
+       git checkout graphics  --    \
+               'opt/drawable/*.svg' \
+               'opt/drawable/*.xcf' \
+               'res/drawable/*.png' \
+               'res/drawable/*.jpg' \
+               || true
+       git reset HEAD --            \
+               'opt/drawable/*.svg' \
+               'opt/drawable/*.xcf' \
+               'res/drawable/*.png' \
+               'res/drawable/*.jpg' \
+               || true
+
+convert:
+       for svg in opt/drawable/*.svg; do        \
+               png=$${svg/svg/png};             \
+               png=$${png/opt/res};             \
+               rsvg-convert -w 2048 -h 2048     \
+                       $$svg -o $$png;          \
+               convert -trim -resize '256x256!' \
+                       $$png $$png;             \
+       done
+
 # Rules
-%.apk: %.dex %.res | bin
+%.dbg: %.dex %.res | bin
        @echo "APK    $@.in"
        @apkbuilder $@.in -f $*.dex -z $*.res
-       @echo ALIGN $@
+       @echo "ALIGN  $@"
+       @zipalign -f 4 $@.in $@
+
+%.apk: %.dex %.res | bin
+       @echo "APKU   $@.in"
+       @apkbuilder $@.in -u -f $*.dex -z $*.res
+       @echo "SIGN   $@.in"
+       @jarsigner -storetype $(KEYTYPE)  \
+                  -keystore  $(KEYFILE)  \
+                  $@.in      $(KEYNAME)
+       @echo "ALIGN  $@"
        @zipalign -f 4 $@.in $@
 
 %.dex: $(OBJ) | bin
@@ -58,8 +100,8 @@ uninstall:
                -F $*.res
 
 $(OBJ): $(SRC) $(GEN) | obj
-       @echo "JAVAC  $@"
-       @javac -g                         \
+       @echo "JAVAC  *.class"
+       @javac -g -Xlint:unchecked        \
                -bootclasspath $(ANDROID) \
                -encoding      UTF-8      \
                -source        1.5        \
@@ -69,6 +111,11 @@ $(OBJ): $(SRC) $(GEN) | obj
                $+
 
 $(GEN): AndroidManifest.xml $(RES) | gen
+       @if ! [ -d "res/drawable" ]; then \
+               echo Please run           \
+                    \'make graphics\';   \
+               exit 1;                   \
+       fi
        @echo "GEN    $@"
        @aapt package -f -m               \
                -I $(ANDROID)             \
@@ -79,3 +126,7 @@ $(GEN): AndroidManifest.xml $(RES) | gen
 # Directories
 bin gen obj:
        @mkdir -p $@
+
+# Use parallel javac instead
+.PRECIOUS: %.dex %.res
+.NOTPARALLEL: