From f8cf88068368e5ae9a2b2aa90b0bc38e3238fac1 Mon Sep 17 00:00:00 2001 From: Kamil Doległo Date: Sun, 15 Sep 2019 21:31:34 +0200 Subject: Fix a bug with non-native Android --- .../kotlin/org/jetbrains/dokka/gradle/ConfigurationExtractor.kt | 5 ++--- .../src/main/kotlin/org/jetbrains/dokka/gradle/DokkaTask.kt | 9 +++++++-- .../src/main/kotlin/org/jetbrains/dokka/gradle/utils.kt | 3 +++ 3 files changed, 12 insertions(+), 5 deletions(-) (limited to 'runners/gradle-plugin/src/main/kotlin') diff --git a/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/ConfigurationExtractor.kt b/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/ConfigurationExtractor.kt index 96cd0824..9f8dfc33 100644 --- a/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/ConfigurationExtractor.kt +++ b/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/ConfigurationExtractor.kt @@ -13,7 +13,6 @@ import org.gradle.api.plugins.JavaPluginConvention import org.gradle.api.tasks.SourceSet import org.gradle.api.tasks.compile.AbstractCompile import org.jetbrains.dokka.ReflectDsl -import org.jetbrains.kotlin.android.synthetic.diagnostic.AndroidExtensionPropertiesCallChecker import org.jetbrains.kotlin.gradle.dsl.KotlinCommonOptions import org.jetbrains.kotlin.gradle.dsl.KotlinMultiplatformExtension import org.jetbrains.kotlin.gradle.dsl.KotlinSingleTargetExtension @@ -156,9 +155,9 @@ class ConfigurationExtractor(private val project: Project) { .orEmpty() private fun getMainCompilation(target: KotlinTarget?): KotlinCompilation? = - target?.compilations?.getByName(getMainCompilationName()) + target?.compilations?.getByName(getMainCompilationName(target)) - private fun getMainCompilationName() = if (project.isAndroidProject()) + private fun getMainCompilationName(target: KotlinTarget?) = if (target?.isAndroidTarget() == true) getVariants(project).filter { it.name == BuilderConstants.RELEASE }.map { it.name }.first() else KotlinCompilation.MAIN_COMPILATION_NAME 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 f20b6651..4dc23b4b 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 @@ -301,12 +301,12 @@ open class DokkaTask : DefaultTask() { config.samples = config.samples.map { project.file(it).absolutePath } config.includes = config.includes.map { project.file(it).absolutePath } config.suppressedFiles += collectSuppressedFiles(config.sourceRoots) - if (project.isAndroidProject() && !config.noAndroidSdkLink) { + if (project.isAndroidProject() && !config.noAndroidSdkLink) { // TODO: introduce Android as a separate Dokka platform? config.externalDocumentationLinks.add(ANDROID_REFERENCE_URL) } config.externalDocumentationLinks.addAll(externalDocumentationLinks) if (config.platform != null && config.platform.toString().isNotEmpty()) { - config.analysisPlatform = Platform.fromString(config.platform.toString()) + config.analysisPlatform = dokkaPlatformFromString(config.platform.toString()) } if (globalConfig != null) { config.perPackageOptions.addAll(globalConfig.perPackageOptions) @@ -316,6 +316,11 @@ open class DokkaTask : DefaultTask() { return config } + private fun dokkaPlatformFromString(platform: String) = when (platform.toLowerCase()) { + "androidjvm", "android" -> Platform.jvm + else -> Platform.fromString(platform) + } + // Needed for Gradle incremental build @OutputDirectory fun getOutputDirectoryAsFile(): File = project.file(outputDirectory) diff --git a/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/utils.kt b/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/utils.kt index 90dcde7b..d70b0499 100644 --- a/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/utils.kt +++ b/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/utils.kt @@ -2,6 +2,8 @@ package org.jetbrains.dokka.gradle import org.gradle.api.Project import org.gradle.api.UnknownDomainObjectException +import org.jetbrains.kotlin.gradle.plugin.KotlinPlatformType +import org.jetbrains.kotlin.gradle.plugin.KotlinTarget fun Project.isAndroidProject() = try { @@ -13,4 +15,5 @@ fun Project.isAndroidProject() = try { false } +fun KotlinTarget.isAndroidTarget() = this.platformType == KotlinPlatformType.androidJvm fun DokkaTask.isMultiplatformProject() = this.multiplatform.isNotEmpty() \ No newline at end of file -- cgit