diff options
author | aclement <aclement> | 2008-06-06 20:38:14 +0000 |
---|---|---|
committer | aclement <aclement> | 2008-06-06 20:38:14 +0000 |
commit | 3b2109ac656e354034713b090f7d70a2d9898486 (patch) | |
tree | 37eeae36a0151be9baee9d8b2f4c034cac8e6f37 /org.aspectj.ajdt.core | |
parent | 70f144da25e3d5b01f728757e5ea27b1cd0a8e56 (diff) | |
download | aspectj-3b2109ac656e354034713b090f7d70a2d9898486.tar.gz aspectj-3b2109ac656e354034713b090f7d70a2d9898486.zip |
227295: fix to avoid CCE
Diffstat (limited to 'org.aspectj.ajdt.core')
-rw-r--r-- | org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/lookup/EclipseFactory.java | 51 |
1 files changed, 36 insertions, 15 deletions
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()); } |