diff options
author | Adriaan Moors <adriaan.moors@typesafe.com> | 2013-12-08 20:58:35 -0800 |
---|---|---|
committer | Adriaan Moors <adriaan.moors@typesafe.com> | 2013-12-08 20:58:35 -0800 |
commit | 9751d19471c8ab7c1cc2a618fe097af9dddbd03b (patch) | |
tree | f4c4333702e5b72315d29ee1a2c6eb2a3acad899 /test | |
parent | d938f59e40e7ba97b199e5f70f252d191c19d93e (diff) | |
parent | 1b454185c44a0817a1f30c3d93a91b16805ce84b (diff) | |
download | scala-9751d19471c8ab7c1cc2a618fe097af9dddbd03b.tar.gz scala-9751d19471c8ab7c1cc2a618fe097af9dddbd03b.tar.bz2 scala-9751d19471c8ab7c1cc2a618fe097af9dddbd03b.zip |
Merge pull request #3225 from som-snytt/issue/8013-interp-nowarn
SI-8013 Nowarn on macro str interpolation
Diffstat (limited to 'test')
-rw-r--r-- | test/files/pos/t8013.flags | 1 | ||||
-rw-r--r-- | test/files/pos/t8013/inpervolated_2.scala | 11 | ||||
-rw-r--r-- | test/files/pos/t8013/inpervolator_1.scala | 33 |
3 files changed, 45 insertions, 0 deletions
diff --git a/test/files/pos/t8013.flags b/test/files/pos/t8013.flags new file mode 100644 index 0000000000..954eaba352 --- /dev/null +++ b/test/files/pos/t8013.flags @@ -0,0 +1 @@ +-Xfatal-warnings -Xlint diff --git a/test/files/pos/t8013/inpervolated_2.scala b/test/files/pos/t8013/inpervolated_2.scala new file mode 100644 index 0000000000..90e571b42c --- /dev/null +++ b/test/files/pos/t8013/inpervolated_2.scala @@ -0,0 +1,11 @@ +/* + * scalac: -Xfatal-warnings -Xlint + */ +package t8013 + +// unsuspecting user of perverse macro +trait User { + import Perverse.Impervolator + val foo = "bar" + Console println p"Hello, $foo" +} diff --git a/test/files/pos/t8013/inpervolator_1.scala b/test/files/pos/t8013/inpervolator_1.scala new file mode 100644 index 0000000000..fb71571afc --- /dev/null +++ b/test/files/pos/t8013/inpervolator_1.scala @@ -0,0 +1,33 @@ + +package t8013 + +// perverse macro to confuse Xlint + +import scala.language.experimental.macros +import scala.reflect.macros.{ BlackboxContext => 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.lineContent 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 + } +} |