javac throws a NPE when compiling a lambda expression
Arul Dhesiaseelan
aruld at acm.org
Fri Jun 10 22:30:19 PDT 2011
public class TestLambda {
class Payment {
private int amount;
Payment(int amount) {
this.amount = amount;
}
public int getAmount() {
return amount;
}
}
interface PaymentProcessor {
void process(Payment pmt);
}
{
invokeProcessor(# { pmt - > log("Processed # " + pmt.getAmount() + " at
" + new Date()) });
}
void invokeProcessor(PaymentProcessor processor) {
processor.process(new Payment(42));
}
void log(String msg) {
System.out.println(msg);
}
}
I am trying to rebuild my old Lambda example (which used to work with
earlier prototype using build 115), but failed to compile with the latest
prototype using build 145:
An exception has occurred in the compiler (1.7.0-internal). Please file a
bug at the Java Developer Connection (http://java.sun.com/webapps/bugreport)
after checking the Bug Parade for duplicates. Include your program and the
following diagnostic in your report. Thank you.
java.lang.NullPointerException
at com.sun.tools.javac.comp.Flow.visitNewClass(Flow.java:1308)
at
com.sun.tools.javac.tree.JCTree$JCNewClass.accept(JCTree.java:1391)
at com.sun.tools.javac.tree.TreeScanner.scan(TreeScanner.java:49)
at com.sun.tools.javac.comp.Flow.scanExpr(Flow.java:572)
at com.sun.tools.javac.comp.Flow.visitBinary(Flow.java:1504)
at com.sun.tools.javac.tree.JCTree$JCBinary.accept(JCTree.java:1654)
at com.sun.tools.javac.tree.TreeScanner.scan(TreeScanner.java:49)
at com.sun.tools.javac.comp.Flow.scanExpr(Flow.java:572)
at com.sun.tools.javac.comp.Flow.scanExprs(Flow.java:582)
at com.sun.tools.javac.comp.Flow.visitApply(Flow.java:1299)
at
com.sun.tools.javac.tree.JCTree$JCMethodInvocation.accept(JCTree.java:1337)
at com.sun.tools.javac.tree.TreeScanner.scan(TreeScanner.java:49)
at com.sun.tools.javac.comp.Flow.scanStat(Flow.java:556)
at com.sun.tools.javac.comp.Flow.analyzeLambda(Flow.java:1370)
at com.sun.tools.javac.comp.Attr.attribLambda(Attr.java:2314)
at com.sun.tools.javac.comp.Attr$1.deferredAttr(Attr.java:2194)
at com.sun.tools.javac.comp.Attr$1.deferredAttr(Attr.java:2185)
at
com.sun.tools.javac.comp.Attr$SAMDeferredAttribution.complete(Attr.java:2793)
at
com.sun.tools.javac.comp.Infer$InferPolyCompleter.complete(Infer.java:737)
at com.sun.tools.javac.comp.Infer.instantiatePoly(Infer.java:748)
at
com.sun.tools.javac.comp.Resolve.checkRawArgumentsAcceptable(Resolve.java:553)
at com.sun.tools.javac.comp.Infer.instantiateMethod(Infer.java:419)
at com.sun.tools.javac.comp.Resolve.rawInstantiate(Resolve.java:396)
at com.sun.tools.javac.comp.Resolve.selectBest(Resolve.java:820)
at com.sun.tools.javac.comp.Resolve.findMethod(Resolve.java:1064)
at com.sun.tools.javac.comp.Resolve.findMethod(Resolve.java:1025)
at com.sun.tools.javac.comp.Resolve.findFun(Resolve.java:1158)
at com.sun.tools.javac.comp.Resolve.resolveMethod(Resolve.java:1582)
at com.sun.tools.javac.comp.Attr.visitIdent(Attr.java:2546)
at com.sun.tools.javac.tree.JCTree$JCIdent.accept(JCTree.java:1826)
at com.sun.tools.javac.comp.Attr.attribTree(Attr.java:466)
at com.sun.tools.javac.comp.Attr.visitApply(Attr.java:1578)
at
com.sun.tools.javac.tree.JCTree$JCMethodInvocation.accept(JCTree.java:1337)
at com.sun.tools.javac.comp.Attr.attribTree(Attr.java:466)
at com.sun.tools.javac.comp.Attr.attribTree(Attr.java:484)
at com.sun.tools.javac.comp.Attr.attribExpr(Attr.java:499)
at com.sun.tools.javac.comp.Attr.visitExec(Attr.java:1334)
at
com.sun.tools.javac.tree.JCTree$JCExpressionStatement.accept(JCTree.java:1180)
at com.sun.tools.javac.comp.Attr.attribTree(Attr.java:466)
at com.sun.tools.javac.comp.Attr.attribTree(Attr.java:484)
at com.sun.tools.javac.comp.Attr.attribStat(Attr.java:519)
at com.sun.tools.javac.comp.Attr.attribStats(Attr.java:535)
at com.sun.tools.javac.comp.Attr.visitBlock(Attr.java:952)
at com.sun.tools.javac.tree.JCTree$JCBlock.accept(JCTree.java:794)
at com.sun.tools.javac.comp.Attr.attribTree(Attr.java:466)
at com.sun.tools.javac.comp.Attr.attribTree(Attr.java:484)
at com.sun.tools.javac.comp.Attr.attribStat(Attr.java:519)
at com.sun.tools.javac.comp.Attr.attribClassBody(Attr.java:3793)
at com.sun.tools.javac.comp.Attr.attribClass(Attr.java:3715)
at com.sun.tools.javac.comp.Attr.attribClass(Attr.java:3651)
at com.sun.tools.javac.comp.Attr.attrib(Attr.java:3625)
at
com.sun.tools.javac.main.JavaCompiler.attribute(JavaCompiler.java:1189)
at
com.sun.tools.javac.main.JavaCompiler.compile2(JavaCompiler.java:877)
at
com.sun.tools.javac.main.JavaCompiler.compile(JavaCompiler.java:836)
at com.sun.tools.javac.main.Main.compile(Main.java:417)
at com.sun.tools.javac.main.Main.compile(Main.java:331)
at com.sun.tools.javac.main.Main.compile(Main.java:322)
at com.sun.tools.javac.Main.compile(Main.java:76)
at com.sun.tools.javac.Main.main(Main.java:61)
java version "1.7.0-ea"
Java(TM) SE Runtime Environment (build 1.7.0-ea-b145)
Java HotSpot(TM) 64-Bit Server VM (build 21.0-b15, mixed mode)
I am not sure what has changed since then. Any clues?
-Arul
More information about the lambda-dev
mailing list