File: Macros_1.scala

package info (click to toggle)
scala 2.11.12-5
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 62,828 kB
  • sloc: javascript: 28,808; java: 13,415; xml: 3,250; sh: 1,620; python: 756; makefile: 38; awk: 36; ansic: 6
file content (24 lines) | stat: -rw-r--r-- 733 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
import scala.language.experimental.macros
import scala.reflect.macros.blackbox.Context

object Macros {
  def impl(c: Context) = {
    import c.universe._

    def test(tree: Tree, mode: c.TypecheckMode): String = {
      try c.typecheck(tree, mode, silent = false).tpe.toString
      catch { case c.TypecheckException(_, msg) => msg }
    }

    q"""
      println(${test(q"List(1, 2)", c.TERMmode)})
      println(${test(q"List", c.TERMmode)})
      println(${test(q"RuntimeException", c.TERMmode)})
      println(${test(tq"List[Int]", c.TYPEmode)})
      println(${test(tq"List", c.TYPEmode)})
      println(${test(q"List", c.TYPEmode)})
      println(${test(q"List(1, 2)", c.TYPEmode)})
    """
  }
  def foo: Unit = macro impl
}