diff options
author | Simon Ogorodnik <Simon.Ogorodnik@jetbrains.com> | 2017-05-11 21:37:33 +0300 |
---|---|---|
committer | Simon Ogorodnik <Simon.Ogorodnik@jetbrains.com> | 2017-05-11 21:37:33 +0300 |
commit | 46b615b49fd9af994fc85c84596aa73bebed476c (patch) | |
tree | c0ec544d471f4bc37b3b73c7cd9fcf269b4ba854 /core/src/main/kotlin/Model | |
parent | 0e8733ead6d5c4c6db7e4fe8a1f34b7598823290 (diff) | |
download | dokka-46b615b49fd9af994fc85c84596aa73bebed476c.tar.gz dokka-46b615b49fd9af994fc85c84596aa73bebed476c.tar.bz2 dokka-46b615b49fd9af994fc85c84596aa73bebed476c.zip |
Resolve links in package docs in whole module
#KT-16485 fixed
Diffstat (limited to 'core/src/main/kotlin/Model')
-rw-r--r-- | core/src/main/kotlin/Model/PackageDocs.kt | 13 |
1 files changed, 9 insertions, 4 deletions
diff --git a/core/src/main/kotlin/Model/PackageDocs.kt b/core/src/main/kotlin/Model/PackageDocs.kt index 5ebf2119..d057d4d0 100644 --- a/core/src/main/kotlin/Model/PackageDocs.kt +++ b/core/src/main/kotlin/Model/PackageDocs.kt @@ -17,7 +17,7 @@ class PackageDocs val packageContent: Map<String, Content> get() = _packageContent - fun parse(fileName: String, linkResolveContext: LazyPackageDescriptor?) { + fun parse(fileName: String, linkResolveContext: List<LazyPackageDescriptor>) { val file = File(fileName) if (file.exists()) { val text = file.readText() @@ -51,9 +51,14 @@ class PackageDocs private fun findOrCreatePackageContent(packageName: String) = _packageContent.getOrPut(packageName) { -> MutableContent() } - private fun resolveContentLink(href: String, linkResolveContext: LazyPackageDescriptor?): ContentBlock { - if (linkResolveContext != null && linkResolver != null) { - return linkResolver.resolveContentLink(linkResolveContext, href) + private fun resolveContentLink(href: String, linkResolveContext: List<LazyPackageDescriptor>): ContentBlock { + if (linkResolver != null) { + linkResolveContext + .asSequence() + .map { p -> linkResolver.tryResolveContentLink(p, href) } + .filterNotNull() + .firstOrNull() + ?.let { return it } } return ContentExternalLink("#") } |