aboutsummaryrefslogtreecommitdiff
path: root/plugins/base/src/main/kotlin/parsers
diff options
context:
space:
mode:
authorAndrzej Ratajczak <andrzej.ratajczak98@gmail.com>2020-08-24 10:43:10 +0200
committerSebastian Sellmair <34319766+sellmair@users.noreply.github.com>2020-08-28 15:35:09 +0200
commite64cb9bfbef093bcc4046a5081393f3c9778b42a (patch)
tree5b92ffeabcce5ebc1d8c86240ce4a8891bdd8cda /plugins/base/src/main/kotlin/parsers
parent56199ef712c442a960e11ec9a7bff6de4bc4a532 (diff)
downloaddokka-e64cb9bfbef093bcc4046a5081393f3c9778b42a.tar.gz
dokka-e64cb9bfbef093bcc4046a5081393f3c9778b42a.tar.bz2
dokka-e64cb9bfbef093bcc4046a5081393f3c9778b42a.zip
Fix losing tokens while parsing markdown italic text
Diffstat (limited to 'plugins/base/src/main/kotlin/parsers')
-rw-r--r--plugins/base/src/main/kotlin/parsers/MarkdownParser.kt13
1 files changed, 11 insertions, 2 deletions
diff --git a/plugins/base/src/main/kotlin/parsers/MarkdownParser.kt b/plugins/base/src/main/kotlin/parsers/MarkdownParser.kt
index dfb95373..8422d3be 100644
--- a/plugins/base/src/main/kotlin/parsers/MarkdownParser.kt
+++ b/plugins/base/src/main/kotlin/parsers/MarkdownParser.kt
@@ -48,9 +48,18 @@ class MarkdownParser(
private fun emphasisHandler(node: ASTNode): DocTag =
DocTagsFromIElementFactory.getInstance(
node.type,
- children = listOf(visitNode(node.children[node.children.size / 2]))
+ children = node.children.evaluateChildrenWithDroppedEnclosingTokens(1)
)
+ private fun strongHandler(node: ASTNode): DocTag =
+ DocTagsFromIElementFactory.getInstance(
+ node.type,
+ children = node.children.evaluateChildrenWithDroppedEnclosingTokens(2)
+ )
+
+ private fun List<ASTNode>.evaluateChildrenWithDroppedEnclosingTokens(count: Int) =
+ drop(count).dropLast(count).evaluateChildren()
+
private fun blockquotesHandler(node: ASTNode): DocTag =
DocTagsFromIElementFactory.getInstance(
node.type, children = node.children
@@ -256,7 +265,7 @@ class MarkdownParser(
MarkdownElementTypes.ATX_5,
MarkdownElementTypes.ATX_6 -> headersHandler(node)
MarkdownTokenTypes.HORIZONTAL_RULE -> horizontalRulesHandler(node)
- MarkdownElementTypes.STRONG,
+ MarkdownElementTypes.STRONG -> strongHandler(node)
MarkdownElementTypes.EMPH -> emphasisHandler(node)
MarkdownElementTypes.FULL_REFERENCE_LINK,
MarkdownElementTypes.SHORT_REFERENCE_LINK -> referenceLinksHandler(node)