1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
|
package dotty.tools.dottydoc
package util
import dotty.tools.dotc.config.Printers.dottydoc
import _root_.java.io.{
File => JFile,
PrintWriter => JPrintWriter,
FileReader => JFileReader,
BufferedInputStream,
FileInputStream,
FileOutputStream,
BufferedOutputStream,
FileNotFoundException
}
import _root_.java.util.{ Map => JMap, List => JList }
import model.{ Entity, Package }
import model.json._
import com.github.mustachejava.DefaultMustacheFactory
import scala.collection.JavaConverters._
class OutputWriter {
def writeJava(packs: JMap[String, Package], templatePath: String, outPath: String, resources: JList[String]): Unit = {
write(packs.asScala, templatePath, outPath, resources.asScala)
}
def write(packs: collection.Map[String, Package], templatePath: String, outPath: String, resources: Iterable[String]): Unit = {
// Write all packages to `outPath`
for (pack <- packs.values) {
println(s"""Writing '${pack.path.mkString(".")}'""")
writeFile(
expandTemplate(templatePath, pack, outPath),
outPath + pack.path.mkString("/", "/", "/"),
"index.html")
// Write all package children to outPath
for {
child <- pack.children
if child.kind != "package"
} {
println(s"""Writing '${child.path.mkString(".")}'""")
writeFile(
expandTemplate(templatePath, child, outPath),
outPath + child.path.dropRight(1).mkString("/", "/", "/"),
child.path.last + ".html")
}
}
// Write full index to outPath
val js = "Index = {}; Index.packages = " + packs.json + ";"
println("Writing index.js...")
writeFile(js, outPath + "/docassets/", "index.js")
// Write resources to outPath
println("Copying CSS/JS resources to destination...")
assert(resources.nonEmpty)
resources.map(s => copy(new JFile(s), outPath))
println("Done writing static material, building js-app")
}
def writeJsonJava(index: JMap[String, Package], outputDir: String): Unit =
writeJson(index.asScala, outputDir)
def writeJson(index: collection.Map[String, Package], outputDir: String): Unit =
writeFile(index.json, outputDir + "/", "index.json")
def expandTemplate(templatePath: String, entity: Entity, outPath: String): String = try {
import model.json._
import model.java._
val writer = new _root_.java.io.StringWriter()
val mf = new DefaultMustacheFactory()
def toRoot = "../" * (entity.path.length - 1)
val entityWithExtras = entity.asJava(Map(
"assets" -> s"${toRoot}docassets",
"index" -> s"${toRoot}docassets/index.js",
"currentEntity" -> entity.json
))
mf.compile(new JFileReader(templatePath), "template")
.execute(writer, entityWithExtras)
writer.flush()
writer.toString
} catch {
case fnf: FileNotFoundException =>
dottydoc.println(s"""Couldn't find the template: "$templatePath"...exiting""")
System.exit(1); ""
}
def writeFile(str: String, path: String, file: String): Unit =
writeFile(str.map(_.toByte).toArray, path, file)
def writeFile(bytes: Array[Byte], path: String, file: String): Unit = {
def printToFile(f: JFile)(op: JPrintWriter => Unit) = {
val bos = new BufferedOutputStream(new FileOutputStream(f))
try {
Stream.continually(bos.write(bytes))
} finally bos.close()
}
new JFile(path).mkdirs()
printToFile(new JFile(path + file))(printer => bytes.foreach(printer.print))
}
def copy(src: JFile, path: String): Unit = {
val reader = new BufferedInputStream(new FileInputStream(src))
try {
val bytes = Stream.continually(reader.read).takeWhile(-1 != _).map(_.toByte)
writeFile(bytes.toArray, path + "/docassets/", src.getName)
} finally reader.close()
}
}
|