From f9cba3714a2c8cd3b1a9e35252b347d75b2ddfa9 Mon Sep 17 00:00:00 2001 From: mcimadamore Date: Mon, 7 Feb 2011 18:10:13 +0000 Subject: [PATCH] 7007615: java_util/generics/phase2/NameClashTest02 fails since jdk7/pit/b123. Summary: override clash algorithm is not implemented correctly Reviewed-by: jjg --- .../com/sun/tools/javac/code/Scope.java | 79 ++-------- .../com/sun/tools/javac/code/Symbol.java | 6 +- .../com/sun/tools/javac/code/Symtab.java | 8 +- .../com/sun/tools/javac/code/Types.java | 67 +++++++-- .../com/sun/tools/javac/comp/Attr.java | 6 +- .../com/sun/tools/javac/comp/Check.java | 140 ++++++++++-------- .../com/sun/tools/javac/comp/Enter.java | 8 +- .../com/sun/tools/javac/comp/Lower.java | 4 +- .../com/sun/tools/javac/comp/MemberEnter.java | 4 +- .../com/sun/tools/javac/jvm/ClassReader.java | 6 +- .../tools/javac/resources/compiler.properties | 12 +- .../examples/NameClashSameErasureNoHide.java | 34 +++++ .../NameClashSameErasureNoOverride.java | 6 +- .../NameClashSameErasureNoOverride1.java | 39 +++++ .../tools/javac/generics/5009937/T5009937.out | 2 +- .../javac/generics/6182950/T6182950b.out | 2 +- .../javac/generics/6476118/T6476118a.out | 2 +- .../javac/generics/6476118/T6476118b.out | 2 +- .../javac/generics/6476118/T6476118c.java | 2 +- .../javac/generics/6476118/T6476118c.out | 4 +- .../javac/generics/6985719/T6985719e.out | 2 +- .../javac/generics/6985719/T6985719f.out | 2 +- .../javac/generics/6985719/T6985719g.out | 2 +- .../javac/generics/6985719/T6985719h.out | 2 +- .../javac/generics/7007615/T7007615.java | 27 ++++ .../tools/javac/generics/7007615/T7007615.out | 3 + .../7007615/acc1/AccessibilityCheck01.java | 12 ++ .../javac/generics/7007615/acc1/p1/C.java | 25 ++++ .../javac/generics/7007615/acc1/p1/D.java | 25 ++++ .../javac/generics/7007615/acc1/p2/E.java | 25 ++++ .../7007615/acc2/AccessibilityCheck02.java | 13 ++ .../7007615/acc2/AccessibilityCheck02.out | 2 + .../javac/generics/7007615/acc2/p1/C.java | 25 ++++ .../javac/generics/7007615/acc2/p1/D.java | 25 ++++ .../javac/generics/7007615/acc2/p2/E.java | 25 ++++ test/tools/javac/scope/HashCollisionTest.java | 4 +- test/tools/javac/scope/StarImportTest.java | 4 +- 37 files changed, 470 insertions(+), 186 deletions(-) create mode 100644 test/tools/javac/diags/examples/NameClashSameErasureNoHide.java create mode 100644 test/tools/javac/diags/examples/NameClashSameErasureNoOverride1.java create mode 100644 test/tools/javac/generics/7007615/T7007615.java create mode 100644 test/tools/javac/generics/7007615/T7007615.out create mode 100644 test/tools/javac/generics/7007615/acc1/AccessibilityCheck01.java create mode 100644 test/tools/javac/generics/7007615/acc1/p1/C.java create mode 100644 test/tools/javac/generics/7007615/acc1/p1/D.java create mode 100644 test/tools/javac/generics/7007615/acc1/p2/E.java create mode 100644 test/tools/javac/generics/7007615/acc2/AccessibilityCheck02.java create mode 100644 test/tools/javac/generics/7007615/acc2/AccessibilityCheck02.out create mode 100644 test/tools/javac/generics/7007615/acc2/p1/C.java create mode 100644 test/tools/javac/generics/7007615/acc2/p1/D.java create mode 100644 test/tools/javac/generics/7007615/acc2/p2/E.java diff --git a/src/share/classes/com/sun/tools/javac/code/Scope.java b/src/share/classes/com/sun/tools/javac/code/Scope.java index 20d88df1..51c46785 100644 --- a/src/share/classes/com/sun/tools/javac/code/Scope.java +++ b/src/share/classes/com/sun/tools/javac/code/Scope.java @@ -72,49 +72,10 @@ public class Scope { */ int nelems = 0; - /** A timestamp - useful to quickly check whether a scope has changed or not - */ - public ScopeCounter scopeCounter; - - static ScopeCounter dummyCounter = new ScopeCounter() { - @Override - public void inc() { - //do nothing - } - }; - /** A list of scopes to be notified if items are to be removed from this scope. */ List listeners = List.nil(); - public static class ScopeCounter { - protected static final Context.Key scopeCounterKey = - new Context.Key(); - - public static ScopeCounter instance(Context context) { - ScopeCounter instance = context.get(scopeCounterKey); - if (instance == null) - instance = new ScopeCounter(context); - return instance; - } - - protected ScopeCounter(Context context) { - context.put(scopeCounterKey, this); - } - - private ScopeCounter() {}; - - private long val = 0; - - public void inc() { - val++; - } - - public long val() { - return val; - } - } - /** Use as a "not-found" result for lookup. * Also used to mark deleted entries in the table. */ @@ -126,35 +87,30 @@ public class Scope { /** A value for the empty scope. */ - public static final Scope emptyScope = new Scope(null, null, new Entry[]{}, dummyCounter); + public static final Scope emptyScope = new Scope(null, null, new Entry[]{}); /** Construct a new scope, within scope next, with given owner, using * given table. The table's length must be an exponent of 2. */ - private Scope(Scope next, Symbol owner, Entry[] table, ScopeCounter scopeCounter) { + private Scope(Scope next, Symbol owner, Entry[] table) { this.next = next; Assert.check(emptyScope == null || owner != null); this.owner = owner; this.table = table; this.hashMask = table.length - 1; - this.scopeCounter = scopeCounter; } /** Convenience constructor used for dup and dupUnshared. */ - private Scope(Scope next, Symbol owner, Entry[] table) { - this(next, owner, table, next.scopeCounter); - this.nelems = next.nelems; + private Scope(Scope next, Symbol owner, Entry[] table, int nelems) { + this(next, owner, table); + this.nelems = nelems; } /** Construct a new scope, within scope next, with given owner, * using a fresh table of length INITIAL_SIZE. */ public Scope(Symbol owner) { - this(owner, dummyCounter); - } - - protected Scope(Symbol owner, ScopeCounter scopeCounter) { - this(null, owner, new Entry[INITIAL_SIZE], scopeCounter); + this(null, owner, new Entry[INITIAL_SIZE]); } /** Construct a fresh scope within this scope, with same owner, @@ -172,7 +128,7 @@ public class Scope { * of fresh tables. */ public Scope dup(Symbol newOwner) { - Scope result = new Scope(this, newOwner, this.table); + Scope result = new Scope(this, newOwner, this.table, this.nelems); shared++; // System.out.println("====> duping scope " + this.hashCode() + " owned by " + newOwner + " to " + result.hashCode()); // new Error().printStackTrace(System.out); @@ -184,7 +140,7 @@ public class Scope { * the table of its outer scope. */ public Scope dupUnshared() { - return new Scope(this, this.owner, this.table.clone()); + return new Scope(this, this.owner, this.table.clone(), this.nelems); } /** Remove all entries of this scope from its table, if shared @@ -263,7 +219,6 @@ public class Scope { Entry e = makeEntry(sym, old, elems, s, origin); table[hash] = e; elems = e; - scopeCounter.inc(); } Entry makeEntry(Symbol sym, Entry shadowed, Entry sibling, Scope scope, Scope origin) { @@ -278,8 +233,6 @@ public class Scope { Entry e = lookup(sym.name); if (e.scope == null) return; - scopeCounter.inc(); - // remove e from table and shadowed list; int i = getIndex(sym.name); Entry te = table[i]; @@ -559,7 +512,7 @@ public class Scope { public static final Entry[] emptyTable = new Entry[0]; public DelegatedScope(Scope outer) { - super(outer, outer.owner, emptyTable, outer.scopeCounter); + super(outer, outer.owner, emptyTable); delegatee = outer; } public Scope dup() { @@ -585,22 +538,10 @@ public class Scope { } } - /** A class scope, for which a scope counter should be provided */ - public static class ClassScope extends Scope { - - ClassScope(Scope next, Symbol owner, Entry[] table, ScopeCounter scopeCounter) { - super(next, owner, table, scopeCounter); - } - - public ClassScope(Symbol owner, ScopeCounter scopeCounter) { - super(owner, scopeCounter); - } - } - /** An error scope, for which the owner should be an error symbol. */ public static class ErrorScope extends Scope { ErrorScope(Scope next, Symbol errSymbol, Entry[] table) { - super(next, /*owner=*/errSymbol, table, dummyCounter); + super(next, /*owner=*/errSymbol, table); } public ErrorScope(Symbol errSymbol) { super(errSymbol); diff --git a/src/share/classes/com/sun/tools/javac/code/Symbol.java b/src/share/classes/com/sun/tools/javac/code/Symbol.java index 4d862baf..04424145 100644 --- a/src/share/classes/com/sun/tools/javac/code/Symbol.java +++ b/src/share/classes/com/sun/tools/javac/code/Symbol.java @@ -729,6 +729,10 @@ public abstract class Symbol implements Element { */ public Pool pool; + /** members closure cache (set by Types.membersClosure) + */ + Scope membersClosure; + public ClassSymbol(long flags, Name name, Type type, Symbol owner) { super(flags, name, type, owner); this.members_field = null; @@ -1222,7 +1226,7 @@ public abstract class Symbol implements Element { }; public MethodSymbol implementation(TypeSymbol origin, Types types, boolean checkResult, Filter implFilter) { - MethodSymbol res = types.implementation(this, origin, types, checkResult, implFilter); + MethodSymbol res = types.implementation(this, origin, checkResult, implFilter); if (res != null) return res; // if origin is derived from a raw type, we might have missed diff --git a/src/share/classes/com/sun/tools/javac/code/Symtab.java b/src/share/classes/com/sun/tools/javac/code/Symtab.java index 48996a04..5b1633a0 100644 --- a/src/share/classes/com/sun/tools/javac/code/Symtab.java +++ b/src/share/classes/com/sun/tools/javac/code/Symtab.java @@ -74,7 +74,6 @@ public class Symtab { public final JCNoType voidType = new JCNoType(TypeTags.VOID); private final Names names; - private final Scope.ScopeCounter scopeCounter; private final ClassReader reader; private final Target target; @@ -343,7 +342,6 @@ public class Symtab { context.put(symtabKey, this); names = Names.instance(context); - scopeCounter = Scope.ScopeCounter.instance(context); target = Target.instance(context); // Create the unknown type @@ -390,7 +388,7 @@ public class Symtab { // Create class to hold all predefined constants and operations. predefClass = new ClassSymbol(PUBLIC|ACYCLIC, names.empty, rootPackage); - Scope scope = new Scope.ClassScope(predefClass, scopeCounter); + Scope scope = new Scope(predefClass); predefClass.members_field = scope; // Enter symbols for basic types. @@ -483,7 +481,7 @@ public class Symtab { proprietarySymbol.completer = null; proprietarySymbol.flags_field = PUBLIC|ACYCLIC|ANNOTATION|INTERFACE; proprietarySymbol.erasure_field = proprietaryType; - proprietarySymbol.members_field = new Scope.ClassScope(proprietarySymbol, scopeCounter); + proprietarySymbol.members_field = new Scope(proprietarySymbol); proprietaryType.typarams_field = List.nil(); proprietaryType.allparams_field = List.nil(); proprietaryType.supertype_field = annotationType; @@ -495,7 +493,7 @@ public class Symtab { ClassType arrayClassType = (ClassType)arrayClass.type; arrayClassType.supertype_field = objectType; arrayClassType.interfaces_field = List.of(cloneableType, serializableType); - arrayClass.members_field = new Scope.ClassScope(arrayClass, scopeCounter); + arrayClass.members_field = new Scope(arrayClass); lengthVar = new VarSymbol( PUBLIC | FINAL, names.length, diff --git a/src/share/classes/com/sun/tools/javac/code/Types.java b/src/share/classes/com/sun/tools/javac/code/Types.java index 77454482..56e8172c 100644 --- a/src/share/classes/com/sun/tools/javac/code/Types.java +++ b/src/share/classes/com/sun/tools/javac/code/Types.java @@ -36,6 +36,7 @@ import com.sun.tools.javac.code.Attribute.RetentionPolicy; import com.sun.tools.javac.code.Lint.LintCategory; import com.sun.tools.javac.comp.Check; +import static com.sun.tools.javac.code.Scope.*; import static com.sun.tools.javac.code.Type.*; import static com.sun.tools.javac.code.TypeTags.*; import static com.sun.tools.javac.code.Symbol.*; @@ -70,7 +71,6 @@ public class Types { new Context.Key(); final Symtab syms; - final Scope.ScopeCounter scopeCounter; final JavacMessages messages; final Names names; final boolean allowBoxing; @@ -91,7 +91,6 @@ public class Types { protected Types(Context context) { context.put(typesKey, this); syms = Symtab.instance(context); - scopeCounter = Scope.ScopeCounter.instance(context); names = Names.instance(context); allowBoxing = Source.instance(context).allowBoxing(); reader = ClassReader.instance(context); @@ -2024,26 +2023,22 @@ public class Types { final MethodSymbol cachedImpl; final Filter implFilter; final boolean checkResult; - final Scope.ScopeCounter scopeCounter; public Entry(MethodSymbol cachedImpl, Filter scopeFilter, - boolean checkResult, - Scope.ScopeCounter scopeCounter) { + boolean checkResult) { this.cachedImpl = cachedImpl; this.implFilter = scopeFilter; this.checkResult = checkResult; - this.scopeCounter = scopeCounter; } - boolean matches(Filter scopeFilter, boolean checkResult, Scope.ScopeCounter scopeCounter) { + boolean matches(Filter scopeFilter, boolean checkResult) { return this.implFilter == scopeFilter && - this.checkResult == checkResult && - this.scopeCounter.val() >= scopeCounter.val(); + this.checkResult == checkResult; } } - MethodSymbol get(MethodSymbol ms, TypeSymbol origin, boolean checkResult, Filter implFilter, Scope.ScopeCounter scopeCounter) { + MethodSymbol get(MethodSymbol ms, TypeSymbol origin, boolean checkResult, Filter implFilter) { SoftReference> ref_cache = _map.get(ms); Map cache = ref_cache != null ? ref_cache.get() : null; if (cache == null) { @@ -2052,9 +2047,9 @@ public class Types { } Entry e = cache.get(origin); if (e == null || - !e.matches(implFilter, checkResult, scopeCounter)) { + !e.matches(implFilter, checkResult)) { MethodSymbol impl = implementationInternal(ms, origin, Types.this, checkResult, implFilter); - cache.put(origin, new Entry(impl, implFilter, checkResult, scopeCounter)); + cache.put(origin, new Entry(impl, implFilter, checkResult)); return impl; } else { @@ -2081,11 +2076,55 @@ public class Types { private ImplementationCache implCache = new ImplementationCache(); - public MethodSymbol implementation(MethodSymbol ms, TypeSymbol origin, Types types, boolean checkResult, Filter implFilter) { - return implCache.get(ms, origin, checkResult, implFilter, scopeCounter); + public MethodSymbol implementation(MethodSymbol ms, TypeSymbol origin, boolean checkResult, Filter implFilter) { + return implCache.get(ms, origin, checkResult, implFilter); } // + // + public Scope membersClosure(Type site) { + return membersClosure.visit(site); + } + + UnaryVisitor membersClosure = new UnaryVisitor() { + + public Scope visitType(Type t, Void s) { + return null; + } + + @Override + public Scope visitClassType(ClassType t, Void s) { + ClassSymbol csym = (ClassSymbol)t.tsym; + if (csym.membersClosure == null) { + Scope membersClosure = new Scope(csym); + for (Type i : interfaces(t)) { + enterAll(visit(i), membersClosure); + } + enterAll(visit(supertype(t)), membersClosure); + enterAll(csym.members(), membersClosure); + csym.membersClosure = membersClosure; + } + return csym.membersClosure; + } + + @Override + public Scope visitTypeVar(TypeVar t, Void s) { + return visit(t.getUpperBound()); + } + + public void enterAll(Scope s, Scope to) { + if (s == null) return; + List syms = List.nil(); + for (Scope.Entry e = s.elems ; e != null ; e = e.sibling) { + syms = syms.prepend(e.sym); + } + for (Symbol sym : syms) { + to.enter(sym); + } + } + }; + // + /** * Does t have the same arguments as s? It is assumed that both * types are (possibly polymorphic) method types. Monomorphic diff --git a/src/share/classes/com/sun/tools/javac/comp/Attr.java b/src/share/classes/com/sun/tools/javac/comp/Attr.java index 3a3592ab..2da16a7e 100644 --- a/src/share/classes/com/sun/tools/javac/comp/Attr.java +++ b/src/share/classes/com/sun/tools/javac/comp/Attr.java @@ -709,7 +709,11 @@ public class Attr extends JCTree.Visitor { // If we override any other methods, check that we do so properly. // JLS ??? - chk.checkClashes(tree.pos(), env.enclClass.type, m); + if (m.isStatic()) { + chk.checkHideClashes(tree.pos(), env.enclClass.type, m); + } else { + chk.checkOverrideClashes(tree.pos(), env.enclClass.type, m); + } chk.checkOverride(tree, m); // Create a new environment with local scope diff --git a/src/share/classes/com/sun/tools/javac/comp/Check.java b/src/share/classes/com/sun/tools/javac/comp/Check.java index ca04b1eb..a10f8214 100644 --- a/src/share/classes/com/sun/tools/javac/comp/Check.java +++ b/src/share/classes/com/sun/tools/javac/comp/Check.java @@ -1679,7 +1679,7 @@ public class Check { "(" + types.memberType(t2, s2).getParameterTypes() + ")"); return s2; } - } else if (!checkNameClash((ClassSymbol)site.tsym, s1, s2)) { + } else if (checkNameClash((ClassSymbol)site.tsym, s1, s2)) { log.error(pos, "name.clash.same.erasure.no.override", s1, s1.location(), @@ -1761,18 +1761,10 @@ public class Check { } private boolean checkNameClash(ClassSymbol origin, Symbol s1, Symbol s2) { - if (s1.kind == MTH && - s1.isInheritedIn(origin, types) && - (s1.flags() & SYNTHETIC) == 0 && - !s2.isConstructor()) { - Type er1 = s2.erasure(types); - Type er2 = s1.erasure(types); - if (types.isSameTypes(er1.getParameterTypes(), - er2.getParameterTypes())) { - return false; - } - } - return true; + ClashFilter cf = new ClashFilter(origin.type); + return (cf.accepts(s1) && + cf.accepts(s2) && + types.hasSameArgs(s1.erasure(types), s2.erasure(types))); } @@ -2111,52 +2103,82 @@ public class Check { * @param site The class whose methods are checked. * @param sym The method symbol to be checked. */ - void checkClashes(DiagnosticPosition pos, Type site, Symbol sym) { - List supertypes = types.closure(site); - for (List l = supertypes; l.nonEmpty(); l = l.tail) { - for (List m = supertypes; m.nonEmpty(); m = m.tail) { - checkClashes(pos, l.head, m.head, site, sym); + void checkOverrideClashes(DiagnosticPosition pos, Type site, MethodSymbol sym) { + ClashFilter cf = new ClashFilter(site); + //for each method m1 that is a member of 'site'... + for (Scope.Entry e1 = types.membersClosure(site).lookup(sym.name, cf) ; + e1.scope != null ; e1 = e1.next(cf)) { + //...find another method m2 that is overridden (directly or indirectly) + //by method 'sym' in 'site' + for (Scope.Entry e2 = types.membersClosure(site).lookup(sym.name, cf) ; + e2.scope != null ; e2 = e2.next(cf)) { + if (e1.sym == e2.sym || !sym.overrides(e2.sym, site.tsym, types, false)) continue; + //if (i) the signature of 'sym' is not a subsignature of m1 (seen as + //a member of 'site') and (ii) m1 has the same erasure as m2, issue an error + if (!types.isSubSignature(sym.type, types.memberType(site, e1.sym)) && + types.hasSameArgs(e1.sym.erasure(types), e2.sym.erasure(types))) { + sym.flags_field |= CLASH; + String key = e2.sym == sym ? + "name.clash.same.erasure.no.override" : + "name.clash.same.erasure.no.override.1"; + log.error(pos, + key, + sym, sym.location(), + e1.sym, e1.sym.location(), + e2.sym, e2.sym.location()); + return; + } } } } - /** Reports an error whenever 'sym' seen as a member of type 't1' clashes with - * some unrelated method defined in 't2'. + /** Check that all static methods accessible from 'site' are + * mutually compatible (JLS 8.4.8). + * + * @param pos Position to be used for error reporting. + * @param site The class whose methods are checked. + * @param sym The method symbol to be checked. */ - private void checkClashes(DiagnosticPosition pos, Type t1, Type t2, Type site, Symbol s1) { + void checkHideClashes(DiagnosticPosition pos, Type site, MethodSymbol sym) { ClashFilter cf = new ClashFilter(site); - s1 = ((MethodSymbol)s1).implementedIn(t1.tsym, types); - if (s1 == null) return; - Type st1 = types.memberType(site, s1); - for (Scope.Entry e2 = t2.tsym.members().lookup(s1.name, cf); e2.scope != null; e2 = e2.next(cf)) { - Symbol s2 = e2.sym; - if (s1 == s2) continue; - Type st2 = types.memberType(site, s2); - if (!types.overrideEquivalent(st1, st2) && - !checkNameClash((ClassSymbol)site.tsym, s1, s2)) { + //for each method m1 that is a member of 'site'... + for (Scope.Entry e = types.membersClosure(site).lookup(sym.name, cf) ; + e.scope != null ; e = e.next(cf)) { + //if (i) the signature of 'sym' is not a subsignature of m1 (seen as + //a member of 'site') and (ii) 'sym' has the same erasure as m1, issue an error + if (!types.isSubSignature(sym.type, types.memberType(site, e.sym)) && + types.hasSameArgs(e.sym.erasure(types), sym.erasure(types))) { log.error(pos, - "name.clash.same.erasure.no.override", - s1, s1.location(), - s2, s2.location()); - } - } - } - //where - private class ClashFilter implements Filter { + "name.clash.same.erasure.no.hide", + sym, sym.location(), + e.sym, e.sym.location()); + return; + } + } + } - Type site; + //where + private class ClashFilter implements Filter { - ClashFilter(Type site) { - this.site = site; - } + Type site; - public boolean accepts(Symbol s) { - return s.kind == MTH && - (s.flags() & (SYNTHETIC | CLASH)) == 0 && - s.isInheritedIn(site.tsym, types) && - !s.isConstructor(); - } - } + ClashFilter(Type site) { + this.site = site; + } + + boolean shouldSkip(Symbol s) { + return (s.flags() & CLASH) != 0 && + s.owner == site.tsym; + } + + public boolean accepts(Symbol s) { + return s.kind == MTH && + (s.flags() & SYNTHETIC) == 0 && + !shouldSkip(s) && + s.isInheritedIn(site.tsym, types) && + !s.isConstructor(); + } + } /** Report a conflict between a user symbol and a synthetic symbol. */ @@ -2638,10 +2660,10 @@ public class Check { if (sym.owner.name == names.any) return false; for (Scope.Entry e = s.lookup(sym.name); e.scope == s; e = e.next()) { if (sym != e.sym && - (e.sym.flags() & CLASH) == 0 && - sym.kind == e.sym.kind && - sym.name != names.error && - (sym.kind != MTH || types.hasSameArgs(types.erasure(sym.type), types.erasure(e.sym.type)))) { + (e.sym.flags() & CLASH) == 0 && + sym.kind == e.sym.kind && + sym.name != names.error && + (sym.kind != MTH || types.hasSameArgs(types.erasure(sym.type), types.erasure(e.sym.type)))) { if ((sym.flags() & VARARGS) != (e.sym.flags() & VARARGS)) { varargsDuplicateError(pos, sym, e.sym); return true; @@ -2667,13 +2689,13 @@ public class Check { return types.hasSameArgs(mt1.asMethodType(), mt2.asMethodType()); } - /** Report duplicate declaration error. - */ - void duplicateErasureError(DiagnosticPosition pos, Symbol sym1, Symbol sym2) { - if (!sym1.type.isErroneous() && !sym2.type.isErroneous()) { - log.error(pos, "name.clash.same.erasure", sym1, sym2); - } + /** Report duplicate declaration error. + */ + void duplicateErasureError(DiagnosticPosition pos, Symbol sym1, Symbol sym2) { + if (!sym1.type.isErroneous() && !sym2.type.isErroneous()) { + log.error(pos, "name.clash.same.erasure", sym1, sym2); } + } /** Check that single-type import is not already imported or top-level defined, * but make an exception for two single-type imports which denote the same type. diff --git a/src/share/classes/com/sun/tools/javac/comp/Enter.java b/src/share/classes/com/sun/tools/javac/comp/Enter.java index b11062d8..282b2dd7 100644 --- a/src/share/classes/com/sun/tools/javac/comp/Enter.java +++ b/src/share/classes/com/sun/tools/javac/comp/Enter.java @@ -95,7 +95,6 @@ public class Enter extends JCTree.Visitor { Log log; Symtab syms; - Scope.ScopeCounter scopeCounter; Check chk; TreeMaker make; ClassReader reader; @@ -123,7 +122,6 @@ public class Enter extends JCTree.Visitor { reader = ClassReader.instance(context); make = TreeMaker.instance(context); syms = Symtab.instance(context); - scopeCounter = Scope.ScopeCounter.instance(context); chk = Check.instance(context); memberEnter = MemberEnter.instance(context); types = Types.instance(context); @@ -192,7 +190,7 @@ public class Enter extends JCTree.Visitor { */ public Env classEnv(JCClassDecl tree, Env env) { Env localEnv = - env.dup(tree, env.info.dup(new Scope.ClassScope(tree.sym, scopeCounter))); + env.dup(tree, env.info.dup(new Scope(tree.sym))); localEnv.enclClass = tree; localEnv.outer = env; localEnv.info.isSelfCall = false; @@ -328,7 +326,7 @@ public class Enter extends JCTree.Visitor { c.flatname = names.fromString(tree.packge + "." + name); c.sourcefile = tree.sourcefile; c.completer = null; - c.members_field = new Scope.ClassScope(c, scopeCounter); + c.members_field = new Scope(c); tree.packge.package_info = c; } classEnter(tree.defs, topEnv); @@ -396,7 +394,7 @@ public class Enter extends JCTree.Visitor { c.completer = memberEnter; c.flags_field = chk.checkFlags(tree.pos(), tree.mods.flags, c, tree); c.sourcefile = env.toplevel.sourcefile; - c.members_field = new Scope.ClassScope(c, scopeCounter); + c.members_field = new Scope(c); ClassType ct = (ClassType)c.type; if (owner.kind != PCK && (c.flags_field & STATIC) == 0) { diff --git a/src/share/classes/com/sun/tools/javac/comp/Lower.java b/src/share/classes/com/sun/tools/javac/comp/Lower.java index 7a19fb95..8675759f 100644 --- a/src/share/classes/com/sun/tools/javac/comp/Lower.java +++ b/src/share/classes/com/sun/tools/javac/comp/Lower.java @@ -68,7 +68,6 @@ public class Lower extends TreeTranslator { private Names names; private Log log; private Symtab syms; - private Scope.ScopeCounter scopeCounter; private Resolve rs; private Check chk; private Attr attr; @@ -91,7 +90,6 @@ public class Lower extends TreeTranslator { names = Names.instance(context); log = Log.instance(context); syms = Symtab.instance(context); - scopeCounter = Scope.ScopeCounter.instance(context); rs = Resolve.instance(context); chk = Check.instance(context); attr = Attr.instance(context); @@ -571,7 +569,7 @@ public class Lower extends TreeTranslator { c.flatname = chk.localClassName(c); c.sourcefile = owner.sourcefile; c.completer = null; - c.members_field = new Scope.ClassScope(c, scopeCounter); + c.members_field = new Scope(c); c.flags_field = flags; ClassType ctype = (ClassType) c.type; ctype.supertype_field = syms.objectType; diff --git a/src/share/classes/com/sun/tools/javac/comp/MemberEnter.java b/src/share/classes/com/sun/tools/javac/comp/MemberEnter.java index d6ae4063..abcbb9b1 100644 --- a/src/share/classes/com/sun/tools/javac/comp/MemberEnter.java +++ b/src/share/classes/com/sun/tools/javac/comp/MemberEnter.java @@ -67,7 +67,6 @@ public class MemberEnter extends JCTree.Visitor implements Completer { private final Check chk; private final Attr attr; private final Symtab syms; - private final Scope.ScopeCounter scopeCounter; private final TreeMaker make; private final ClassReader reader; private final Todo todo; @@ -94,7 +93,6 @@ public class MemberEnter extends JCTree.Visitor implements Completer { chk = Check.instance(context); attr = Attr.instance(context); syms = Symtab.instance(context); - scopeCounter = Scope.ScopeCounter.instance(context); make = TreeMaker.instance(context); reader = ClassReader.instance(context); todo = Todo.instance(context); @@ -1023,7 +1021,7 @@ public class MemberEnter extends JCTree.Visitor implements Completer { } private Env baseEnv(JCClassDecl tree, Env env) { - Scope baseScope = new Scope.ClassScope(tree.sym, scopeCounter); + Scope baseScope = new Scope(tree.sym); //import already entered local classes into base scope for (Scope.Entry e = env.outer.info.scope.elems ; e != null ; e = e.sibling) { if (e.sym.isLocal()) { diff --git a/src/share/classes/com/sun/tools/javac/jvm/ClassReader.java b/src/share/classes/com/sun/tools/javac/jvm/ClassReader.java index c81d9026..8a39e681 100644 --- a/src/share/classes/com/sun/tools/javac/jvm/ClassReader.java +++ b/src/share/classes/com/sun/tools/javac/jvm/ClassReader.java @@ -138,9 +138,6 @@ public class ClassReader implements Completer { /** The symbol table. */ Symtab syms; - /** The scope counter */ - Scope.ScopeCounter scopeCounter; - Types types; /** The name table. */ @@ -264,7 +261,6 @@ public class ClassReader implements Completer { names = Names.instance(context); syms = Symtab.instance(context); - scopeCounter = Scope.ScopeCounter.instance(context); types = Types.instance(context); fileManager = context.get(JavaFileManager.class); if (fileManager == null) @@ -1881,7 +1877,7 @@ public class ClassReader implements Completer { ClassType ct = (ClassType)c.type; // allocate scope for members - c.members_field = new Scope.ClassScope(c, scopeCounter); + c.members_field = new Scope(c); // prepare type variable table typevars = typevars.dup(currentOwner); diff --git a/src/share/classes/com/sun/tools/javac/resources/compiler.properties b/src/share/classes/com/sun/tools/javac/resources/compiler.properties index 395cf1b3..2945971e 100644 --- a/src/share/classes/com/sun/tools/javac/resources/compiler.properties +++ b/src/share/classes/com/sun/tools/javac/resources/compiler.properties @@ -521,10 +521,20 @@ compiler.err.enums.must.be.static=\ compiler.err.name.clash.same.erasure=\ name clash: {0} and {1} have the same erasure -# 0: symbol, 1: symbol, 2: symbol, 3: symbol +# 0: symbol, 1: symbol, 2: symbol, 3: symbol, 4: unused, 5: unused compiler.err.name.clash.same.erasure.no.override=\ name clash: {0} in {1} and {2} in {3} have the same erasure, yet neither overrides the other +# 0: symbol, 1: symbol, 2: symbol, 3: symbol, 4: symbol, 5: symbol +compiler.err.name.clash.same.erasure.no.override.1=\ + name clash: {0} in {1} overrides a method whose erasure is the same as another method, yet neither overrides the other\n\ + first method: {2} in {3}\n\ + second method: {4} in {5} + +# 0: symbol, 1: symbol, 2: symbol, 3: symbol +compiler.err.name.clash.same.erasure.no.hide=\ + name clash: {0} in {1} and {2} in {3} have the same erasure, yet neither hides the other + compiler.err.name.reserved.for.internal.use=\ {0} is reserved for internal use diff --git a/test/tools/javac/diags/examples/NameClashSameErasureNoHide.java b/test/tools/javac/diags/examples/NameClashSameErasureNoHide.java new file mode 100644 index 00000000..377855f2 --- /dev/null +++ b/test/tools/javac/diags/examples/NameClashSameErasureNoHide.java @@ -0,0 +1,34 @@ +/* + * Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +// key: compiler.err.name.clash.same.erasure.no.hide + +public class NameClashSameErasureNoHide { + static class A { + static void m(NameClashSameErasureNoHide l) {} + } + + static class B extends A { + static void m(NameClashSameErasureNoHide l) {} + } +} diff --git a/test/tools/javac/diags/examples/NameClashSameErasureNoOverride.java b/test/tools/javac/diags/examples/NameClashSameErasureNoOverride.java index 649cb0fa..f7baa370 100644 --- a/test/tools/javac/diags/examples/NameClashSameErasureNoOverride.java +++ b/test/tools/javac/diags/examples/NameClashSameErasureNoOverride.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -25,10 +25,10 @@ public class NameClashSameErasureNoOverride { static class A { - static void m(NameClashSameErasureNoOverride l) {} + void m(NameClashSameErasureNoOverride l) {} } static class B extends A { - static void m(NameClashSameErasureNoOverride l) {} + void m(NameClashSameErasureNoOverride l) {} } } diff --git a/test/tools/javac/diags/examples/NameClashSameErasureNoOverride1.java b/test/tools/javac/diags/examples/NameClashSameErasureNoOverride1.java new file mode 100644 index 00000000..77376436 --- /dev/null +++ b/test/tools/javac/diags/examples/NameClashSameErasureNoOverride1.java @@ -0,0 +1,39 @@ +/* + * Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +// key: compiler.err.name.clash.same.erasure.no.override.1 + +public class NameClashSameErasureNoOverride1 { + + interface I { + void m(X l); + } + + class A { + void m(Object l) {} + } + + class B extends A implements I { + public void m(Integer l) {} + } +} diff --git a/test/tools/javac/generics/5009937/T5009937.out b/test/tools/javac/generics/5009937/T5009937.out index 31982e9a..f338f3c6 100644 --- a/test/tools/javac/generics/5009937/T5009937.out +++ b/test/tools/javac/generics/5009937/T5009937.out @@ -1,2 +1,2 @@ -T5009937.java:16:21: compiler.err.name.clash.same.erasure.no.override: m(T5009937), T5009937.B, m(T5009937), T5009937.A +T5009937.java:16:21: compiler.err.name.clash.same.erasure.no.hide: m(T5009937), T5009937.B, m(T5009937), T5009937.A 1 error diff --git a/test/tools/javac/generics/6182950/T6182950b.out b/test/tools/javac/generics/6182950/T6182950b.out index 6771ad35..09284ef5 100644 --- a/test/tools/javac/generics/6182950/T6182950b.out +++ b/test/tools/javac/generics/6182950/T6182950b.out @@ -1,2 +1,2 @@ -T6182950b.java:15:16: compiler.err.name.clash.same.erasure.no.override: m(java.util.List), T6182950b.B, m(java.util.List), T6182950b.A +T6182950b.java:15:16: compiler.err.name.clash.same.erasure.no.override: m(java.util.List), T6182950b.B, m(java.util.List), T6182950b.A, m(java.util.List), T6182950b.B 1 error diff --git a/test/tools/javac/generics/6476118/T6476118a.out b/test/tools/javac/generics/6476118/T6476118a.out index bcd39858..27f39aef 100644 --- a/test/tools/javac/generics/6476118/T6476118a.out +++ b/test/tools/javac/generics/6476118/T6476118a.out @@ -1,2 +1,2 @@ -T6476118a.java:14:20: compiler.err.name.clash.same.erasure.no.override: compareTo(T), java.lang.Comparable, compareTo(java.lang.Object), T6476118a.A +T6476118a.java:14:20: compiler.err.name.clash.same.erasure.no.override.1: compareTo(T6476118a.B), T6476118a.B, compareTo(java.lang.Object), T6476118a.A, compareTo(T), java.lang.Comparable 1 error diff --git a/test/tools/javac/generics/6476118/T6476118b.out b/test/tools/javac/generics/6476118/T6476118b.out index 56aa3190..eb38f323 100644 --- a/test/tools/javac/generics/6476118/T6476118b.out +++ b/test/tools/javac/generics/6476118/T6476118b.out @@ -1,2 +1,2 @@ -T6476118b.java:12:20: compiler.err.name.clash.same.erasure.no.override: compareTo(T), java.lang.Comparable, compareTo(java.lang.Object), T6476118b +T6476118b.java:12:20: compiler.err.name.clash.same.erasure.no.override.1: compareTo(T6476118b.B), T6476118b.B, compareTo(java.lang.Object), T6476118b, compareTo(T), java.lang.Comparable 1 error diff --git a/test/tools/javac/generics/6476118/T6476118c.java b/test/tools/javac/generics/6476118/T6476118c.java index 751b4fb9..dd9ea289 100644 --- a/test/tools/javac/generics/6476118/T6476118c.java +++ b/test/tools/javac/generics/6476118/T6476118c.java @@ -5,7 +5,7 @@ * @compile/fail/ref=T6476118c.out -XDrawDiagnostics T6476118c.java */ -class T6476118b { +class T6476118c { static class A { public void foo(T t) { } } diff --git a/test/tools/javac/generics/6476118/T6476118c.out b/test/tools/javac/generics/6476118/T6476118c.out index 6b4d0b67..2e7cabe4 100644 --- a/test/tools/javac/generics/6476118/T6476118c.out +++ b/test/tools/javac/generics/6476118/T6476118c.out @@ -1,3 +1,3 @@ -T6476118c.java:18:21: compiler.err.name.clash.same.erasure.no.override: foo(java.lang.Object), T6476118b.C, foo(T), T6476118b.A -T6476118c.java:19:21: compiler.err.name.clash.same.erasure.no.override: foo(java.lang.Number), T6476118b.C, foo(T), T6476118b.B +T6476118c.java:18:21: compiler.err.name.clash.same.erasure.no.override: foo(java.lang.Object), T6476118c.C, foo(T), T6476118c.A, foo(java.lang.Object), T6476118c.C +T6476118c.java:19:21: compiler.err.name.clash.same.erasure.no.override: foo(java.lang.Number), T6476118c.C, foo(T), T6476118c.B, foo(java.lang.Number), T6476118c.C 2 errors diff --git a/test/tools/javac/generics/6985719/T6985719e.out b/test/tools/javac/generics/6985719/T6985719e.out index 82fd2cd3..ff6c47c6 100644 --- a/test/tools/javac/generics/6985719/T6985719e.out +++ b/test/tools/javac/generics/6985719/T6985719e.out @@ -1,2 +1,2 @@ -T6985719e.java:13:34: compiler.err.name.clash.same.erasure.no.override: f(java.util.List), T6985719e.B, f(java.util.List), T6985719e.A +T6985719e.java:13:34: compiler.err.name.clash.same.erasure.no.override: f(java.util.List), T6985719e.B, f(java.util.List), T6985719e.A, f(java.util.List), T6985719e.B 1 error diff --git a/test/tools/javac/generics/6985719/T6985719f.out b/test/tools/javac/generics/6985719/T6985719f.out index 12a07a27..192d8d65 100644 --- a/test/tools/javac/generics/6985719/T6985719f.out +++ b/test/tools/javac/generics/6985719/T6985719f.out @@ -1,2 +1,2 @@ -T6985719f.java:13:39: compiler.err.name.clash.same.erasure.no.override: f(java.util.List), T6985719f.B, f(java.util.List), T6985719f.A +T6985719f.java:13:39: compiler.err.name.clash.same.erasure.no.override: f(java.util.List), T6985719f.B, f(java.util.List), T6985719f.A, f(java.util.List), T6985719f.B 1 error diff --git a/test/tools/javac/generics/6985719/T6985719g.out b/test/tools/javac/generics/6985719/T6985719g.out index 1d37a789..a6caaebe 100644 --- a/test/tools/javac/generics/6985719/T6985719g.out +++ b/test/tools/javac/generics/6985719/T6985719g.out @@ -1,2 +1,2 @@ -T6985719g.java:13:42: compiler.err.name.clash.same.erasure.no.override: f(java.util.List), T6985719g.B, f(java.util.List), T6985719g.A +T6985719g.java:13:42: compiler.err.name.clash.same.erasure.no.override: f(java.util.List), T6985719g.B, f(java.util.List), T6985719g.A, f(java.util.List), T6985719g.B 1 error diff --git a/test/tools/javac/generics/6985719/T6985719h.out b/test/tools/javac/generics/6985719/T6985719h.out index 64b3e4a3..00fc35db 100644 --- a/test/tools/javac/generics/6985719/T6985719h.out +++ b/test/tools/javac/generics/6985719/T6985719h.out @@ -1,2 +1,2 @@ -T6985719h.java:13:56: compiler.err.name.clash.same.erasure.no.override: f(java.util.List), T6985719h.B, f(java.util.List), T6985719h.A +T6985719h.java:13:56: compiler.err.name.clash.same.erasure.no.override: f(java.util.List), T6985719h.B, f(java.util.List), T6985719h.A, f(java.util.List), T6985719h.B 1 error diff --git a/test/tools/javac/generics/7007615/T7007615.java b/test/tools/javac/generics/7007615/T7007615.java new file mode 100644 index 00000000..0c7fc62c --- /dev/null +++ b/test/tools/javac/generics/7007615/T7007615.java @@ -0,0 +1,27 @@ +/* + * @test /nodynamiccopyright/ + * @bug 7007615 + * @summary java_util/generics/phase2/NameClashTest02 fails since jdk7/pit/b123. + * @author mcimadamore + * @compile/fail/ref=T7007615.out -XDrawDiagnostics T7007615.java + */ + +class T6985719a { + class AX { + void foo(T t) { } + } + + class BX extends AX { + @Override + void foo(S t) { } + void bar(BX bx){} + } + + class DX extends BX { + void foo(Number t) { } + void bar(BX bx) { } + + @Override + void foo(Integer t) { } + } +} diff --git a/test/tools/javac/generics/7007615/T7007615.out b/test/tools/javac/generics/7007615/T7007615.out new file mode 100644 index 00000000..a6be0019 --- /dev/null +++ b/test/tools/javac/generics/7007615/T7007615.out @@ -0,0 +1,3 @@ +T7007615.java:21:14: compiler.err.name.clash.same.erasure.no.override: foo(java.lang.Number), T6985719a.DX, foo(T), T6985719a.AX, foo(java.lang.Number), T6985719a.DX +T7007615.java:22:14: compiler.err.name.clash.same.erasure.no.override: bar(T6985719a.BX), T6985719a.DX, bar(T6985719a.BX), T6985719a.BX, bar(T6985719a.BX), T6985719a.DX +2 errors diff --git a/test/tools/javac/generics/7007615/acc1/AccessibilityCheck01.java b/test/tools/javac/generics/7007615/acc1/AccessibilityCheck01.java new file mode 100644 index 00000000..c262a462 --- /dev/null +++ b/test/tools/javac/generics/7007615/acc1/AccessibilityCheck01.java @@ -0,0 +1,12 @@ +/* + * @test /nodynamiccopyright/ + * @bug 7007615 + * @summary java_util/generics/phase2/NameClashTest02 fails since jdk7/pit/b123. + * @author dlsmith + * @compile AccessibilityCheck01.java + */ + +public class AccessibilityCheck01 extends p2.E { + String m(Object o) { return "hi"; } // this is okay + int m(String s) { return 3; } // this overrides m(String) illegally +} diff --git a/test/tools/javac/generics/7007615/acc1/p1/C.java b/test/tools/javac/generics/7007615/acc1/p1/C.java new file mode 100644 index 00000000..04bd262d --- /dev/null +++ b/test/tools/javac/generics/7007615/acc1/p1/C.java @@ -0,0 +1,25 @@ +/* + * Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +package p1; +public class C { void m(T arg) { } /* implicit: m(Object) */ } diff --git a/test/tools/javac/generics/7007615/acc1/p1/D.java b/test/tools/javac/generics/7007615/acc1/p1/D.java new file mode 100644 index 00000000..6d420442 --- /dev/null +++ b/test/tools/javac/generics/7007615/acc1/p1/D.java @@ -0,0 +1,25 @@ +/* + * Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +package p1; +public class D extends C { /* inherits m(T), implicit m(Object) */ } diff --git a/test/tools/javac/generics/7007615/acc1/p2/E.java b/test/tools/javac/generics/7007615/acc1/p2/E.java new file mode 100644 index 00000000..35ee493e --- /dev/null +++ b/test/tools/javac/generics/7007615/acc1/p2/E.java @@ -0,0 +1,25 @@ +/* + * Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +package p2; +public class E extends p1.D { /* inherits nothing */ } diff --git a/test/tools/javac/generics/7007615/acc2/AccessibilityCheck02.java b/test/tools/javac/generics/7007615/acc2/AccessibilityCheck02.java new file mode 100644 index 00000000..ef8a3971 --- /dev/null +++ b/test/tools/javac/generics/7007615/acc2/AccessibilityCheck02.java @@ -0,0 +1,13 @@ +/* + * @test /nodynamiccopyright/ + * @bug 7007615 + * @summary java_util/generics/phase2/NameClashTest02 fails since jdk7/pit/b123. + * @author dlsmith + * @compile/fail/ref=AccessibilityCheck02.out -XDrawDiagnostics AccessibilityCheck02.java + */ + +public class AccessibilityCheck02 extends p2.E { + String m(Object o) { return "hi"; } // this is okay + public int m(String s) { return 3; } // this overrides m(String) illegally +} + diff --git a/test/tools/javac/generics/7007615/acc2/AccessibilityCheck02.out b/test/tools/javac/generics/7007615/acc2/AccessibilityCheck02.out new file mode 100644 index 00000000..7497bc7a --- /dev/null +++ b/test/tools/javac/generics/7007615/acc2/AccessibilityCheck02.out @@ -0,0 +1,2 @@ +AccessibilityCheck02.java:11:14: compiler.err.override.incompatible.ret: (compiler.misc.cant.override: m(java.lang.String), AccessibilityCheck02, m(java.lang.String), p1.D), int, void +1 error diff --git a/test/tools/javac/generics/7007615/acc2/p1/C.java b/test/tools/javac/generics/7007615/acc2/p1/C.java new file mode 100644 index 00000000..04bd262d --- /dev/null +++ b/test/tools/javac/generics/7007615/acc2/p1/C.java @@ -0,0 +1,25 @@ +/* + * Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +package p1; +public class C { void m(T arg) { } /* implicit: m(Object) */ } diff --git a/test/tools/javac/generics/7007615/acc2/p1/D.java b/test/tools/javac/generics/7007615/acc2/p1/D.java new file mode 100644 index 00000000..a3a1ec18 --- /dev/null +++ b/test/tools/javac/generics/7007615/acc2/p1/D.java @@ -0,0 +1,25 @@ +/* + * Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +package p1; +public class D extends C { public void m(String arg) {} /* implicit bridge: m(Object) */ } diff --git a/test/tools/javac/generics/7007615/acc2/p2/E.java b/test/tools/javac/generics/7007615/acc2/p2/E.java new file mode 100644 index 00000000..15e9e5fd --- /dev/null +++ b/test/tools/javac/generics/7007615/acc2/p2/E.java @@ -0,0 +1,25 @@ +/* + * Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +package p2; +public class E extends p1.D { /* inherits m(String) but not m(Object) */ } diff --git a/test/tools/javac/scope/HashCollisionTest.java b/test/tools/javac/scope/HashCollisionTest.java index b0a1ef51..d969dfa9 100644 --- a/test/tools/javac/scope/HashCollisionTest.java +++ b/test/tools/javac/scope/HashCollisionTest.java @@ -47,7 +47,6 @@ public class HashCollisionTest { JavacFileManager.preRegister(context); // required by ClassReader which is required by Symtab names = Names.instance(context); // Name.Table impls tied to an instance of Names symtab = Symtab.instance(context); - scopeCounter = ScopeCounter.instance(context); // determine hashMask for an empty scope Scope emptyScope = new Scope(symtab.unnamedPackage); // any owner will do @@ -171,7 +170,7 @@ public class HashCollisionTest { */ ClassSymbol createClass(Name name, Symbol owner) { ClassSymbol sym = new ClassSymbol(0, name, owner); - sym.members_field = new ClassScope(sym, scopeCounter); + sym.members_field = new Scope(sym); if (owner != symtab.unnamedPackage) owner.members().enter(sym); return sym; @@ -247,5 +246,4 @@ public class HashCollisionTest { Names names; Symtab symtab; - ScopeCounter scopeCounter; } diff --git a/test/tools/javac/scope/StarImportTest.java b/test/tools/javac/scope/StarImportTest.java index 600b0227..b8197224 100644 --- a/test/tools/javac/scope/StarImportTest.java +++ b/test/tools/javac/scope/StarImportTest.java @@ -136,7 +136,6 @@ public class StarImportTest { JavacFileManager.preRegister(context); // required by ClassReader which is required by Symtab names = Names.instance(context); // Name.Table impls tied to an instance of Names symtab = Symtab.instance(context); - scopeCounter = ScopeCounter.instance(context); int setupCount = rgen.nextInt(MAX_SETUP_COUNT); for (int i = 0; i < setupCount; i++) { switch (random(SetupKind.values())) { @@ -303,7 +302,7 @@ public class StarImportTest { ClassSymbol createClass(Name name, Symbol owner) { ClassSymbol sym = new ClassSymbol(0, name, owner); - sym.members_field = new ClassScope(sym, scopeCounter); + sym.members_field = new Scope(sym); if (owner != symtab.unnamedPackage) owner.members().enter(sym); return sym; @@ -311,7 +310,6 @@ public class StarImportTest { Context context; Symtab symtab; - ScopeCounter scopeCounter; Names names; int nextNameSerial; List packages = new ArrayList(); -- GitLab