创建扩展为类定义的Scala宏

时间:2016-06-27 18:32:01

标签: scala macros scala-macros scala-macro-paradise

正如标题所示,我正在尝试创建一个生成类定义的Scala宏。基本上我想最终做以下事情:

classify("StandardEvent", Map("name" -> String, "id" -> Int))
// should at compile-time expand to
case class StandardEvent(name: String, id: Int) extends Event

这甚至可能吗?如果是这样,有人能指出我如何做到正确的方向吗?实际上,我甚至无法使用以下简单的宏来工作:

// Macro definition:
def classify(): Unit =
  macro classifyImpl

def classifyImpl(c: Context)(): c.Tree = {
  import c.universe._
  q"class SomeClass"
}

// Macro usage in seperate compilation unit
classify()
val s = new SomeClass

这会出现以下错误消息:

[error] ClassifyTest.scala:6: not found: type SomeClass
[error]   val s = new SomeClass
[error]               ^
[trace] Stack trace suppressed: run last app/compile:compileIncremental for the full output.
[error] (app/compile:compileIncremental) java.lang.AssertionError: assertion failed: 
[error]   class SomeClass extends scala.AnyRef {
[error]   def <init>() = {
[error]     super.<init>();
[error]     ()
[error]   }
[error] }
[error]      while compiling: ClassifyTest.scala
[error]         during phase: typer
[error]      library version: version 2.11.8
[error]     compiler version: version 2.11.8
[error]   reconstructed args: -bootclasspath // ...
[error] 
[error]   last tree to typer: type SomeClass
[error]        tree position: line 5 of ClassifyTest.scala
[error]               symbol: <none>
[error]    symbol definition: <none> (a NoSymbol)
[error]       symbol package: <none>
[error]        symbol owners: 
[error]            call site: <none> in <none>
[error] 
[error] == Source file context for tree position ==
[error] 
[error]      2 object ClassifyTest extends App {
[error]      3 
[error]      4   classify()
[error]      5   val s = new SomeClass
[error]      6 
[error]      7 }

有人能理解这个吗?非常感谢帮助。

0 个答案:

没有答案