summaryrefslogtreecommitdiff
path: root/test/files/run/t5266_1.scala
diff options
context:
space:
mode:
authorEugene Burmako <xeno.by@gmail.com>2011-12-07 21:18:25 +0100
committerEugene Burmako <xeno.by@gmail.com>2011-12-07 22:38:48 +0100
commita6152b4c2c0a26835e60a8ef209cca87bec8510e (patch)
tree706474dd4f3756a06dd0b14671e626c773c838a3 /test/files/run/t5266_1.scala
parent332fec96e31840878bed41dd7b5314b97d8da7c2 (diff)
downloadscala-a6152b4c2c0a26835e60a8ef209cca87bec8510e.tar.gz
scala-a6152b4c2c0a26835e60a8ef209cca87bec8510e.tar.bz2
scala-a6152b4c2c0a26835e60a8ef209cca87bec8510e.zip
Fix reflective toolbox producing invalid bytecode
Wrapper method for AST undergoing a reflective compilation has been incorrectly marked as static. This was off the radars until one day the code being compiled declared a top-level method. During flatten that method got hoisted into the wrapper module, and its invocation got translated into an instance call upon the module. This led to static wrapper method trying to call an instance method, and that blew up the bytecode verifier. More info: https://issues.scala-lang.org/browse/SI-5266. Fixes SI-5266, review by @odersky.
Diffstat (limited to 'test/files/run/t5266_1.scala')
-rw-r--r--test/files/run/t5266_1.scala16
1 files changed, 16 insertions, 0 deletions
diff --git a/test/files/run/t5266_1.scala b/test/files/run/t5266_1.scala
new file mode 100644
index 0000000000..18e288e685
--- /dev/null
+++ b/test/files/run/t5266_1.scala
@@ -0,0 +1,16 @@
+import scala.tools.nsc.reporters._
+import scala.tools.nsc.Settings
+import reflect.runtime.Mirror.ToolBox
+
+object Test extends App {
+ val code = scala.reflect.Code.lift{
+ def x = 2
+ println(x)
+ };
+
+ val reporter = new ConsoleReporter(new Settings)
+ val toolbox = new ToolBox(reporter)
+ val ttree = toolbox.typeCheck(code.tree)
+ val evaluated = toolbox.runExpr(ttree)
+ println("evaluated = " + evaluated)
+} \ No newline at end of file