[lworld] RFR: 8244231: [lworld] Add support for ref-default and val-default inline classes.
    Srikanth Adayapalam 
    sadayapalam at openjdk.java.net
       
    Mon Jul 19 06:33:16 UTC 2021
    
    
  
On Fri, 16 Jul 2021 08:05:02 GMT, Srikanth Adayapalam <sadayapalam at openjdk.org> wrote:
> Code changes and tests
src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Attr.java line 326:
> 324:                 */
> 325:                 if (env.info.inWithField && v.getKind() == ElementKind.FIELD && (v.flags() & STATIC) == 0 && v.owner.isPrimitiveClass()) {
> 326:                     if (env.enclClass.sym.outermostClass() == v.owner.outermostClass())
This is an example of a code change you will see recur several times: Earlier when we had only value default primitive classes to check if a field is a field of a primitive class it was alright to ask
types.isPrimitiveClass(v.owner.type)
With ref-default classes entering the picture if v.owner is a ref-default primitive class then v.owner.type will not
answer true for the above check. (For a ref-default primitive class Optional.val, Optional.type is 'L' type not Q type) and we need to check
owner.isPrimitiveClass()
which will answer true for both val-default and ref-default primitive classes.
-------------
PR: https://git.openjdk.java.net/valhalla/pull/482
    
    
More information about the valhalla-dev
mailing list