aboutsummaryrefslogtreecommitdiff
path: root/tests/disabled/macro/run/macroPlugins-macroExpand/Plugin_1.scala
blob: 13df85cb23a965ca351e9e74eef81a267c2c4bba (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
package macroExpand

import scala.tools.nsc.Global
import scala.tools.nsc.plugins.{Plugin => NscPlugin}

class Plugin(val global: Global) extends NscPlugin {
  import global._
  import analyzer._
  import scala.reflect.internal.Mode

  val name = "macroExpand"
  val description = "A sample analyzer plugin that overrides macroExpand."
  val components = Nil
  addMacroPlugin(MacroPlugin)

  object MacroPlugin extends MacroPlugin {
    override def pluginsMacroExpand(typer: Typer, expandee: Tree, mode: Mode, pt: Type): Option[Tree] = {
      object expander extends DefMacroExpander(typer, expandee, mode, pt) {
        override def onSuccess(expanded: Tree) = {
          val message = s"expanded into ${expanded.toString}"
          typer.typed(q"println($message)")
        }
      }
      Some(expander(expandee))
    }
  }
}