File: inpervolator_1.scala

package info (click to toggle)
scala 2.11.12-6
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 62,924 kB
  • sloc: javascript: 28,808; java: 13,415; xml: 3,135; sh: 1,620; python: 756; makefile: 38; awk: 36; ansic: 6
file content (33 lines) | stat: -rw-r--r-- 959 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
25
26
27
28
29
30
31
32
33

package t8013

// perverse macro to confuse Xlint

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

object Perverse {

  implicit class Impervolator(sc: StringContext) {
    def p(args: Any*): String = macro pImpl
  }

  // turn a nice interpolation into something that looks
  // nothing like an interpolation or anything we might
  // recognize, but which includes a "$id" in an apply.
  def pImpl(c: Context)(args: c.Expr[Any]*): c.Expr[String] = {
    import c.universe._
    val macroPos = c.macroApplication.pos
    val text = macroPos.source.lineToString(macroPos.line - 1) substring macroPos.column
    val tt = Literal(Constant(text))
    val tree = q"t8013.Perverse.pervert($tt)"
    c.Expr[String](tree)
  }

  // identity doesn't seem very perverse in this context
  //def pervert(text: String): String = text
  def pervert(text: String): String = {
    Console println s"Perverting [$text]"
    text
  }
}