-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathantlr.sc
62 lines (53 loc) · 1.95 KB
/
antlr.sc
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
//package net.mlbox.millantlr
// https://github.com/da-tubi/antlr4-scala-example/blob/master/antlr.sc
import mill._
import mill.define._
import mill.scalalib._
import $ivy.`org.antlr:antlr4:4.9.3`
import org.antlr.v4.tool.{ANTLRMessage, ANTLRToolListener}
import scala.collection.mutable
trait AntlrModule extends JavaModule {
def antlrGrammarSources: mill.define.Target[Seq[mill.api.PathRef]]
def antlrPackage: Option[String] = None
def antlrGenerateVisitor: Boolean = false
def antlrGenerateListener: Boolean = false
def antlrGrammarSourceFiles = T {
antlrGrammarSources().flatMap { source =>
if (os.isDir(source.path)) {
os.walk(source.path)
} else {
Seq(source.path)
}
}.filter { path =>
os.isFile(path) && path.ext == "g4"
}.map(PathRef(_))
}
def antlrGenerate = T {
val antlrToolArgs = mutable.ArrayBuffer.empty[String]
antlrToolArgs.appendAll(antlrGrammarSourceFiles().map(_.path.relativeTo(os.pwd).toString))
antlrToolArgs.append("-o")
antlrToolArgs.append(s"${T.dest}")
if (antlrGenerateVisitor) {
antlrToolArgs.append("-visitor")
}
if (antlrGenerateListener) {
antlrToolArgs.append("-listener")
}
if (antlrPackage.isDefined) {
antlrToolArgs.append("-package")
antlrToolArgs.append(antlrPackage.get)
}
val antlrTool = new org.antlr.v4.Tool(antlrToolArgs.toArray)
antlrTool.addListener(new ToolListener())
antlrTool.processGrammarsOnCommandLine()
os.walk(T.dest).filter(path => os.isFile(path) && path.ext == "java").map(PathRef(_))
}
override def generatedSources = T {
super.generatedSources() ++ antlrGenerate()
}
}
class ToolListener extends ANTLRToolListener {
override def info(msg: String): Unit = throw new RuntimeException(msg)
override def error(msg: ANTLRMessage): Unit = throw new RuntimeException(msg.toString)
override def warning(msg: ANTLRMessage): Unit = throw new RuntimeException(msg.toString)
}