blob: 54298e2a1ee8f7d641901663884fcb3747ae3218 [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 Ryzhenkovaa59acb2014-07-15 20:05:55 +040058 to.append(text)
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040059 }
60
61 override public fun appendHeader(to: StringBuilder, text: String, level: Int) {
62 appendLine(to)
63 appendLine(to, "${"#".repeat(level)} $text")
64 appendLine(to)
65 }
66
67 override public fun appendBlockCode(to: StringBuilder, lines: Iterable<String>) {
Ilya Ryzhenkovfb41c692014-07-15 18:23:15 +040068 appendLine(to)
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040069 appendLine(to, "```")
70 for (line in lines)
Ilya Ryzhenkovfb41c692014-07-15 18:23:15 +040071 to.appendln(line)
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040072 appendLine(to, "```")
Ilya Ryzhenkovfb41c692014-07-15 18:23:15 +040073 appendLine(to)
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040074 }
75
76 override public fun appendBlockCode(to: StringBuilder, line: String) {
kisenka8fbeb612014-10-10 20:33:05 +040077 appendLine(to)
78 to.appendln("```")
Ilya Ryzhenkovfb41c692014-07-15 18:23:15 +040079 to.appendln(line)
kisenka8fbeb612014-10-10 20:33:05 +040080 to.appendln("```")
81 appendLine(to)
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040082 }
Ilya Ryzhenkov499d0822014-07-15 16:18:53 +040083
Ilya Ryzhenkovaa59acb2014-07-15 20:05:55 +040084 override fun appendTable(to: StringBuilder, body: () -> Unit) {
85 to.appendln()
86 body()
87 to.appendln()
88 }
89
90 override fun appendTableHeader(to: StringBuilder, body: () -> Unit) {
91 body()
92 }
93
94 override fun appendTableBody(to: StringBuilder, body: () -> Unit) {
95 body()
96 }
97
98 override fun appendTableRow(to: StringBuilder, body: () -> Unit) {
kisenka290d5a92014-10-10 16:16:34 +040099 to.append("| ")
Ilya Ryzhenkovaa59acb2014-07-15 20:05:55 +0400100 body()
101 to.appendln()
102 }
103
104 override fun appendTableCell(to: StringBuilder, body: () -> Unit) {
105 body()
kisenka290d5a92014-10-10 16:16:34 +0400106 to.append(" | ")
Ilya Ryzhenkovaa59acb2014-07-15 20:05:55 +0400107 }
108
Ilya Ryzhenkov499d0822014-07-15 16:18:53 +0400109 var outlineLevel = 0
110 override fun appendOutlineHeader(to: StringBuilder, node: DocumentationNode) {
111 val indent = " ".repeat(outlineLevel)
112 appendLine(to, "$indent- title: ${languageService.renderName(node)}")
113 appendLine(to, "$indent url: ${locationService.location(node).path}")
114 }
115
116 override fun appendOutlineChildren(to: StringBuilder, nodes: Iterable<DocumentationNode>) {
117 val indent = " ".repeat(outlineLevel)
118 appendLine(to, "$indent content:")
119 outlineLevel++
120 for (node in nodes) {
121 appendOutlineHeader(to, node)
122 if (node.members.any()) {
123 appendOutlineChildren(to, node.members)
124 }
125 appendLine(to)
126 }
127 outlineLevel--
128 }
Ilya Ryzhenkov68d3bc82014-07-14 19:34:52 +0400129}