summaryrefslogtreecommitdiff
path: root/test/files/jvm/t9105.scala
diff options
context:
space:
mode:
authorAdriaan Moors <adriaan.moors@typesafe.com>2015-02-13 11:47:52 -0800
committerAdriaan Moors <adriaan.moors@typesafe.com>2015-02-13 11:47:52 -0800
commitda49d9a00ec373a0e7f2ffe946a897a65c9b0741 (patch)
tree3b6de81397aa269a2e426edb023b714316f08e50 /test/files/jvm/t9105.scala
parent3b93e1fecaa8aa76d36abd327e146c6b16cd453b (diff)
parentc283ce145a7b34f18deeeac5c3de2b102169e074 (diff)
downloadscala-da49d9a00ec373a0e7f2ffe946a897a65c9b0741.tar.gz
scala-da49d9a00ec373a0e7f2ffe946a897a65c9b0741.tar.bz2
scala-da49d9a00ec373a0e7f2ffe946a897a65c9b0741.zip
Merge pull request #4296 from lrytz/t9105
Fixes and tests for InnerClass / EnclsoingMethod classfile attributes
Diffstat (limited to 'test/files/jvm/t9105.scala')
-rw-r--r--test/files/jvm/t9105.scala22
1 files changed, 22 insertions, 0 deletions
diff --git a/test/files/jvm/t9105.scala b/test/files/jvm/t9105.scala
new file mode 100644
index 0000000000..636ee8a768
--- /dev/null
+++ b/test/files/jvm/t9105.scala
@@ -0,0 +1,22 @@
+class C {
+ val fun = () => {
+ class A
+ def m: Object = { class B; new B }
+ val f: Object = { class C; new C }
+ val g = () => { class D; new D }
+ List[Object](new A, m, f, g())
+ }
+ def met = () => {
+ class E
+ def m: Object = { class F; new F }
+ val f: Object = { class G; new G }
+ val g = () => { class H; new H }
+ List[Object](new E, m, f, g())
+ }
+}
+
+object Test extends App {
+ val x = new C().fun.apply() ::: new C().met.apply()
+ val results = x.map(_.getClass).map(cls => (cls, cls.getEnclosingClass, cls.getEnclosingMethod))
+ println(results.mkString("\n"))
+}