8057650: uniform error diagnostics for inconsistent inherited method signatures
Consolidate diagnostics for bad overrides Reviewed-by: vromero
This commit is contained in:
parent
f06ebe9b3a
commit
ede41aa311
@ -1976,8 +1976,8 @@ public class Check {
|
|||||||
types.covariantReturnType(rt2, rt1, types.noWarnings)) ||
|
types.covariantReturnType(rt2, rt1, types.noWarnings)) ||
|
||||||
checkCommonOverriderIn(s1,s2,site);
|
checkCommonOverriderIn(s1,s2,site);
|
||||||
if (!compat) {
|
if (!compat) {
|
||||||
log.error(pos, Errors.TypesIncompatibleDiffRet(t1, t2, s2.name +
|
log.error(pos, Errors.TypesIncompatible(t1, t2,
|
||||||
"(" + types.memberType(t2, s2).getParameterTypes() + ")"));
|
Fragments.IncompatibleDiffRet(s2.name, types.memberType(t2, s2).getParameterTypes())));
|
||||||
return s2;
|
return s2;
|
||||||
}
|
}
|
||||||
} else if (checkNameClash((ClassSymbol)site.tsym, s1, s2) &&
|
} else if (checkNameClash((ClassSymbol)site.tsym, s1, s2) &&
|
||||||
@ -2563,20 +2563,22 @@ public class Check {
|
|||||||
//strong semantics - issue an error if two sibling interfaces
|
//strong semantics - issue an error if two sibling interfaces
|
||||||
//have two override-equivalent defaults - or if one is abstract
|
//have two override-equivalent defaults - or if one is abstract
|
||||||
//and the other is default
|
//and the other is default
|
||||||
String errKey;
|
Fragment diagKey;
|
||||||
Symbol s1 = defaults.first();
|
Symbol s1 = defaults.first();
|
||||||
Symbol s2;
|
Symbol s2;
|
||||||
if (defaults.size() > 1) {
|
if (defaults.size() > 1) {
|
||||||
errKey = "types.incompatible.unrelated.defaults";
|
|
||||||
s2 = defaults.toList().tail.head;
|
s2 = defaults.toList().tail.head;
|
||||||
|
diagKey = Fragments.IncompatibleUnrelatedDefaults(Kinds.kindName(site.tsym), site,
|
||||||
|
m.name, types.memberType(site, m).getParameterTypes(),
|
||||||
|
s1.location(), s2.location());
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
errKey = "types.incompatible.abstract.default";
|
|
||||||
s2 = abstracts.first();
|
s2 = abstracts.first();
|
||||||
|
diagKey = Fragments.IncompatibleAbstractDefault(Kinds.kindName(site.tsym), site,
|
||||||
|
m.name, types.memberType(site, m).getParameterTypes(),
|
||||||
|
s1.location(), s2.location());
|
||||||
}
|
}
|
||||||
log.error(pos, errKey,
|
log.error(pos, Errors.TypesIncompatible(s1.location().type, s2.location().type, diagKey));
|
||||||
Kinds.kindName(site.tsym), site,
|
|
||||||
m.name, types.memberType(site, m).getParameterTypes(),
|
|
||||||
s1.location(), s2.location());
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1136,16 +1136,21 @@ compiler.err.type.var.more.than.once=\
|
|||||||
compiler.err.type.var.more.than.once.in.result=\
|
compiler.err.type.var.more.than.once.in.result=\
|
||||||
type variable {0} occurs more than once in type of {1}; cannot be left uninstantiated
|
type variable {0} occurs more than once in type of {1}; cannot be left uninstantiated
|
||||||
|
|
||||||
# 0: type, 1: type, 2: string
|
# 0: type, 1: type, 2: fragment
|
||||||
compiler.err.types.incompatible.diff.ret=\
|
compiler.err.types.incompatible=\
|
||||||
types {0} and {1} are incompatible; both define {2}, but with unrelated return types
|
types {0} and {1} are incompatible;\n\
|
||||||
|
{2}
|
||||||
|
|
||||||
|
# 0: name, 1: list of type
|
||||||
|
compiler.misc.incompatible.diff.ret=\
|
||||||
|
both define {0}({1}), but with unrelated return types
|
||||||
|
|
||||||
# 0: kind name, 1: type, 2: name, 3: list of type, 4: symbol, 5: symbol
|
# 0: kind name, 1: type, 2: name, 3: list of type, 4: symbol, 5: symbol
|
||||||
compiler.err.types.incompatible.unrelated.defaults=\
|
compiler.misc.incompatible.unrelated.defaults=\
|
||||||
{0} {1} inherits unrelated defaults for {2}({3}) from types {4} and {5}
|
{0} {1} inherits unrelated defaults for {2}({3}) from types {4} and {5}
|
||||||
|
|
||||||
# 0: kind name, 1: type, 2: name, 3: list of type, 4: symbol, 5: symbol
|
# 0: kind name, 1: type, 2: name, 3: list of type, 4: symbol, 5: symbol
|
||||||
compiler.err.types.incompatible.abstract.default=\
|
compiler.misc.incompatible.abstract.default=\
|
||||||
{0} {1} inherits abstract and default for {2}({3}) from types {4} and {5}
|
{0} {1} inherits abstract and default for {2}({3}) from types {4} and {5}
|
||||||
|
|
||||||
# 0: name, 1: kind name, 2: symbol
|
# 0: name, 1: kind name, 2: symbol
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
BadCovar.java:22:10: compiler.err.types.incompatible.diff.ret: bad.covar.B, bad.covar.A, f()
|
BadCovar.java:22:10: compiler.err.types.incompatible: bad.covar.B, bad.covar.A, (compiler.misc.incompatible.diff.ret: f, )
|
||||||
1 error
|
1 error
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
InconsistentInheritedSignature.java:17:1: compiler.err.types.incompatible.diff.ret: I2, I1, f()
|
InconsistentInheritedSignature.java:17:1: compiler.err.types.incompatible: I2, I1, (compiler.misc.incompatible.diff.ret: f, )
|
||||||
1 error
|
1 error
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
InconsistentReturn.java:17:1: compiler.err.types.incompatible.diff.ret: I2, I1, f()
|
InconsistentReturn.java:17:1: compiler.err.types.incompatible: I2, I1, (compiler.misc.incompatible.diff.ret: f, )
|
||||||
1 error
|
1 error
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
Neg01.java:14:12: compiler.err.types.incompatible.unrelated.defaults: kindname.class, Neg01.AB, m, , Neg01.IA, Neg01.IB
|
Neg01.java:14:12: compiler.err.types.incompatible: Neg01.IA, Neg01.IB, (compiler.misc.incompatible.unrelated.defaults: kindname.class, Neg01.AB, m, , Neg01.IA, Neg01.IB)
|
||||||
1 error
|
1 error
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
Neg02.java:16:13: compiler.err.types.incompatible.unrelated.defaults: kindname.class, Neg02.X, m, , Neg02.A, Neg02.B
|
Neg02.java:16:13: compiler.err.types.incompatible: Neg02.A, Neg02.B, (compiler.misc.incompatible.unrelated.defaults: kindname.class, Neg02.X, m, , Neg02.A, Neg02.B)
|
||||||
1 error
|
1 error
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
Neg14.java:10:14: compiler.err.types.incompatible.abstract.default: kindname.class, Neg14.AB, m, , Neg14.IB, Neg14.IA
|
Neg14.java:10:14: compiler.err.types.incompatible: Neg14.IB, Neg14.IA, (compiler.misc.incompatible.abstract.default: kindname.class, Neg14.AB, m, , Neg14.IB, Neg14.IA)
|
||||||
1 error
|
1 error
|
||||||
|
@ -21,7 +21,8 @@
|
|||||||
* questions.
|
* questions.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
// key: compiler.err.types.incompatible.diff.ret
|
// key: compiler.err.types.incompatible
|
||||||
|
// key: compiler.misc.incompatible.diff.ret
|
||||||
// key: compiler.err.prob.found.req
|
// key: compiler.err.prob.found.req
|
||||||
// key: compiler.misc.incompatible.descs.in.functional.intf
|
// key: compiler.misc.incompatible.descs.in.functional.intf
|
||||||
// key: compiler.misc.descriptor
|
// key: compiler.misc.descriptor
|
||||||
|
@ -21,7 +21,8 @@
|
|||||||
* questions.
|
* questions.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
// key: compiler.err.types.incompatible.diff.ret
|
// key: compiler.err.types.incompatible
|
||||||
|
// key: compiler.misc.incompatible.diff.ret
|
||||||
|
|
||||||
interface A {
|
interface A {
|
||||||
int m();
|
int m();
|
||||||
|
@ -21,7 +21,8 @@
|
|||||||
* questions.
|
* questions.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
// key: compiler.err.types.incompatible.abstract.default
|
// key: compiler.err.types.incompatible
|
||||||
|
// key: compiler.misc.incompatible.abstract.default
|
||||||
|
|
||||||
class TypesIncompatibleAbstractDefault {
|
class TypesIncompatibleAbstractDefault {
|
||||||
interface A {
|
interface A {
|
||||||
|
@ -21,7 +21,8 @@
|
|||||||
* questions.
|
* questions.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
// key: compiler.err.types.incompatible.unrelated.defaults
|
// key: compiler.err.types.incompatible
|
||||||
|
// key: compiler.misc.incompatible.unrelated.defaults
|
||||||
|
|
||||||
class TypesIncompatibleUnrelatedDefaults {
|
class TypesIncompatibleUnrelatedDefaults {
|
||||||
interface A {
|
interface A {
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
T6294779c.java:29:5: compiler.err.types.incompatible.diff.ret: T6294779c.I2, T6294779c.I1, get()
|
T6294779c.java:29:5: compiler.err.types.incompatible: T6294779c.I2, T6294779c.I1, (compiler.misc.incompatible.diff.ret: get, )
|
||||||
1 error
|
1 error
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
T4717181c.java:15:21: compiler.err.types.incompatible.diff.ret: T4717181c.A<java.lang.Integer>, T4717181c.A<java.lang.Integer>, f(java.lang.Integer)
|
T4717181c.java:15:21: compiler.err.types.incompatible: T4717181c.A<java.lang.Integer>, T4717181c.A<java.lang.Integer>, (compiler.misc.incompatible.diff.ret: f, java.lang.Integer)
|
||||||
1 error
|
1 error
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
Test3.java:14:1: compiler.err.types.incompatible.diff.ret: B, A, m()
|
Test3.java:14:1: compiler.err.types.incompatible: B, A, (compiler.misc.incompatible.diff.ret: m, )
|
||||||
Test3.java:19:1: compiler.err.types.incompatible.diff.ret: D, C, m()
|
Test3.java:19:1: compiler.err.types.incompatible: D, C, (compiler.misc.incompatible.diff.ret: m, )
|
||||||
Test3.java:27:1: compiler.err.types.incompatible.diff.ret: E<T>, B, m()
|
Test3.java:27:1: compiler.err.types.incompatible: E<T>, B, (compiler.misc.incompatible.diff.ret: m, )
|
||||||
Test3.java:33:1: compiler.err.types.incompatible.diff.ret: F<V>, E<U>, m()
|
Test3.java:33:1: compiler.err.types.incompatible: F<V>, E<U>, (compiler.misc.incompatible.diff.ret: m, )
|
||||||
Test3.java:37:1: compiler.err.types.incompatible.diff.ret: F<V>, E<U>, m()
|
Test3.java:37:1: compiler.err.types.incompatible: F<V>, E<U>, (compiler.misc.incompatible.diff.ret: m, )
|
||||||
5 errors
|
5 errors
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
T4856983a.java:13:6: compiler.err.types.incompatible.diff.ret: I2, I1, m()
|
T4856983a.java:13:6: compiler.err.types.incompatible: I2, I1, (compiler.misc.incompatible.diff.ret: m, )
|
||||||
1 error
|
1 error
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
T4856983b.java:12:24: compiler.err.types.incompatible.diff.ret: I2, I1, m()
|
T4856983b.java:12:24: compiler.err.types.incompatible: I2, I1, (compiler.misc.incompatible.diff.ret: m, )
|
||||||
1 error
|
1 error
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
T6199146.java:9:25: compiler.err.types.incompatible.diff.ret: T6199146.I2, T6199146.I1, getFoo()
|
T6199146.java:9:25: compiler.err.types.incompatible: T6199146.I2, T6199146.I1, (compiler.misc.incompatible.diff.ret: getFoo, )
|
||||||
1 error
|
1 error
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
T7034495.java:40:17: compiler.err.types.incompatible.diff.ret: T7034495.B<compiler.misc.type.captureof: 1, ?>, T7034495.A<compiler.misc.type.captureof: 2, ?>, foo()
|
T7034495.java:40:17: compiler.err.types.incompatible: T7034495.B<compiler.misc.type.captureof: 1, ?>, T7034495.A<compiler.misc.type.captureof: 2, ?>, (compiler.misc.incompatible.diff.ret: foo, )
|
||||||
1 error
|
1 error
|
||||||
|
@ -1,3 +1,3 @@
|
|||||||
BadConv04.java:19:5: compiler.err.types.incompatible.diff.ret: BadConv04.I2, BadConv04.I1, m()
|
BadConv04.java:19:5: compiler.err.types.incompatible: BadConv04.I2, BadConv04.I1, (compiler.misc.incompatible.diff.ret: m, )
|
||||||
BadConv04.java:21:13: compiler.err.prob.found.req: (compiler.misc.incompatible.descs.in.functional.intf: kindname.interface, BadConv04.SAM,{(compiler.misc.descriptor: m, , long, ),(compiler.misc.descriptor: m, , int, )})
|
BadConv04.java:21:13: compiler.err.prob.found.req: (compiler.misc.incompatible.descs.in.functional.intf: kindname.interface, BadConv04.SAM,{(compiler.misc.descriptor: m, , long, ),(compiler.misc.descriptor: m, , int, )})
|
||||||
2 errors
|
2 errors
|
||||||
|
@ -1001,18 +1001,18 @@ public class BridgeMethodsTemplateTest extends BridgeMethodTestCase {
|
|||||||
|
|
||||||
public void testA5() throws IOException, ReflectiveOperationException {
|
public void testA5() throws IOException, ReflectiveOperationException {
|
||||||
compileSpec("C(A(Id0),Jd0)",
|
compileSpec("C(A(Id0),Jd0)",
|
||||||
"compiler.err.types.incompatible.unrelated.defaults");
|
"compiler.err.types.incompatible");
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testA6() throws IOException, ReflectiveOperationException {
|
public void testA6() throws IOException, ReflectiveOperationException {
|
||||||
compileSpec("C(A(Ia0,Jd0))",
|
compileSpec("C(A(Ia0,Jd0))",
|
||||||
"compiler.err.does.not.override.abstract",
|
"compiler.err.does.not.override.abstract",
|
||||||
"compiler.err.types.incompatible.abstract.default");
|
"compiler.err.types.incompatible");
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testA7() throws IOException, ReflectiveOperationException {
|
public void testA7() throws IOException, ReflectiveOperationException {
|
||||||
compileSpec("C(A(Id0,Jd0))",
|
compileSpec("C(A(Id0,Jd0))",
|
||||||
"compiler.err.types.incompatible.unrelated.defaults");
|
"compiler.err.types.incompatible");
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testA8() throws IOException, ReflectiveOperationException {
|
public void testA8() throws IOException, ReflectiveOperationException {
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
NonSAM2.java:13:1: compiler.err.types.incompatible.diff.ret: Bar1, Foo1, getAge(java.lang.String)
|
NonSAM2.java:13:1: compiler.err.types.incompatible: Bar1, Foo1, (compiler.misc.incompatible.diff.ret: getAge, java.lang.String)
|
||||||
NonSAM2.java:15:1: compiler.err.name.clash.same.erasure.no.override: getOldest, java.util.List<?>, C, getOldest, java.util.List<java.lang.Number>, A
|
NonSAM2.java:15:1: compiler.err.name.clash.same.erasure.no.override: getOldest, java.util.List<?>, C, getOldest, java.util.List<java.lang.Number>, A
|
||||||
NonSAM2.java:17:1: compiler.err.name.clash.same.erasure.no.override: getOldest, java.util.List<java.lang.Integer>, D, getOldest, java.util.List<java.lang.Number>, A
|
NonSAM2.java:17:1: compiler.err.name.clash.same.erasure.no.override: getOldest, java.util.List<java.lang.Integer>, D, getOldest, java.util.List<java.lang.Number>, A
|
||||||
NonSAM2.java:21:1: compiler.err.name.clash.same.erasure.no.override: m, T2, Bar2, m, T1, Foo2
|
NonSAM2.java:21:1: compiler.err.name.clash.same.erasure.no.override: m, T2, Bar2, m, T1, Foo2
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
T4.java:3:10: compiler.err.types.incompatible.diff.ret: iclss01004_2, iclss01004_1, foo(int)
|
T4.java:3:10: compiler.err.types.incompatible: iclss01004_2, iclss01004_1, (compiler.misc.incompatible.diff.ret: foo, int)
|
||||||
1 error
|
1 error
|
||||||
|
Loading…
Reference in New Issue
Block a user