org.jetbrains.dokka.gfm.templateProcessing.GfmTemplateProcessingStrategy.kt Maven / Gradle / Ivy
/*
* Copyright 2014-2024 JetBrains s.r.o. Use of this source code is governed by the Apache 2.0 license.
*/
package org.jetbrains.dokka.gfm.templateProcessing
import org.jetbrains.dokka.DokkaConfiguration
import org.jetbrains.dokka.allModulesPage.AllModulesPagePlugin
import org.jetbrains.dokka.base.templating.parseJson
import org.jetbrains.dokka.gfm.GfmCommand
import org.jetbrains.dokka.gfm.GfmCommand.Companion.command
import org.jetbrains.dokka.gfm.GfmCommand.Companion.label
import org.jetbrains.dokka.gfm.GfmCommand.Companion.templateCommandRegex
import org.jetbrains.dokka.gfm.ResolveLinkGfmCommand
import org.jetbrains.dokka.links.DRI
import org.jetbrains.dokka.plugability.DokkaContext
import org.jetbrains.dokka.plugability.plugin
import org.jetbrains.dokka.plugability.querySingle
import org.jetbrains.dokka.templates.TemplateProcessingStrategy
import java.io.BufferedWriter
import java.io.File
public class GfmTemplateProcessingStrategy(
public val context: DokkaContext
) : TemplateProcessingStrategy {
private val externalModuleLinkResolver =
context.plugin().querySingle { externalModuleLinkResolver }
override fun process(input: File, output: File, moduleContext: DokkaConfiguration.DokkaModuleDescription?): Boolean =
if (input.extension == "md") {
input.bufferedReader().use { reader ->
//This should also work whenever we have a misconfigured dokka and output is pointing to the input
//the same way that html processing does
if (input.absolutePath == output.absolutePath) {
context.logger.info("Attempting to process GFM templates in place for directory $input, this suggests miss configuration.")
val lines = reader.readLines()
output.bufferedWriter().use { writer ->
lines.forEach { line ->
writer.processAndWrite(line, output)
}
}
} else {
output.bufferedWriter().use { writer ->
reader.lineSequence().forEach { line ->
writer.processAndWrite(line, output)
}
}
}
}
true
} else false
private fun BufferedWriter.processAndWrite(line: String, output: File) =
processLine(line, output).run {
write(this)
newLine()
}
private fun processLine(line: String, output: File): String =
line.replace(templateCommandRegex) {
when (val command = parseJson(it.command)) {
is ResolveLinkGfmCommand -> resolveLink(output, command.dri, it.label)
}
}
private fun resolveLink(fileContext: File, dri: DRI, label: String): String =
externalModuleLinkResolver.resolve(dri, fileContext)?.let { address ->
"[$label]($address)"
} ?: label
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy