2017-01-18 07:01:25 -08:00
|
|
|
def INITIAL_CLIENT_VERS = 8
|
2017-05-18 06:53:03 -07:00
|
|
|
def VERSION_CODE_BASE = 114
|
|
|
|
def VERSION_NAME = '4.4.118'
|
2017-05-23 06:37:31 -07:00
|
|
|
def VARIANTS = [ "xw4", "xw4d" ]
|
2017-01-18 07:01:25 -08:00
|
|
|
def BUILDS = [ "Debug", "Release" ]
|
2017-05-24 20:16:07 -07:00
|
|
|
boolean forFDroid = hasProperty('forFDroid')
|
2017-05-24 06:49:09 -07:00
|
|
|
|
|
|
|
// Get the git revision we're using. Since fdroid modifies files as
|
|
|
|
// part of its build process -dirty will always be added, confusing
|
|
|
|
// users. So add that for the non-fdroid case.
|
|
|
|
def GITREV = "git describe --tags"
|
2017-05-24 20:16:07 -07:00
|
|
|
if (! forFDroid) {
|
2017-05-24 06:49:09 -07:00
|
|
|
GITREV += " --dirty"
|
|
|
|
}
|
|
|
|
GITREV = GITREV.execute().text.trim()
|
2017-01-18 07:01:25 -08:00
|
|
|
|
|
|
|
apply plugin: 'com.android.application'
|
|
|
|
|
|
|
|
android {
|
2017-02-04 08:12:40 -08:00
|
|
|
buildToolsVersion '23.0.3'
|
2017-01-18 07:01:25 -08:00
|
|
|
defaultConfig {
|
|
|
|
minSdkVersion 7
|
|
|
|
targetSdkVersion 23
|
|
|
|
versionCode VERSION_CODE_BASE
|
|
|
|
versionName VERSION_NAME
|
|
|
|
}
|
|
|
|
|
|
|
|
// Rename all output artifacts to include version information
|
|
|
|
applicationVariants.all { variant ->
|
|
|
|
// renameArtifact(variant)
|
|
|
|
// variant.buildConfigField "String", "FIELD_NAME", "\"my String\""
|
|
|
|
def GCM_SENDER_ID = System.getenv("GCM_SENDER_ID")
|
|
|
|
variant.buildConfigField "String", "SENDER_ID", "\"$GCM_SENDER_ID\""
|
|
|
|
def CRITTERCISM_APP_ID = System.getenv("CRITTERCISM_APP_ID")
|
|
|
|
variant.buildConfigField "String", "CRITTERCISM_APP_ID", "\"$CRITTERCISM_APP_ID\""
|
|
|
|
|
2017-01-22 16:22:35 -08:00
|
|
|
resValue "string", "git_rev", "$GITREV"
|
|
|
|
variant.buildConfigField "String", "GIT_REV", "\"$GITREV\""
|
2017-01-18 08:27:48 -08:00
|
|
|
|
|
|
|
// def stamp = Long.valueOf('date +\'%s\''.execute().text.trim());
|
|
|
|
def stamp = Math.round(System.currentTimeMillis() / 1000)
|
|
|
|
variant.buildConfigField "long", "BUILD_STAMP", "$stamp"
|
|
|
|
|
|
|
|
// FIX ME
|
|
|
|
variant.buildConfigField "String", "STRINGS_HASH", "\"00000\""
|
|
|
|
|
|
|
|
def senderID = System.getenv("GCM_SENDER_ID")
|
|
|
|
variant.buildConfigField "String", "GCM_SENDER_ID", "\"$senderID\""
|
|
|
|
|
|
|
|
variant.buildConfigField "short", "CLIENT_VERS_RELAY", "$INITIAL_CLIENT_VERS"
|
2017-05-24 20:16:07 -07:00
|
|
|
|
|
|
|
variant.buildConfigField "boolean", "FOR_FDROID", "$forFDroid"
|
2017-01-18 07:01:25 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
flavorDimensions "variant"//, "abi"
|
|
|
|
productFlavors {
|
|
|
|
xw4 {
|
|
|
|
dimension "variant"
|
2017-05-23 06:37:31 -07:00
|
|
|
applicationId "org.eehouse.android.xw4"
|
2017-01-18 07:01:25 -08:00
|
|
|
manifestPlaceholders = [ APP_ID: applicationId ]
|
|
|
|
resValue "string", "app_name", "CrossWords"
|
|
|
|
resValue "string", "nbs_port", "3344"
|
|
|
|
resValue "string", "invite_prefix", "/and/"
|
2017-01-20 07:56:03 -08:00
|
|
|
buildConfigField "boolean", "WIDIR_ENABLED", "false"
|
2017-01-18 07:01:25 -08:00
|
|
|
}
|
2017-05-23 06:37:31 -07:00
|
|
|
xw4d {
|
2017-01-18 07:01:25 -08:00
|
|
|
dimension "variant"
|
2017-05-23 06:37:31 -07:00
|
|
|
applicationId "org.eehouse.android.xw4dbg"
|
2017-01-18 07:01:25 -08:00
|
|
|
manifestPlaceholders = [ APP_ID: applicationId ]
|
|
|
|
resValue "string", "app_name", "CrossDbg"
|
|
|
|
resValue "string", "nbs_port", "3345"
|
|
|
|
resValue "string", "invite_prefix", "/anddbg/"
|
2017-01-20 07:56:03 -08:00
|
|
|
buildConfigField "boolean", "WIDIR_ENABLED", "true"
|
2017-01-18 07:01:25 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
// WARNING: "all" breaks things. Seems to be a keyword. Need
|
|
|
|
// to figure out how to express include-all-abis
|
|
|
|
// all {
|
|
|
|
// dimension "abi"
|
|
|
|
// versionCode 0 + VERSION_CODE_BASE
|
|
|
|
// }
|
|
|
|
// armeabi {
|
|
|
|
// dimension "abi"
|
|
|
|
// versionCode 1 + VERSION_CODE_BASE
|
|
|
|
// }
|
|
|
|
// x86 {
|
|
|
|
// dimension "abi"
|
|
|
|
// versionCode 2 + VERSION_CODE_BASE
|
|
|
|
// }
|
|
|
|
// armeabiv7a {
|
|
|
|
// dimension "abi"
|
|
|
|
// versionCode 3 + VERSION_CODE_BASE
|
|
|
|
// }
|
|
|
|
}
|
|
|
|
|
|
|
|
signingConfigs {
|
2017-01-22 15:27:35 -08:00
|
|
|
debug {
|
|
|
|
def path = System.getenv("DEBUG_KEYSTORE_PATH")
|
|
|
|
if (! path) {
|
|
|
|
path = "./debug.keystore"
|
|
|
|
}
|
|
|
|
storeFile file(path)
|
|
|
|
keyAlias "androiddebugkey"
|
|
|
|
storePassword "android"
|
|
|
|
keyPassword "android"
|
|
|
|
}
|
2017-01-18 07:01:25 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
buildTypes {
|
|
|
|
release {
|
|
|
|
debuggable false
|
2017-01-18 21:27:48 -08:00
|
|
|
minifyEnabled false // PENDING
|
2017-01-18 07:01:25 -08:00
|
|
|
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
|
|
|
|
}
|
|
|
|
debug {
|
|
|
|
debuggable true
|
|
|
|
// This doesn't work on marshmallow: duplicate permission error
|
|
|
|
// applicationIdSuffix ".debug"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
sourceSets {
|
|
|
|
// Use symlinks instead of setting non-conventional
|
|
|
|
// directories here. AS doesn't respect what's set here: it'll
|
|
|
|
// compile, but post-install app launch and source-level
|
|
|
|
// debugging don't work.
|
2017-01-19 08:10:16 -08:00
|
|
|
xw4 {
|
|
|
|
release {
|
|
|
|
jniLibs.srcDir "../libs-release-xw4"
|
|
|
|
}
|
|
|
|
debug {
|
|
|
|
jniLibs.srcDir "../libs-debug-xw4"
|
|
|
|
}
|
2017-01-18 07:01:25 -08:00
|
|
|
}
|
2017-05-23 06:37:31 -07:00
|
|
|
xw4d {
|
2017-01-19 08:10:16 -08:00
|
|
|
release {
|
2017-05-23 06:37:31 -07:00
|
|
|
jniLibs.srcDir "../libs-release-xw4d"
|
2017-01-19 08:10:16 -08:00
|
|
|
}
|
|
|
|
debug {
|
2017-05-23 06:37:31 -07:00
|
|
|
jniLibs.srcDir "../libs-debug-xw4d"
|
2017-01-19 08:10:16 -08:00
|
|
|
}
|
2017-01-18 07:01:25 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
lintOptions {
|
|
|
|
abortOnError false
|
|
|
|
}
|
|
|
|
|
|
|
|
applicationVariants.all { variant ->
|
|
|
|
variant.outputs.each { output ->
|
2017-01-22 15:55:31 -08:00
|
|
|
def newName = output.outputFile.name
|
2017-01-22 16:22:35 -08:00
|
|
|
newName = newName.replace(".apk","-${GITREV}.apk")
|
2017-01-22 15:55:31 -08:00
|
|
|
newName = newName.replace("app-","")
|
|
|
|
output.outputFile = new File(output.outputFile.parent, newName)
|
2017-01-18 07:01:25 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
dependencies {
|
2017-01-18 19:03:36 -08:00
|
|
|
// Look into replacing this with a fetch too PENDING
|
|
|
|
compile files('../libs/gcm.jar')
|
|
|
|
|
2017-02-04 08:12:40 -08:00
|
|
|
compile 'com.android.support:support-v4:23.4.0'
|
2017-01-18 19:03:36 -08:00
|
|
|
|
2017-05-23 06:37:31 -07:00
|
|
|
xw4dCompile 'com.crittercism:crittercism-android-agent:+'
|
2017-01-18 07:01:25 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
task mkImages(type: Exec) {
|
|
|
|
workingDir '../'
|
|
|
|
commandLine './scripts/mkimages.sh'
|
|
|
|
}
|
|
|
|
|
|
|
|
task copyStrings(type: Exec) {
|
|
|
|
workingDir '../'
|
|
|
|
commandLine './scripts/copy-strings.py'
|
|
|
|
}
|
|
|
|
|
|
|
|
task ndkSetup(type: Exec) {
|
|
|
|
workingDir '../'
|
|
|
|
commandLine "./scripts/ndksetup.sh", "--with-clang"
|
|
|
|
}
|
|
|
|
|
|
|
|
task myPreBuild(dependsOn: ['ndkSetup', 'mkImages', 'copyStrings', 'mkXml']) {
|
|
|
|
}
|
|
|
|
preBuild.dependsOn myPreBuild
|
|
|
|
|
|
|
|
task mkXml(type: Exec) {
|
|
|
|
workingDir '../'
|
|
|
|
commandLine './scripts/mk_xml.py', '-o',
|
|
|
|
"app/src/main/java/org/eehouse/android/xw4/loc/LocIDsData.java",
|
|
|
|
'-t', "debug"
|
|
|
|
}
|
|
|
|
|
|
|
|
afterEvaluate {
|
|
|
|
VARIANTS.each { VARIANT ->
|
|
|
|
String variantCaps = VARIANT.capitalize()
|
|
|
|
BUILDS.each { BUILD ->
|
|
|
|
String nameLC = BUILD.toLowerCase()
|
2017-01-19 08:10:16 -08:00
|
|
|
String lib = "libs-${nameLC}-${VARIANT}"
|
|
|
|
String ndkBuildTask = "ndkBuild${variantCaps}${BUILD}"
|
|
|
|
task "$ndkBuildTask"(type: Exec) {
|
2017-01-18 07:01:25 -08:00
|
|
|
workingDir '../'
|
|
|
|
commandLine './scripts/ndkbuild.sh', '-j3',
|
|
|
|
"BUILD_TARGET=${nameLC}", "INITIAL_CLIENT_VERS=$INITIAL_CLIENT_VERS",
|
2017-01-19 08:10:16 -08:00
|
|
|
"VARIANT=$VARIANT", "NDK_LIBS_OUT=${lib}", "NDK_OUT=./obj-${nameLC}-${VARIANT}"
|
2017-01-18 07:01:25 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
String compileTask = "compile${variantCaps}${BUILD}Ndk"
|
2017-01-19 08:10:16 -08:00
|
|
|
tasks.getByName(compileTask).dependsOn ndkBuildTask
|
2017-01-18 07:01:25 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-05-23 06:37:31 -07:00
|
|
|
String copyStringsTask = "copyStringsXw4D"
|
2017-01-18 07:01:25 -08:00
|
|
|
task "$copyStringsTask"(type: Exec) {
|
|
|
|
workingDir './'
|
|
|
|
environment.put('APPNAME', 'CrossDbg')
|
|
|
|
commandLine 'make', '-f', '../scripts/Variant.mk',
|
2017-05-23 06:37:31 -07:00
|
|
|
"src/xw4d/res/values/strings.xml"
|
2017-01-18 07:01:25 -08:00
|
|
|
}
|
|
|
|
preBuild.dependsOn copyStringsTask
|
|
|
|
}
|
|
|
|
|
2017-01-19 08:10:16 -08:00
|
|
|
clean.dependsOn 'cleanNDK'
|
|
|
|
task cleanNDK(type: Exec) {
|
|
|
|
ArrayList<String> lst = new ArrayList<String>(["rm", "-rf"]);
|
|
|
|
BUILDS.each { BUILD ->
|
|
|
|
String buildLC = BUILD.toLowerCase()
|
|
|
|
VARIANTS.each { VARIANT ->
|
|
|
|
lst.add("libs-${buildLC}-${VARIANT}")
|
|
|
|
lst.add("obj-${buildLC}-${VARIANT}")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
workingDir '../'
|
|
|
|
commandLine lst
|
|
|
|
}
|
|
|
|
|
2017-05-24 07:09:11 -07:00
|
|
|
task makeBuildAssets() {
|
|
|
|
def assetsDir = android.sourceSets.main.assets.srcDirs.toArray()[0]
|
|
|
|
String path = new File(assetsDir, 'build-info.txt').getAbsolutePath()
|
|
|
|
File file = new File(path);
|
|
|
|
file.write("git: ${GITREV}\n");
|
|
|
|
}
|
2017-01-18 07:01:25 -08:00
|
|
|
|
2017-05-24 07:09:11 -07:00
|
|
|
gradle.projectsEvaluated {
|
|
|
|
build.dependsOn(makeBuildAssets)
|
|
|
|
}
|