blob: a835a6737dc2b0ee550914844844cf9e43d1abab [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 Ryzhenkov62cb5092014-07-15 15:54:05 +040033 override public fun formatBold(text: String): String {
34 return "**$text**"
Ilya Ryzhenkova0bfdbd2014-07-14 15:00:33 +040035 }
Ilya Ryzhenkovcd7084d2014-07-14 21:15:04 +040036
Ilya Ryzhenkov499d0822014-07-15 16:18:53 +040037 override public fun formatLink(text: String, location: Location): String {
Ilya Ryzhenkov71cd87e2014-10-03 22:51:44 +040038 return "[$text](${location.path})"
39 }
40
41 override fun formatLink(text: String, href: String): String {
42 return "[$text]($href)"
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040043 }
44
45 override public fun appendLine(to: StringBuilder) {
46 to.appendln()
47 }
48
49 override public fun appendLine(to: StringBuilder, text: String) {
Ilya Ryzhenkovaa59acb2014-07-15 20:05:55 +040050 to.appendln(text)
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040051 }
52
53 override public fun appendText(to: StringBuilder, text: String) {
Ilya Ryzhenkovaa59acb2014-07-15 20:05:55 +040054 to.append(text)
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040055 }
56
57 override public fun appendHeader(to: StringBuilder, text: String, level: Int) {
58 appendLine(to)
59 appendLine(to, "${"#".repeat(level)} $text")
60 appendLine(to)
61 }
62
63 override public fun appendBlockCode(to: StringBuilder, lines: Iterable<String>) {
Ilya Ryzhenkovfb41c692014-07-15 18:23:15 +040064 appendLine(to)
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040065 appendLine(to, "```")
66 for (line in lines)
Ilya Ryzhenkovfb41c692014-07-15 18:23:15 +040067 to.appendln(line)
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040068 appendLine(to, "```")
Ilya Ryzhenkovfb41c692014-07-15 18:23:15 +040069 appendLine(to)
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040070 }
71
72 override public fun appendBlockCode(to: StringBuilder, line: String) {
kisenka8fbeb612014-10-10 20:33:05 +040073 appendLine(to)
74 to.appendln("```")
Ilya Ryzhenkovfb41c692014-07-15 18:23:15 +040075 to.appendln(line)
kisenka8fbeb612014-10-10 20:33:05 +040076 to.appendln("```")
77 appendLine(to)
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040078 }
Ilya Ryzhenkov499d0822014-07-15 16:18:53 +040079
Ilya Ryzhenkovaa59acb2014-07-15 20:05:55 +040080 override fun appendTable(to: StringBuilder, body: () -> Unit) {
81 to.appendln()
82 body()
83 to.appendln()
84 }
85
86 override fun appendTableHeader(to: StringBuilder, body: () -> Unit) {
87 body()
88 }
89
90 override fun appendTableBody(to: StringBuilder, body: () -> Unit) {
91 body()
92 }
93
94 override fun appendTableRow(to: StringBuilder, body: () -> Unit) {
kisenka290d5a92014-10-10 16:16:34 +040095 to.append("| ")
Ilya Ryzhenkovaa59acb2014-07-15 20:05:55 +040096 body()
97 to.appendln()
98 }
99
100 override fun appendTableCell(to: StringBuilder, body: () -> Unit) {
101 body()
kisenka290d5a92014-10-10 16:16:34 +0400102 to.append(" | ")
Ilya Ryzhenkovaa59acb2014-07-15 20:05:55 +0400103 }
104
Ilya Ryzhenkov499d0822014-07-15 16:18:53 +0400105 var outlineLevel = 0
106 override fun appendOutlineHeader(to: StringBuilder, node: DocumentationNode) {
107 val indent = " ".repeat(outlineLevel)
108 appendLine(to, "$indent- title: ${languageService.renderName(node)}")
109 appendLine(to, "$indent url: ${locationService.location(node).path}")
110 }
111
112 override fun appendOutlineChildren(to: StringBuilder, nodes: Iterable<DocumentationNode>) {
113 val indent = " ".repeat(outlineLevel)
114 appendLine(to, "$indent content:")
115 outlineLevel++
116 for (node in nodes) {
117 appendOutlineHeader(to, node)
118 if (node.members.any()) {
119 appendOutlineChildren(to, node.members)
120 }
121 appendLine(to)
122 }
123 outlineLevel--
124 }
Ilya Ryzhenkov68d3bc82014-07-14 19:34:52 +0400125}