forked from shadaj/slinky
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbuild.sbt
92 lines (83 loc) · 3.15 KB
/
build.sbt
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
import java.io.PrintWriter
enablePlugins(ScalaJSPlugin)
name := "slinky-readwrite"
libraryDependencies += "org.scala-lang" % "scala-reflect" % scalaVersion.value
libraryDependencies += "org.scala-lang" % "scala-compiler" % scalaVersion.value
sourceGenerators in Compile += Def.task {
val genFile = (sourceManaged in Compile).value / "GenWriters.scala"
(sourceManaged in Compile).value.mkdirs()
genFile.createNewFile()
val out = new PrintWriter(genFile)
val gens = (0 to 22).map { n =>
s"""implicit def function$n[${(0 until n).map(i => s"I$i, ").mkString} O]
| (implicit ${(0 until n).map(i => s"i${i}Reader: Reader[I$i], ").mkString} oWriter: Writer[O]): Writer[(${(0 until n).map(i => s"I$i").mkString(", ")}) => O] = s => {
| val fn: js.Function$n[${(0 until n).map(_ => "js.Object, ").mkString} js.Object] = (${(0 until n).map(i => s"i$i: js.Object").mkString(", ")}) => {
| oWriter.write(s(${(0 until n).map(i => s"i${i}Reader.read(i$i)").mkString(", ")}))
| }
|
| fn.asInstanceOf[js.Object]
|}""".stripMargin
}
out.println(
s"""package slinky.readwrite
|
|import scala.scalajs.js
|
|trait Writer[P] {
| def write(p: P): js.Object
|}
|
|object Writer extends CoreWriters {
| ${gens.mkString("\n")}
|}""".stripMargin)
out.close()
Seq(genFile)
}
sourceGenerators in Compile += Def.task {
val genFile = (sourceManaged in Compile).value / "GenReaders.scala"
(sourceManaged in Compile).value.mkdirs()
genFile.createNewFile()
val out = new PrintWriter(genFile)
val gens = (0 to 22).map { n =>
s"""implicit def function$n[${(0 until n).map(i => s"I$i, ").mkString} O]
| (implicit ${(0 until n).map(i => s"i${i}Writer: Writer[I$i], ").mkString} oReader: Reader[O]): Reader[(${(0 until n).map(i => s"I$i").mkString(", ")}) => O] = s => {
| val fn = s.asInstanceOf[js.Function$n[${(0 until n).map(_ => "js.Object, ").mkString} js.Object]]
| (${(0 until n).map(i => s"i$i: I$i").mkString(", ")}) => {
| oReader.read(fn(${(0 until n).map(i => s"i${i}Writer.write(i$i)").mkString(", ")}))
| }
|}""".stripMargin
}
out.println(
s"""package slinky.readwrite
|
|import scala.scalajs.js
|
|trait Reader[P] {
| def read(o: js.Object): P = {
| val ret = if (js.typeOf(o) == "object" && o != null && !js.isUndefined(o.asInstanceOf[js.Dynamic].__)) {
| o.asInstanceOf[js.Dynamic].__.asInstanceOf[P]
| } else {
| forceRead(o)
| }
|
| if (ret.isInstanceOf[WithRaw]) {
| ret.asInstanceOf[js.Dynamic].__slinky_raw = o
| }
|
| ret
| }
|
| protected def forceRead(o: js.Object): P
|}
|
|trait AlwaysReadReader[P] extends Reader[P] {
| override def read(o: js.Object): P = forceRead(o)
| protected def forceRead(o: js.Object): P
|}
|
|object Reader extends CoreReaders {
| ${gens.mkString("\n")}
|}""".stripMargin)
out.close()
Seq(genFile)
}