blob: bbe0d7be6d8c8819a995602b35b05840fa5aa24f [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) {
73 appendLine(to, "```")
Ilya Ryzhenkovfb41c692014-07-15 18:23:15 +040074 to.appendln(line)
Ilya Ryzhenkov62cb5092014-07-15 15:54:05 +040075 appendLine(to, "```")
76 }
Ilya Ryzhenkov499d0822014-07-15 16:18:53 +040077
Ilya Ryzhenkovaa59acb2014-07-15 20:05:55 +040078 override fun appendTable(to: StringBuilder, body: () -> Unit) {
79 to.appendln()
80 body()
81 to.appendln()
82 }
83
84 override fun appendTableHeader(to: StringBuilder, body: () -> Unit) {
85 body()
86 }
87
88 override fun appendTableBody(to: StringBuilder, body: () -> Unit) {
89 body()
90 }
91
92 override fun appendTableRow(to: StringBuilder, body: () -> Unit) {
93 to.append("|")
94 body()
95 to.appendln()
96 }
97
98 override fun appendTableCell(to: StringBuilder, body: () -> Unit) {
99 body()
100 to.append("|")
101 }
102
Ilya Ryzhenkov499d0822014-07-15 16:18:53 +0400103 var outlineLevel = 0
104 override fun appendOutlineHeader(to: StringBuilder, node: DocumentationNode) {
105 val indent = " ".repeat(outlineLevel)
106 appendLine(to, "$indent- title: ${languageService.renderName(node)}")
107 appendLine(to, "$indent url: ${locationService.location(node).path}")
108 }
109
110 override fun appendOutlineChildren(to: StringBuilder, nodes: Iterable<DocumentationNode>) {
111 val indent = " ".repeat(outlineLevel)
112 appendLine(to, "$indent content:")
113 outlineLevel++
114 for (node in nodes) {
115 appendOutlineHeader(to, node)
116 if (node.members.any()) {
117 appendOutlineChildren(to, node.members)
118 }
119 appendLine(to)
120 }
121 outlineLevel--
122 }
Ilya Ryzhenkov68d3bc82014-07-14 19:34:52 +0400123}