-
Notifications
You must be signed in to change notification settings - Fork 1.2k
Expand file tree
/
Copy pathinpervolator_1.scala
More file actions
33 lines (26 loc) · 961 Bytes
/
inpervolator_1.scala
File metadata and controls
33 lines (26 loc) · 961 Bytes
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 Wshadow
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
}
}