build.gradle.kts 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. import java.util.*
  2. plugins {
  3. id("com.android.application")
  4. kotlin("android")
  5. kotlin("kapt")
  6. }
  7. android {
  8. compileSdk = buildTargetSdkVersion
  9. flavorDimensions(buildFlavor)
  10. defaultConfig {
  11. applicationId = "com.github.kr328.clash"
  12. minSdk = buildMinSdkVersion
  13. targetSdk = buildTargetSdkVersion
  14. versionCode = buildVersionCode
  15. versionName = buildVersionName
  16. resConfigs("zh-rCN", "zh-rHK", "zh-rTW")
  17. resValue("string", "release_name", "v$buildVersionName")
  18. resValue("integer", "release_code", "$buildVersionCode")
  19. }
  20. packagingOptions {
  21. exclude("DebugProbesKt.bin")
  22. }
  23. buildTypes {
  24. named("release") {
  25. isMinifyEnabled = true
  26. isShrinkResources = true
  27. proguardFiles(
  28. getDefaultProguardFile("proguard-android-optimize.txt"),
  29. "proguard-rules.pro"
  30. )
  31. }
  32. }
  33. productFlavors {
  34. create("foss") {
  35. dimension = "foss"
  36. versionNameSuffix = ".foss"
  37. applicationIdSuffix = ".foss"
  38. }
  39. create("premium") {
  40. dimension = "premium"
  41. versionNameSuffix = ".premium"
  42. if (buildFlavor == "premium") {
  43. val localFile = rootProject.file("local.properties")
  44. if (localFile.exists()) {
  45. val appCenterKey = localFile.inputStream()
  46. .use { Properties().apply { load(it) } }
  47. .getProperty("appcenter.key", null)
  48. if (appCenterKey != null) {
  49. buildConfigField("String", "APP_CENTER_KEY", "\"$appCenterKey\"")
  50. } else {
  51. buildConfigField("String", "APP_CENTER_KEY", "null")
  52. }
  53. } else {
  54. buildConfigField("String", "APP_CENTER_KEY", "null")
  55. }
  56. }
  57. }
  58. }
  59. val signingFile = rootProject.file("keystore.properties")
  60. if (signingFile.exists()) {
  61. val properties = Properties().apply {
  62. signingFile.inputStream().use {
  63. load(it)
  64. }
  65. }
  66. signingConfigs {
  67. create("release") {
  68. storeFile = rootProject.file(properties.getProperty("storeFile")!!)
  69. storePassword = properties.getProperty("storePassword")!!
  70. keyAlias = properties.getProperty("keyAlias")!!
  71. keyPassword = properties.getProperty("keyPassword")!!
  72. }
  73. }
  74. buildTypes {
  75. named("release") {
  76. signingConfig = signingConfigs["release"]
  77. }
  78. }
  79. }
  80. buildFeatures {
  81. dataBinding = true
  82. }
  83. compileOptions {
  84. sourceCompatibility = JavaVersion.VERSION_1_8
  85. targetCompatibility = JavaVersion.VERSION_1_8
  86. }
  87. kotlinOptions {
  88. jvmTarget = "1.8"
  89. }
  90. splits {
  91. abi {
  92. isEnable = true
  93. isUniversalApk = true
  94. }
  95. }
  96. }
  97. dependencies {
  98. val premiumImplementation by configurations
  99. api(project(":core"))
  100. api(project(":service"))
  101. api(project(":design"))
  102. api(project(":common"))
  103. premiumImplementation("com.microsoft.appcenter:appcenter-analytics:$appcenterVersion")
  104. premiumImplementation("com.microsoft.appcenter:appcenter-crashes:$appcenterVersion")
  105. implementation(kotlin("stdlib-jdk7"))
  106. implementation("org.jetbrains.kotlinx:kotlinx-coroutines-android:$coroutineVersion")
  107. implementation("androidx.core:core-ktx:$coreVersion")
  108. implementation("androidx.activity:activity:$activityVersion")
  109. implementation("androidx.appcompat:appcompat:$appcompatVersion")
  110. implementation("androidx.coordinatorlayout:coordinatorlayout:$coordinatorlayoutVersion")
  111. implementation("androidx.recyclerview:recyclerview:$recyclerviewVersion")
  112. implementation("androidx.fragment:fragment:$fragmentVersion")
  113. implementation("com.google.android.material:material:$materialVersion")
  114. }
  115. task("cleanRelease", type = Delete::class) {
  116. delete(file("release"))
  117. }
  118. afterEvaluate {
  119. tasks["clean"].dependsOn(tasks["cleanRelease"])
  120. }