build.gradle.kts 8.1 KB

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