AssertionError while trying to print a diagnostic

Jonathan Gibbons jonathan.gibbons at oracle.com
Tue May 14 11:23:23 PDT 2013


Oops. 8014556

-- Jon

On 05/14/2013 10:51 AM, Raluca Sauciuc wrote:
> Hi compiler-dev,
>
> Martin and I ran into an unexpected javac7 stacktrace, and I think the 
> following code exposes a bug:
>
> abstract class Formatter<K> {
>  abstract String format(K value);
>
>    static <J> Formatter<Object> fromGetter(final Getter<J> g, final 
> Formatter<J> f) {
>        return new Formatter<J>() {
>      @Override
>          public String format(Object obj) {
>              return f.format(g.get(obj));
>          }
>      };
>  }
>
>  interface Getter<K> {
>      K get(Object obj);
>  }
> }
>
> The compiler is trying to print this error message:
>
> error: incompatible types
>  return new Formatter<J>() {
>         ^
>  required: Formatter<java.lang.Object>
>  found:    <anonymous Formatter<J>>
>
> but fails instead with the following stacktrace:
>
> java.lang.AssertionError: Missing type variable in where clause J
>    at 
> com.sun.tools.javac.util.RichDiagnosticFormatter.unique(RichDiagnosticFormatter.java:234)
>    at 
> com.sun.tools.javac.util.RichDiagnosticFormatter.access$100(RichDiagnosticFormatter.java:67)
>    at 
> com.sun.tools.javac.util.RichDiagnosticFormatter$RichPrinter.visitTypeVar(RichDiagnosticFormatter.java:384)
>    at 
> com.sun.tools.javac.util.RichDiagnosticFormatter$RichPrinter.visitTypeVar(RichDiagnosticFormatter.java:326)
>    at com.sun.tools.javac.code.Type$TypeVar.accept(Type.java:1030)
>    at com.sun.tools.javac.code.Printer.visit(Printer.java:131)
>    at com.sun.tools.javac.code.Printer.visitTypes(Printer.java:103)
>    at com.sun.tools.javac.code.Printer.visitClassType(Printer.java:194)
>    at 
> com.sun.tools.javac.util.RichDiagnosticFormatter$RichPrinter.visitClassType(RichDiagnosticFormatter.java:366)
>    at 
> com.sun.tools.javac.util.RichDiagnosticFormatter$RichPrinter.visitClassType(RichDiagnosticFormatter.java:326)
>    at com.sun.tools.javac.code.Type$ClassType.accept(Type.java:583)
>    at com.sun.tools.javac.code.Printer.visit(Printer.java:131)
>    at com.sun.tools.javac.code.Printer.className(Printer.java:265)
>    at 
> com.sun.tools.javac.util.RichDiagnosticFormatter$RichPrinter.className(RichDiagnosticFormatter.java:374)
>    at com.sun.tools.javac.code.Printer.visitClassType(Printer.java:190)
>    at 
> com.sun.tools.javac.util.RichDiagnosticFormatter$RichPrinter.visitClassType(RichDiagnosticFormatter.java:366)
>    at 
> com.sun.tools.javac.util.RichDiagnosticFormatter$RichPrinter.visitClassType(RichDiagnosticFormatter.java:326)
>    at com.sun.tools.javac.code.Type$ClassType.accept(Type.java:583)
>    at com.sun.tools.javac.code.Printer.visit(Printer.java:131)
>    at 
> com.sun.tools.javac.util.AbstractDiagnosticFormatter.formatArgument(AbstractDiagnosticFormatter.java:187)
>    at 
> com.sun.tools.javac.util.AbstractDiagnosticFormatter.formatArguments(AbstractDiagnosticFormatter.java:158)
>    at 
> com.sun.tools.javac.util.BasicDiagnosticFormatter.formatMessage(BasicDiagnosticFormatter.java:111)
>    at 
> com.sun.tools.javac.util.BasicDiagnosticFormatter.formatMeta(BasicDiagnosticFormatter.java:184)
>    at 
> com.sun.tools.javac.util.BasicDiagnosticFormatter.formatDiagnostic(BasicDiagnosticFormatter.java:100)
>    at 
> com.sun.tools.javac.util.AbstractDiagnosticFormatter.format(AbstractDiagnosticFormatter.java:114)
>    at 
> com.sun.tools.javac.util.RichDiagnosticFormatter.format(RichDiagnosticFormatter.java:112)
>    at 
> com.sun.tools.javac.util.RichDiagnosticFormatter.format(RichDiagnosticFormatter.java:67)
>    at com.sun.tools.javac.util.Log.writeDiagnostic(Log.java:434)
>    at com.sun.tools.javac.util.Log.report(Log.java:416)
>    at com.sun.tools.javac.util.AbstractLog.error(AbstractLog.java:94)
>    at com.sun.tools.javac.comp.Check.typeError(Check.java:269)
>    at com.sun.tools.javac.comp.Check.checkType(Check.java:452)
>    at com.sun.tools.javac.comp.Attr.check(Attr.java:203)
>    at com.sun.tools.javac.comp.Attr.visitNewClass(Attr.java:1817)
>    at com.sun.tools.javac.tree.JCTree$JCNewClass.accept(JCTree.java:1372)
>    at com.sun.tools.javac.comp.Attr.attribTree(Attr.java:431)
>    at com.sun.tools.javac.comp.Attr.attribTree(Attr.java:418)
>    at com.sun.tools.javac.comp.Attr.attribExpr(Attr.java:449)
>    at com.sun.tools.javac.comp.Attr.visitReturn(Attr.java:1384)
>    at com.sun.tools.javac.tree.JCTree$JCReturn.accept(JCTree.java:1240)
>    at com.sun.tools.javac.comp.Attr.attribTree(Attr.java:431)
>    at com.sun.tools.javac.comp.Attr.attribTree(Attr.java:418)
>    at com.sun.tools.javac.comp.Attr.attribStat(Attr.java:480)
>    at com.sun.tools.javac.comp.Attr.attribStats(Attr.java:496)
>    at com.sun.tools.javac.comp.Attr.visitBlock(Attr.java:911)
>    at com.sun.tools.javac.tree.JCTree$JCBlock.accept(JCTree.java:781)
>    at com.sun.tools.javac.comp.Attr.attribTree(Attr.java:431)
>    at com.sun.tools.javac.comp.Attr.attribTree(Attr.java:418)
>    at com.sun.tools.javac.comp.Attr.attribStat(Attr.java:480)
>    at com.sun.tools.javac.comp.Attr.visitMethodDef(Attr.java:829)
>    at com.sun.tools.javac.tree.JCTree$JCMethodDecl.accept(JCTree.java:669)
>    at com.sun.tools.javac.comp.Attr.attribTree(Attr.java:431)
>    at com.sun.tools.javac.comp.Attr.attribTree(Attr.java:418)
>    at com.sun.tools.javac.comp.Attr.attribStat(Attr.java:480)
>    at com.sun.tools.javac.comp.Attr.attribClassBody(Attr.java:3254)
>    at com.sun.tools.javac.comp.Attr.attribClass(Attr.java:3177)
>    at com.sun.tools.javac.comp.Attr.attribClass(Attr.java:3133)
>    at com.sun.tools.javac.comp.Attr.attribClass(Attr.java:3113)
>    at com.sun.tools.javac.comp.Attr.visitClassDef(Attr.java:701)
>    at com.sun.tools.javac.tree.JCTree$JCClassDecl.accept(JCTree.java:591)
>    at com.sun.tools.javac.comp.Attr.attribTree(Attr.java:431)
>    at com.sun.tools.javac.comp.Attr.attribTree(Attr.java:418)
>    at com.sun.tools.javac.comp.Attr.attribStat(Attr.java:480)
>    at com.sun.tools.javac.comp.Attr.visitNewClass(Attr.java:1781)
>    at com.sun.tools.javac.tree.JCTree$JCNewClass.accept(JCTree.java:1372)
>    at com.sun.tools.javac.comp.Attr.attribTree(Attr.java:431)
>    at com.sun.tools.javac.comp.Attr.attribTree(Attr.java:418)
>    at com.sun.tools.javac.comp.Attr.attribArgs(Attr.java:504)
>    at com.sun.tools.javac.comp.Attr.visitNewClass(Attr.java:1647)
>    at com.sun.tools.javac.tree.JCTree$JCNewClass.accept(JCTree.java:1372)
>    at com.sun.tools.javac.comp.Attr.attribTree(Attr.java:431)
>    at com.sun.tools.javac.comp.Attr.attribTree(Attr.java:418)
>    at com.sun.tools.javac.comp.Attr.attribExpr(Attr.java:449)
>    at com.sun.tools.javac.comp.Attr.visitVarDef(Attr.java:880)
>    at 
> com.sun.tools.javac.tree.JCTree$JCVariableDecl.accept(JCTree.java:725)
>    at com.sun.tools.javac.comp.Attr.attribTree(Attr.java:431)
>    at com.sun.tools.javac.comp.Attr.attribTree(Attr.java:418)
>    at com.sun.tools.javac.comp.Attr.attribStat(Attr.java:480)
>    at com.sun.tools.javac.comp.Attr.attribStats(Attr.java:496)
>    at com.sun.tools.javac.comp.Attr.visitBlock(Attr.java:911)
>    at com.sun.tools.javac.tree.JCTree$JCBlock.accept(JCTree.java:781)
>    at com.sun.tools.javac.comp.Attr.attribTree(Attr.java:431)
>    at com.sun.tools.javac.comp.Attr.attribTree(Attr.java:418)
>    at com.sun.tools.javac.comp.Attr.attribStat(Attr.java:480)
>    at com.sun.tools.javac.comp.Attr.visitMethodDef(Attr.java:829)
>    at com.sun.tools.javac.tree.JCTree$JCMethodDecl.accept(JCTree.java:669)
>    at com.sun.tools.javac.comp.Attr.attribTree(Attr.java:431)
>    at com.sun.tools.javac.comp.Attr.attribTree(Attr.java:418)
>    at com.sun.tools.javac.comp.Attr.attribStat(Attr.java:480)
>    at com.sun.tools.javac.comp.Attr.attribClassBody(Attr.java:3254)
>    at com.sun.tools.javac.comp.Attr.attribClass(Attr.java:3177)
>    at com.sun.tools.javac.comp.Attr.attribClass(Attr.java:3113)
>    at com.sun.tools.javac.comp.Attr.attrib(Attr.java:3087)
>    at 
> com.sun.tools.javac.main.JavaCompiler.attribute(JavaCompiler.java:1184)
>    at 
> com.sun.tools.javac.main.JavaCompiler.compile2(JavaCompiler.java:870)
>    at com.sun.tools.javac.main.JavaCompiler.compile(JavaCompiler.java:829)
>    at com.sun.tools.javac.main.Main.compile(Main.java:439)
>    at com.sun.tools.javac.main.Main.compile(Main.java:353)
>    at com.sun.tools.javac.main.Main.compile(Main.java:342)
>    at com.sun.tools.javac.main.Main.compile(Main.java:333)
>    at com.sun.tools.javac.Main.compile(Main.java:76)
>    at com.sun.tools.javac.Main.main(Main.java:61)
>
>

-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://mail.openjdk.java.net/pipermail/compiler-dev/attachments/20130514/2cd3f5b5/attachment-0001.html 


More information about the compiler-dev mailing list