javac throws a NPE when compiling a lambda expression

Ali Ebrahimi ali.ebrahimi1781 at gmail.com
Mon Jun 13 02:28:27 PDT 2011


Hi,
yes i had import statement. by removing that crash occurs.

Ali Ebrahimi

On Mon, Jun 13, 2011 at 12:07 PM, Maurizio Cimadamore <
maurizio.cimadamore at oracle.com> wrote:

> I confirm that the following simplified example actually fails with the
> latest compiler:
>
> class TestLambda {
>
>
>  interface SAM {
>    void m();
>  }
>
>  {
>    call(#{ -> log(new Date() + "");  });
>  }
>
>  void call(SAM s) { }
>
>
>  void log(String msg) {
>    System.out.println(msg);
>  }
>  }
>
> The problem is caused by a bad error recovery - in the above example
> java.util.Date cannot be found, because the corresponding import is missing.
> Which means that the compiler should emit an error, but in this case the
> error is swallen when attributing the lambda body - which means that the
> compiler tries to emit code for an incorrect source program - hence the NPE.
>
> Maurizio
>
>
>
> On 13/06/11 07:46, Ali Ebrahimi wrote:
>
>> Hi,
>> This sample code compiles with current lambda repository build.
>>
>> Ali Ebrahimi
>>
>> On Sat, Jun 11, 2011 at 9:00 AM, Arul Dhesiaseelan<aruld at acm.org>  wrote:
>>
>>  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