mirror of
https://github.com/mamoe/mirai.git
synced 2025-01-19 10:59:14 +08:00
Add dummy jvmBase target for IDE
This commit is contained in:
parent
7dbb1a5ad7
commit
cca40b8aa3
@ -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> {
|
||||||
|
@ -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}"
|
||||||
|
@ -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`)
|
||||||
|
@ -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'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user