mirai/gradle/publish.gradle

129 lines
3.5 KiB
Groovy
Raw Normal View History

2020-04-11 00:04:45 +08:00
import upload.Bintray
2019-11-23 22:34:57 +08:00
// 部分源码来自 kotlinx.coroutines
2020-02-18 14:28:28 +08:00
// Source code from kotlinx.coroutines
2019-11-23 22:34:57 +08:00
2020-04-11 00:21:44 +08:00
task ensureBintrayAvailable() {
2020-04-11 00:28:18 +08:00
doLast {
if (!Bintray.isBintrayAvailable(project)) {
throw new IllegalStateException("bintray isn't available. ")
}
2020-04-11 00:21:44 +08:00
}
}
2020-04-11 00:18:14 +08:00
if (!Bintray.isBintrayAvailable(project)) {
println("bintray isn't available. NO PUBLICATIONS WILL BE SET")
return
}
2020-04-12 00:42:07 +08:00
def miraiGitHubUrl = "https://github.com/mamoe/mirai"
2019-11-23 22:34:57 +08:00
bintray {
2020-04-11 00:04:45 +08:00
user = Bintray.getUser(project)
key = Bintray.getKey(project)
2019-11-23 22:34:57 +08:00
pkg {
repo = 'mirai'
2020-06-16 17:28:14 +08:00
name = project.name
2019-11-23 22:34:57 +08:00
licenses = ['AGPL']
2020-04-12 00:42:07 +08:00
vcsUrl = miraiGitHubUrl
websiteUrl = miraiGitHubUrl
githubRepo = miraiGitHubUrl
issueTrackerUrl = "$miraiGitHubUrl/issues"
/* version {
name = project.version
}*/
2019-11-23 22:34:57 +08:00
}
}
afterEvaluate {
project.publishing.publications.forEach { publication ->
publication.pom.withXml {
def root = asNode()
//root.appendNode('groupId', project.group)
//root.appendNode('artifactId', project.name)
//root.appendNode('version', project.version)
root.appendNode('name', project.name)
root.appendNode('description', project.description)
2020-04-12 00:42:07 +08:00
root.appendNode('url', miraiGitHubUrl)
2020-04-12 00:47:36 +08:00
root.children().last() + {
licenses {
license {
name "AGPL-V3"
url "https://www.gnu.org/licenses/agpl-3.0.txt"
distribution "repo"
}
}
developers {
developer {
id "mamoe"
name "Mamoe Technologies"
email "support@mamoe.net"
}
}
scm {
url miraiGitHubUrl
}
}
2019-11-23 22:34:57 +08:00
}
}
}
bintrayUpload.doFirst {
publications = project.publishing.publications
}
bintrayUpload.dependsOn {
def list = new LinkedList<Task>()
list.add(tasks.getByName("build"))
list.addAll(tasks.findAll { task -> task.name.contains('Jar') })
list.addAll(tasks.findAll { task -> task.name.startsWith('generateMetadataFileFor') })
list.addAll(tasks.findAll { task -> task.name.startsWith('generatePomFileFor') })
list
}
2020-04-11 00:04:45 +08:00
try {
2019-11-23 22:34:57 +08:00
// empty xxx-javadoc.jar
2020-02-16 13:54:42 +08:00
task javadocJar(type: Jar) {
archiveClassifier = 'javadoc'
}
2019-11-23 22:34:57 +08:00
2020-04-11 00:04:45 +08:00
} catch (Exception ignored) {
2020-02-16 13:54:42 +08:00
}
2019-11-23 22:34:57 +08:00
publishing {
publications.all {
// add empty javadocs (no need for MPP root publication which publishes only pom file)
if (it.name != 'kotlinMultiplatform') {
it.artifact(javadocJar)
}
// Rename MPP artifacts for backward compatibility
def type = it.name
switch (type) {
case 'kotlinMultiplatform':
2020-04-12 00:42:07 +08:00
it.artifactId = "$project.name-native"
2019-11-23 22:34:57 +08:00
break
case 'metadata':
it.artifactId = "$project.name-common"
break
case 'jvm':
2020-04-12 00:42:07 +08:00
it.artifactId = "$project.name"
2019-11-23 22:34:57 +08:00
break
case 'js':
case 'native':
it.artifactId = "$project.name-$type"
break
}
// disable metadata everywhere, but in native modules
if (type == 'maven' || type == 'metadata' || type == 'jvm' || type == 'js') {
moduleDescriptorGenerator = null
}
}
2020-04-12 00:42:07 +08:00
}
// bintrayUpload.dependsOn publishToMavenLocal