如何生成静态成员并将其添加到类型宏中的类?

时间:2013-01-22 16:36:08

标签: scala reflection static macros scala-macros

我想将静态字段(在此示例中名为bar)添加到具有类型宏(名为Foo)的类(名为Static)。

我正在尝试这样做:

import language.experimental.macros
import scala.reflect.macros.Context

package object statics {

  type Static = macro Statics.addStaticField

  object Statics {

    def addStaticField(c: Context): c.Tree = {
      import c.universe._

      val STATIC = 1 << 23
      type CompilerSymbol = scala.tools.nsc.Global#Symbol
      def setFlag(symbol: Symbol, flag: Long) {
        val compilerSymbol = symbol.asInstanceOf[CompilerSymbol]
        println("Setting flag ...")
        compilerSymbol.setFlag(flag)
      }
      def printFlags(symbol: Symbol) {
        println("Flags: " + symbol.asInstanceOf[CompilerSymbol].flagString)
      }

      val staticField: ValDef =
        ValDef(
          mods = Modifiers(),
          name = TermName("bar"),
          tpt  = TypeTree(),
          rhs  = Literal(Constant(42))
        )
      printFlags(staticField.symbol)
      setFlag(staticField.symbol, STATIC)
      printFlags(staticField.symbol)

      val Template(parents, _, existingCode) = c.enclosingTemplate

      Template(Nil, emptyValDef, staticField :: existingCode)
    }
  }
}

在编译期间,对setFlag的调用似乎有效,因为标志字符串发生了变化:

Flags: 
Setting flag ...
Flags: <static>

但似乎它在使用网站上根本没有实际效果:

package statics

class Foo extends Static

object Main extends App {
  Foo.bar        // Fails to compile
  (new Foo).bar  // Compiles
}

showshowRaw也没有显示STATIC的任何迹象。

我该如何解决这个问题?

1 个答案:

答案 0 :(得分:1)

据我所知,你需要生成一个伴随对象来拥有一个静态字段,而目前这对于类型宏是不可能的。