aboutsummaryrefslogtreecommitdiff
path: root/plugins/base/src/main/kotlin
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/base/src/main/kotlin')
-rw-r--r--plugins/base/src/main/kotlin/transformers/documentables/DefaultDocumentableMerger.kt34
1 files changed, 1 insertions, 33 deletions
diff --git a/plugins/base/src/main/kotlin/transformers/documentables/DefaultDocumentableMerger.kt b/plugins/base/src/main/kotlin/transformers/documentables/DefaultDocumentableMerger.kt
index a7cd171e..053aaa79 100644
--- a/plugins/base/src/main/kotlin/transformers/documentables/DefaultDocumentableMerger.kt
+++ b/plugins/base/src/main/kotlin/transformers/documentables/DefaultDocumentableMerger.kt
@@ -1,24 +1,20 @@
package org.jetbrains.dokka.base.transformers.documentables
import org.jetbrains.dokka.DokkaConfiguration
-import org.jetbrains.dokka.DokkaSourceSetID
import org.jetbrains.dokka.model.*
import org.jetbrains.dokka.model.properties.ExtraProperty
import org.jetbrains.dokka.model.properties.MergeStrategy
-import org.jetbrains.dokka.model.properties.WithExtraProperties
import org.jetbrains.dokka.model.properties.mergeExtras
import org.jetbrains.dokka.plugability.DokkaContext
import org.jetbrains.dokka.transformers.documentation.DocumentableMerger
import org.jetbrains.kotlin.utils.addToStdlib.firstNotNullResult
-import org.jetbrains.kotlin.utils.addToStdlib.safeAs
internal class DefaultDocumentableMerger(val context: DokkaContext) : DocumentableMerger {
private val dependencyInfo = context.getDependencyInfo()
-
override fun invoke(modules: Collection<DModule>): DModule {
- return topologicalSort(modules).reduce { left, right ->
+ return modules.reduce { left, right ->
val list = listOf(left, right)
DModule(
name = modules.map { it.name }.distinct().joinToString("|"),
@@ -32,34 +28,6 @@ internal class DefaultDocumentableMerger(val context: DokkaContext) : Documentab
}
}
- private fun topologicalSort(allModules: Collection<DModule>): List<DModule> {
-
- val modulesMap: Map<DokkaSourceSetID, ModuleOfDifferentTranslators> =
- allModules.groupBy { it.sourceSets.single().sourceSetID }
-
- //this returns representation of graph where directed edges are leading from module to modules that depend on it
- val graph: Map<ModuleOfDifferentTranslators, List<ModuleOfDifferentTranslators>> =
- modulesMap.flatMap { (_, module) ->
- module.first().sourceSets.single().dependentSourceSets.map { sourceSet ->
- modulesMap[sourceSet]!! to module
- }
- }.groupingBy { it.first }.fold({ _, value -> listOf(value.second) }) { _, accumulator, value ->
- accumulator + listOf(value.second)
- }
-
- val visited = modulesMap.map { it.value to false }.toMap().toMutableMap()
- val topologicalSortedList: MutableList<ModuleOfDifferentTranslators> = mutableListOf()
-
- fun dfs(module: ModuleOfDifferentTranslators) {
- visited[module] = true
- graph[module]?.forEach { if (!visited[it]!!) dfs(it) }
- topologicalSortedList.add(0, module)
- }
- modulesMap.values.forEach { if (!visited[it]!!) dfs(it) }
-
- return topologicalSortedList.flatten()
- }
-
private fun DokkaContext.getDependencyInfo()
: Map<DokkaConfiguration.DokkaSourceSet, List<DokkaConfiguration.DokkaSourceSet>> {