apply plugin: 'android-sdk-manager' apply plugin: 'com.android.application' apply plugin: 'spoon' apply plugin: 'kotlin-android' apply plugin: 'kotlin-android-extensions' apply plugin: 'kotlin-kapt' apply plugin: 'de.mobilej.unmock' apply plugin: 'com.github.ben-manes.versions' repositories { jcenter() mavenLocal() maven { url 'https://jitpack.io' } } android { compileSdkVersion 25 buildToolsVersion "25.0.1" defaultConfig { versionCode 330 versionName "3.3.0" minSdkVersion 9 targetSdkVersion 25 applicationId "org.ligi.passandroid" testInstrumentationRunner "org.ligi.passandroid.AppReplacingRunner" archivesBaseName = "PassAndroid-$versionName" vectorDrawables.useSupportLibrary = true } flavorDimensions "maps", "analytics", "distribution" productFlavors { withMaps { dimension "maps" } noMaps { dimension "maps" } withAnalytics { dimension "analytics" } noAnalytics { dimension "analytics" } forFDroid { dimension "distribution" } forPlay { dimension "distribution" } } packagingOptions { // needed for assertJ exclude 'asm-license.txt' exclude 'LICENSE' exclude 'NOTICE' // hack for instrumentation testing :-( exclude 'LICENSE.txt' exclude 'META-INF/maven/com.google.guava/guava/pom.properties' exclude 'META-INF/maven/com.google.guava/guava/pom.xml' } lintOptions { warning 'MissingTranslation' warning 'InvalidPackage' } buildTypes { release { minifyEnabled true shrinkResources true proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-project.txt' } } } dependencies { compile "com.google.dagger:dagger:$dagger_version" kapt "com.google.dagger:dagger-compiler:$dagger_version" compile 'com.github.hotchemi:permissionsdispatcher:2.2.0' kapt 'com.github.hotchemi:permissionsdispatcher-processor:2.2.0' provided 'org.glassfish:javax.annotation:10.0-b28' kaptAndroidTest "com.google.dagger:dagger-compiler:$dagger_version" androidTestCompile "com.android.support:support-annotations:$support_version" androidTestCompile('com.github.ligi:trulesk:0.8') { // http://stackoverflow.com/questions/30578243/why-would-adding-espresso-contrib-cause-an-inflateexception exclude group: 'javax.inject' } androidTestCompile('com.android.support.test.espresso:espresso-contrib:2.2.2') { // http://stackoverflow.com/questions/30578243/why-would-adding-espresso-contrib-cause-an-inflateexception exclude group: 'com.android.support', module: 'appcompat' exclude group: 'com.android.support', module: 'support-v4' exclude group: 'javax.inject' exclude module: 'recyclerview-v7' } androidTestCompile('com.android.support.test.espresso:espresso-web:2.2.2') { // http://stackoverflow.com/questions/30578243/why-would-adding-espresso-contrib-cause-an-inflateexception exclude group: 'javax.inject' } androidTestCompile 'com.squareup.assertj:assertj-android:1.1.1' androidTestCompile 'org.mockito:mockito-core:1.9.5' androidTestCompile 'com.google.dexmaker:dexmaker-mockito:1.2' androidTestCompile "com.android.support:appcompat-v7:$support_version" androidTestCompile "com.android.support:design:$support_version" androidTestCompile 'com.google.code.findbugs:jsr305:3.0.1' compile 'com.github.ligi:TouchImageView:2.1' compile 'com.github.ligi:ExtraCompats:0.4' compile 'net.lingala.zip4j:zip4j:1.3.2' compile 'com.jakewharton.threetenabp:threetenabp:1.0.4' compile 'org.greenrobot:eventbus:3.0.0' compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" compile "org.jetbrains.kotlin:kotlin-runtime:$kotlin_version" compile "com.android.support:support-annotations:$support_version" compile "com.android.support:recyclerview-v7:$support_version" compile "com.android.support:appcompat-v7:$support_version" compile "com.android.support:cardview-v7:$support_version" compile "com.android.support:design:$support_version" compile "com.android.support:preference-v7:$support_version" compile 'net.i2p.android.ext:floatingactionbutton:1.10.1' compile 'com.github.ligi:KAXT:0.8' compile 'com.github.ligi:loadtoast:1.10.11' compile 'com.github.ligi:tracedroid:1.4' compile 'com.github.ligi:snackengage:0.9' compile 'com.squareup.okhttp3:okhttp:3.4.2' compile 'com.larswerkman:HoloColorPicker:1.5' compile 'com.google.code.findbugs:jsr305:3.0.1' compile 'com.squareup.moshi:moshi:1.2.0' compile 'com.chibatching:kotpref:1.4.0' testCompile "com.android.support:support-annotations:$support_version" testCompile 'com.squareup.assertj:assertj-android:1.1.1' testCompile 'junit:junit:4.12' testCompile 'org.mockito:mockito-core:1.9.5' testCompile 'org.threeten:threetenbp:1.3.2' // cannot use this new version: https://github.com/zxing/zxing/issues/165 // WARNING: might work on some devices or the emulator - but fails on others compile 'com.google.zxing:core:3.3.0' //compile fileTree(dir: 'libs', include: 'zxing-core-2.3.0-SNAPSHOT.jar') debugCompile 'com.squareup.leakcanary:leakcanary-android:1.4' releaseCompile 'com.squareup.leakcanary:leakcanary-android-no-op:1.4' withAnalyticsCompile "com.google.android.gms:play-services-analytics:$play_version" withMapsCompile "com.google.android.gms:play-services-maps:$play_version" } spoon { debug = true grantAllPermissions = true }