6

我想将一个静态字段(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

我该如何解决这个问题?

4

1 回答 1

1

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

于 2013-01-22T17:45:11.840 回答