blob: 288ec279601908d45ce48d15cd144c7a0546a527 [file] [log] [blame]
/*
* Copyright 2016-2018 JetBrains s.r.o. Use of this source code is governed by the Apache 2.0 license.
*/
// Configures generation of JavaDoc & Dokka artifacts
def platform = platformOf(project)
def coroutines_core = platformLib("kotlinx-coroutines-core", platform)
def makeLinkMapping(dokka, projectDir) {
dokka.linkMapping {
def relPath = rootProject.projectDir.toPath().relativize(projectDir.toPath())
dir = "$projectDir/src"
url = "http://github.com/kotlin/kotlinx.coroutines/tree/master/$relPath/src"
suffix = "#L"
}
}
configurations {
dokkaStubs.extendsFrom compileOnly
}
if (platform == "jvm") {
apply plugin: 'org.jetbrains.dokka'
tasks.withType(dokka.getClass()) {
jdkVersion = 8
includes = ['README.md']
}
dependencies {
dokkaStubs project(":stdlib-stubs")
}
dokka {
kotlinTasks { [] }
outputFormat = 'kotlin-website'
dependsOn(project.configurations.dokkaStubs)
dependsOn(project.configurations.compileClasspath)
dependsOn(project.sourceSets.main.output)
afterEvaluate {
classpath = project.configurations.dokkaStubs.files + project.configurations.compileClasspath.files + project.sourceSets.main.output.files
}
}
if (project.name == coroutines_core) {
// Custom configuration for MPP modules
dependencies {
dokkaStubs project(":js-stub") // so that JS library reference can resolve properly
}
dokka {
kotlinTasks { [] }
suppressedModifiers = ['actual']
// map for JS, Native, and Common sources
makeLinkMapping(it, projectDir)
makeLinkMapping(it, rootProject.file("js/$project.name-js"))
makeLinkMapping(it, rootProject.file("native/$project.name-native"))
makeLinkMapping(it, rootProject.file("common/$project.name-common"))
// source roots
impliedPlatforms = ['JVM', 'JS', 'Native']
sourceRoot {
path = rootProject.file("core/$project.name/src")
platforms = ['JVM']
}
sourceRoot {
path = rootProject.file("js/$project.name-js/src")
platforms = ['JS']
}
sourceRoot {
path = rootProject.file("native/$project.name-native/src")
platforms = ['Native']
}
sourceRoot {
path = rootProject.file("common/$project.name-common/src")
}
}
}
// real xxx-javadoc.jar for JVM
task dokkaJavadoc(type: dokka.getClass()) {
outputFormat = 'javadoc'
outputDirectory = "$buildDir/javadoc"
}
task javadocJar(type: Jar, dependsOn: dokkaJavadoc) {
classifier = 'javadoc'
from "$buildDir/javadoc"
}
} else {
// empty xxx-javadoc.jar for JS and Common modules
task javadocJar(type: Jar) {
classifier = 'javadoc'
from "$buildDir/javadoc" // would not exist
}
}