build.gradle.kts 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289
  1. import org.gradle.api.tasks.testing.logging.TestLogEvent
  2. import org.jetbrains.kotlin.gradle.tasks.KotlinCompile
  3. plugins {
  4. id("com.android.application")
  5. id("com.mikepenz.aboutlibraries.plugin")
  6. kotlin("android")
  7. kotlin("plugin.serialization")
  8. id("com.github.zellius.shortcut-helper")
  9. }
  10. if (gradle.startParameter.taskRequests.toString().contains("Standard")) {
  11. apply<com.google.gms.googleservices.GoogleServicesPlugin>()
  12. }
  13. shortcutHelper.setFilePath("./shortcuts.xml")
  14. val SUPPORTED_ABIS = setOf("armeabi-v7a", "arm64-v8a", "x86")
  15. android {
  16. compileSdk = AndroidConfig.compileSdk
  17. ndkVersion = AndroidConfig.ndk
  18. defaultConfig {
  19. applicationId = "eu.kanade.tachiyomi"
  20. minSdk = AndroidConfig.minSdk
  21. targetSdk = AndroidConfig.targetSdk
  22. versionCode = 81
  23. versionName = "0.13.5"
  24. buildConfigField("String", "COMMIT_COUNT", "\"${getCommitCount()}\"")
  25. buildConfigField("String", "COMMIT_SHA", "\"${getGitSha()}\"")
  26. buildConfigField("String", "BUILD_TIME", "\"${getBuildTime()}\"")
  27. buildConfigField("boolean", "INCLUDE_UPDATER", "false")
  28. buildConfigField("boolean", "PREVIEW", "false")
  29. // Please disable ACRA or use your own instance in forked versions of the project
  30. buildConfigField("String", "ACRA_URI", "\"https://tachiyomi.kanade.eu/crash_report\"")
  31. ndk {
  32. abiFilters += SUPPORTED_ABIS
  33. }
  34. testInstrumentationRunner = "androidx.test.runner.AndroidJUnitRunner"
  35. }
  36. splits {
  37. abi {
  38. isEnable = true
  39. reset()
  40. include(*SUPPORTED_ABIS.toTypedArray())
  41. isUniversalApk = true
  42. }
  43. }
  44. buildTypes {
  45. named("debug") {
  46. versionNameSuffix = "-${getCommitCount()}"
  47. applicationIdSuffix = ".debug"
  48. }
  49. named("release") {
  50. isShrinkResources = true
  51. isMinifyEnabled = true
  52. proguardFiles("proguard-android-optimize.txt", "proguard-rules.pro")
  53. }
  54. create("preview") {
  55. initWith(getByName("release"))
  56. buildConfigField("boolean", "PREVIEW", "true")
  57. val debugType = getByName("debug")
  58. signingConfig = debugType.signingConfig
  59. versionNameSuffix = debugType.versionNameSuffix
  60. applicationIdSuffix = debugType.applicationIdSuffix
  61. }
  62. }
  63. sourceSets {
  64. getByName("preview").res.srcDirs("src/debug/res")
  65. }
  66. flavorDimensions.add("default")
  67. productFlavors {
  68. create("standard") {
  69. buildConfigField("boolean", "INCLUDE_UPDATER", "true")
  70. dimension = "default"
  71. }
  72. create("dev") {
  73. resourceConfigurations.addAll(listOf("en", "xxhdpi"))
  74. dimension = "default"
  75. }
  76. }
  77. packagingOptions {
  78. resources.excludes.addAll(listOf(
  79. "META-INF/DEPENDENCIES",
  80. "LICENSE.txt",
  81. "META-INF/LICENSE",
  82. "META-INF/LICENSE.txt",
  83. "META-INF/README.md",
  84. "META-INF/NOTICE",
  85. "META-INF/*.kotlin_module",
  86. "META-INF/*.version",
  87. ))
  88. }
  89. dependenciesInfo {
  90. includeInApk = false
  91. }
  92. buildFeatures {
  93. viewBinding = true
  94. // Disable some unused things
  95. aidl = false
  96. renderScript = false
  97. shaders = false
  98. }
  99. lint {
  100. disable.addAll(listOf("MissingTranslation", "ExtraTranslation"))
  101. abortOnError = false
  102. checkReleaseBuilds = false
  103. }
  104. compileOptions {
  105. sourceCompatibility = JavaVersion.VERSION_1_8
  106. targetCompatibility = JavaVersion.VERSION_1_8
  107. }
  108. kotlinOptions {
  109. jvmTarget = JavaVersion.VERSION_1_8.toString()
  110. }
  111. }
  112. dependencies {
  113. implementation(kotlinx.reflect)
  114. implementation(kotlinx.bundles.coroutines)
  115. // Source models and interfaces from Tachiyomi 1.x
  116. implementation(libs.tachiyomi.api)
  117. // AndroidX libraries
  118. implementation(androidx.annotation)
  119. implementation(androidx.appcompat)
  120. implementation(androidx.biometricktx)
  121. implementation(androidx.constraintlayout)
  122. implementation(androidx.coordinatorlayout)
  123. implementation(androidx.corektx)
  124. implementation(androidx.splashscreen)
  125. implementation(androidx.recyclerview)
  126. implementation(androidx.swiperefreshlayout)
  127. implementation(androidx.viewpager)
  128. implementation(androidx.bundles.lifecycle)
  129. // Job scheduling
  130. implementation(androidx.bundles.workmanager)
  131. // RX
  132. implementation(libs.bundles.reactivex)
  133. implementation(libs.flowreactivenetwork)
  134. // Network client
  135. implementation(libs.bundles.okhttp)
  136. implementation(libs.okio)
  137. // TLS 1.3 support for Android < 10
  138. implementation(libs.conscrypt.android)
  139. // Data serialization (JSON, protobuf)
  140. implementation(kotlinx.bundles.serialization)
  141. // JavaScript engine
  142. implementation(libs.bundles.js.engine)
  143. // HTML parser
  144. implementation(libs.jsoup)
  145. // Disk
  146. implementation(libs.disklrucache)
  147. implementation(libs.unifile)
  148. implementation(libs.junrar)
  149. // Database
  150. implementation(libs.bundles.sqlite)
  151. implementation("com.github.inorichi.storio:storio-common:8be19de@aar")
  152. implementation("com.github.inorichi.storio:storio-sqlite:8be19de@aar")
  153. // Preferences
  154. implementation(libs.preferencektx)
  155. implementation(libs.flowpreferences)
  156. // Model View Presenter
  157. implementation(libs.bundles.nucleus)
  158. // Dependency injection
  159. implementation(libs.injekt.core)
  160. // Image loading
  161. implementation(libs.bundles.coil)
  162. implementation(libs.subsamplingscaleimageview) {
  163. exclude(module = "image-decoder")
  164. }
  165. implementation(libs.image.decoder)
  166. // Sort
  167. implementation(libs.natural.comparator)
  168. // UI libraries
  169. implementation(libs.material)
  170. implementation(libs.androidprocessbutton)
  171. implementation(libs.flexible.adapter.core)
  172. implementation(libs.flexible.adapter.ui)
  173. implementation(libs.viewstatepageradapter)
  174. implementation(libs.photoview)
  175. implementation(libs.directionalviewpager) {
  176. exclude(group = "androidx.viewpager", module = "viewpager")
  177. }
  178. implementation(libs.insetter)
  179. implementation(libs.markwon)
  180. // Conductor
  181. implementation(libs.bundles.conductor)
  182. // FlowBinding
  183. implementation(libs.bundles.flowbinding)
  184. // Logging
  185. implementation(libs.logcat)
  186. // Crash reports/analytics
  187. implementation(libs.acra.http)
  188. "standardImplementation"(libs.firebase.analytics)
  189. // Licenses
  190. implementation(libs.aboutlibraries.core)
  191. // Shizuku
  192. implementation(libs.bundles.shizuku)
  193. // Tests
  194. testImplementation(libs.junit)
  195. // For detecting memory leaks; see https://square.github.io/leakcanary/
  196. // debugImplementation(libs.leakcanary.android)
  197. }
  198. tasks {
  199. withType<Test> {
  200. useJUnitPlatform()
  201. testLogging {
  202. events(TestLogEvent.PASSED, TestLogEvent.SKIPPED, TestLogEvent.FAILED)
  203. }
  204. }
  205. // See https://kotlinlang.org/docs/reference/experimental.html#experimental-status-of-experimental-api(-markers)
  206. withType<KotlinCompile> {
  207. kotlinOptions.freeCompilerArgs += listOf(
  208. "-Xopt-in=kotlin.Experimental",
  209. "-Xopt-in=kotlin.RequiresOptIn",
  210. "-Xopt-in=kotlin.ExperimentalStdlibApi",
  211. "-Xopt-in=kotlinx.coroutines.FlowPreview",
  212. "-Xopt-in=kotlinx.coroutines.ExperimentalCoroutinesApi",
  213. "-Xopt-in=kotlinx.coroutines.InternalCoroutinesApi",
  214. "-Xopt-in=kotlinx.serialization.ExperimentalSerializationApi",
  215. "-Xopt-in=coil.annotation.ExperimentalCoilApi",
  216. )
  217. }
  218. // Duplicating Hebrew string assets due to some locale code issues on different devices
  219. val copyHebrewStrings = task("copyHebrewStrings", type = Copy::class) {
  220. from("./src/main/res/values-he")
  221. into("./src/main/res/values-iw")
  222. include("**/*")
  223. }
  224. preBuild {
  225. dependsOn(formatKotlin, copyHebrewStrings)
  226. }
  227. }
  228. buildscript {
  229. dependencies {
  230. classpath(kotlinx.gradle)
  231. }
  232. }