blob: 96f64eecd46cf3e644e8be5a810265d8b3e34f24 [file] [log] [blame]
Ilya Ryzhenkova0bfdbd2014-07-14 15:00:33 +04001package org.jetbrains.dokka
2
Ilya Ryzhenkov68d3bc82014-07-14 19:34:52 +04003
Ilya Ryzhenkov455d74a2014-09-19 22:25:27 +03004public open class MarkdownFormatService(locationService: LocationService,
Ilya Ryzhenkov455d74a2014-09-19 22:25:27 +03005 signatureGenerator: LanguageService)
Ilya Ryzhenkovd6fd0452014-10-03 20:20:02 +04006: StructuredFormatService(locationService, signatureGenerator) {
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +04007
Ilya Ryzhenkova0bfdbd2014-07-14 15:00:33 +04008 override val extension: String = "md"
Ilya Ryzhenkova0bfdbd2014-07-14 15:00:33 +04009
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040010 override public fun formatBreadcrumbs(items: Iterable<FormatLink>): String {
11 return items.map { formatLink(it) }.joinToString(" / ")
Ilya Ryzhenkovcd7084d2014-07-14 21:15:04 +040012 }
13
Ilya Ryzhenkovfb41c692014-07-15 18:23:15 +040014 override public fun formatText(text: String): String {
15 return text.htmlEscape()
16 }
17
Ilya Ryzhenkov7c6da4b2014-10-03 19:09:31 +040018 override fun formatSymbol(text: String): String {
19 return text.htmlEscape()
20 }
21
22 override fun formatKeyword(text: String): String {
23 return text.htmlEscape()
24 }
25 override fun formatIdentifier(text: String): String {
26 return text.htmlEscape()
27 }
28
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040029 override public fun formatCode(code: String): String {
30 return "`$code`"
Ilya Ryzhenkovcd7084d2014-07-14 21:15:04 +040031 }
32
Ilya Ryzhenkov18399492014-12-22 09:50:17 +020033 override public fun formatList(text: String): String {
34 return text
35 }
36
37 override fun formatListItem(text: String): String {
38 return "* $text"
39 }
40
Ilya Ryzhenkov9f0ff552014-10-13 13:38:40 +040041 override public fun formatStrong(text: String): String {
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040042 return "**$text**"
Ilya Ryzhenkova0bfdbd2014-07-14 15:00:33 +040043 }
Ilya Ryzhenkovcd7084d2014-07-14 21:15:04 +040044
Ilya Ryzhenkov9f0ff552014-10-13 13:38:40 +040045 override fun formatEmphasis(text: String): String {
46 return "*$text*"
47 }
48
Ilya Ryzhenkov499d0822014-07-15 16:18:53 +040049 override public fun formatLink(text: String, location: Location): String {
Ilya Ryzhenkov71cd87e2014-10-03 22:51:44 +040050 return "[$text](${location.path})"
51 }
52
53 override fun formatLink(text: String, href: String): String {
54 return "[$text]($href)"
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040055 }
56
57 override public fun appendLine(to: StringBuilder) {
58 to.appendln()
59 }
60
61 override public fun appendLine(to: StringBuilder, text: String) {
Ilya Ryzhenkovaa59acb2014-07-15 20:05:55 +040062 to.appendln(text)
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040063 }
64
Dmitry Jemerov8ef68182014-12-30 12:36:14 +010065 override public fun appendParagraph(to: StringBuilder, text: String) {
Ilya Ryzhenkov280dc292014-10-14 16:08:10 +040066 to.appendln()
67 to.appendln(text)
68 to.appendln()
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040069 }
70
71 override public fun appendHeader(to: StringBuilder, text: String, level: Int) {
72 appendLine(to)
73 appendLine(to, "${"#".repeat(level)} $text")
74 appendLine(to)
75 }
76
77 override public fun appendBlockCode(to: StringBuilder, lines: Iterable<String>) {
Ilya Ryzhenkovfb41c692014-07-15 18:23:15 +040078 appendLine(to)
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040079 appendLine(to, "```")
80 for (line in lines)
Ilya Ryzhenkovfb41c692014-07-15 18:23:15 +040081 to.appendln(line)
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040082 appendLine(to, "```")
Ilya Ryzhenkovfb41c692014-07-15 18:23:15 +040083 appendLine(to)
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040084 }
85
86 override public fun appendBlockCode(to: StringBuilder, line: String) {
kisenka8fbeb612014-10-10 20:33:05 +040087 appendLine(to)
88 to.appendln("```")
Ilya Ryzhenkovfb41c692014-07-15 18:23:15 +040089 to.appendln(line)
kisenka8fbeb612014-10-10 20:33:05 +040090 to.appendln("```")
91 appendLine(to)
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040092 }
Ilya Ryzhenkov499d0822014-07-15 16:18:53 +040093
Ilya Ryzhenkovaa59acb2014-07-15 20:05:55 +040094 override fun appendTable(to: StringBuilder, body: () -> Unit) {
95 to.appendln()
96 body()
97 to.appendln()
98 }
99
100 override fun appendTableHeader(to: StringBuilder, body: () -> Unit) {
101 body()
102 }
103
104 override fun appendTableBody(to: StringBuilder, body: () -> Unit) {
105 body()
106 }
107
108 override fun appendTableRow(to: StringBuilder, body: () -> Unit) {
kisenka290d5a92014-10-10 16:16:34 +0400109 to.append("| ")
Ilya Ryzhenkovaa59acb2014-07-15 20:05:55 +0400110 body()
111 to.appendln()
112 }
113
114 override fun appendTableCell(to: StringBuilder, body: () -> Unit) {
115 body()
kisenka290d5a92014-10-10 16:16:34 +0400116 to.append(" | ")
Ilya Ryzhenkovaa59acb2014-07-15 20:05:55 +0400117 }
118
Ilya Ryzhenkov499d0822014-07-15 16:18:53 +0400119 var outlineLevel = 0
120 override fun appendOutlineHeader(to: StringBuilder, node: DocumentationNode) {
121 val indent = " ".repeat(outlineLevel)
122 appendLine(to, "$indent- title: ${languageService.renderName(node)}")
123 appendLine(to, "$indent url: ${locationService.location(node).path}")
124 }
125
126 override fun appendOutlineChildren(to: StringBuilder, nodes: Iterable<DocumentationNode>) {
127 val indent = " ".repeat(outlineLevel)
128 appendLine(to, "$indent content:")
129 outlineLevel++
130 for (node in nodes) {
131 appendOutlineHeader(to, node)
132 if (node.members.any()) {
133 appendOutlineChildren(to, node.members)
134 }
135 appendLine(to)
136 }
137 outlineLevel--
138 }
Ilya Ryzhenkov68d3bc82014-07-14 19:34:52 +0400139}