From 3b2109ac656e354034713b090f7d70a2d9898486 Mon Sep 17 00:00:00 2001 From: aclement Date: Fri, 6 Jun 2008 20:38:14 +0000 Subject: 227295: fix to avoid CCE --- .../internal/compiler/lookup/EclipseFactory.java | 51 +++++++++++++++------- 1 file changed, 36 insertions(+), 15 deletions(-) (limited to 'org.aspectj.ajdt.core') diff --git a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/lookup/EclipseFactory.java b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/lookup/EclipseFactory.java index 59cc0b10c..5271aff58 100644 --- a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/lookup/EclipseFactory.java +++ b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/lookup/EclipseFactory.java @@ -53,6 +53,7 @@ import org.aspectj.org.eclipse.jdt.internal.compiler.lookup.SyntheticFieldBindin import org.aspectj.org.eclipse.jdt.internal.compiler.lookup.TypeBinding; import org.aspectj.org.eclipse.jdt.internal.compiler.lookup.TypeVariableBinding; import org.aspectj.org.eclipse.jdt.internal.compiler.lookup.WildcardBinding; +import org.aspectj.weaver.BCException; import org.aspectj.weaver.BoundedReferenceType; import org.aspectj.weaver.ConcreteTypeMunger; import org.aspectj.weaver.IHasPosition; @@ -657,22 +658,42 @@ public class EclipseFactory { RawTypeBinding rtb = lookupEnvironment.createRawType(baseTypeBinding,baseTypeBinding.enclosingType()); return rtb; } else if (typeX.isGenericWildcard()) { - // translate from boundedreferencetype to WildcardBinding - BoundedReferenceType brt = (BoundedReferenceType)typeX; - // Work out 'kind' for the WildcardBinding - int boundkind = Wildcard.UNBOUND; - TypeBinding bound = null; - if (brt.isExtends()) { - boundkind = Wildcard.EXTENDS; - bound = makeTypeBinding(brt.getUpperBound()); - } else if (brt.isSuper()) { - boundkind = Wildcard.SUPER; - bound = makeTypeBinding(brt.getLowerBound()); + if (typeX instanceof WildcardedUnresolvedType) { + WildcardedUnresolvedType wut = (WildcardedUnresolvedType)typeX; + int boundkind = Wildcard.UNBOUND; + TypeBinding bound = null; + if (wut.isExtends()) { + boundkind = Wildcard.EXTENDS; + bound = makeTypeBinding(wut.getUpperBound()); + } else if (wut.isSuper()) { + boundkind = Wildcard.SUPER; + bound = makeTypeBinding(wut.getLowerBound()); + } + TypeBinding[] otherBounds = null; + // TODO 2 ought to support extra bounds for WildcardUnresolvedType + // if (wut.getAdditionalBounds()!=null && wut.getAdditionalBounds().length!=0) otherBounds = makeTypeBindings(wut.getAdditionalBounds()); + WildcardBinding wb = lookupEnvironment.createWildcard(baseTypeForParameterizedType,indexOfTypeParameterBeingConverted,bound,otherBounds,boundkind); + return wb; + } else if (typeX instanceof BoundedReferenceType) { + // translate from boundedreferencetype to WildcardBinding + BoundedReferenceType brt = (BoundedReferenceType)typeX; + // Work out 'kind' for the WildcardBinding + int boundkind = Wildcard.UNBOUND; + TypeBinding bound = null; + if (brt.isExtends()) { + boundkind = Wildcard.EXTENDS; + bound = makeTypeBinding(brt.getUpperBound()); + } else if (brt.isSuper()) { + boundkind = Wildcard.SUPER; + bound = makeTypeBinding(brt.getLowerBound()); + } + TypeBinding[] otherBounds = null; + if (brt.getAdditionalBounds()!=null && brt.getAdditionalBounds().length!=0) otherBounds = makeTypeBindings(brt.getAdditionalBounds()); + WildcardBinding wb = lookupEnvironment.createWildcard(baseTypeForParameterizedType,indexOfTypeParameterBeingConverted,bound,otherBounds,boundkind); + return wb; + } else { + throw new BCException("This type "+typeX+" (class "+typeX.getClass().getName()+") should not be claiming to be a wildcard!"); } - TypeBinding[] otherBounds = null; - if (brt.getAdditionalBounds()!=null && brt.getAdditionalBounds().length!=0) otherBounds = makeTypeBindings(brt.getAdditionalBounds()); - WildcardBinding wb = lookupEnvironment.createWildcard(baseTypeForParameterizedType,indexOfTypeParameterBeingConverted,bound,otherBounds,boundkind); - return wb; } else { return lookupBinding(typeX.getName()); } -- cgit v1.2.3