mirror of
https://github.com/ankidroid/Anki-Android.git
synced 2024-09-20 03:52:15 +02:00
c344988170
* build(deps): ignore commons-compress below 1.25 now We are still not minSdkVersion >= API26 so we may not advance this dependency yet, we just notch this forward one version at a time so we continue to be aware of their releases, but ignore them for now * build(deps): bump androidx.annotation:annotation from 1.6.0 to 1.7.0 Bumps androidx.annotation:annotation from 1.6.0 to 1.7.0. --- updated-dependencies: - dependency-name: androidx.annotation:annotation dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> * build(deps): bump com.google.protobuf:protobuf-kotlin-lite Bumps com.google.protobuf:protobuf-kotlin-lite from 3.24.2 to 3.24.3. --- updated-dependencies: - dependency-name: com.google.protobuf:protobuf-kotlin-lite dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] <support@github.com> * build(deps): bump org.jlleitschuh.gradle.ktlint from 11.5.1 to 11.6.0 Bumps org.jlleitschuh.gradle.ktlint from 11.5.1 to 11.6.0. --- updated-dependencies: - dependency-name: org.jlleitschuh.gradle.ktlint dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> * build(deps): bump com.google.protobuf:protobuf-kotlin-lite Bumps com.google.protobuf:protobuf-kotlin-lite from 3.24.3 to 3.24.4. --- updated-dependencies: - dependency-name: com.google.protobuf:protobuf-kotlin-lite dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] <support@github.com> * build(deps): bump commons-io:commons-io from 2.13.0 to 2.14.0 Bumps commons-io:commons-io from 2.13.0 to 2.14.0. --- updated-dependencies: - dependency-name: commons-io:commons-io dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> * build(deps): bump io.mockk:mockk from 1.13.7 to 1.13.8 Bumps [io.mockk:mockk](https://github.com/mockk/mockk) from 1.13.7 to 1.13.8. - [Release notes](https://github.com/mockk/mockk/releases) - [Commits](https://github.com/mockk/mockk/compare/1.13.7...1.13.8) --- updated-dependencies: - dependency-name: io.mockk:mockk dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] <support@github.com> * Update Gradle Wrapper from 8.3 to 8.4. Signed-off-by: gradle-update-robot <gradle-update-robot@regolo.cc> * Only split APK build by ABI in release builds This avoids the upstream android gradle plugin issue introduced in AGPv8.1.2 (and seemingly fixed in AGBv8.3.0-alpha07) where doing an ABI split while including resources crashes the build: https://issuetracker.google.com/issues/302961829 If this causes problems or is distasteful, can be reverted when AGP v8.3+ is adopted, or if they do pick it to AGPv8.2+, at that time * Adopt android gradle plugin v8.1.2 * ignore dynamic receiver registrations without export-type specified these receivers *should* specify at registration whether they are for export or not for export but if that is added (such as in PR 14158) then there is also a need to add a new permission to the manifest or you get runtime errors, and we haven't figured that out yet * build(deps): bump org.jetbrains.dokka from 1.9.0 to 1.9.10 Bumps [org.jetbrains.dokka](https://github.com/Kotlin/dokka) from 1.9.0 to 1.9.10. - [Release notes](https://github.com/Kotlin/dokka/releases) - [Commits](https://github.com/Kotlin/dokka/compare/v1.9.0...v1.9.10) --- updated-dependencies: - dependency-name: org.jetbrains.dokka dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] <support@github.com> * build(deps): bump com.squareup.okhttp3:okhttp from 4.11.0 to 4.12.0 Bumps [com.squareup.okhttp3:okhttp](https://github.com/square/okhttp) from 4.11.0 to 4.12.0. - [Changelog](https://github.com/square/okhttp/blob/master/CHANGELOG.md) - [Commits](https://github.com/square/okhttp/compare/parent-4.11.0...parent-4.12.0) --- updated-dependencies: - dependency-name: com.squareup.okhttp3:okhttp dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> * build(deps): bump org.jlleitschuh.gradle.ktlint from 11.6.0 to 11.6.1 Bumps org.jlleitschuh.gradle.ktlint from 11.6.0 to 11.6.1. --- updated-dependencies: - dependency-name: org.jlleitschuh.gradle.ktlint dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] <support@github.com> * Bump compileSdk to 34, handle new deprecations (#14556) * Bump compileSdk to 34 * Alter system API overrides to handle newly nullable items in API34 Investigating the various changes led me to conclude that simple null checks and default returns if null was an adequate response to the newly-possible null case in the various parameters * API34 deprecates Class.newInstance, get ctor and newInstance that instead * use new API34 pixel calc style if available this apparently allows for finer more dynamic user text sizing * Temporarily suppress deprecation on animation overrides API34 adds new predictive back behavior, which implies that the transition animation overrides for activity stack change animations now need to know whether the animation override is for activity open or close, whereas we override both as a unit without thought This needs a solution before the deprecated methods go away, likely in the form of plumbing through (via a new parameter) the idea of whether the call site intended to override open, close, or both animations. For backwards compatibility this will likely need to be a Compat interface (or interfaces) to replace the current implementation * build(deps): bump androidx.webkit:webkit from 1.7.0 to 1.8.0 Bumps androidx.webkit:webkit from 1.7.0 to 1.8.0. --- updated-dependencies: - dependency-name: androidx.webkit:webkit dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> * build(deps): bump androidx.browser:browser from 1.5.0 to 1.6.0 Bumps androidx.browser:browser from 1.5.0 to 1.6.0. --- updated-dependencies: - dependency-name: androidx.browser:browser dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> * build(deps): bump androidx.activity:activity-ktx from 1.7.2 to 1.8.0 (#14515) * build(deps): bump androidx.activity:activity-ktx from 1.7.2 to 1.8.0 Bumps androidx.activity:activity-ktx from 1.7.2 to 1.8.0. --- updated-dependencies: - dependency-name: androidx.activity:activity-ktx dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> * call super.onBackPressed in onBackPressed overrides This is more "predictive back" feature fallout, this commit should be examined, and the behavior in these 4 objects may need a change, in order to more correctly deal with API34 predictive back --------- Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Mike Hardy <github@mikehardy.net> * build(deps): bump androidx.recyclerview:recyclerview from 1.3.1 to 1.3.2 Bumps androidx.recyclerview:recyclerview from 1.3.1 to 1.3.2. --- updated-dependencies: - dependency-name: androidx.recyclerview:recyclerview dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] <support@github.com> * build(deps): bump androidx.core:core-ktx from 1.10.1 to 1.12.0 (#14407) * build(deps): bump androidx.core:core-ktx from 1.10.1 to 1.12.0 Bumps androidx.core:core-ktx from 1.10.1 to 1.12.0. --- updated-dependencies: - dependency-name: androidx.core:core-ktx dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> * PendingIntentCompat.getBroadcast() is nullable now, wrap use of result in null checks It will only return null if we specify intent flags which we never specify, so our behavior does not need to change, but we must respect the type system by wrapping the use of the now-nullable result in null checks --------- Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Mike Hardy <github@mikehardy.net> * build(deps): bump androidx.sqlite:sqlite-framework from 2.3.1 to 2.4.0 Bumps androidx.sqlite:sqlite-framework from 2.3.1 to 2.4.0. --- updated-dependencies: - dependency-name: androidx.sqlite:sqlite-framework dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> * build(deps): bump androidx.appcompat:appcompat Bumps androidx.appcompat:appcompat from 1.7.0-alpha02 to 1.7.0-alpha03. --- updated-dependencies: - dependency-name: androidx.appcompat:appcompat dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] <support@github.com> --------- Signed-off-by: dependabot[bot] <support@github.com> Signed-off-by: gradle-update-robot <gradle-update-robot@regolo.cc> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: gradle-update-robot <gradle-update-robot@regolo.cc>
152 lines
7.4 KiB
Groovy
152 lines
7.4 KiB
Groovy
import org.gradle.internal.jvm.Jvm
|
|
|
|
// Top-level build file where you can add configuration options common to all sub-projects/modules.
|
|
buildscript {
|
|
// The version for the Kotlin plugin and dependencies
|
|
// If changing this, make sure to update org.jetbrains.kotlin.plugin.serialization version too
|
|
ext.kotlin_version = '1.9.10'
|
|
ext.lint_version = '31.1.1'
|
|
ext.acra_version = '5.11.2'
|
|
ext.ankidroid_backend_version = '0.1.26-anki23.10beta'
|
|
ext.hamcrest_version = '2.2'
|
|
ext.junit_version = '5.10.0'
|
|
ext.coroutines_version = '1.7.3'
|
|
ext.fragments_version = "1.6.1"
|
|
ext.espresso_version = '3.5.1'
|
|
ext.androidx_test_version = '1.5.0'
|
|
ext.androidx_test_junit_version = '1.1.5'
|
|
ext.robolectric_version = '4.10.3'
|
|
ext.android_gradle_plugin = "8.1.2"
|
|
ext.dokka_version = "1.9.10" // not the same with kotlin version!
|
|
|
|
configurations.all {
|
|
resolutionStrategy.eachDependency { details ->
|
|
if (details.requested.group == 'org.jetbrains.kotlinx'
|
|
&& details.requested.name.contains('kotlinx-serialization-runtime')
|
|
&& details.requested.version.contains('0.11.0')) {
|
|
details.useVersion "0.14.0"
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
plugins {
|
|
id 'com.android.application' version "$android_gradle_plugin" apply false
|
|
id 'com.android.library' version "$android_gradle_plugin" apply false
|
|
id 'org.jetbrains.kotlin.jvm' version "$kotlin_version" apply false
|
|
id 'org.jetbrains.kotlin.android' version "$kotlin_version" apply false
|
|
id 'org.jetbrains.kotlin.plugin.parcelize' version "$kotlin_version" apply false
|
|
id 'org.jetbrains.kotlin.plugin.serialization' version "$kotlin_version" apply false
|
|
id 'org.jlleitschuh.gradle.ktlint' version '11.6.1' apply false
|
|
id 'org.jetbrains.dokka' version "$dokka_version" apply false
|
|
}
|
|
|
|
Properties localProperties = new Properties()
|
|
if (project.rootProject.file('local.properties').exists()) {
|
|
localProperties.load(project.rootProject.file('local.properties').newDataInputStream())
|
|
}
|
|
Boolean fatalWarnings = !(localProperties['fatal_warnings'] == "false")
|
|
|
|
// Here we extract per-module "best practices" settings to a single top-level evaluation
|
|
subprojects {
|
|
apply plugin: "org.jlleitschuh.gradle.ktlint"
|
|
|
|
afterEvaluate { project ->
|
|
if (project.hasProperty('android')) {
|
|
project.android.testOptions.unitTests {
|
|
includeAndroidResources = true
|
|
}
|
|
project.android.testOptions.unitTests.all {
|
|
// tell backend to avoid rollover time, and disable interval fuzzing
|
|
environment "ANKI_TEST_MODE", "1"
|
|
|
|
useJUnitPlatform()
|
|
testLogging {
|
|
events "failed", "skipped"
|
|
showStackTraces = true
|
|
exceptionFormat = "full"
|
|
}
|
|
|
|
maxParallelForks = gradleTestMaxParallelForks
|
|
forkEvery = 40
|
|
systemProperties['junit.jupiter.execution.parallel.enabled'] = true
|
|
systemProperties['junit.jupiter.execution.parallel.mode.default'] = "concurrent"
|
|
}
|
|
}
|
|
|
|
/**
|
|
Kotlin allows concrete function implementations inside interfaces.
|
|
For those to work when Kotlin compilation targets the JVM backend, you have to enable the interoperability via
|
|
'freeCompilerArgs' in your gradle file, and you have to choose one of the appropriate '-Xjvm-default' modes.
|
|
|
|
https://kotlinlang.org/docs/java-to-kotlin-interop.html#default-methods-in-interfaces
|
|
|
|
and we used "all" because we don't have downstream consumers
|
|
https://docs.gradle.org/current/userguide/task_configuration_avoidance.html
|
|
|
|
Related to ExperimentalCoroutinesApi: this opt-in is added to enable usage of experimental
|
|
coroutines API, this targets all project modules with the exception of the "api" module,
|
|
which doesn't use coroutines so the annotation isn't not available. This would normally
|
|
result in a warning but we treat warnings as errors.
|
|
(see https://youtrack.jetbrains.com/issue/KT-28777/Using-experimental-coroutines-api-causes-unresolved-dependency)
|
|
*/
|
|
tasks.withType(org.jetbrains.kotlin.gradle.tasks.KotlinCompile).all {
|
|
kotlinOptions {
|
|
allWarningsAsErrors = fatalWarnings
|
|
def compilerArgs = ['-Xjvm-default=all']
|
|
if (project.name != "api") {
|
|
compilerArgs += ['-opt-in=kotlinx.coroutines.ExperimentalCoroutinesApi']
|
|
}
|
|
freeCompilerArgs = compilerArgs
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
ext {
|
|
|
|
jvmVersion = Jvm.current().javaVersion.majorVersion
|
|
if (jvmVersion != "17" && jvmVersion != "18") {
|
|
println "\n\n\n"
|
|
println "**************************************************************************************************************"
|
|
println "\n\n\n"
|
|
println "ERROR: AnkiDroid builds with JVM version 17 or 18."
|
|
println " Incompatible major version detected: '" + jvmVersion + "'"
|
|
println "\n\n\n"
|
|
println " If you receive this error because you want to use a newer JDK, we may accept PRs to support new versions."
|
|
println " Edit the main build.gradle file, find this message in the file, and add support for the new version."
|
|
println " Please make sure the `jacocoTestReport` target works on an emulator with our minSdkVersion (currently 21)."
|
|
println "\n\n\n"
|
|
println "**************************************************************************************************************"
|
|
println "\n\n\n"
|
|
System.exit(1)
|
|
}
|
|
ciBuild = System.getenv("CI") == "true" // works for Travis CI or Github Actions
|
|
// allows for -Dpre-dex=false to be set
|
|
preDexEnabled = "true" == System.getProperty("pre-dex", "true")
|
|
// allows for universal APKs to be generated
|
|
universalApkEnabled = "true" == System.getProperty("universal-apk", "false")
|
|
|
|
if (System.getProperty("os.name") == "Mac OS X") {
|
|
// macOS reports hardware cores. This is accurate for CI, Intel (halved due to SMT) and Apple Silicon
|
|
gradleTestMaxParallelForks = "sysctl -n hw.physicalcpu".execute().text.toInteger()
|
|
} else if (ciBuild) {
|
|
// GitHub Actions (Standard_DS2_v2) are 1:1 on Linux/Windows with two vCPU cores
|
|
// Sources:
|
|
// Standard_DS2_v2 https://docs.github.com/en/actions/using-github-hosted-runners/about-github-hosted-runners#cloud-hosts-for-github-hosted-runners
|
|
// Which is 1:1 https://docs.microsoft.com/en-gb/azure/virtual-machines/acu : DS1_v2 - DS15_v2 | 1:1
|
|
gradleTestMaxParallelForks = 2
|
|
|
|
// separate gradle compile process is a major speed improvement, but consumes 2x RAM
|
|
// the CI machines don't have enough RAM to do that without going in to swap quite a bit
|
|
// so for CI machines only - to improve reliability despite compilation speed hit, compile kotlin in process
|
|
println "CI build detected: setting compiler execution strategy to IN_PROCESS"
|
|
tasks.withType(org.jetbrains.kotlin.gradle.tasks.KotlinCompile).configureEach {
|
|
compilerExecutionStrategy.set(org.jetbrains.kotlin.gradle.tasks.KotlinCompilerExecutionStrategy.IN_PROCESS)
|
|
}
|
|
} else {
|
|
// Use 50% of cores to account for SMT which doesn't help this workload
|
|
gradleTestMaxParallelForks = Runtime.runtime.availableProcessors().intdiv(2) ?: 1
|
|
}
|
|
}
|