Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/kotlin/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Android &引用;检测到不支持的模块“;向库添加kotlin多平台支持时_Android_Kotlin_Kotlin Multiplatform - Fatal编程技术网

Android &引用;检测到不支持的模块“;向库添加kotlin多平台支持时

Android &引用;检测到不支持的模块“;向库添加kotlin多平台支持时,android,kotlin,kotlin-multiplatform,Android,Kotlin,Kotlin Multiplatform,我有一个android库,我正试图把它变成kotlin多平台库。当我在AndroidStudio中使用kotlin多平台插件创建新的KMM模块并尝试编译时,我得到一个错误,即 Unsupported modules detected: Compilation is not supported for following modules: .sharedmodule.androidAndroidTestRelease, .sharedmodule.commonMain, .sharedmod

我有一个android库,我正试图把它变成kotlin多平台库。当我在AndroidStudio中使用kotlin多平台插件创建新的KMM模块并尝试编译时,我得到一个错误,即

Unsupported modules detected: Compilation is not supported for
following modules: 
.sharedmodule.androidAndroidTestRelease, 
.sharedmodule.commonMain, 
.sharedmodule.commonTest, 
.sharedmodule.iosArm64Main, 
.sharedmodule.iosArm64Test, 
.sharedmodule.iosMain,  
.sharedmodule.iosTest, 
.sharedmodule.iosX64Main,  
.sharedmodule.iosX64Test.  
Unfortunately you can't have non-Gradle Java modules and Android-Gradle modules in one project.
因此,基本上所有的东西都被添加到创建KMM模块中

这是gt通过插件创建的gradle文件

import org.jetbrains.kotlin.gradle.plugin.mpp.KotlinNativeTarget

plugins {
    kotlin("multiplatform")
    id("com.android.library")
    id("kotlin-android-extensions")
    id("kotlinx-serialization")
}

repositories {
    gradlePluginPortal()
    google()
    jcenter()
    mavenCentral()
    maven {
        url = uri("https://dl.bintray.com/kotlin/kotlin-eap")
    }
}
kotlin {
    android()
    ios {
        binaries {
            framework {
                baseName = "sharedmodule"
            }
        }
    }
    sourceSets {
        val commonMain by getting{
            dependencies {
                implementation(kotlin("io.ktor:ktor-client-core:1.4.1"))
                implementation(kotlin("io.ktor:ktor-client-json:1.4.1"))
                implementation(kotlin("io.ktor:ktor-client-serialization:1.4.1"))
                implementation(kotlin("org.jetbrains.kotlinx:kotlinx-coroutines-core-common:1.4.0"))
            }
        }
        val commonTest by getting {
            dependencies {
                implementation(kotlin("test-common"))
                implementation(kotlin("test-annotations-common"))
            }
        }
        val androidMain by getting {
            dependencies {
                implementation("androidx.core:core-ktx:1.3.2")
            }
        }
        val androidTest by getting {
            dependencies {
                implementation(kotlin("test-junit"))
                implementation("junit:junit:4.12")
            }
        }
        val iosMain by getting{
            dependencies{
//                implementation("org.jetbrains.kotlinx:kotlinx-coroutines-core-native:1.3.8")
            }
        }
        val iosTest by getting
    }
}
android {
    compileSdkVersion(30)
    sourceSets["main"].manifest.srcFile("src/androidMain/AndroidManifest.xml")
    defaultConfig {
        minSdkVersion(24)
        targetSdkVersion(30)
        versionCode = 1
        versionName = "1.0"
    }
    buildTypes {
        getByName("release") {
            isMinifyEnabled = false
        }
    }

    packagingOptions{
        excludes.add("META-INF/*.kotlin_module")
    }
    compileOptions {
        sourceCompatibility = JavaVersion.VERSION_1_8
        targetCompatibility = JavaVersion.VERSION_1_8
    }
    tasks.withType<org.jetbrains.kotlin.gradle.tasks.KotlinCompile>().all {
        kotlinOptions {
            jvmTarget = "1.8"
        }
    }
}
val packForXcode by tasks.creating(Sync::class) {
    group = "build"
    val mode = System.getenv("CONFIGURATION") ?: "DEBUG"
    val sdkName = System.getenv("SDK_NAME") ?: "iphonesimulator"
    val targetName = "ios" + if (sdkName.startsWith("iphoneos")) "Arm64" else "X64"
    val framework =
        kotlin.targets.getByName<KotlinNativeTarget>(targetName).binaries.getFramework(mode)
    inputs.property("mode", mode)
    dependsOn(framework.linkTask)
    val targetDir = File(buildDir, "xcode-frameworks")
    from({ framework.outputDirectory })
    into(targetDir)
}
tasks.getByName("build").dependsOn(packForXcode)
import org.jetbrains.kotlin.gradle.plugin.mpp.KotlinNativeTarget
插件{
科特林(“多平台”)
id(“com.android.library”)
id(“kotlin android扩展”)
id(“kotlinx序列化”)
}
存储库{
gradlePluginPortal()
谷歌()
jcenter()
mavenCentral()
马文{
url=uri(“https://dl.bintray.com/kotlin/kotlin-eap")
}
}
科特林{
安卓()
ios{
二进制文件{
框架{
baseName=“sharedmodule”
}
}
}
源集{
通过获取{
依赖关系{
实现(kotlin(“io.ktor:ktor客户端核心:1.4.1”))
实现(kotlin(“io.ktor:ktor客户端json:1.4.1”))
实现(kotlin(“io.ktor:ktor客户端序列化:1.4.1”))
实现(kotlin(“org.jetbrains.kotlinx:kotlinx coroutines core common:1.4.0”))
}
}
通过获取{
依赖关系{
实现(kotlin(“测试通用”))
实现(kotlin(“测试注释通用”))
}
}
val androidMain通过获取{
依赖关系{
实施(“androidx.core:core-ktx:1.3.2”)
}
}
val Android通过获取{
依赖关系{
实现(kotlin(“测试junit”))
实现(“junit:junit:4.12”)
}
}
通过获得{
依赖关系{
//实现(“org.jetbrains.kotlinx:kotlinx coroutines核心本机:1.3.8”)
}
}
通过获取
}
}
安卓{
编译DK版本(30)
sourceset[“main”].manifest.srcFile(“src/androidMain/AndroidManifest.xml”)
默认配置{
明斯克版本(24)
targetSdkVersion(30)
版本代码=1
versionName=“1.0”
}
建筑类型{
getByName(“发布”){
isMinifyEnabled=false
}
}
包装选项{
排除.add(“META-INF/*.kotlin_模块”)
}
编译选项{
sourceCompatibility=JavaVersion.VERSION\u 1\u 8
targetCompatibility=JavaVersion.VERSION\u 1\u 8
}
tasks.withType().all{
科特洛普斯酒店{
jvmTarget=“1.8”
}
}
}
val packForXcode by tasks.creating(Sync::class){
group=“build”
val mode=System.getenv(“配置”)?:“调试”
val sdkName=System.getenv(“SDK_名称”)?:“iphonesimulator”
val targetName=“ios”+if(sdkName.startsWith(“iphoneos”)“Arm64”或“X64”
val框架=
targets.getByName(targetName).binaries.getFramework(模式)
属性(“模式”,模式)
dependsOn(framework.linkTask)
val targetDir=File(buildDir,“xcode框架”)
来自({framework.outputDirectory})
进入(targetDir)
}
tasks.getByName(“构建”).dependsOn(packForXcode)

有人能告诉我如何修复错误吗?

您是如何尝试编译的?您是如何尝试编译的?