blob: e2c3073fdfda18ccf4118d2df916bfb1e6ef324d (
plain) (
blame)
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
|
package mill.util
import upickle.Js
import upickle.default.{ReadWriter => RW}
import scala.util.matching.Regex
object JsonFormatters extends JsonFormatters
trait JsonFormatters {
implicit val pathReadWrite: RW[os.Path] = upickle.default.readwriter[String]
.bimap[os.Path](
_.toString,
os.Path(_)
)
implicit val regexReadWrite: RW[Regex] = upickle.default.readwriter[String]
.bimap[Regex](
_.pattern.toString,
_.r
)
implicit val bytesReadWrite: RW[os.Bytes] = upickle.default.readwriter[String]
.bimap(
o => java.util.Base64.getEncoder.encodeToString(o.array),
str => new os.Bytes(java.util.Base64.getDecoder.decode(str))
)
implicit lazy val crFormat: RW[os.CommandResult] = upickle.default.macroRW
implicit lazy val modFormat: RW[coursier.Module] = upickle.default.macroRW
implicit lazy val depFormat: RW[coursier.Dependency]= upickle.default.macroRW
implicit lazy val attrFormat: RW[coursier.Attributes] = upickle.default.macroRW
implicit val stackTraceRW = upickle.default.readwriter[Js.Obj].bimap[StackTraceElement](
ste => Js.Obj(
"declaringClass" -> Js.Str(ste.getClassName),
"methodName" -> Js.Str(ste.getMethodName),
"fileName" -> Js.Str(ste.getFileName),
"lineNumber" -> Js.Num(ste.getLineNumber)
),
{case json: Js.Obj =>
new StackTraceElement(
json("declaringClass").str.toString,
json("methodName").str.toString,
json("fileName").str.toString,
json("lineNumber").num.toInt
)
}
)
}
|