发布跨平台的库
你可以使用 maven-publish
Gradle plugin, 将跨平台的库发布到本地的 Maven 仓库. 只需要在 shared/build.gradle.kts
文件中, 指定库的 group, version, 以及需要发布到的 仓库. plugin 会自动创建发布任务.
发布的结构
当与 maven-publish
一起使用时, Kotlin plugin 对在当前主机上能够构建的每个编译目标, 都会自动创建发布任务, Android 编译目标除外, 因为它需要 更多步骤来配置发布任务.
跨平台库的发布会包含一个额外的 root 发布 kotlinMultiplatform
, 这是用作整个库的发布, 如果将它添加为共通源代码集的依赖项, 它会自动解析为适当的平台相关 artifact. 详情请参见 添加依赖项.
这个 kotlinMultiplatform
发布包含元数据 artifact, 而且会引用其他发布作为它的变体(variant).
如果仓库要求, kotlinMultiplatform
发布还可能会需要源代码和文档的 artifact. 这种情况下, 请在 publication 内使用 artifact(...)
添加这些需要的 artifact.
对主机的要求
除 Apple 平台的编译目标之外, Kotlin/Native 支持交叉编译(cross-compilation), 可以在任何主机上生成需要的 artifact.
为了避免发布期间发生问题:
如果你的项目的编译目标包含 Apple 操作系统, 请只从 Apple 主机发布.
只从一个主机发布所有的 artifact, 以免在仓库中重复发布.
例如, Maven Central, 明确禁止重复发布, 并会让发布过程失败.
如果你使用 Kotlin 1.7.0 或更早版本
在 1.7.20 之前, Kotlin/Native 编译器不支持全部的交叉编译(cross-compilation)选项. 如果你使用更早的版本, 你可能需要从多个主机发布跨平台项目: 使用 Windows 主机编译 Windows 编译目标, 使用 Linux 主机编译 Linux 编译目标, 等等. 这可能会导致那些交叉编译的模块被重复发布. 要避免这个问题, 最直接的方法是, 升级到比较新的 Kotlin 版本, 如上文描述的那样, 从单个主机进行发布.
如果无法升级, 请在 shared/build.gradle(.kts)
文件中为每个编译目标指定一个 main host, 并检查这个标记:
发布 Android 库
要发布一个 Android 库, 需要一些额外的配置.
默认情况下, 没有任何 Android 库的 artifact 会发布. 要发布一组 Android 编译变体(variant) 生成的 artifact, 需要在 shared/build.gradle.kts
文件的 Android 编译目标代码段内指定编译变体名称 :
上面的示例适用于没有 产品风格(Product Flavor) 的 Android 库. 对于存在产品风格(Product Flavor)的库, 编译变体名称还需要包含产品风格名称, 比如 fooBarDebug
或 fooBarRelease
.
默认的发布设置如下:
如果发布的编译变体是相同的构建类型 (比如, 都是
release
或debug
), 那么它们将兼容任意的使用者构建类型.如果发布的编译变体是不同的构建类型, 那么只有 release 变体兼容于与发布的编译变体不同的使用者构建类型. 所有的其他编译变体 (比如
debug
) 只会与使用者的相同构建类型匹配, 除非使用者项目指定了 匹配回退(Matching Fallback).
如果你希望让所有发布的 Android 变体都只兼容于库的使用者的相同构建类型, 请设置 Gradle 属性: kotlin.android.buildTypeAttribute.keep=true
.
也可以将各个编译变体以产品风格为单位分组发布, 使得不同的编译类型的输出文件可以放在同一个模块内, 编译类型成为 artifact 中的一个分类符 (release 编译类型的结果发布时仍然不带分类符). 这种发布模式默认是关闭的, 如果要启用, 请在 shared/build.gradle.kts
文件中使用以下设置:
禁用源代码的发布
Kotlin Multiplatform Gradle plugin 默认会对所有指定的编译目标发布源代码. 但是, 你可以在 shared/build.gradle.kts
文件中使用 withSourcesJar()
API 配置并禁用源代码发布:
对所有的编译目标禁用源代码发布:
kotlin { withSourcesJar(publish = false) jvm() linuxX64() }只对指定的编译目标禁用源代码发布:
kotlin { // 只对 JVM 禁用源代码发布: jvm { withSourcesJar(publish = false) } linuxX64() }对指定的编译目标之外的所有编译目标禁用源代码发布:
kotlin { // 对 JVM 之外的所有编译目标禁用源代码发布: withSourcesJar(publish = false) jvm { withSourcesJar(publish = true) } linuxX64() }