blob: 8f9699c2ca63c98d7039e26cbccc353611a4c8a2 [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 Ryzhenkov9f0ff552014-10-13 13:38:40 +040033 override public fun formatStrong(text: String): String {
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040034 return "**$text**"
Ilya Ryzhenkova0bfdbd2014-07-14 15:00:33 +040035 }
Ilya Ryzhenkovcd7084d2014-07-14 21:15:04 +040036
Ilya Ryzhenkov9f0ff552014-10-13 13:38:40 +040037 override fun formatEmphasis(text: String): String {
38 return "*$text*"
39 }
40
Ilya Ryzhenkov499d0822014-07-15 16:18:53 +040041 override public fun formatLink(text: String, location: Location): String {
Ilya Ryzhenkov71cd87e2014-10-03 22:51:44 +040042 return "[$text](${location.path})"
43 }
44
45 override fun formatLink(text: String, href: String): String {
46 return "[$text]($href)"
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040047 }
48
49 override public fun appendLine(to: StringBuilder) {
50 to.appendln()
51 }
52
53 override public fun appendLine(to: StringBuilder, text: String) {
Ilya Ryzhenkovaa59acb2014-07-15 20:05:55 +040054 to.appendln(text)
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040055 }
56
57 override public fun appendText(to: StringBuilder, text: String) {
Ilya Ryzhenkov280dc292014-10-14 16:08:10 +040058 to.appendln()
59 to.appendln(text)
60 to.appendln()
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040061 }
62
63 override public fun appendHeader(to: StringBuilder, text: String, level: Int) {
64 appendLine(to)
65 appendLine(to, "${"#".repeat(level)} $text")
66 appendLine(to)
67 }
68
69 override public fun appendBlockCode(to: StringBuilder, lines: Iterable<String>) {
Ilya Ryzhenkovfb41c692014-07-15 18:23:15 +040070 appendLine(to)
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040071 appendLine(to, "```")
72 for (line in lines)
Ilya Ryzhenkovfb41c692014-07-15 18:23:15 +040073 to.appendln(line)
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040074 appendLine(to, "```")
Ilya Ryzhenkovfb41c692014-07-15 18:23:15 +040075 appendLine(to)
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040076 }
77
78 override public fun appendBlockCode(to: StringBuilder, line: String) {
kisenka8fbeb612014-10-10 20:33:05 +040079 appendLine(to)
80 to.appendln("```")
Ilya Ryzhenkovfb41c692014-07-15 18:23:15 +040081 to.appendln(line)
kisenka8fbeb612014-10-10 20:33:05 +040082 to.appendln("```")
83 appendLine(to)
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040084 }
Ilya Ryzhenkov499d0822014-07-15 16:18:53 +040085
Ilya Ryzhenkovaa59acb2014-07-15 20:05:55 +040086 override fun appendTable(to: StringBuilder, body: () -> Unit) {
87 to.appendln()
88 body()
89 to.appendln()
90 }
91
92 override fun appendTableHeader(to: StringBuilder, body: () -> Unit) {
93 body()
94 }
95
96 override fun appendTableBody(to: StringBuilder, body: () -> Unit) {
97 body()
98 }
99
100 override fun appendTableRow(to: StringBuilder, body: () -> Unit) {
kisenka290d5a92014-10-10 16:16:34 +0400101 to.append("| ")
Ilya Ryzhenkovaa59acb2014-07-15 20:05:55 +0400102 body()
103 to.appendln()
104 }
105
106 override fun appendTableCell(to: StringBuilder, body: () -> Unit) {
107 body()
kisenka290d5a92014-10-10 16:16:34 +0400108 to.append(" | ")
Ilya Ryzhenkovaa59acb2014-07-15 20:05:55 +0400109 }
110
Ilya Ryzhenkov499d0822014-07-15 16:18:53 +0400111 var outlineLevel = 0
112 override fun appendOutlineHeader(to: StringBuilder, node: DocumentationNode) {
113 val indent = " ".repeat(outlineLevel)
114 appendLine(to, "$indent- title: ${languageService.renderName(node)}")
115 appendLine(to, "$indent url: ${locationService.location(node).path}")
116 }
117
118 override fun appendOutlineChildren(to: StringBuilder, nodes: Iterable<DocumentationNode>) {
119 val indent = " ".repeat(outlineLevel)
120 appendLine(to, "$indent content:")
121 outlineLevel++
122 for (node in nodes) {
123 appendOutlineHeader(to, node)
124 if (node.members.any()) {
125 appendOutlineChildren(to, node.members)
126 }
127 appendLine(to)
128 }
129 outlineLevel--
130 }
Ilya Ryzhenkov68d3bc82014-07-14 19:34:52 +0400131}