build.gradle.kts 8.5 KB

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