org.jetbrains.dokka.base.DokkaBase.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of dokka-base Show documentation
Show all versions of dokka-base Show documentation
Dokka is an API documentation engine for Kotlin
/*
* Copyright 2014-2024 JetBrains s.r.o. Use of this source code is governed by the Apache 2.0 license.
*/
package org.jetbrains.dokka.base
import org.jetbrains.dokka.CoreExtensions
import org.jetbrains.dokka.base.generation.SingleModuleGeneration
import org.jetbrains.dokka.base.generation.SourceSetIdUniquenessChecker
import org.jetbrains.dokka.base.renderers.*
import org.jetbrains.dokka.base.renderers.html.*
import org.jetbrains.dokka.base.renderers.html.command.consumers.PathToRootConsumer
import org.jetbrains.dokka.base.renderers.html.command.consumers.ReplaceVersionsConsumer
import org.jetbrains.dokka.base.renderers.html.command.consumers.ResolveLinkConsumer
import org.jetbrains.dokka.base.resolvers.external.DefaultExternalLocationProviderFactory
import org.jetbrains.dokka.base.resolvers.external.ExternalLocationProviderFactory
import org.jetbrains.dokka.base.resolvers.external.javadoc.JavadocExternalLocationProviderFactory
import org.jetbrains.dokka.base.resolvers.local.DokkaLocationProviderFactory
import org.jetbrains.dokka.base.resolvers.local.LocationProviderFactory
import org.jetbrains.dokka.base.resolvers.shared.RecognizedLinkFormat
import org.jetbrains.dokka.base.signatures.KotlinSignatureProvider
import org.jetbrains.dokka.base.signatures.SignatureProvider
import org.jetbrains.dokka.base.templating.ImmediateHtmlCommandConsumer
import org.jetbrains.dokka.base.transformers.documentables.*
import org.jetbrains.dokka.base.transformers.pages.DefaultSamplesTransformer
import org.jetbrains.dokka.base.transformers.pages.annotations.SinceKotlinTransformer
import org.jetbrains.dokka.base.transformers.pages.comments.CommentsToContentConverter
import org.jetbrains.dokka.base.transformers.pages.comments.DocTagToContentConverter
import org.jetbrains.dokka.base.transformers.pages.merger.*
import org.jetbrains.dokka.base.transformers.pages.sourcelinks.SourceLinksTransformer
import org.jetbrains.dokka.base.transformers.pages.tags.CustomTagContentProvider
import org.jetbrains.dokka.base.transformers.pages.tags.SinceKotlinTagContentProvider
import org.jetbrains.dokka.base.translators.documentables.DefaultDocumentableToPageTranslator
import org.jetbrains.dokka.generation.Generation
import org.jetbrains.dokka.plugability.*
import org.jetbrains.dokka.renderers.Renderer
import org.jetbrains.dokka.transformers.documentation.*
import org.jetbrains.dokka.transformers.pages.PageTransformer
@Suppress("unused")
public class DokkaBase : DokkaPlugin() {
public val preMergeDocumentableTransformer: ExtensionPoint by extensionPoint()
public val pageMergerStrategy: ExtensionPoint by extensionPoint()
public val commentsToContentConverter: ExtensionPoint by extensionPoint()
public val customTagContentProvider: ExtensionPoint by extensionPoint()
public val signatureProvider: ExtensionPoint by extensionPoint()
public val locationProviderFactory: ExtensionPoint by extensionPoint()
public val externalLocationProviderFactory: ExtensionPoint by extensionPoint()
public val outputWriter: ExtensionPoint by extensionPoint()
public val htmlPreprocessors: ExtensionPoint by extensionPoint()
/**
* Extension point for providing custom HTML code block renderers.
*
* This extension point allows overriding the rendering of code blocks in different programming languages.
* Multiple renderers can be installed to support different languages independently.
*/
public val htmlCodeBlockRenderers: ExtensionPoint by extensionPoint()
@Deprecated("It is not used anymore")
public val tabSortingStrategy: ExtensionPoint by extensionPoint()
public val immediateHtmlCommandConsumer: ExtensionPoint by extensionPoint()
public val singleGeneration: Extension by extending {
CoreExtensions.generation providing ::SingleModuleGeneration
}
public val documentableMerger: Extension by extending {
CoreExtensions.documentableMerger providing ::DefaultDocumentableMerger
}
public val deprecatedDocumentableFilter: Extension by extending {
preMergeDocumentableTransformer providing ::DeprecatedDocumentableFilterTransformer
}
public val suppressedDocumentableFilter: Extension by extending {
preMergeDocumentableTransformer providing ::SuppressedByConfigurationDocumentableFilterTransformer
}
public val suppressedBySuppressTagDocumentableFilter: Extension by extending {
preMergeDocumentableTransformer providing ::SuppressTagDocumentableFilter
}
public val jvmMappedMethodsFilter: Extension by extending {
preMergeDocumentableTransformer providing ::JvmMappedMethodsDocumentableFilterTransformer order {
before(kotlinArrayDocumentableReplacer)
}
}
public val documentableVisibilityFilter: Extension by extending {
preMergeDocumentableTransformer providing ::DocumentableVisibilityFilterTransformer
}
public val obviousFunctionsVisbilityFilter: Extension by extending {
preMergeDocumentableTransformer providing ::ObviousFunctionsDocumentableFilterTransformer
}
public val inheritedEntriesVisbilityFilter: Extension by extending {
preMergeDocumentableTransformer providing ::InheritedEntriesDocumentableFilterTransformer
}
public val kotlinArrayDocumentableReplacer: Extension by extending {
preMergeDocumentableTransformer providing ::KotlinArrayDocumentableReplacerTransformer
}
public val emptyPackagesFilter: Extension by extending {
preMergeDocumentableTransformer providing ::EmptyPackagesFilterTransformer order {
after(
deprecatedDocumentableFilter,
suppressedDocumentableFilter,
documentableVisibilityFilter,
suppressedBySuppressTagDocumentableFilter,
obviousFunctionsVisbilityFilter,
inheritedEntriesVisbilityFilter,
)
}
}
public val emptyModulesFilter: Extension by extending {
preMergeDocumentableTransformer with EmptyModulesFilterTransformer() order {
after(emptyPackagesFilter)
}
}
public val modulesAndPackagesDocumentation: Extension by extending {
preMergeDocumentableTransformer providing ::ModuleAndPackageDocumentationTransformer
}
public val actualTypealiasAdder: Extension by extending {
CoreExtensions.documentableTransformer with ActualTypealiasAdder()
}
public val kotlinSignatureProvider: Extension by extending {
signatureProvider providing ::KotlinSignatureProvider
}
public val sinceKotlinTransformer: Extension by extending {
CoreExtensions.documentableTransformer providing ::SinceKotlinTransformer applyIf {
DokkaBaseInternalConfiguration.sinceKotlinRenderingEnabled
} order {
before(extensionsExtractor)
}
}
public val inheritorsExtractor: Extension by extending {
CoreExtensions.documentableTransformer with InheritorsExtractorTransformer()
}
public val undocumentedCodeReporter: Extension by extending {
CoreExtensions.documentableTransformer with ReportUndocumentedTransformer()
}
public val extensionsExtractor: Extension by extending {
CoreExtensions.documentableTransformer with ExtensionExtractorTransformer()
}
public val documentableToPageTranslator: Extension by extending {
CoreExtensions.documentableToPageTranslator providing ::DefaultDocumentableToPageTranslator
}
public val docTagToContentConverter: Extension by extending {
commentsToContentConverter with DocTagToContentConverter()
}
public val sinceKotlinTagContentProvider: Extension by extending {
customTagContentProvider with SinceKotlinTagContentProvider applyIf {
DokkaBaseInternalConfiguration.sinceKotlinRenderingEnabled
}
}
public val pageMerger: Extension by extending {
CoreExtensions.pageTransformer providing ::PageMerger
}
public val sourceSetMerger: Extension by extending {
CoreExtensions.pageTransformer providing ::SourceSetMergingPageTransformer
}
public val fallbackMerger: Extension by extending {
pageMergerStrategy providing { ctx -> FallbackPageMergerStrategy(ctx.logger) }
}
public val sameMethodNameMerger: Extension by extending {
pageMergerStrategy providing { ctx -> SameMethodNamePageMergerStrategy(ctx.logger) } order {
before(fallbackMerger)
}
}
public val htmlRenderer: Extension by extending {
CoreExtensions.renderer providing ::HtmlRenderer
}
public val locationProvider: Extension by extending {
locationProviderFactory providing ::DokkaLocationProviderFactory
}
public val javadocLocationProvider: Extension by extending {
externalLocationProviderFactory providing ::JavadocExternalLocationProviderFactory
}
public val dokkaLocationProvider: Extension by extending {
externalLocationProviderFactory providing ::DefaultExternalLocationProviderFactory
}
public val fileWriter: Extension by extending {
outputWriter providing ::FileWriter
}
public val rootCreator: Extension by extending {
htmlPreprocessors with RootCreator applyIf { !delayTemplateSubstitution }
}
public val defaultSamplesTransformer: Extension by extending {
CoreExtensions.pageTransformer providing ::DefaultSamplesTransformer order {
before(pageMerger)
}
}
public val sourceLinksTransformer: Extension by extending {
htmlPreprocessors providing ::SourceLinksTransformer order { after(rootCreator) }
}
public val navigationPageInstaller: Extension by extending {
htmlPreprocessors providing ::NavigationPageInstaller order { after(rootCreator) }
}
public val scriptsInstaller: Extension by extending {
htmlPreprocessors providing ::ScriptsInstaller order { after(rootCreator) }
}
public val stylesInstaller: Extension by extending {
htmlPreprocessors providing ::StylesInstaller order { after(rootCreator) }
}
public val assetsInstaller: Extension by extending {
htmlPreprocessors with AssetsInstaller order { after(rootCreator) } applyIf { !delayTemplateSubstitution }
}
public val customResourceInstaller: Extension by extending {
htmlPreprocessors providing { ctx -> CustomResourceInstaller(ctx) } order {
after(stylesInstaller)
after(scriptsInstaller)
after(assetsInstaller)
}
}
public val packageListCreator: Extension by extending {
htmlPreprocessors providing {
PackageListCreator(it, RecognizedLinkFormat.DokkaHtml)
} order { after(rootCreator) }
}
public val sourcesetDependencyAppender: Extension by extending {
htmlPreprocessors providing ::SourcesetDependencyAppender order { after(rootCreator) }
}
public val resolveLinkConsumer: Extension by extending {
immediateHtmlCommandConsumer with ResolveLinkConsumer
}
public val replaceVersionConsumer: Extension by extending {
immediateHtmlCommandConsumer providing ::ReplaceVersionsConsumer
}
public val pathToRootConsumer: Extension by extending {
immediateHtmlCommandConsumer with PathToRootConsumer
}
public val baseSearchbarDataInstaller: Extension by extending {
htmlPreprocessors providing ::SearchbarDataInstaller order { after(sourceLinksTransformer) }
}
internal val sourceSetIdUniquenessChecker by extending {
CoreExtensions.preGenerationCheck providing ::SourceSetIdUniquenessChecker
}
//
@Suppress("DEPRECATION_ERROR")
@Deprecated(message = org.jetbrains.dokka.base.deprecated.ANALYSIS_API_DEPRECATION_MESSAGE, level = DeprecationLevel.ERROR)
public val kotlinAnalysis: ExtensionPoint by extensionPoint()
@Suppress("DEPRECATION_ERROR")
@Deprecated(message = org.jetbrains.dokka.base.deprecated.ANALYSIS_API_DEPRECATION_MESSAGE, level = DeprecationLevel.ERROR)
public val externalDocumentablesProvider: ExtensionPoint by extensionPoint()
@Suppress("DEPRECATION_ERROR")
@Deprecated(message = org.jetbrains.dokka.base.deprecated.ANALYSIS_API_DEPRECATION_MESSAGE, level = DeprecationLevel.ERROR)
public val externalClasslikesTranslator: ExtensionPoint by extensionPoint()
@Suppress("DeprecatedCallableAddReplaceWith")
@Deprecated(message = org.jetbrains.dokka.base.deprecated.ANALYSIS_API_DEPRECATION_MESSAGE, level = DeprecationLevel.ERROR)
public val descriptorToDocumentableTranslator: org.jetbrains.dokka.plugability.Extension
get() = throw org.jetbrains.dokka.base.deprecated.AnalysisApiDeprecatedError()
@Suppress("DeprecatedCallableAddReplaceWith")
@Deprecated(message = org.jetbrains.dokka.base.deprecated.ANALYSIS_API_DEPRECATION_MESSAGE, level = DeprecationLevel.ERROR)
public val psiToDocumentableTranslator: org.jetbrains.dokka.plugability.Extension
get() = throw org.jetbrains.dokka.base.deprecated.AnalysisApiDeprecatedError()
@Suppress("DEPRECATION_ERROR", "DeprecatedCallableAddReplaceWith")
@Deprecated(message = org.jetbrains.dokka.base.deprecated.ANALYSIS_API_DEPRECATION_MESSAGE, level = DeprecationLevel.ERROR)
public val defaultKotlinAnalysis: org.jetbrains.dokka.plugability.Extension
get() = throw org.jetbrains.dokka.base.deprecated.AnalysisApiDeprecatedError()
@Suppress("DEPRECATION_ERROR", "DeprecatedCallableAddReplaceWith")
@Deprecated(message = org.jetbrains.dokka.base.deprecated.ANALYSIS_API_DEPRECATION_MESSAGE, level = DeprecationLevel.ERROR)
public val defaultExternalDocumentablesProvider: org.jetbrains.dokka.plugability.Extension
get() = throw org.jetbrains.dokka.base.deprecated.AnalysisApiDeprecatedError()
@Suppress("DEPRECATION_ERROR", "DeprecatedCallableAddReplaceWith")
@Deprecated(message = org.jetbrains.dokka.base.deprecated.ANALYSIS_API_DEPRECATION_MESSAGE, level = DeprecationLevel.ERROR)
public val defaultExternalClasslikesTranslator: org.jetbrains.dokka.plugability.Extension
get() = throw org.jetbrains.dokka.base.deprecated.AnalysisApiDeprecatedError()
//
@OptIn(DokkaPluginApiPreview::class)
override fun pluginApiPreviewAcknowledgement(): PluginApiPreviewAcknowledgement =
PluginApiPreviewAcknowledgement
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy