Skip to content

Commit

Permalink
Fix testTypeReference22
Browse files Browse the repository at this point in the history
Signed-off-by: Rob Stryker <[email protected]>
  • Loading branch information
Rob Stryker committed Dec 2, 2024
1 parent 8d01163 commit 7b76acb
Showing 1 changed file with 39 additions and 32 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -271,6 +271,42 @@ private JavacPackageBinding preferentiallyInsertPackageBinding(JavacPackageBindi
public JavacTypeBinding getTypeBinding(JCTree tree, com.sun.tools.javac.code.Type type) {
return getTypeBinding(type, tree instanceof JCClassDecl);
}

public IBinding getFieldAccessBinding(JCFieldAccess fieldAccess) {
JCFieldAccess jcfa2 = (fieldAccess.sym == null && fieldAccess.selected instanceof JCFieldAccess jcfa3) ? jcfa3 : fieldAccess;
if( jcfa2.sym != null ) {
com.sun.tools.javac.code.Type typeToUse = jcfa2.type;
if(jcfa2.selected instanceof JCTypeApply) {
typeToUse = jcfa2.sym.type;
}
IBinding bRet = this.getBinding(jcfa2.sym, typeToUse);
if( jcfa2 != fieldAccess && bRet instanceof ITypeBinding itb ) {
String fieldAccessIdentifier = fieldAccess.getIdentifier().toString();
// If we changed the field access, we need to go one generation lower
Function<IBinding[], IBinding> func = bindings -> {
for( int i = 0; i < bindings.length; i++ ) {
String childName = bindings[i].getName();
if( childName.equals(fieldAccessIdentifier)) {
return bindings[i];
}
}
return null;
};
IBinding ret = func.apply(itb.getDeclaredTypes());
if( ret != null )
return ret;
ret = func.apply(itb.getDeclaredFields());
if( ret != null )
return ret;
ret = func.apply(itb.getDeclaredMethods());
if( ret != null )
return ret;
}
return bRet;
}
return null;
}

public JavacTypeBinding getTypeBinding(com.sun.tools.javac.code.Type type) {
if (type == null) {
return null;
Expand Down Expand Up @@ -565,7 +601,8 @@ public ITypeBinding resolveType(Type type) {
return this.bindings.getTypeBinding(ident.type);
}
if (jcTree instanceof JCFieldAccess access) {
return this.bindings.getTypeBinding(access.type);
IBinding b = this.bindings.getFieldAccessBinding(access);
return b instanceof ITypeBinding tb ? tb : null;
}
if (jcTree instanceof JCPrimitiveTypeTree primitive && primitive.type != null) {
return this.bindings.getTypeBinding(primitive.type);
Expand Down Expand Up @@ -1165,37 +1202,7 @@ IBinding resolveNameToJavac(Name name, JCTree tree) {
return this.bindings.getTypeBinding(variableDecl.type);
}
if (tree instanceof JCFieldAccess fieldAccess) {
JCFieldAccess jcfa2 = (fieldAccess.sym == null && fieldAccess.selected instanceof JCFieldAccess jcfa3) ? jcfa3 : fieldAccess;
if( jcfa2.sym != null ) {
com.sun.tools.javac.code.Type typeToUse = jcfa2.type;
if(jcfa2.selected instanceof JCTypeApply) {
typeToUse = jcfa2.sym.type;
}
IBinding bRet = this.bindings.getBinding(jcfa2.sym, typeToUse);
if( jcfa2 != fieldAccess && bRet instanceof ITypeBinding itb ) {
String fieldAccessIdentifier = fieldAccess.getIdentifier().toString();
// If we changed the field access, we need to go one generation lower
Function<IBinding[], IBinding> func = bindings -> {
for( int i = 0; i < bindings.length; i++ ) {
String childName = bindings[i].getName();
if( childName.equals(fieldAccessIdentifier)) {
return bindings[i];
}
}
return null;
};
IBinding ret = func.apply(itb.getDeclaredTypes());
if( ret != null )
return ret;
ret = func.apply(itb.getDeclaredFields());
if( ret != null )
return ret;
ret = func.apply(itb.getDeclaredMethods());
if( ret != null )
return ret;
}
return bRet;
}
return this.bindings.getFieldAccessBinding(fieldAccess);
}
if (tree instanceof JCMethodInvocation methodInvocation && methodInvocation.meth.type != null) {
return this.bindings.getBinding(((JCFieldAccess)methodInvocation.meth).sym, methodInvocation.meth.type);
Expand Down

0 comments on commit 7b76acb

Please sign in to comment.