2017-01-18 16:01:25 +01:00
|
|
|
def INITIAL_CLIENT_VERS = 8
|
2017-11-20 05:10:54 +01:00
|
|
|
def VERSION_CODE_BASE = 126
|
|
|
|
def VERSION_NAME = '4.4.130'
|
2017-06-21 06:45:44 +02:00
|
|
|
def FABRIC_API_KEY = System.getenv("FABRIC_API_KEY")
|
2017-09-24 23:30:59 +02:00
|
|
|
def GCM_SENDER_ID = System.getenv("GCM_SENDER_ID")
|
2017-09-24 23:32:58 +02:00
|
|
|
def BUILD_INFO_NAME = "build-info.txt"
|
2017-06-21 06:45:44 +02:00
|
|
|
|
2017-05-25 05:16:07 +02:00
|
|
|
boolean forFDroid = hasProperty('forFDroid')
|
2017-05-24 15:49:09 +02: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-25 05:16:07 +02:00
|
|
|
if (! forFDroid) {
|
2017-05-24 15:49:09 +02:00
|
|
|
GITREV += " --dirty"
|
|
|
|
}
|
|
|
|
GITREV = GITREV.execute().text.trim()
|
2017-01-18 16:01:25 +01:00
|
|
|
|
|
|
|
apply plugin: 'com.android.application'
|
|
|
|
|
2017-06-21 06:45:44 +02:00
|
|
|
|
|
|
|
if ( FABRIC_API_KEY && hasProperty('useCrashlytics') ) {
|
|
|
|
apply plugin: 'io.fabric'
|
|
|
|
}
|
|
|
|
repositories {
|
|
|
|
maven { url 'https://maven.fabric.io/public' }
|
|
|
|
}
|
|
|
|
|
2017-01-18 16:01:25 +01:00
|
|
|
android {
|
2017-02-04 17:12:40 +01:00
|
|
|
buildToolsVersion '23.0.3'
|
2017-01-18 16:01:25 +01:00
|
|
|
defaultConfig {
|
2017-07-12 17:02:52 +02:00
|
|
|
minSdkVersion 8
|
2017-01-18 16:01:25 +01:00
|
|
|
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\""
|
2017-06-21 06:45:44 +02:00
|
|
|
variant.buildConfigField "String", "FABRIC_API_KEY", "\"$FABRIC_API_KEY\""
|
2017-01-18 16:01:25 +01:00
|
|
|
|
2017-01-23 01:22:35 +01:00
|
|
|
resValue "string", "git_rev", "$GITREV"
|
|
|
|
variant.buildConfigField "String", "GIT_REV", "\"$GITREV\""
|
2017-01-18 17:27:48 +01: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\""
|
|
|
|
|
|
|
|
variant.buildConfigField "short", "CLIENT_VERS_RELAY", "$INITIAL_CLIENT_VERS"
|
2017-05-25 05:16:07 +02:00
|
|
|
|
|
|
|
variant.buildConfigField "boolean", "FOR_FDROID", "$forFDroid"
|
2017-01-18 16:01:25 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
flavorDimensions "variant"//, "abi"
|
|
|
|
productFlavors {
|
2017-09-24 23:32:58 +02:00
|
|
|
all {
|
|
|
|
buildConfigField "String", "BUILD_INFO_NAME", "\"${BUILD_INFO_NAME}\""
|
|
|
|
}
|
|
|
|
|
2017-01-18 16:01:25 +01:00
|
|
|
xw4 {
|
|
|
|
dimension "variant"
|
2017-05-23 15:37:31 +02:00
|
|
|
applicationId "org.eehouse.android.xw4"
|
2017-01-18 16:01:25 +01:00
|
|
|
manifestPlaceholders = [ APP_ID: applicationId ]
|
|
|
|
resValue "string", "app_name", "CrossWords"
|
|
|
|
resValue "string", "nbs_port", "3344"
|
|
|
|
resValue "string", "invite_prefix", "/and/"
|
2017-01-20 16:56:03 +01:00
|
|
|
buildConfigField "boolean", "WIDIR_ENABLED", "false"
|
2017-07-24 01:45:14 +02:00
|
|
|
buildConfigField "boolean", "RELAYINVITE_SUPPORTED", "false"
|
2017-09-24 23:30:59 +02:00
|
|
|
|
|
|
|
buildConfigField "String", "GCM_SENDER_ID", "\"$GCM_SENDER_ID\""
|
2017-01-18 16:01:25 +01:00
|
|
|
}
|
2017-05-23 15:37:31 +02:00
|
|
|
xw4d {
|
2017-01-18 16:01:25 +01:00
|
|
|
dimension "variant"
|
2017-06-21 06:45:44 +02:00
|
|
|
minSdkVersion 8
|
2017-05-23 15:37:31 +02:00
|
|
|
applicationId "org.eehouse.android.xw4dbg"
|
2017-06-21 06:45:44 +02:00
|
|
|
manifestPlaceholders = [ FABRIC_API_KEY: "$FABRIC_API_KEY", APP_ID: applicationId, ]
|
2017-01-18 16:01:25 +01:00
|
|
|
resValue "string", "app_name", "CrossDbg"
|
|
|
|
resValue "string", "nbs_port", "3345"
|
|
|
|
resValue "string", "invite_prefix", "/anddbg/"
|
2017-01-20 16:56:03 +01:00
|
|
|
buildConfigField "boolean", "WIDIR_ENABLED", "true"
|
2017-07-24 01:45:14 +02:00
|
|
|
buildConfigField "boolean", "RELAYINVITE_SUPPORTED", "true"
|
2017-09-24 23:30:59 +02:00
|
|
|
|
|
|
|
buildConfigField "String", "GCM_SENDER_ID", "\"\""
|
2017-01-18 16:01:25 +01: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-23 00:27:35 +01: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 16:01:25 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
buildTypes {
|
|
|
|
release {
|
|
|
|
debuggable false
|
2017-01-19 06:27:48 +01:00
|
|
|
minifyEnabled false // PENDING
|
2017-07-19 15:27:56 +02:00
|
|
|
// proguard crashes when I do this (the optimize part)
|
|
|
|
// proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
|
2017-01-18 16:01:25 +01:00
|
|
|
}
|
|
|
|
debug {
|
|
|
|
debuggable true
|
2017-07-12 16:16:57 +02:00
|
|
|
minifyEnabled true // for testing
|
|
|
|
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
|
2017-01-18 16:01:25 +01:00
|
|
|
// 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 17:10:16 +01:00
|
|
|
xw4 {
|
|
|
|
release {
|
2017-06-01 16:41:51 +02:00
|
|
|
jniLibs.srcDir "../libs-xw4Release"
|
2017-01-19 17:10:16 +01:00
|
|
|
}
|
|
|
|
debug {
|
2017-06-01 16:41:51 +02:00
|
|
|
jniLibs.srcDir "../libs-xw4Debug"
|
2017-01-19 17:10:16 +01:00
|
|
|
}
|
2017-01-18 16:01:25 +01:00
|
|
|
}
|
2017-05-23 15:37:31 +02:00
|
|
|
xw4d {
|
2017-01-19 17:10:16 +01:00
|
|
|
release {
|
2017-06-01 16:41:51 +02:00
|
|
|
jniLibs.srcDir "../libs-xw4dRelease"
|
2017-01-19 17:10:16 +01:00
|
|
|
}
|
|
|
|
debug {
|
2017-06-01 16:41:51 +02:00
|
|
|
jniLibs.srcDir "../libs-xw4dDebug"
|
2017-01-19 17:10:16 +01:00
|
|
|
}
|
2017-01-18 16:01:25 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
lintOptions {
|
|
|
|
abortOnError false
|
|
|
|
}
|
|
|
|
|
|
|
|
applicationVariants.all { variant ->
|
|
|
|
variant.outputs.each { output ->
|
2017-01-23 00:55:31 +01:00
|
|
|
def newName = output.outputFile.name
|
2017-01-23 01:22:35 +01:00
|
|
|
newName = newName.replace(".apk","-${GITREV}.apk")
|
2017-01-23 00:55:31 +01:00
|
|
|
newName = newName.replace("app-","")
|
|
|
|
output.outputFile = new File(output.outputFile.parent, newName)
|
2017-01-18 16:01:25 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
dependencies {
|
2017-01-19 04:03:36 +01:00
|
|
|
// Look into replacing this with a fetch too PENDING
|
|
|
|
compile files('../libs/gcm.jar')
|
|
|
|
|
2017-02-04 17:12:40 +01:00
|
|
|
compile 'com.android.support:support-v4:23.4.0'
|
2017-01-19 04:03:36 +01:00
|
|
|
|
2017-06-21 06:45:44 +02:00
|
|
|
xw4dCompile('com.crashlytics.sdk.android:crashlytics:2.6.8@aar') {
|
|
|
|
transitive = true;
|
|
|
|
}
|
2017-01-18 16:01:25 +01: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 {
|
2017-06-01 16:41:51 +02:00
|
|
|
ArrayList<String> cleanCmdLst = new ArrayList<>(["rm", "-rf"]);
|
|
|
|
android.applicationVariants.all { variant ->
|
|
|
|
// print "variant: " + variant.name + "\n"
|
|
|
|
String BUILD = variant.getBuildType().getName()
|
|
|
|
// print "type: " + BUILD + "\n"
|
|
|
|
String FLAVOR = variant.getFlavorName()
|
|
|
|
// print "flavor: " + variant.getFlavorName() + "\n"
|
|
|
|
// print "variant: " + variant + "\n"
|
|
|
|
|
|
|
|
String variantCaps = variant.name.capitalize()
|
|
|
|
String nameLC = variant.getBuildType().getName().toLowerCase()
|
|
|
|
String lib = "libs-${variant.name}"
|
|
|
|
String ndkBuildTask = "ndkBuild${variantCaps}"
|
|
|
|
task "$ndkBuildTask"(type: Exec) {
|
2017-01-18 16:01:25 +01:00
|
|
|
workingDir '../'
|
|
|
|
commandLine './scripts/ndkbuild.sh', '-j3',
|
|
|
|
"BUILD_TARGET=${nameLC}", "INITIAL_CLIENT_VERS=$INITIAL_CLIENT_VERS",
|
2017-06-01 16:41:51 +02:00
|
|
|
"VARIANT=${FLAVOR}", "NDK_LIBS_OUT=${lib}",
|
|
|
|
"NDK_OUT=./obj-${variant.name}"
|
2017-01-18 16:01:25 +01:00
|
|
|
}
|
|
|
|
|
2017-06-01 16:41:51 +02:00
|
|
|
String compileTask = "compile${variantCaps}Ndk"
|
|
|
|
tasks.getByName(compileTask).dependsOn ndkBuildTask
|
|
|
|
|
|
|
|
// For clean task
|
|
|
|
cleanCmdLst.add("libs-${variant.name}")
|
|
|
|
cleanCmdLst.add("./obj-${variant.name}")
|
2017-01-18 16:01:25 +01:00
|
|
|
}
|
|
|
|
|
2017-06-01 16:41:51 +02:00
|
|
|
task cleanNDK(type: Exec) {
|
|
|
|
workingDir '../'
|
|
|
|
commandLine cleanCmdLst
|
|
|
|
}
|
|
|
|
clean.dependsOn 'cleanNDK'
|
|
|
|
|
2017-05-23 15:37:31 +02:00
|
|
|
String copyStringsTask = "copyStringsXw4D"
|
2017-01-18 16:01:25 +01:00
|
|
|
task "$copyStringsTask"(type: Exec) {
|
|
|
|
workingDir './'
|
|
|
|
environment.put('APPNAME', 'CrossDbg')
|
|
|
|
commandLine 'make', '-f', '../scripts/Variant.mk',
|
2017-05-23 15:37:31 +02:00
|
|
|
"src/xw4d/res/values/strings.xml"
|
2017-01-18 16:01:25 +01:00
|
|
|
}
|
|
|
|
preBuild.dependsOn copyStringsTask
|
|
|
|
}
|
|
|
|
|
2017-05-24 16:09:11 +02:00
|
|
|
task makeBuildAssets() {
|
|
|
|
def assetsDir = android.sourceSets.main.assets.srcDirs.toArray()[0]
|
2017-09-24 23:32:58 +02:00
|
|
|
String path = new File(assetsDir, BUILD_INFO_NAME).getAbsolutePath()
|
2017-09-22 15:46:19 +02:00
|
|
|
String out = "git: ${GITREV}\n"
|
|
|
|
|
|
|
|
String diff = "git diff".execute().text.trim()
|
|
|
|
if (diff) {
|
|
|
|
out += "\n" + diff
|
|
|
|
}
|
2017-09-24 23:32:58 +02:00
|
|
|
new File(path).write(out)
|
2017-05-24 16:09:11 +02:00
|
|
|
}
|
2017-01-18 16:01:25 +01:00
|
|
|
|
2017-05-24 16:09:11 +02:00
|
|
|
gradle.projectsEvaluated {
|
|
|
|
build.dependsOn(makeBuildAssets)
|
|
|
|
}
|