org.jetbrains.dokka.base.resolvers.local.LocationProvider.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
The newest version!
/*
* 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.resolvers.local
import org.jetbrains.dokka.DokkaException
import org.jetbrains.dokka.base.resolvers.local.DokkaLocationProvider.Companion.identifierToFilename
import org.jetbrains.dokka.links.DRI
import org.jetbrains.dokka.model.DisplaySourceSet
import org.jetbrains.dokka.pages.PageNode
public interface LocationProvider {
public fun resolve(dri: DRI, sourceSets: Set, context: PageNode? = null): String?
public fun resolve(node: PageNode, context: PageNode? = null, skipExtension: Boolean = false): String?
public fun pathToRoot(from: PageNode): String
public fun ancestors(node: PageNode): List
/**
* This method should return guessed filesystem location for a given [DRI]
* It is used to decide if a [DRI] should be present in the relocation list of the
* generated package-list so it is ok if the path differs from the one returned by [resolve]
* @return Path to a giver [DRI] or null if path should not be considered for relocations
*/
public fun expectedLocationForDri(dri: DRI): String =
(listOf(dri.packageName) +
dri.classNames?.split(".")?.map { identifierToFilename(it) }.orEmpty() +
listOf(dri.callable?.let { identifierToFilename(it.name) } ?: "index")
).filterNotNull().joinToString("/")
}
public fun LocationProvider.resolveOrThrow(
dri: DRI, sourceSets: Set,
context: PageNode? = null
): String {
return resolve(dri = dri, sourceSets = sourceSets, context = context)
?: throw DokkaException("Cannot resolve path for $dri")
}
public fun LocationProvider.resolveOrThrow(
node: PageNode,
context: PageNode? = null,
skipExtension: Boolean = false
): String {
return resolve(node = node, context = context, skipExtension = skipExtension)
?: throw DokkaException("Cannot resolve path for ${node.name}")
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy