KT-3257 Bad diagnostics when trying to instantiate a private class

#KT-3257 Fixed
This commit is contained in:
Mohammad Shamsi
2013-05-05 19:15:46 +08:00
committed by Nikolay Krasko
parent d645fcaaa7
commit 4b656d8c8d
7 changed files with 40 additions and 9 deletions
@@ -105,17 +105,21 @@ public class Visibilities {
}
public static boolean isVisible(@Nullable DeclarationDescriptorWithVisibility what, @NotNull DeclarationDescriptor from) {
return findInvisibleMember(what, from) == null;
}
public static DeclarationDescriptorWithVisibility findInvisibleMember(
@Nullable DeclarationDescriptorWithVisibility what,
@NotNull DeclarationDescriptor from
) {
DeclarationDescriptorWithVisibility parent = what;
while (parent != null) {
if (parent.getVisibility() == LOCAL) {
return true;
}
while (parent != null && parent.getVisibility() != LOCAL) {
if (!parent.getVisibility().isVisible(parent, from)) {
return false;
return parent;
}
parent = DescriptorUtils.getParentOfType(parent, DeclarationDescriptorWithVisibility.class);
}
return true;
return null;
}
private static final Map<Visibility, Integer> ORDERED_VISIBILITIES = Maps.newHashMap();
@@ -93,9 +93,12 @@ public class CandidateResolver {
return;
}
if (!Visibilities.isVisible(candidate, context.scope.getContainingDeclaration())) {
DeclarationDescriptorWithVisibility invisibleMember =
Visibilities.findInvisibleMember(candidate, context.scope.getContainingDeclaration());
if (invisibleMember != null) {
candidateCall.addStatus(OTHER_ERROR);
context.tracing.invisibleMember(context.trace, candidate);
context.tracing.invisibleMember(context.trace, invisibleMember);
return;
}
@@ -0,0 +1,15 @@
package foo.bar
class A {
private class B
public class C private()
private fun bar() {}
}
fun foo() {
A.B() // ERROR 1: Cannot access 'B': it is 'private' in 'A'
A.C() // ERROR 2: Cannot access '' : it is 'private' in 'C'
A().bar() // ERROR 3: Cannot access 'bar' : it is 'private' in 'A'
}
@@ -0,0 +1,2 @@
<!-- invisibleMember1 -->
Cannot access 'B': it is 'private' in 'A'
@@ -0,0 +1,2 @@
<!-- invisibleMember2 -->
Cannot access '<init>': it is 'private' in 'C'
@@ -0,0 +1,2 @@
<!-- invisibleMember3 -->
Cannot access 'bar': it is 'private' in 'A'
@@ -34,7 +34,6 @@ import org.jetbrains.jet.lang.resolve.java.AnalyzerFacadeForJVM;
import org.jetbrains.jet.plugin.PluginTestCaseBase;
import java.util.Collections;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
@@ -110,4 +109,8 @@ public class DiagnosticMessageTest extends JetLiteFixture {
public void testTypeMismatchWithNothing() throws Exception {
doTest("typeMismatchWithNothing", 1, Errors.TYPE_MISMATCH);
}
public void testInvisibleMember() throws Exception {
doTest("invisibleMember", 3, Errors.INVISIBLE_MEMBER, Errors.INVISIBLE_MEMBER, Errors.INVISIBLE_MEMBER);
}
}