Skip to content

Commit 6baf7c8

Browse files
authored
Restore Android compatibility in Executor.asCoroutineDispatcher (#4396)
An Android compatibility trick was removed in #4196, and animal-sniffer was misconfigured and didn't catch that. With this change, animal-sniffer works once again, and the trick is restored.
1 parent dbca4c1 commit 6baf7c8

File tree

17 files changed

+110
-86
lines changed

17 files changed

+110
-86
lines changed

build.gradle.kts

Lines changed: 13 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -95,7 +95,19 @@ allprojects {
9595
}
9696

9797
// needs to be before evaluationDependsOn due to weird Gradle ordering
98-
apply(plugin = "animalsniffer-conventions")
98+
configure(subprojects) {
99+
fun Project.shouldSniff(): Boolean =
100+
platformOf(project) == "jvm" && project.name !in unpublished && project.name !in sourceless
101+
&& project.name !in androidNonCompatibleProjects
102+
// Skip JDK 8 projects or unpublished ones
103+
if (shouldSniff()) {
104+
if (isMultiplatform) {
105+
apply(plugin = "animalsniffer-multiplatform-conventions")
106+
} else {
107+
apply(plugin = "animalsniffer-jvm-conventions")
108+
}
109+
}
110+
}
99111

100112
configure(subprojects.filter { !sourceless.contains(it.name) }) {
101113
if (isMultiplatform) {
@@ -157,4 +169,3 @@ rootProject.registerTopLevelDeployTask()
157169

158170
// Report Kotlin compiler version when building project
159171
println("Using Kotlin compiler version: ${KotlinCompilerVersion.VERSION}")
160-

buildSrc/src/main/kotlin/AuxBuildConfiguration.kt

Lines changed: 0 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -13,7 +13,6 @@ object AuxBuildConfiguration {
1313
@JvmStatic
1414
fun configure(rootProject: Project) {
1515
rootProject.allprojects {
16-
workaroundForCleanTask()
1716
CacheRedirector.configure(this)
1817
workaroundForCoroutinesLeakageToClassPath()
1918
}
@@ -27,18 +26,6 @@ object AuxBuildConfiguration {
2726
}
2827
}
2928

30-
private fun Project.workaroundForCleanTask() {
31-
// the 'clean' task cannot delete expanded.lock file on Windows as it is still held by Gradle, failing the build
32-
// Gradle issue: https://github.com/gradle/gradle/issues/25752
33-
tasks {
34-
val clean by existing(Delete::class) {
35-
setDelete(fileTree(layout.buildDirectory) {
36-
exclude("tmp/.cache/expanded/expanded.lock")
37-
})
38-
}
39-
}
40-
}
41-
4229
/*
4330
* 'kotlinx-coroutines-core' dependency leaks into test runtime classpath via 'kotlin-compiler-embeddable'
4431
* and conflicts with our own test/runtime incompatibilities (e.g. when class is moved from a main to test),

buildSrc/src/main/kotlin/animalsniffer-conventions.gradle.kts

Lines changed: 0 additions & 39 deletions
This file was deleted.
Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,11 @@
1+
plugins {
2+
id("ru.vyarus.animalsniffer")
3+
}
4+
5+
project.plugins.withType(JavaPlugin::class.java) {
6+
val signature: Configuration by configurations
7+
dependencies {
8+
signature("net.sf.androidscents.signature:android-api-level-14:4.0_r4@signature")
9+
signature("org.codehaus.mojo.signature:java17:1.0@signature")
10+
}
11+
}
Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,11 @@
1+
plugins {
2+
id("ru.vyarus.animalsniffer")
3+
}
4+
5+
project.plugins.withType(KotlinMultiplatformConventionsPlugin::class.java) {
6+
val signature: Configuration by configurations
7+
dependencies {
8+
signature("net.sf.androidscents.signature:android-api-level-14:4.0_r4@signature")
9+
signature("org.codehaus.mojo.signature:java17:1.0@signature")
10+
}
11+
}

gradle.properties

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -28,7 +28,7 @@ jna_version=5.9.0
2828

2929
# Gradle
3030
jdk_toolchain_version=11
31-
animalsniffer_version=1.7.1
31+
animalsniffer_version=2.0.0
3232

3333
# Android versions
3434
android_version=4.1.1.4

gradle/wrapper/gradle-wrapper.jar

243 Bytes
Binary file not shown.

gradle/wrapper/gradle-wrapper.properties

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,7 @@
11
distributionBase=GRADLE_USER_HOME
22
distributionPath=wrapper/dists
3-
distributionUrl=https\://services.gradle.org/distributions/gradle-8.5-all.zip
3+
distributionSha256Sum=fba8464465835e74f7270bbf43d6d8a8d7709ab0a43ce1aa3323f73e9aa0c612
4+
distributionUrl=https\://services.gradle.org/distributions/gradle-8.13-all.zip
45
networkTimeout=10000
56
validateDistributionUrl=true
67
zipStoreBase=GRADLE_USER_HOME

gradlew

Lines changed: 5 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -15,6 +15,8 @@
1515
# See the License for the specific language governing permissions and
1616
# limitations under the License.
1717
#
18+
# SPDX-License-Identifier: Apache-2.0
19+
#
1820

1921
##############################################################################
2022
#
@@ -55,7 +57,7 @@
5557
# Darwin, MinGW, and NonStop.
5658
#
5759
# (3) This script is generated from the Groovy template
58-
# https://github.com/gradle/gradle/blob/HEAD/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
60+
# https://github.com/gradle/gradle/blob/HEAD/platforms/jvm/plugins-application/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
5961
# within the Gradle project.
6062
#
6163
# You can find Gradle at https://github.com/gradle/gradle/.
@@ -84,7 +86,7 @@ done
8486
# shellcheck disable=SC2034
8587
APP_BASE_NAME=${0##*/}
8688
# Discard cd standard output in case $CDPATH is set (https://github.com/gradle/gradle/issues/25036)
87-
APP_HOME=$( cd "${APP_HOME:-./}" > /dev/null && pwd -P ) || exit
89+
APP_HOME=$( cd -P "${APP_HOME:-./}" > /dev/null && printf '%s\n' "$PWD" ) || exit
8890

8991
# Use the maximum available, or set MAX_FD != -1 to use that value.
9092
MAX_FD=maximum
@@ -203,7 +205,7 @@ fi
203205
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
204206

205207
# Collect all arguments for the java command:
206-
# * DEFAULT_JVM_OPTS, JAVA_OPTS, JAVA_OPTS, and optsEnvironmentVar are not allowed to contain shell fragments,
208+
# * DEFAULT_JVM_OPTS, JAVA_OPTS, and optsEnvironmentVar are not allowed to contain shell fragments,
207209
# and any embedded shellness will be escaped.
208210
# * For example: A user cannot expect ${Hostname} to be expanded, as it is an environment variable and will be
209211
# treated as '${Hostname}' itself on the command line.

gradlew.bat

Lines changed: 12 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -13,6 +13,8 @@
1313
@rem See the License for the specific language governing permissions and
1414
@rem limitations under the License.
1515
@rem
16+
@rem SPDX-License-Identifier: Apache-2.0
17+
@rem
1618

1719
@if "%DEBUG%"=="" @echo off
1820
@rem ##########################################################################
@@ -43,11 +45,11 @@ set JAVA_EXE=java.exe
4345
%JAVA_EXE% -version >NUL 2>&1
4446
if %ERRORLEVEL% equ 0 goto execute
4547

46-
echo.
47-
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
48-
echo.
49-
echo Please set the JAVA_HOME variable in your environment to match the
50-
echo location of your Java installation.
48+
echo. 1>&2
49+
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 1>&2
50+
echo. 1>&2
51+
echo Please set the JAVA_HOME variable in your environment to match the 1>&2
52+
echo location of your Java installation. 1>&2
5153

5254
goto fail
5355

@@ -57,11 +59,11 @@ set JAVA_EXE=%JAVA_HOME%/bin/java.exe
5759

5860
if exist "%JAVA_EXE%" goto execute
5961

60-
echo.
61-
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
62-
echo.
63-
echo Please set the JAVA_HOME variable in your environment to match the
64-
echo location of your Java installation.
62+
echo. 1>&2
63+
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% 1>&2
64+
echo. 1>&2
65+
echo Please set the JAVA_HOME variable in your environment to match the 1>&2
66+
echo location of your Java installation. 1>&2
6567

6668
goto fail
6769

0 commit comments

Comments
 (0)