package org.jetbrains.dokka import java.util.LinkedHashSet public open class DocumentationNode(val name: String, val content: Content, val kind: DocumentationNode.Kind) { private val references = LinkedHashSet() public val summary: ContentNode get() { val contentSection = content.sections["\$summary"] if (contentSection != null) return contentSection val ownerSection = owner?.content?.sections?.get(name) if (ownerSection != null) return ownerSection return ContentNode.empty } public val owner: DocumentationNode? get() = references(DocumentationReference.Kind.Owner).singleOrNull()?.to public val details: List get() = references(DocumentationReference.Kind.Detail).map { it.to } public val members: List get() = references(DocumentationReference.Kind.Member).map { it.to } public val extensions: List get() = references(DocumentationReference.Kind.Extension).map { it.to } public val inheritors: List get() = references(DocumentationReference.Kind.Inheritor).map { it.to } public val links: List get() = references(DocumentationReference.Kind.Link).map { it.to } public val annotations: List get() = references(DocumentationReference.Kind.Annotation).map { it.to } // TODO: Should we allow node mutation? Model merge will copy by ref, so references are transparent, which could nice public fun addReferenceTo(to: DocumentationNode, kind: DocumentationReference.Kind) { references.add(DocumentationReference(this, to, kind)) } public fun addAllReferencesFrom(other: DocumentationNode) { references.addAll(other.references) } public fun details(kind: DocumentationNode.Kind): List = details.filter { it.kind == kind } public fun members(kind: DocumentationNode.Kind): List = members.filter { it.kind == kind } public fun links(kind: DocumentationNode.Kind): List = links.filter { it.kind == kind } public fun detail(kind: DocumentationNode.Kind): DocumentationNode = details.filter { it.kind == kind }.single() public fun member(kind: DocumentationNode.Kind): DocumentationNode = members.filter { it.kind == kind }.single() public fun link(kind: DocumentationNode.Kind): DocumentationNode = links.filter { it.kind == kind }.single() public fun references(kind: DocumentationReference.Kind): List = references.filter { it.kind == kind } public fun allReferences(): Set = references public override fun toString(): String { return "$kind:$name" } public enum class Kind { Unknown Package Class Interface Enum AnnotationClass EnumItem Object Constructor Function Property PropertyAccessor ClassObjectProperty ClassObjectFunction Parameter Receiver TypeParameter Type Supertype UpperBound LowerBound Exception Modifier Module Annotation } } val DocumentationNode.path: List get() { val parent = owner if (parent == null) return listOf(this) return parent.path + this }