diff options
Diffstat (limited to 'plugins/base/src/main/kotlin')
3 files changed, 63 insertions, 40 deletions
diff --git a/plugins/base/src/main/kotlin/DokkaBase.kt b/plugins/base/src/main/kotlin/DokkaBase.kt index 50d86892..2da3fbd4 100644 --- a/plugins/base/src/main/kotlin/DokkaBase.kt +++ b/plugins/base/src/main/kotlin/DokkaBase.kt @@ -25,6 +25,7 @@ import org.jetbrains.dokka.base.transformers.pages.samples.SamplesTransformer import org.jetbrains.dokka.base.transformers.pages.sourcelinks.SourceLinksTransformer import org.jetbrains.dokka.base.translators.descriptors.DefaultDescriptorToDocumentableTranslator import org.jetbrains.dokka.base.translators.documentables.DefaultDocumentableToPageTranslator +import org.jetbrains.dokka.base.translators.documentables.PageContentBuilder import org.jetbrains.dokka.base.translators.psi.DefaultPsiToDocumentableTranslator import org.jetbrains.dokka.plugability.DokkaPlugin import org.jetbrains.dokka.transformers.pages.PageTransformer @@ -135,7 +136,16 @@ class DokkaBase : DokkaPlugin() { } val sourceLinksTransformer by extending { - htmlPreprocessors providing ::SourceLinksTransformer order { after(rootCreator) } + htmlPreprocessors providing { + SourceLinksTransformer( + it, + PageContentBuilder( + it.single(commentsToContentConverter), + it.single(signatureProvider), + it.logger + ) + ) + } order { after(rootCreator) } } val navigationPageInstaller by extending { diff --git a/plugins/base/src/main/kotlin/transformers/pages/sourcelinks/SourceLinksTransformer.kt b/plugins/base/src/main/kotlin/transformers/pages/sourcelinks/SourceLinksTransformer.kt index 6cb35e66..bf411a1f 100644 --- a/plugins/base/src/main/kotlin/transformers/pages/sourcelinks/SourceLinksTransformer.kt +++ b/plugins/base/src/main/kotlin/transformers/pages/sourcelinks/SourceLinksTransformer.kt @@ -2,23 +2,19 @@ package org.jetbrains.dokka.base.transformers.pages.sourcelinks import com.intellij.psi.PsiElement import com.intellij.psi.PsiDocumentManager -import com.intellij.psi.util.PsiTreeUtil import org.jetbrains.dokka.DokkaConfiguration -import org.jetbrains.dokka.links.DRI +import org.jetbrains.dokka.base.translators.documentables.PageContentBuilder import org.jetbrains.dokka.model.DescriptorDocumentableSource import org.jetbrains.dokka.model.WithExpectActual -import org.jetbrains.dokka.model.properties.PropertyContainer import org.jetbrains.dokka.pages.* import org.jetbrains.dokka.plugability.DokkaContext import org.jetbrains.dokka.transformers.pages.PageTransformer import org.jetbrains.kotlin.descriptors.DeclarationDescriptorWithSource -import org.jetbrains.kotlin.kdoc.psi.api.KDoc -import org.jetbrains.kotlin.psi.KtDeclaration import org.jetbrains.kotlin.resolve.source.getPsi import org.jetbrains.kotlin.utils.addToStdlib.cast import org.jetbrains.kotlin.utils.addToStdlib.safeAs -class SourceLinksTransformer(val context: DokkaContext) : PageTransformer { +class SourceLinksTransformer(val context: DokkaContext, val builder: PageContentBuilder) : PageTransformer { override fun invoke(input: RootPageNode): RootPageNode { @@ -26,15 +22,36 @@ class SourceLinksTransformer(val context: DokkaContext) : PageTransformer { .flatMap { it.sourceLinks.map { sl -> SourceLink(sl, it.platformData) } } return input.transformContentPagesTree { node -> - node.documentable.safeAs<WithExpectActual>()?.sources?.map?.entries?.fold(node) { acc, entry -> - sourceLinks.find { entry.value.path.contains(it.path) && it.platformData == entry.key }?.run { - acc.modified( - content = acc.content.addSource( + node.documentable.safeAs<WithExpectActual>()?.sources?.map?.entries?.let { entries -> + val resolvedSources = entries.mapNotNull { entry -> + sourceLinks.find { entry.value.path.contains(it.path) && it.platformData == entry.key }?.let { + Pair( entry.key, - entry.value.cast<DescriptorDocumentableSource>().toLink(this) + entry.value.cast<DescriptorDocumentableSource>().toLink(it) ) - ) - } ?: acc + } + } + if (resolvedSources.isNotEmpty()) { + val table = builder.contentFor(node.dri.first(), node.documentable!!.platformData.toSet()) { + header(2) { text("Sources") } + +ContentTable( + emptyList(), + resolvedSources.map { + buildGroup(node.dri.first(), setOf(it.first), ContentKind.Source) { + platformDependentHint(node.dri.first(), setOf(it.first)) { + +link("(source)", it.second, ContentKind.Source, mainPlatformData, mainStyles, mainExtra) + } + } + }, + DCI(node.dri, ContentKind.Subtypes), + node.documentable!!.platformData.toSet(), + style = emptySet() + ) + } + node.modified(content = node.content.addTable(table)) + } else { + node + } } ?: node } } @@ -45,40 +62,19 @@ class SourceLinksTransformer(val context: DokkaContext) : PageTransformer { sourceLink.lineSuffix + "${this.descriptor.cast<DeclarationDescriptorWithSource>().source.getPsi()?.lineNumber() ?: 1}" - private fun ContentNode.addSource(platformData: PlatformData, address: String?): ContentNode = - if (address != null) when (this) { + private fun ContentNode.addTable(table: ContentGroup): ContentNode = + when (this) { is ContentGroup -> copy( - children = children + listOf(platformHintedContentResolvedLink(platformData, dci.dri, address)) + children = children + table ) else -> ContentGroup( - children = listOf(this, platformHintedContentResolvedLink(platformData, dci.dri, address)), + children = listOf(this, table), extra = this.extra, platforms = this.platforms, dci = this.dci, style = this.style ) - } else this - - private fun platformHintedContentResolvedLink(platformData: PlatformData, dri: Set<DRI>, address: String) = - PlatformHintedContent( - inner = ContentResolvedLink( - children = listOf( - ContentText( - text = "(source)", - dci = DCI(dri, ContentKind.BriefComment), - platforms = setOf(platformData), - style = emptySet(), - extra = PropertyContainer.empty() - ) - ), - address = address, - extra = PropertyContainer.empty(), - dci = DCI(dri, ContentKind.Source), - platforms = setOf(platformData), - style = emptySet() - ), - platforms = setOf(platformData) - ) + } private fun PsiElement.lineNumber(): Int? { val doc = PsiDocumentManager.getInstance(project).getDocument(containingFile) diff --git a/plugins/base/src/main/kotlin/translators/documentables/PageContentBuilder.kt b/plugins/base/src/main/kotlin/translators/documentables/PageContentBuilder.kt index a99fc6b3..6cb47b7f 100644 --- a/plugins/base/src/main/kotlin/translators/documentables/PageContentBuilder.kt +++ b/plugins/base/src/main/kotlin/translators/documentables/PageContentBuilder.kt @@ -194,6 +194,23 @@ open class PageContentBuilder( } fun link( + text: String, + address: String, + kind: Kind = ContentKind.Main, + platformData: Set<PlatformData> = mainPlatformData, + styles: Set<Style> = mainStyles, + extra: PropertyContainer<ContentNode> = mainExtra + ) = + ContentResolvedLink( + children = listOf(createText(text, kind, platformData, styles, extra)), + address = address, + extra = PropertyContainer.empty(), + dci = DCI(setOf(mainDRI), kind), + platforms = platformData, + style = emptySet() + ) + + fun link( address: DRI, kind: Kind = ContentKind.Main, platformData: Set<PlatformData> = mainPlatformData, |