2014-08-09 22:41:29 +02:00
|
|
|
android {
|
2017-04-13 21:40:57 +02:00
|
|
|
buildToolsVersion '25.0.0'
|
|
|
|
compileSdkVersion 24
|
2014-08-09 22:41:29 +02:00
|
|
|
sourceSets {
|
|
|
|
main {
|
|
|
|
manifest.srcFile 'AndroidManifest.xml'
|
|
|
|
java.srcDirs = ['src']
|
|
|
|
aidl.srcDirs = ['src']
|
|
|
|
renderscript.srcDirs = ['src']
|
|
|
|
res.srcDirs = ['res']
|
|
|
|
assets.srcDirs = ['assets']
|
2017-04-13 22:01:57 +02:00
|
|
|
jniLibs.srcDirs = ['libs']
|
2014-08-09 22:41:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
instrumentTest.setRoot('tests')
|
|
|
|
}
|
|
|
|
}
|
2017-04-13 22:01:57 +02:00
|
|
|
|
|
|
|
|
2014-08-09 22:41:29 +02:00
|
|
|
// called every time gradle gets executed, takes the native dependencies of
|
|
|
|
// the natives configuration, and extracts them to the proper libs/ folders
|
|
|
|
// so they get packed with the APK.
|
2017-04-13 21:40:57 +02:00
|
|
|
task copyAndroidNatives() {
|
2014-08-09 22:41:29 +02:00
|
|
|
file("libs/armeabi/").mkdirs();
|
|
|
|
file("libs/armeabi-v7a/").mkdirs();
|
|
|
|
file("libs/x86/").mkdirs();
|
|
|
|
|
|
|
|
configurations.natives.files.each { jar ->
|
|
|
|
def outputDir = null
|
2017-04-13 22:01:57 +02:00
|
|
|
if(jar.name.endsWith("natives-armeabi-v7a.jar")) outputDir = file("libs/armeabi-v7a")
|
|
|
|
if(jar.name.endsWith("natives-armeabi.jar")) outputDir = file("libs/armeabi")
|
|
|
|
if(jar.name.endsWith("natives-x86.jar")) outputDir = file("libs/x86")
|
|
|
|
if(outputDir != null) {
|
2014-08-09 22:41:29 +02:00
|
|
|
copy {
|
|
|
|
from zipTree(jar)
|
|
|
|
into outputDir
|
|
|
|
include "*.so"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2017-04-13 22:01:57 +02:00
|
|
|
|
2014-08-09 22:41:29 +02:00
|
|
|
task run(type: Exec) {
|
|
|
|
def path
|
|
|
|
def localProperties = project.file("../local.properties")
|
|
|
|
if (localProperties.exists()) {
|
|
|
|
Properties properties = new Properties()
|
|
|
|
localProperties.withInputStream { instr ->
|
|
|
|
properties.load(instr)
|
|
|
|
}
|
|
|
|
def sdkDir = properties.getProperty('sdk.dir')
|
|
|
|
if (sdkDir) {
|
|
|
|
path = sdkDir
|
|
|
|
} else {
|
|
|
|
path = "$System.env.ANDROID_HOME"
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
path = "$System.env.ANDROID_HOME"
|
|
|
|
}
|
|
|
|
|
|
|
|
def adb = path + "/platform-tools/adb"
|
|
|
|
commandLine "$adb", 'shell', 'am', 'start', '-n', 'de.samdev.colorrunner.android/de.samdev.colorrunner.android.AndroidLauncher'
|
|
|
|
}
|
2017-04-13 22:01:57 +02:00
|
|
|
|
2014-08-09 22:41:29 +02:00
|
|
|
// sets up the Android Eclipse project, using the old Ant based build.
|
|
|
|
eclipse {
|
|
|
|
// need to specify Java source sets explicitely, SpringSource Gradle Eclipse plugin
|
|
|
|
// ignores any nodes added in classpath.file.withXml
|
|
|
|
sourceSets {
|
|
|
|
main {
|
|
|
|
java.srcDirs "src", 'gen'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
jdt {
|
|
|
|
sourceCompatibility = 1.6
|
|
|
|
targetCompatibility = 1.6
|
|
|
|
}
|
|
|
|
|
|
|
|
classpath {
|
2017-04-13 22:01:57 +02:00
|
|
|
plusConfigurations += [ project.configurations.compile ]
|
2017-04-13 21:40:57 +02:00
|
|
|
containers 'com.android.ide.eclipse.adt.ANDROID_FRAMEWORK', 'com.android.ide.eclipse.adt.LIBRARIES'
|
2014-08-09 22:41:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
project {
|
|
|
|
name = appName + "-android"
|
|
|
|
natures 'com.android.ide.eclipse.adt.AndroidNature'
|
|
|
|
buildCommands.clear();
|
|
|
|
buildCommand "com.android.ide.eclipse.adt.ResourceManagerBuilder"
|
|
|
|
buildCommand "com.android.ide.eclipse.adt.PreCompilerBuilder"
|
|
|
|
buildCommand "org.eclipse.jdt.core.javabuilder"
|
|
|
|
buildCommand "com.android.ide.eclipse.adt.ApkBuilder"
|
|
|
|
}
|
|
|
|
}
|
2017-04-13 22:01:57 +02:00
|
|
|
|
2014-08-09 22:41:29 +02:00
|
|
|
// sets up the Android Idea project, using the old Ant based build.
|
|
|
|
idea {
|
|
|
|
module {
|
|
|
|
sourceDirs += file("src");
|
2017-04-13 22:01:57 +02:00
|
|
|
scopes = [ COMPILE: [plus:[project.configurations.compile]]]
|
2014-08-09 22:41:29 +02:00
|
|
|
|
|
|
|
iml {
|
|
|
|
withXml {
|
|
|
|
def node = it.asNode()
|
|
|
|
def builder = NodeBuilder.newInstance();
|
|
|
|
builder.current = node;
|
|
|
|
builder.component(name: "FacetManager") {
|
|
|
|
facet(type: "android", name: "Android") {
|
|
|
|
configuration {
|
2017-04-13 22:01:57 +02:00
|
|
|
option(name: "UPDATE_PROPERTY_FILES", value:"true")
|
2014-08-09 22:41:29 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2017-04-13 22:01:57 +02:00
|
|
|
}
|