summaryrefslogtreecommitdiff
path: root/test/files/run/t2106.check
diff options
context:
space:
mode:
authorLukas Rytz <lukas.rytz@gmail.com>2015-05-27 17:29:03 +0200
committerLukas Rytz <lukas.rytz@gmail.com>2015-05-28 11:42:40 +0200
commit7db3a58872593526c2cc175df633161f2ce9cccb (patch)
tree0f051049363fc48f3aba98eb676abe2362f2092d /test/files/run/t2106.check
parentbb302833c7bad6ff7591cdf6d10ec7ffdf683d6a (diff)
downloadscala-7db3a58872593526c2cc175df633161f2ce9cccb.tar.gz
scala-7db3a58872593526c2cc175df633161f2ce9cccb.tar.bz2
scala-7db3a58872593526c2cc175df633161f2ce9cccb.zip
Fix illegal inlining of instructions accessing protected members
There were two issues in the new inliner that would cause a VerifyError and an IllegalAccessError. First, an access to a public member of package protected class C can only be inlined if the destination class can access C. This is tested by t7582b. Second, an access to a protected member requires the receiver object to be a subtype of the class where the instruction is located. So when inlining such an access, we need to know the type of the receiver object - which we don't have. Therefore we don't inline in this case for now. This can be fixed once we have a type propagation analyis. https://github.com/scala-opt/scala/issues/13. This case is tested by t2106. Force kmpSliceSearch test to delambdafy:inline See discussion on https://github.com/scala/scala/pull/4505. The issue will go away when moving to indy-lambda.
Diffstat (limited to 'test/files/run/t2106.check')
-rw-r--r--test/files/run/t2106.check7
1 files changed, 7 insertions, 0 deletions
diff --git a/test/files/run/t2106.check b/test/files/run/t2106.check
index f8f625ff46..66a0e707b3 100644
--- a/test/files/run/t2106.check
+++ b/test/files/run/t2106.check
@@ -1,3 +1,10 @@
+#partest -Ybackend:GenBCode
+t2106.scala:7: warning: A::foo()Ljava/lang/Object; is annotated @inline but could not be inlined:
+The callee A::foo()Ljava/lang/Object; contains the instruction INVOKEVIRTUAL java/lang/Object.clone ()Ljava/lang/Object;
+that would cause an IllegalAccessError when inlined into class Test$.
+ def main(args: Array[String]): Unit = x.foo
+ ^
+#partest !-Ybackend:GenBCode
t2106.scala:7: warning: Could not inline required method foo because access level required by callee not matched by caller.
def main(args: Array[String]): Unit = x.foo
^