From e9c62838d5bbf3e2ac62c2f3046b6147ce1c0743 Mon Sep 17 00:00:00 2001 From: Kamil Doległo Date: Mon, 5 Aug 2019 18:08:53 +0300 Subject: Move kotlinTasks, update README, minor refactoring --- .../kotlin/org/jetbrains/dokka/gradle/DokkaTask.kt | 37 +++++++--------------- .../dokka/gradle/configurationImplementations.kt | 10 ++++++ .../main/kotlin/org/jetbrains/dokka/gradle/main.kt | 27 +++++++++------- 3 files changed, 37 insertions(+), 37 deletions(-) (limited to 'runners/gradle-plugin/src/main/kotlin') diff --git a/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/DokkaTask.kt b/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/DokkaTask.kt index 84bbaf78..6a4fbe4f 100644 --- a/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/DokkaTask.kt +++ b/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/DokkaTask.kt @@ -21,7 +21,8 @@ import java.util.function.BiConsumer open class DokkaTask : DefaultTask() { - fun defaultKotlinTasks() = with(ReflectDsl) { + @Suppress("MemberVisibilityCanBePrivate") + fun defaultKotlinTasks(): List = with(ReflectDsl) { val abstractKotlinCompileClz = try { project.buildscript.classLoader.loadClass(ABSTRACT_KOTLIN_COMPILE) } catch (cnfe: ClassNotFoundException) { @@ -48,13 +49,6 @@ open class DokkaTask : DefaultTask() { var dokkaRuntime: Configuration? = null - var defaultDokkaRuntime: Configuration? = null - - @Input - var dokkaFatJar: String = "dokka-fatjar-${DokkaVersion.version}" - - private val defaultDokkaFatJar = "dokka-fatjar-${DokkaVersion.version}" - @Input var impliedPlatforms: MutableList = arrayListOf() @@ -77,26 +71,15 @@ open class DokkaTask : DefaultTask() { protected var externalDocumentationLinks: MutableList = mutableListOf() - private var kotlinTasksConfigurator: () -> List? = { defaultKotlinTasks() } private val kotlinTasks: List by lazy { extractKotlinCompileTasks() } - @Deprecated("Use manual configuration of source roots or subProjects{} closure") - fun kotlinTasks(taskSupplier: Callable>) { - kotlinTasksConfigurator = { taskSupplier.call() } - } - - @Deprecated("Use manual configuration of source roots or subProjects{} closure") - fun kotlinTasks(closure: Closure) { - kotlinTasksConfigurator = { closure.call() as? List } - } - @Input var subProjects: List = emptyList() @Input var disableAutoconfiguration: Boolean = false - fun tryResolveFatJar(configuration: Configuration?): Set { + private fun tryResolveFatJar(configuration: Configuration?): Set { return try { configuration!!.resolve() } catch (e: Exception) { @@ -104,15 +87,17 @@ open class DokkaTask : DefaultTask() { } } - fun loadFatJar() { + private fun loadFatJar() { if (ClassloaderContainer.fatJarClassLoader == null) { - val jars = tryResolveFatJar(dokkaRuntime).toList().union(tryResolveFatJar(defaultDokkaRuntime).toList()).filter { it.name.contains(dokkaFatJar) || it.name.contains(defaultDokkaFatJar) } + val jars = tryResolveFatJar(dokkaRuntime).toList() ClassloaderContainer.fatJarClassLoader = URLClassLoader(jars.map { it.toURI().toURL() }.toTypedArray(), ClassLoader.getSystemClassLoader().parent) } } private fun extractKotlinCompileTasks(): List { - val inputList = (kotlinTasksConfigurator.invoke() ?: emptyList()).filterNotNull() + val collectTasks = configuration.collectKotlinTasks ?: { defaultKotlinTasks() } + + val inputList = (collectTasks.invoke() ?: emptyList()).filterNotNull() val (paths, other) = inputList.partition { it is String } val taskContainer = project.tasks @@ -200,9 +185,9 @@ open class DokkaTask : DefaultTask() { private fun collectFromSinglePlatform(): List { if (disableAutoconfiguration) return listOf(configuration) - val autoConfig = ConfigurationExtractor.extractFromSinglePlatform(project) - val baseConfig = if (autoConfig != null) - listOf(mergeUserConfigurationAndPlatformData(configuration, autoConfig)) + val extractedConfig = ConfigurationExtractor.extractFromSinglePlatform(project) + val baseConfig = if (extractedConfig != null && configuration.collectKotlinTasks == null) + listOf(mergeUserConfigurationAndPlatformData(configuration, extractedConfig)) else collectFromSinglePlatformOldPlugin() diff --git a/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/configurationImplementations.kt b/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/configurationImplementations.kt index 0364985d..2c071bf8 100644 --- a/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/configurationImplementations.kt +++ b/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/configurationImplementations.kt @@ -11,6 +11,7 @@ import org.jetbrains.dokka.Platform import java.io.File import java.io.Serializable import java.net.URL +import java.util.concurrent.Callable import kotlin.reflect.KMutableProperty import kotlin.reflect.full.memberProperties @@ -48,6 +49,15 @@ open class GradlePassConfigurationImpl(@Transient val name: String = ""): PassCo @Input @Optional var platform: String? = null @Input override var targets: List = emptyList() @Input @Optional override var sinceKotlin: String? = null + @Transient var collectKotlinTasks: (() -> List?)? = null + + fun kotlinTasks(taskSupplier: Callable>) { + collectKotlinTasks = { taskSupplier.call() } + } + + fun kotlinTasks(closure: Closure) { + collectKotlinTasks = { closure.call() as? List } + } fun sourceRoot(c: Closure) { val configured = ConfigureUtil.configure(c, GradleSourceRootImpl()) diff --git a/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/main.kt b/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/main.kt index 66020c5c..a47c238f 100644 --- a/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/main.kt +++ b/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/main.kt @@ -2,6 +2,7 @@ package org.jetbrains.dokka.gradle import org.gradle.api.Plugin import org.gradle.api.Project +import org.gradle.api.artifacts.Configuration import org.gradle.util.GradleVersion import java.io.File import java.io.InputStream @@ -11,31 +12,35 @@ internal const val CONFIGURATION_EXTENSION_NAME = "configuration" internal const val MULTIPLATFORM_EXTENSION_NAME = "multiplatform" open class DokkaPlugin : Plugin { + private val taskName = "dokka" override fun apply(project: Project) { - DokkaVersion.loadFrom(javaClass.getResourceAsStream("/META-INF/gradle-plugins/org.jetbrains.dokka.properties")) + loadDokkaVersion() + val dokkaRuntimeConfiguration = addConfiguration(project) + addTasks(project, dokkaRuntimeConfiguration, DokkaTask::class.java) + } - val dokkaRuntimeConfiguration = project.configurations.create("dokkaRuntime") - val defaultDokkaRuntimeConfiguration = project.configurations.create("defaultDokkaRuntime") - val taskName = "dokka" + protected fun loadDokkaVersion() = DokkaVersion.loadFrom(javaClass.getResourceAsStream("/META-INF/gradle-plugins/org.jetbrains.dokka.properties")) - defaultDokkaRuntimeConfiguration.defaultDependencies{ dependencies -> dependencies.add(project.dependencies.create("org.jetbrains.dokka:dokka-fatjar:${DokkaVersion.version}")) } + protected fun addConfiguration(project: Project) = + project.configurations.create("dokkaRuntime").apply { + defaultDependencies{ dependencies -> dependencies.add(project.dependencies.create("org.jetbrains.dokka:dokka-fatjar:${DokkaVersion.version}")) } + } + protected fun addTasks(project: Project, runtimeConfiguration: Configuration, taskClass: Class) { if(GradleVersion.current() >= GradleVersion.version("4.10")) { - project.tasks.register(taskName, DokkaTask::class.java).configure { + project.tasks.register(taskName, taskClass).configure { it.outputDirectory = File(project.buildDir, taskName).absolutePath } } else { - project.tasks.create(taskName, DokkaTask::class.java).apply { + project.tasks.create(taskName, taskClass).apply { outputDirectory = File(project.buildDir, taskName).absolutePath } } - - project.tasks.withType(DokkaTask::class.java) { task -> + project.tasks.withType(taskClass) { task -> task.multiplatform = project.container(GradlePassConfigurationImpl::class.java) task.configuration = GradlePassConfigurationImpl() - task.dokkaRuntime = dokkaRuntimeConfiguration - task.defaultDokkaRuntime = defaultDokkaRuntimeConfiguration + task.dokkaRuntime = runtimeConfiguration } } } -- cgit