File: Macros_1.scala

package info (click to toggle)
scala 2.11.12-4
  • links: PTS, VCS
  • area: main
  • in suites: bullseye, buster
  • size: 62,776 kB
  • sloc: java: 13,415; xml: 3,252; sh: 1,620; python: 756; makefile: 38; awk: 36; ansic: 6
file content (15 lines) | stat: -rw-r--r-- 454 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
import scala.language.experimental.macros
import scala.reflect.macros.blackbox.Context

object Macros {
  implicit class Error(ctx: StringContext) {
    def err(args: Any*): Unit = macro impl
  }

  def impl(c: Context)(args: c.Tree*): c.Tree = {
    import c.universe._
    val q"Macros.Error(scala.StringContext.apply($arg)).err()" = c.macroApplication
    for (i <- 1 to 3) c.error(arg.pos.withPoint(arg.pos.point + i - 1), i.toString)
    q"()"
  }
}