Add dummy jvmBase target for IDE

This commit is contained in:
Him188 2022-06-11 12:55:25 +01:00
parent 7dbb1a5ad7
commit cca40b8aa3
4 changed files with 31 additions and 113 deletions

View File

@ -11,7 +11,6 @@ import com.google.gradle.osdetector.OsDetector
import org.gradle.api.Project import org.gradle.api.Project
import org.gradle.api.attributes.Attribute import org.gradle.api.attributes.Attribute
import org.gradle.kotlin.dsl.get import org.gradle.kotlin.dsl.get
import org.gradle.kotlin.dsl.getByName
import org.gradle.kotlin.dsl.getting import org.gradle.kotlin.dsl.getting
import org.gradle.kotlin.dsl.withType import org.gradle.kotlin.dsl.withType
import org.jetbrains.kotlin.gradle.dsl.KotlinMultiplatformExtension import org.jetbrains.kotlin.gradle.dsl.KotlinMultiplatformExtension
@ -23,7 +22,7 @@ import org.jetbrains.kotlin.gradle.plugin.KotlinTargetPreset
import org.jetbrains.kotlin.gradle.plugin.mpp.KotlinNativeCompilation import org.jetbrains.kotlin.gradle.plugin.mpp.KotlinNativeCompilation
import org.jetbrains.kotlin.gradle.plugin.mpp.KotlinNativeTarget import org.jetbrains.kotlin.gradle.plugin.mpp.KotlinNativeTarget
import org.jetbrains.kotlin.gradle.plugin.mpp.NativeBuildType import org.jetbrains.kotlin.gradle.plugin.mpp.NativeBuildType
import org.jetbrains.kotlin.gradle.targets.native.tasks.KotlinNativeTest import org.jetbrains.kotlin.gradle.plugin.mpp.TestExecutable
import java.io.File import java.io.File
private val miraiPlatform = Attribute.of( private val miraiPlatform = Attribute.of(
@ -116,18 +115,22 @@ val NATIVE_TARGETS by lazy { UNIX_LIKE_TARGETS + WIN_TARGETS }
fun Project.configureJvmTargetsHierarchical() { fun Project.configureJvmTargetsHierarchical() {
extensions.getByType(KotlinMultiplatformExtension::class.java).apply { extensions.getByType(KotlinMultiplatformExtension::class.java).apply {
jvm("jvmBase") { if (IDEA_ACTIVE) {
compilations.all { jvm("jvmBase") { // dummy target for resolution, not published
this.compileKotlinTask.enabled = false // IDE complain compilations.all {
this.compileKotlinTask.enabled = false // IDE complain
}
attributes.attribute(KotlinPlatformType.attribute, KotlinPlatformType.common) // magic
attributes.attribute(miraiPlatform, "jvmBase") // avoid resolution
} }
attributes.attribute(KotlinPlatformType.attribute, KotlinPlatformType.common) // avoid resolving by others
// attributes.attribute(miraiPlatform, "jvmBase")
} }
if (isAndroidSDKAvailable && ANDROID_ENABLED) { if (isAndroidSDKAvailable && ANDROID_ENABLED) {
jvm("android") { jvm("android") {
attributes.attribute(KotlinPlatformType.attribute, KotlinPlatformType.androidJvm) attributes.attribute(KotlinPlatformType.attribute, KotlinPlatformType.androidJvm)
// publishAllLibraryVariants() if (IDEA_ACTIVE) {
attributes.attribute(miraiPlatform, "android") // avoid resolution
}
} }
} else { } else {
printAndroidNotInstalled() printAndroidNotInstalled()
@ -139,89 +142,6 @@ fun Project.configureJvmTargetsHierarchical() {
} }
} }
///**
// * [IDEA_ACTIVE] 时配置单一 'native' target, 基于 host 平台; 否则配置所有 native targets 依赖 'native' 作为中间平台.
// */
//@Deprecated("")
//fun KotlinMultiplatformExtension.configureNativeTargets(
// project: Project
//) {
// val nativeMainSets = mutableListOf<KotlinSourceSet>()
// val nativeTestSets = mutableListOf<KotlinSourceSet>()
// val nativeTargets = mutableListOf<KotlinNativeTarget>()
//
// if (IDEA_ACTIVE) {
// val target = when {
// Os.isFamily(Os.FAMILY_MAC) -> if (Os.isArch("aarch64")) macosArm64("native") else macosX64(
// "native"
// )
// Os.isFamily(Os.FAMILY_WINDOWS) -> mingwX64("native")
// else -> linuxX64("native")
// }
// nativeTargets.add(target)
// } else {
// // 1.6.0
// val nativeTargetNames: List<String> = arrayOf(
// // serialization doesn't support those commented targets
//// "androidNativeArm32, androidNativeArm64, androidNativeX86, androidNativeX64",
// "iosArm32, iosArm64, iosX64, iosSimulatorArm64",
// "watchosArm32, watchosArm64, watchosX86, watchosX64, watchosSimulatorArm64",
// "tvosArm64, tvosX64, tvosSimulatorArm64",
// "macosX64, macosArm64",
//// "linuxMips32, linuxMipsel32, linuxX64",
// "linuxX64",
// "mingwX64",
//// "wasm32" // linuxArm32Hfp, mingwX86
// ).flatMap { it.split(",") }.map { it.trim() }
// presets.filter { it.name in nativeTargetNames }.forEach { preset ->
// val target = targetFromPreset(preset, preset.name) as KotlinNativeTarget
// nativeMainSets.add(target.compilations[MAIN_COMPILATION_NAME].kotlinSourceSets.first())
// nativeTestSets.add(target.compilations[TEST_COMPILATION_NAME].kotlinSourceSets.first())
// nativeTargets.add(target)
// }
//
// if (!IDEA_ACTIVE) {
// project.configure(nativeMainSets) {
// dependsOn(sourceSets.maybeCreate("nativeMain"))
// }
//
// project.configure(nativeTestSets) {
// dependsOn(sourceSets.maybeCreate("nativeTest"))
// }
// }
// }
//
// project.configureNativeInterop("main", project.projectDir.resolve("src/nativeMainInterop"), nativeTargets)
// project.configureNativeInterop("test", project.projectDir.resolve("src/nativeTestInterop"), nativeTargets)
// project.configureNativeLinkOptions(nativeTargets)
//
// val sourceSets = project.kotlinSourceSets.orEmpty()
// val commonMain = sourceSets.single { it.name == "commonMain" }
// val commonTest = sourceSets.single { it.name == "commonTest" }
// val jvmBaseMain = this.sourceSets.maybeCreate("jvmBaseMain")
// val jvmBaseTest = this.sourceSets.maybeCreate("jvmBaseTest")
// val jvmMain = sourceSets.single { it.name == "jvmMain" }
// val jvmTest = sourceSets.single { it.name == "jvmTest" }
// val androidMain = sourceSets.single { it.name == "androidMain" }
// val androidTest = sourceSets.single { it.name == "androidTest" }
//
// val nativeMain = sourceSets.single { it.name == "nativeMain" }
// val nativeTest = sourceSets.single { it.name == "nativeTest" }
//
//
// jvmBaseMain.dependsOn(commonMain)
// jvmBaseTest.dependsOn(commonTest)
//
// jvmMain.dependsOn(jvmBaseMain)
// androidMain.dependsOn(jvmBaseMain)
//
// jvmTest.dependsOn(jvmBaseTest)
// androidTest.dependsOn(jvmBaseTest)
//
// nativeMain.dependsOn(commonMain)
// nativeTest.dependsOn(commonTest)
//}
/** /**
* ``` * ```
* common * common
@ -315,12 +235,12 @@ fun KotlinMultiplatformExtension.configureNativeTargetsHierarchical(
) )
} }
// NATIVE_TARGETS.forEach { targetName -> // WIN_TARGETS.forEach { targetName ->
// val target = targets.getByName(targetName) as KotlinNativeTarget // val target = targets.getByName(targetName) as KotlinNativeTarget
// if (!IDEA_ACTIVE && HOST_KIND == HostKind.WINDOWS) { // if (!IDEA_ACTIVE && HOST_KIND == HostKind.WINDOWS) {
// target.binaries.test(listOf(NativeBuildType.RELEASE)) { // // add release test to run on CI
// // add release test to run on CI // project.afterEvaluate {
// project.afterEvaluate { // target.findOrCreateTest(NativeBuildType.RELEASE) {
// // use linkReleaseTestMingwX64 for mingwX64Test to save memory // // use linkReleaseTestMingwX64 for mingwX64Test to save memory
// tasks.getByName("mingwX64Test", KotlinNativeTest::class) // tasks.getByName("mingwX64Test", KotlinNativeTest::class)
// .executable(linkTask) { linkTask.binary.outputFile } // .executable(linkTask) { linkTask.binary.outputFile }
@ -339,16 +259,6 @@ fun KotlinMultiplatformExtension.configureNativeTargetsHierarchical(
baseName = project.name.toLowerCase().replace("-", "") baseName = project.name.toLowerCase().replace("-", "")
} }
} }
if (!IDEA_ACTIVE && HOST_KIND == HostKind.WINDOWS && targetName == "mingwX64") {
target.binaries.test(listOf(NativeBuildType.RELEASE)) {
// add release test to run on CI
project.afterEvaluate {
// use linkReleaseTestMingwX64 for mingwX64Test to save memory
tasks.getByName("mingwX64Test", KotlinNativeTest::class)
.executable(linkTask) { linkTask.binary.outputFile }
}
}
}
} }
// Register platform tasks, e.g. linkDebugSharedHost // Register platform tasks, e.g. linkDebugSharedHost
@ -403,12 +313,18 @@ fun KotlinMultiplatformExtension.configureNativeTargetsHierarchical(
androidTest.dependsOn(jvmBaseTest) androidTest.dependsOn(jvmBaseTest)
} }
private fun KotlinNativeTarget.findOrCreateTest(buildType: NativeBuildType, configure: TestExecutable.() -> Unit) =
binaries.findTest(buildType)?.apply(configure) ?: binaries.test(listOf(buildType), configure)
// e.g. Linker will try to link curl for mingwX64 but this can't be done on macOS. // e.g. Linker will try to link curl for mingwX64 but this can't be done on macOS.
fun Project.disableCrossCompile() { fun Project.disableCrossCompile() {
project.afterEvaluate { project.afterEvaluate {
if (HOST_KIND !is HostKind.MACOS) { if (HOST_KIND != HostKind.MACOS_ARM64) {
MAC_TARGETS.forEach { target -> disableTargetLink(this, target) } disableTargetLink(this, HostKind.MACOS_ARM64.targetName)
}
if (HOST_KIND != HostKind.MACOS_X64) {
disableTargetLink(this, HostKind.MACOS_X64.targetName)
} }
if (HOST_KIND != HostKind.WINDOWS) { if (HOST_KIND != HostKind.WINDOWS) {
WIN_TARGETS.forEach { target -> disableTargetLink(this, target) } WIN_TARGETS.forEach { target -> disableTargetLink(this, target) }
@ -420,13 +336,13 @@ fun Project.disableCrossCompile() {
} }
private fun disableTargetLink(project: Project, target: String) { private fun disableTargetLink(project: Project, target: String) {
project.tasks.getByName("linkDebugTest${target.titlecase()}").enabled = false project.tasks.findByName("linkDebugTest${target.titlecase()}")?.enabled = false
project.tasks.findByName("linkReleaseTest${target.titlecase()}")?.enabled = false project.tasks.findByName("linkReleaseTest${target.titlecase()}")?.enabled = false
project.tasks.findByName("linkDebugShared${target.titlecase()}")?.enabled = false project.tasks.findByName("linkDebugShared${target.titlecase()}")?.enabled = false
project.tasks.findByName("linkReleaseShared${target.titlecase()}")?.enabled = false project.tasks.findByName("linkReleaseShared${target.titlecase()}")?.enabled = false
project.tasks.findByName("linkDebugStatic${target.titlecase()}")?.enabled = false project.tasks.findByName("linkDebugStatic${target.titlecase()}")?.enabled = false
project.tasks.findByName("linkReleaseStatic${target.titlecase()}")?.enabled = false project.tasks.findByName("linkReleaseStatic${target.titlecase()}")?.enabled = false
project.tasks.getByName("${target}Test").enabled = false project.tasks.findByName("${target}Test")?.enabled = false
} }
private fun Project.linkerDirs(): List<String> { private fun Project.linkerDirs(): List<String> {

View File

@ -156,6 +156,8 @@ const val `bouncycastle` = "org.bouncycastle:bcprov-jdk15on:${Versions.bouncycas
const val `maven-resolver-api` = "org.apache.maven.resolver:maven-resolver-api:${Versions.mavenArtifactResolver}" const val `maven-resolver-api` = "org.apache.maven.resolver:maven-resolver-api:${Versions.mavenArtifactResolver}"
const val `maven-resolver-impl` = "org.apache.maven.resolver:maven-resolver-impl:${Versions.mavenArtifactResolver}" const val `maven-resolver-impl` = "org.apache.maven.resolver:maven-resolver-impl:${Versions.mavenArtifactResolver}"
const val `maven-resolver-connector-basic` = "org.apache.maven.resolver:maven-resolver-connector-basic:${Versions.mavenArtifactResolver}" const val `maven-resolver-connector-basic` =
const val `maven-resolver-transport-http` = "org.apache.maven.resolver:maven-resolver-transport-http:${Versions.mavenArtifactResolver}" "org.apache.maven.resolver:maven-resolver-connector-basic:${Versions.mavenArtifactResolver}"
const val `maven-resolver-transport-http` =
"org.apache.maven.resolver:maven-resolver-transport-http:${Versions.mavenArtifactResolver}"
const val `maven-resolver-provider` = "org.apache.maven:maven-resolver-provider:${Versions.mavenResolverProvider}" const val `maven-resolver-provider` = "org.apache.maven:maven-resolver-provider:${Versions.mavenResolverProvider}"

View File

@ -56,7 +56,7 @@ kotlin {
val jvmBaseMain by getting { val jvmBaseMain by getting {
dependencies { dependencies {
api(`kotlinx-coroutines-jdk8`) api(`kotlinx-coroutines-jdk8`) // use -jvm modules for this magic target 'jvmBase'
implementation(`jetbrains-annotations`) implementation(`jetbrains-annotations`)
implementation(`log4j-api`) implementation(`log4j-api`)
compileOnly(`slf4j-api`) compileOnly(`slf4j-api`)

View File

@ -60,7 +60,7 @@ kotlin {
implementation(`log4j-api`) implementation(`log4j-api`)
implementation(`netty-all`) implementation(`netty-all`)
implementation(`ktor-client-okhttp`) implementation(`ktor-client-okhttp`)
api(`kotlinx-coroutines-core`) api(`kotlinx-coroutines-jdk8`) // use -jvm modules for this magic target 'jvmBase'
} }
} }