Java 7 -> Java8 code breakage scenarios

Boaz Nahum boaznahum at gmail.com
Thu Feb 28 07:32:28 PST 2013


So can I stop my efforts reproducing 'rank' crash ?
Actually I reproduce it, But I'm not able to isolate the case - I can
easily build JDK and test it.

But if you want me to continue retry - no problem.

Boaz


On Thu, Feb 28, 2013 at 3:46 PM, Maurizio Cimadamore <
maurizio.cimadamore at oracle.com> wrote:

> On 28/02/13 13:24, Boaz Nahum wrote:
>
>> //C.java
>>
>>  public class C {
>>>      void test(B b) {
>>>          Tester.m(B.n());
>>>      }
>>> }
>>>
>>> Which is the very one you got. If you'd be so kind to give me some
>>> details
>>> about the other stack trace you were getting (Types.rank) so that I can
>>> come up with some test case (i.e. what is the code that triggered it).
>>>
>>> Maurizio
>>>
>>>  Yes exactly. If you named B.n() instead of inline it in the method call
>> then you got 'normal' error message.
>> The 'rank' exception - I'm working on it.
>>
>> Thanks !!!
>> Boaz
>>
>>  I believe I got at the bottom of the issue - when a completion error
> (i.e. missing classfile) occurs in a nested context (i.e. method call), the
> compiler doesn't always report the error, because of some of the
> intricacies associated with lambda type-checking and nested method calls.
> Those errors should ALWAYS be reported, as a missing classfile error is a
> really bad condition that shouldn't be skipped. The fact that the compiler
> is not reporting them in certain cases lead javac to think that everything
> is ok, so that the subsequent compilation step can be executed - which is
> not true. Hence all the spurious crashes.
>
> Maurizio
>


More information about the lambda-dev mailing list