From 721e0247e1a633882cb89e9c18d6be332054e87e Mon Sep 17 00:00:00 2001 From: vmishenev Date: Fri, 20 Aug 2021 02:14:36 +0300 Subject: Handle `@link` tag --- .../src/main/kotlin/translators/psi/parsers/JavadocParser.kt | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) (limited to 'plugins/base/src/main') diff --git a/plugins/base/src/main/kotlin/translators/psi/parsers/JavadocParser.kt b/plugins/base/src/main/kotlin/translators/psi/parsers/JavadocParser.kt index 8bc950b7..6de3e0e0 100644 --- a/plugins/base/src/main/kotlin/translators/psi/parsers/JavadocParser.kt +++ b/plugins/base/src/main/kotlin/translators/psi/parsers/JavadocParser.kt @@ -312,9 +312,8 @@ class JavadocParser( } private fun PsiElement.toDocumentationLinkString( - labelElement: List? = null + label: String = "" ): String { - val label = labelElement?.toList().takeUnless { it.isNullOrEmpty() } ?: listOf(defaultLabel()) val dri = reference?.resolve()?.takeIf { it !is PsiParameter }?.let { val dri = DRI.from(it) @@ -322,7 +321,7 @@ class JavadocParser( dri.toString() } ?: UNRESOLVED_PSI_ELEMENT - return """${label.joinToString(" ") { it.text }}""" + return """${label.ifBlank{ defaultLabel().text }}""" } private fun convertInlineDocTag( @@ -332,7 +331,9 @@ class JavadocParser( ) = when (tag.name) { "link", "linkplain" -> tag.referenceElement() - ?.toDocumentationLinkString(tag.dataElements.filterIsInstance()) + ?.toDocumentationLinkString(tag.dataElements.filterIsInstance().joinToString("") { + it.stringifyElementAsText(keepFormatting = true).orEmpty() + }) "code" -> "${dataElementsAsText(tag)}" "literal" -> "${dataElementsAsText(tag)}" "index" -> "${tag.children.filterIsInstance().joinToString { it.text }}" @@ -345,7 +346,7 @@ class JavadocParser( private fun dataElementsAsText(tag: PsiInlineDocTag) = tag.dataElements.joinToString("") { - it.stringifyElementAsText(keepFormatting = true).toString() + it.stringifyElementAsText(keepFormatting = true).orEmpty() }.htmlEscape() private fun createLink(element: Element, children: List): DocTag { -- cgit