| /* |
| * Copyright 2017-2021 JetBrains s.r.o. Use of this source code is governed by the Apache 2.0 license. |
| */ |
| |
| // Configures publishing of Maven artifacts to MavenCentral |
| |
| apply plugin: 'maven-publish' |
| apply plugin: 'signing' |
| |
| apply from: project.rootProject.file('gradle/maven-metadata.gradle') |
| |
| def isMultiplatform = project.name in ["kotlinx-serialization-core", "kotlinx-serialization-json", "kotlinx-serialization-json-okio", |
| "kotlinx-serialization-json-tests", "kotlinx-serialization-protobuf", "kotlinx-serialization-cbor", |
| "kotlinx-serialization-properties"] |
| def isBom = project.name == "kotlinx-serialization-bom" |
| |
| if (!isBom) { |
| task stubSources(type: Jar) { |
| archiveClassifier = 'sources' |
| } |
| |
| task stubJavadoc(type: Jar) { |
| archiveClassifier = 'javadoc' |
| } |
| } |
| |
| task emptyJar(type: Jar) { |
| } |
| |
| afterEvaluate { |
| task mainSourcesJar(type: Jar) { |
| classifier = 'sources' |
| if (isMultiplatform) { |
| from kotlin.sourceSets.commonMain.kotlin |
| } else if (isBom) { |
| // no-op: sourceSets is [] for BOM, as it does not have sources. |
| } else { |
| from sourceSets.main.allSource |
| } |
| } |
| } |
| |
| afterEvaluate { |
| publishing { |
| def variantName = "${project.name}" |
| |
| if (!isMultiplatform && !isBom) { |
| publications { |
| maven(MavenPublication) { publication -> |
| artifactId variantName |
| publication.from components.java |
| publication.artifact mainSourcesJar |
| artifact stubJavadoc |
| |
| PublishingKt.configureMavenCentralMetadata(publication.pom, project) |
| PublishingKt.signPublicationIfKeyPresent(project, publication) |
| } |
| } |
| |
| return |
| } |
| |
| // Rename artifacts for backward compatibility |
| publications.all { |
| def type = it.name |
| logger.info("Configuring $type") |
| switch (type) { |
| case 'kotlinMultiplatform': |
| // With Kotlin 1.4.0, the root module ID has no suffix, but for compatibility with |
| // the consumers who can't read Gradle module metadata, we publish the JVM artifacts in it |
| it.artifactId = variantName |
| apply from: "$rootDir/gradle/publish-mpp-root-module-in-platform.gradle" |
| publishPlatformArtifactsInRootModule(publications["jvm"]) |
| break |
| case 'metadata': |
| case 'jvm': |
| case 'js': |
| it.artifactId = "$variantName-$type" |
| break |
| } |
| logger.info("Artifact id = ${it.artifactId}") |
| |
| PublishingKt.configureMavenCentralMetadata(pom, project) |
| PublishingKt.signPublicationIfKeyPresent(project, it) |
| |
| // The 'root' module publishes the JVM module's Javadoc JAR as per publishPlatformArtifactsInRootModule, and |
| // every other module should publish an empty Javadoc JAR. TODO: provide proper documentation artifacts? |
| if (name != "kotlinMultiplatform" && !isBom) { |
| artifact stubJavadoc |
| } |
| } |
| } |
| } |
| |
| publishing { |
| repositories { |
| PublishingKt.configureMavenPublication(delegate, project) |
| } |
| } |
| |
| // Compatibility with old TeamCity configurations that perform :kotlinx-coroutines-core:bintrayUpload |
| task bintrayUpload(dependsOn: publish) |
| |
| // This is required for K/N publishing |
| bintrayUpload.dependsOn publishToMavenLocal |
| |