aboutsummaryrefslogtreecommitdiff
path: root/src/Generation
diff options
context:
space:
mode:
authorIlya Ryzhenkov <orangy@jetbrains.com>2014-07-15 16:18:53 +0400
committerIlya Ryzhenkov <orangy@jetbrains.com>2014-07-15 16:18:53 +0400
commit499d082186fcda877a216d536cf9512d0f0265ac (patch)
treef82c8c5e19cc5c37e4fc3b37706a988fa32b173a /src/Generation
parent62cb509a1a5adf0e5f9ba8d8e7545a93eb8516b2 (diff)
downloaddokka-499d082186fcda877a216d536cf9512d0f0265ac.tar.gz
dokka-499d082186fcda877a216d536cf9512d0f0265ac.tar.bz2
dokka-499d082186fcda877a216d536cf9512d0f0265ac.zip
Cleaning, generalizing, added outline support (hardcoded yml for now)
Diffstat (limited to 'src/Generation')
-rw-r--r--src/Generation/ConsoleGenerator.kt2
-rw-r--r--src/Generation/FileGenerator.kt21
2 files changed, 18 insertions, 5 deletions
diff --git a/src/Generation/ConsoleGenerator.kt b/src/Generation/ConsoleGenerator.kt
index 17e6957b..78164bb9 100644
--- a/src/Generation/ConsoleGenerator.kt
+++ b/src/Generation/ConsoleGenerator.kt
@@ -1,6 +1,6 @@
package org.jetbrains.dokka
-public class ConsoleGenerator(val signatureGenerator: SignatureGenerator, val locationService: LocationService) {
+public class ConsoleGenerator(val signatureGenerator: LanguageService, val locationService: LocationService) {
val IndentStep = " "
public fun generate(node: DocumentationNode, indent: String = "") {
diff --git a/src/Generation/FileGenerator.kt b/src/Generation/FileGenerator.kt
index 6d2c0a3d..dbd631cb 100644
--- a/src/Generation/FileGenerator.kt
+++ b/src/Generation/FileGenerator.kt
@@ -4,13 +4,14 @@ import java.io.FileOutputStream
import java.io.OutputStreamWriter
import java.util.LinkedHashMap
-public class FileGenerator(val signatureGenerator: SignatureGenerator,
+public class FileGenerator(val signatureGenerator: LanguageService,
val locationService: LocationService,
val formatService: FormatService) {
- public fun generate(node: DocumentationNode): Unit = generate(listOf(node))
+ public fun buildPage(node: DocumentationNode): Unit = buildPages(listOf(node))
+ public fun buildOutline(node: DocumentationNode): Unit = buildOutlines(listOf(node))
- public fun generate(nodes: Iterable<DocumentationNode>) {
+ public fun buildPages(nodes: Iterable<DocumentationNode>) {
for ((location, items) in nodes.groupByTo(LinkedHashMap()) { locationService.location(it) }) {
val file = location.file.appendExtension(formatService.extension)
file.getParentFile()?.mkdirs()
@@ -19,7 +20,19 @@ public class FileGenerator(val signatureGenerator: SignatureGenerator,
it.write(formatService.format(items))
}
}
- generate(items.flatMap { it.members })
+ buildPages(items.flatMap { it.members })
+ }
+ }
+
+ public fun buildOutlines(nodes: Iterable<DocumentationNode>) {
+ for ((location, items) in nodes.groupByTo(LinkedHashMap()) { locationService.location(it) }) {
+ val file = location.file.appendExtension("yml")
+ file.getParentFile()?.mkdirs()
+ FileOutputStream(file).use {
+ OutputStreamWriter(it, defaultCharset).use {
+ it.write(formatService.formatOutline(items))
+ }
+ }
}
}
} \ No newline at end of file