From 37d12bed40edc226d96d0e1a4b28a24583ece94f Mon Sep 17 00:00:00 2001 From: "sebastian.sellmair" Date: Wed, 22 Jul 2020 11:12:16 +0200 Subject: DokkaConfiguration: Use `Set` instead of `List` when collections are expected to be distinct --- .../jetbrains/dokka/gradle/DokkaCollectorTask.kt | 2 +- .../jetbrains/dokka/gradle/DokkaMultimoduleTask.kt | 4 +- .../kotlin/org/jetbrains/dokka/gradle/DokkaTask.kt | 2 +- .../dokka/gradle/GradleDokkaSourceSetBuilder.kt | 54 ++++++++++------------ .../dokka/gradle/GradleSourceRootBuilder.kt | 15 ------ .../jetbrains/dokka/gradle/KotlinSourceSetGist.kt | 1 + .../gradle/sourceSetKotlinGistConfiguration.kt | 7 ++- 7 files changed, 34 insertions(+), 51 deletions(-) delete mode 100644 runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/GradleSourceRootBuilder.kt (limited to 'runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka') diff --git a/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/DokkaCollectorTask.kt b/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/DokkaCollectorTask.kt index 7a73d633..4762c333 100644 --- a/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/DokkaCollectorTask.kt +++ b/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/DokkaCollectorTask.kt @@ -10,7 +10,7 @@ open class DokkaCollectorTask : AbstractDokkaParentTask() { cacheRoot = cacheRoot, failOnWarning = failOnWarning, offlineMode = offlineMode, - pluginsClasspath = plugins.resolve().toList(), + pluginsClasspath = plugins.resolve().toSet(), ) val subprojectDokkaConfigurations = dokkaTasks.map { dokkaTask -> dokkaTask.buildDokkaConfiguration() } diff --git a/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/DokkaMultimoduleTask.kt b/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/DokkaMultimoduleTask.kt index 8369954b..48a9721f 100644 --- a/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/DokkaMultimoduleTask.kt +++ b/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/DokkaMultimoduleTask.kt @@ -2,6 +2,7 @@ package org.jetbrains.dokka.gradle import org.gradle.api.internal.tasks.TaskDependencyInternal import org.gradle.api.tasks.Input +import org.gradle.api.tasks.Internal import org.jetbrains.dokka.DokkaConfigurationImpl import org.jetbrains.dokka.DokkaModuleDescriptionImpl import org.jetbrains.dokka.DokkaMultimoduleBootstrapImpl @@ -16,6 +17,7 @@ open class DokkaMultimoduleTask : AbstractDokkaParentTask(DokkaMultimoduleBootst @Input var documentationFileName: String = "README.md" + @Internal override fun getTaskDependencies(): TaskDependencyInternal { return super.getTaskDependencies() + dokkaTasks } @@ -27,7 +29,7 @@ open class DokkaMultimoduleTask : AbstractDokkaParentTask(DokkaMultimoduleBootst pluginsConfiguration = pluginsConfiguration, failOnWarning = failOnWarning, offlineMode = offlineMode, - pluginsClasspath = plugins.resolve().toList(), + pluginsClasspath = plugins.resolve().toSet(), modules = dokkaTasks.map { dokkaTask -> DokkaModuleDescriptionImpl( name = dokkaTask.project.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 a74068ae..06b936ce 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 @@ -29,7 +29,7 @@ open class DokkaTask : AbstractDokkaTask(DokkaBootstrapImpl::class) { failOnWarning = failOnWarning, sourceSets = dokkaSourceSets.build(), pluginsConfiguration = pluginsConfiguration, - pluginsClasspath = plugins.resolve().toList() + pluginsClasspath = plugins.resolve() ) } } diff --git a/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/GradleDokkaSourceSetBuilder.kt b/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/GradleDokkaSourceSetBuilder.kt index e420e1a5..09c9bec9 100644 --- a/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/GradleDokkaSourceSetBuilder.kt +++ b/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/GradleDokkaSourceSetBuilder.kt @@ -27,7 +27,7 @@ open class GradleDokkaSourceSetBuilder constructor( @Classpath @Optional - var classpath: List = emptyList() + val classpath: MutableSet = mutableSetOf() @Input @Optional @@ -41,18 +41,18 @@ open class GradleDokkaSourceSetBuilder constructor( val sourceSetID: DokkaSourceSetID = DokkaSourceSetID(project, name) @Nested - var sourceRoots: MutableList = mutableListOf() + val sourceRoots: MutableSet = mutableSetOf() @Input - var dependentSourceSets: MutableSet = mutableSetOf() + val dependentSourceSets: MutableSet = mutableSetOf() @InputFiles @Optional - var samples: List = emptyList() + val samples: MutableSet = mutableSetOf() @InputFiles @Optional - var includes: List = emptyList() + val includes: MutableSet = mutableSetOf() @Input var includeNonPublic: Boolean = DokkaDefaults.includeNonPublic @@ -73,13 +73,13 @@ open class GradleDokkaSourceSetBuilder constructor( var jdkVersion: Int = DokkaDefaults.jdkVersion @Nested - var sourceLinks: MutableList = mutableListOf() + val sourceLinks: MutableSet = mutableSetOf() @Nested - var perPackageOptions: MutableList = mutableListOf() + val perPackageOptions: MutableList = mutableListOf() @Nested - var externalDocumentationLinks: MutableList = mutableListOf() + val externalDocumentationLinks: MutableSet = mutableSetOf() @Input @Optional @@ -99,7 +99,7 @@ open class GradleDokkaSourceSetBuilder constructor( var noAndroidSdkLink: Boolean = false @Input - var suppressedFiles: List = emptyList() + val suppressedFiles: MutableSet = mutableSetOf() @Input @Optional @@ -134,15 +134,13 @@ open class GradleDokkaSourceSetBuilder constructor( } // TODO NOW: Cover with tests - fun sourceRoot(c: Closure) { - val configured = ConfigureUtil.configure(c, GradleSourceRootBuilder()) - sourceRoots.add(configured) + + fun sourceRoot(file: File) { + sourceRoots.add(file) } - fun sourceRoot(action: Action) { - val sourceRoot = GradleSourceRootBuilder() - action.execute(sourceRoot) - sourceRoots.add(sourceRoot) + fun sourceRoot(path: String) { + sourceRoots.add(project.file(path)) } fun sourceLink(c: Closure) { @@ -241,33 +239,31 @@ open class GradleDokkaSourceSetBuilder constructor( else -> Platform.DEFAULT } - val sourceRoots = sourceRoots.build().distinct() - - val suppressedFiles = suppressedFiles + project.collectSuppressedFiles(sourceRoots) + val suppressedFiles = suppressedFiles + project.collectSuppressedFiles(sourceRoots.toSet()) return DokkaSourceSetImpl( - classpath = classpath.distinct().toList(), + classpath = classpath.toSet(), moduleDisplayName = moduleDisplayName, displayName = displayName, sourceSetID = sourceSetID, - sourceRoots = sourceRoots, + sourceRoots = sourceRoots.toSet(), dependentSourceSets = dependentSourceSets.toSet(), - samples = samples.toList(), - includes = includes.toList(), + samples = samples.toSet(), + includes = includes.toSet(), includeNonPublic = includeNonPublic, includeRootPackage = includeRootPackage, reportUndocumented = reportUndocumented, skipEmptyPackages = skipEmptyPackages, skipDeprecated = skipDeprecated, jdkVersion = jdkVersion, - sourceLinks = sourceLinks.build(), + sourceLinks = sourceLinks.build().toSet(), perPackageOptions = perPackageOptions.build(), - externalDocumentationLinks = externalDocumentationLinks, + externalDocumentationLinks = externalDocumentationLinks.toSet(), languageVersion = languageVersion, apiVersion = apiVersion, noStdlibLink = noStdlibLink, noJdkLink = noJdkLink, - suppressedFiles = suppressedFiles, + suppressedFiles = suppressedFiles.toSet(), analysisPlatform = analysisPlatform ) } @@ -286,13 +282,13 @@ fun GradleDokkaSourceSetBuilder.dependsOn(sourceSet: AndroidSourceSet) { } // TODO NOW: Test -private fun Project.collectSuppressedFiles(sourceRoots: List): List = +private fun Project.collectSuppressedFiles(sourceRoots: Set): Set = if (project.isAndroidProject()) { val generatedRoot = project.buildDir.resolve("generated").absoluteFile sourceRoots - .map { it.directory } .filter { it.startsWith(generatedRoot) } .flatMap { it.walk().toList() } + .toSet() } else { - emptyList() + emptySet() } diff --git a/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/GradleSourceRootBuilder.kt b/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/GradleSourceRootBuilder.kt deleted file mode 100644 index 687dec9c..00000000 --- a/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/GradleSourceRootBuilder.kt +++ /dev/null @@ -1,15 +0,0 @@ -package org.jetbrains.dokka.gradle - -import org.gradle.api.tasks.InputDirectory -import org.jetbrains.dokka.DokkaConfigurationBuilder -import org.jetbrains.dokka.SourceRootImpl -import java.io.File - -class GradleSourceRootBuilder : DokkaConfigurationBuilder { - @InputDirectory - var directory: File? = null - - override fun build(): SourceRootImpl { - return SourceRootImpl(checkNotNull(directory) { "directory not set" }) - } -} diff --git a/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/KotlinSourceSetGist.kt b/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/KotlinSourceSetGist.kt index 334aae15..6e202ac3 100644 --- a/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/KotlinSourceSetGist.kt +++ b/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/KotlinSourceSetGist.kt @@ -11,6 +11,7 @@ import org.jetbrains.kotlin.gradle.plugin.KotlinSourceSet import org.jetbrains.kotlin.gradle.tasks.KotlinCompile import java.io.File +// TODO NOW: Test this all private typealias KotlinCompilation = org.jetbrains.kotlin.gradle.plugin.KotlinCompilation diff --git a/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/sourceSetKotlinGistConfiguration.kt b/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/sourceSetKotlinGistConfiguration.kt index 9bb11f36..88833a76 100644 --- a/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/sourceSetKotlinGistConfiguration.kt +++ b/runners/gradle-plugin/src/main/kotlin/org/jetbrains/dokka/gradle/sourceSetKotlinGistConfiguration.kt @@ -9,13 +9,12 @@ fun GradleDokkaSourceSetBuilder.configureWithKotlinSourceSet(sourceSet: KotlinSo } internal fun GradleDokkaSourceSetBuilder.configureWithKotlinSourceSetGist(sourceSet: KotlinSourceSetGist) { - sourceRoots.addAll(sourceRoots.union(sourceSet.sourceRoots.toSourceRoots()).distinct()) + sourceRoots.addAll(sourceRoots.union(sourceSet.sourceRoots).distinct()) dependentSourceSets.addAll(dependentSourceSets) dependentSourceSets.addAll(sourceSet.dependentSourceSets.map { DokkaSourceSetID(project, it) }) - classpath = classpath.union(sourceSet.classpath).distinct() + classpath.addAll(sourceSet.classpath) if (platform == null && sourceSet.platform != "") platform = sourceSet.platform } -private fun Iterable.toSourceRoots(): List = - this.filter { it.exists() }.map { GradleSourceRootBuilder().apply { directory = it } } + -- cgit