summaryrefslogtreecommitdiffstats
path: root/org.aspectj.ajdt.core/src
diff options
context:
space:
mode:
authoraclement <aclement>2010-06-08 22:56:57 +0000
committeraclement <aclement>2010-06-08 22:56:57 +0000
commitb647286b2267935b6a7ba60515e872de647901f8 (patch)
tree264db4056c1468855647cb667fdb5fcb45d6d917 /org.aspectj.ajdt.core/src
parentb66fddbb4931784d27f2299a0d695f556ff2a836 (diff)
downloadaspectj-b647286b2267935b6a7ba60515e872de647901f8.tar.gz
aspectj-b647286b2267935b6a7ba60515e872de647901f8.zip
generics and ITD inner class updates
Diffstat (limited to 'org.aspectj.ajdt.core/src')
-rw-r--r--org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/ast/AspectDeclaration.java12
-rw-r--r--org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/ast/IntertypeMemberClassDeclaration.java27
-rw-r--r--org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/lookup/EclipseSourceType.java155
-rw-r--r--org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/lookup/EclipseTypeMunger.java2
4 files changed, 136 insertions, 60 deletions
diff --git a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/ast/AspectDeclaration.java b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/ast/AspectDeclaration.java
index d7fb9335d..e9356a783 100644
--- a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/ast/AspectDeclaration.java
+++ b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/ast/AspectDeclaration.java
@@ -280,6 +280,7 @@ public class AspectDeclaration extends TypeDeclaration {
return true;
}
+ @SuppressWarnings("unchecked")
protected void generateAttributes(ClassFile classFile) {
if (!isAbstract()) {
generatePerSupportMembers(classFile);
@@ -299,6 +300,17 @@ public class AspectDeclaration extends TypeDeclaration {
classFile.extraAttributes.add(new EclipseAttributeAdapter(new AjAttribute.PrivilegedAttribute(members)));
}
}
+ if (memberTypes != null) {
+ for (int i = 0; i < memberTypes.length; i++) {
+ if (memberTypes[i] instanceof IntertypeMemberClassDeclaration) {
+ IntertypeMemberClassDeclaration itdMemberClassDeclaration = (IntertypeMemberClassDeclaration) memberTypes[i];
+ AjAttribute attribute = itdMemberClassDeclaration.getAttribute();
+ if (attribute != null) {
+ classFile.extraAttributes.add(new EclipseAttributeAdapter(attribute));
+ }
+ }
+ }
+ }
// XXX need to get this attribute on anyone with a pointcut for good errors
classFile.extraAttributes.add(new EclipseAttributeAdapter(new AjAttribute.SourceContextAttribute(new String(
diff --git a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/ast/IntertypeMemberClassDeclaration.java b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/ast/IntertypeMemberClassDeclaration.java
index dd0d49824..8ee80bdc2 100644
--- a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/ast/IntertypeMemberClassDeclaration.java
+++ b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/ast/IntertypeMemberClassDeclaration.java
@@ -15,8 +15,10 @@ import java.lang.reflect.Modifier;
import java.util.Collections;
import org.aspectj.ajdt.internal.compiler.lookup.EclipseFactory;
+import org.aspectj.ajdt.internal.compiler.lookup.EclipseSourceLocation;
import org.aspectj.ajdt.internal.compiler.lookup.EclipseTypeMunger;
import org.aspectj.ajdt.internal.compiler.lookup.InterTypeScope;
+import org.aspectj.org.eclipse.jdt.internal.compiler.ClassFile;
import org.aspectj.org.eclipse.jdt.internal.compiler.CompilationResult;
import org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeDeclaration;
import org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference;
@@ -24,8 +26,10 @@ import org.aspectj.org.eclipse.jdt.internal.compiler.lookup.BlockScope;
import org.aspectj.org.eclipse.jdt.internal.compiler.lookup.ClassScope;
import org.aspectj.org.eclipse.jdt.internal.compiler.lookup.CompilationUnitScope;
import org.aspectj.org.eclipse.jdt.internal.compiler.lookup.ReferenceBinding;
+import org.aspectj.weaver.AjAttribute;
import org.aspectj.weaver.NewMemberClassTypeMunger;
import org.aspectj.weaver.ResolvedType;
+import org.aspectj.weaver.ResolvedTypeMunger;
/**
* Represents an intertype member class declaration.
@@ -38,6 +42,7 @@ public class IntertypeMemberClassDeclaration extends TypeDeclaration {
// The target type for this inner class
private TypeReference onType;
private ReferenceBinding onTypeResolvedBinding;
+ private NewMemberClassTypeMunger newMemberClassTypeMunger;
protected InterTypeScope interTypeScope;
// When set to true, the scope hierarchy for the field/method declaration has been correctly modified to include an intertype
// scope which resolves things relative to the targeted type.
@@ -47,6 +52,10 @@ public class IntertypeMemberClassDeclaration extends TypeDeclaration {
super(compilationResult);
}
+ public ResolvedTypeMunger getMunger() {
+ return newMemberClassTypeMunger;
+ }
+
@Override
public void resolve(ClassScope aspectScope) {
resolveOnType(aspectScope);
@@ -69,6 +78,21 @@ public class IntertypeMemberClassDeclaration extends TypeDeclaration {
throw new IllegalStateException();
}
+ @SuppressWarnings("unchecked")
+ @Override
+ protected void generateAttributes(ClassFile classFile) {
+ // classFile.extraAttributes.add(new EclipseAttributeAdapter(makeAttribute()));
+ super.generateAttributes(classFile);
+ }
+
+ public AjAttribute getAttribute() {
+ // if there were problems then there is nothing to return
+ if (newMemberClassTypeMunger == null) {
+ return null;
+ }
+ return new AjAttribute.TypeMunger(newMemberClassTypeMunger);
+ }
+
/**
* Called just before the compiler is going to start resolving elements of a declaration, this method adds an intertype scope so
* that elements of the type targeted by the ITD can be resolved. For example, if type variables are referred to in the ontype
@@ -221,7 +245,8 @@ public class IntertypeMemberClassDeclaration extends TypeDeclaration {
// TODO [inner] use the interTypeScope.getRecoveryAliases
// TODO [inner] should mark it in the aspect as unreachable - it is not to be considered part of the aspect
- NewMemberClassTypeMunger newMemberClassTypeMunger = new NewMemberClassTypeMunger(declaringType, new String(this.name));
+ newMemberClassTypeMunger = new NewMemberClassTypeMunger(declaringType, new String(this.name));
+ newMemberClassTypeMunger.setSourceLocation(new EclipseSourceLocation(compilationResult, sourceStart, sourceEnd));
ResolvedType aspectType = world.fromEclipse(classScope.referenceContext.binding);
return new EclipseTypeMunger(world, newMemberClassTypeMunger, aspectType, null);
}
diff --git a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/lookup/EclipseSourceType.java b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/lookup/EclipseSourceType.java
index 3d2c483c7..457af205e 100644
--- a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/lookup/EclipseSourceType.java
+++ b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/lookup/EclipseSourceType.java
@@ -72,6 +72,7 @@ import org.aspectj.weaver.UnresolvedType;
import org.aspectj.weaver.WeaverStateInfo;
import org.aspectj.weaver.World;
import org.aspectj.weaver.bcel.AtAjAttributes.LazyResolvedPointcutDefinition;
+import org.aspectj.weaver.patterns.Declare;
import org.aspectj.weaver.patterns.FormalBinding;
import org.aspectj.weaver.patterns.ParserException;
import org.aspectj.weaver.patterns.PatternParser;
@@ -92,8 +93,8 @@ public class EclipseSourceType extends AbstractReferenceTypeDelegate {
protected ResolvedMember[] declaredMethods = null;
protected ResolvedMember[] declaredFields = null;
- public List declares = new ArrayList();
- public List typeMungers = new ArrayList();
+ public List<Declare> declares = new ArrayList<Declare>();
+ public List<EclipseTypeMunger> typeMungers = new ArrayList<EclipseTypeMunger>();
private final EclipseFactory factory;
@@ -131,20 +132,23 @@ public class EclipseSourceType extends AbstractReferenceTypeDelegate {
}
public boolean isAnonymous() {
- if (declaration.binding != null)
+ if (declaration.binding != null) {
return declaration.binding.isAnonymousType();
+ }
return ((declaration.modifiers & (ASTNode.IsAnonymousType | ASTNode.IsLocalType)) != 0);
}
public boolean isNested() {
- if (declaration.binding != null)
+ if (declaration.binding != null) {
return (declaration.binding.isMemberType());
+ }
return ((declaration.modifiers & ASTNode.IsMemberType) != 0);
}
public ResolvedType getOuterClass() {
- if (declaration.enclosingType == null)
+ if (declaration.enclosingType == null) {
return null;
+ }
return eclipseWorld().fromEclipse(declaration.enclosingType.binding);
}
@@ -164,18 +168,21 @@ public class EclipseSourceType extends AbstractReferenceTypeDelegate {
/** Returns "" if there is a problem */
private String getPointcutStringFromAnnotationStylePointcut(AbstractMethodDeclaration amd) {
Annotation[] ans = amd.annotations;
- if (ans == null)
+ if (ans == null) {
return "";
+ }
for (int i = 0; i < ans.length; i++) {
- if (ans[i].resolvedType == null)
+ if (ans[i].resolvedType == null) {
continue; // XXX happens if we do this very early from
+ }
// buildInterTypeandPerClause
// may prevent us from resolving references made in @Pointcuts to
// an @Pointcut in a code-style aspect
char[] sig = ans[i].resolvedType.signature();
if (CharOperation.equals(pointcutSig, sig)) {
- if (ans[i].memberValuePairs().length == 0)
+ if (ans[i].memberValuePairs().length == 0) {
return ""; // empty pointcut expression
+ }
Expression expr = ans[i].memberValuePairs()[0].value;
if (expr instanceof StringLiteral) {
StringLiteral sLit = ((StringLiteral) expr);
@@ -194,11 +201,13 @@ public class EclipseSourceType extends AbstractReferenceTypeDelegate {
}
private boolean isAnnotationStylePointcut(Annotation[] annotations) {
- if (annotations == null)
+ if (annotations == null) {
return false;
+ }
for (int i = 0; i < annotations.length; i++) {
- if (annotations[i].resolvedType == null)
+ if (annotations[i].resolvedType == null) {
continue; // XXX happens if we do this very early from
+ }
// buildInterTypeandPerClause
// may prevent us from resolving references made in @Pointcuts to
// an @Pointcut in a code-style aspect
@@ -215,8 +224,9 @@ public class EclipseSourceType extends AbstractReferenceTypeDelegate {
}
public ResolvedType getSuperclass() {
- if (binding.isInterface())
+ if (binding.isInterface()) {
return getResolvedTypeX().getWorld().getCoreType(UnresolvedType.OBJECT);
+ }
// XXX what about java.lang.Object
return eclipseWorld().fromEclipse(binding.superclass());
}
@@ -226,9 +236,9 @@ public class EclipseSourceType extends AbstractReferenceTypeDelegate {
}
protected void fillDeclaredMembers() {
- List declaredPointcuts = new ArrayList();
- List declaredMethods = new ArrayList();
- List declaredFields = new ArrayList();
+ List<ResolvedMember> declaredPointcuts = new ArrayList<ResolvedMember>();
+ List<ResolvedMember> declaredMethods = new ArrayList<ResolvedMember>();
+ List<ResolvedMember> declaredFields = new ArrayList<ResolvedMember>();
binding.methods(); // the important side-effect of this call is to make
// sure bindings are completed
@@ -236,12 +246,13 @@ public class EclipseSourceType extends AbstractReferenceTypeDelegate {
if (methods != null) {
for (int i = 0, len = methods.length; i < len; i++) {
AbstractMethodDeclaration amd = methods[i];
- if (amd == null || amd.ignoreFurtherInvestigation)
+ if (amd == null || amd.ignoreFurtherInvestigation) {
continue;
+ }
if (amd instanceof PointcutDeclaration) {
PointcutDeclaration d = (PointcutDeclaration) amd;
ResolvedPointcutDefinition df = d.makeResolvedPointcutDefinition(factory);
- if (df!=null) {
+ if (df != null) {
declaredPointcuts.add(df);
}
} else if (amd instanceof InterTypeDeclaration) {
@@ -260,19 +271,22 @@ public class EclipseSourceType extends AbstractReferenceTypeDelegate {
} else if ((amd.annotations != null) && isAnnotationStylePointcut(amd.annotations)) {
// consider pointcuts defined via annotations
ResolvedPointcutDefinition df = makeResolvedPointcutDefinition(amd);
- if (df != null)
+ if (df != null) {
declaredPointcuts.add(df);
+ }
} else {
- if (amd.binding == null || !amd.binding.isValidBinding())
+ if (amd.binding == null || !amd.binding.isValidBinding()) {
continue;
+ }
ResolvedMember member = factory.makeResolvedMember(amd.binding);
if (unit != null) {
boolean positionKnown = true;
if (amd.binding.sourceMethod() == null) {
if (amd.binding.declaringClass instanceof SourceTypeBinding) {
SourceTypeBinding stb = ((SourceTypeBinding) amd.binding.declaringClass);
- if (stb.scope == null || stb.scope.referenceContext == null)
+ if (stb.scope == null || stb.scope.referenceContext == null) {
positionKnown = false;
+ }
}
}
if (positionKnown) { // pr229829
@@ -294,16 +308,16 @@ public class EclipseSourceType extends AbstractReferenceTypeDelegate {
declaredFields.add(factory.makeResolvedMember(f));
}
- this.declaredPointcuts = (ResolvedPointcutDefinition[]) declaredPointcuts
- .toArray(new ResolvedPointcutDefinition[declaredPointcuts.size()]);
- this.declaredMethods = (ResolvedMember[]) declaredMethods.toArray(new ResolvedMember[declaredMethods.size()]);
- this.declaredFields = (ResolvedMember[]) declaredFields.toArray(new ResolvedMember[declaredFields.size()]);
+ this.declaredPointcuts = declaredPointcuts.toArray(new ResolvedPointcutDefinition[declaredPointcuts.size()]);
+ this.declaredMethods = declaredMethods.toArray(new ResolvedMember[declaredMethods.size()]);
+ this.declaredFields = declaredFields.toArray(new ResolvedMember[declaredFields.size()]);
}
private ResolvedPointcutDefinition makeResolvedPointcutDefinition(AbstractMethodDeclaration md) {
- if (md.binding == null)
+ if (md.binding == null) {
return null; // there is another error that has caused this...
- // pr138143
+ // pr138143
+ }
EclipseSourceContext eSourceContext = new EclipseSourceContext(md.compilationResult);
Pointcut pc = null;
@@ -334,10 +348,12 @@ public class EclipseSourceType extends AbstractReferenceTypeDelegate {
private static final char[] proceedingJoinPoint = "Lorg/aspectj/lang/ProceedingJoinPoint;".toCharArray();
private FormalBinding[] buildFormalAdviceBindingsFrom(AbstractMethodDeclaration mDecl) {
- if (mDecl.arguments == null)
+ if (mDecl.arguments == null) {
return new FormalBinding[0];
- if (mDecl.binding == null)
+ }
+ if (mDecl.binding == null) {
return new FormalBinding[0];
+ }
EclipseFactory factory = EclipseFactory.fromScopeLookupEnvironment(mDecl.scope);
String extraArgName = "";// maybeGetExtraArgName();
FormalBinding[] ret = new FormalBinding[mDecl.arguments.length];
@@ -363,8 +379,9 @@ public class EclipseSourceType extends AbstractReferenceTypeDelegate {
* fields - see bug 129613
*/
public ResolvedMember[] getDeclaredFields() {
- if (declaredFields == null)
+ if (declaredFields == null) {
fillDeclaredMembers();
+ }
return declaredFields;
}
@@ -373,14 +390,16 @@ public class EclipseSourceType extends AbstractReferenceTypeDelegate {
* - see bug 129613
*/
public ResolvedMember[] getDeclaredMethods() {
- if (declaredMethods == null)
+ if (declaredMethods == null) {
fillDeclaredMembers();
+ }
return declaredMethods;
}
public ResolvedMember[] getDeclaredPointcuts() {
- if (declaredPointcuts == null)
+ if (declaredPointcuts == null) {
fillDeclaredMembers();
+ }
return declaredPointcuts;
}
@@ -429,8 +448,9 @@ public class EclipseSourceType extends AbstractReferenceTypeDelegate {
// now check all inherited pointcuts to be sure that they're handled
// reasonably
- if (sawError || !isAspect())
+ if (sawError || !isAspect()) {
return;
+ }
// find all pointcuts that override ones from super and check override
// is legal
@@ -481,12 +501,15 @@ public class EclipseSourceType extends AbstractReferenceTypeDelegate {
public String getRetentionPolicy() {
if (isAnnotation()) {
- if ((binding.getAnnotationTagBits() & TagBits.AnnotationRetentionMASK) == TagBits.AnnotationRuntimeRetention)
+ if ((binding.getAnnotationTagBits() & TagBits.AnnotationRetentionMASK) == TagBits.AnnotationRuntimeRetention) {
return "RUNTIME";
- if ((binding.getAnnotationTagBits() & TagBits.AnnotationRetentionMASK) == TagBits.AnnotationSourceRetention)
+ }
+ if ((binding.getAnnotationTagBits() & TagBits.AnnotationRetentionMASK) == TagBits.AnnotationSourceRetention) {
return "SOURCE";
- if ((binding.getAnnotationTagBits() & TagBits.AnnotationRetentionMASK) == TagBits.AnnotationClassRetention)
+ }
+ if ((binding.getAnnotationTagBits() & TagBits.AnnotationRetentionMASK) == TagBits.AnnotationClassRetention) {
return "CLASS";
+ }
}
return null;
}
@@ -499,8 +522,9 @@ public class EclipseSourceType extends AbstractReferenceTypeDelegate {
}
public AnnotationTargetKind[] getAnnotationTargetKinds() {
- if (discoveredAnnotationTargetKinds)
+ if (discoveredAnnotationTargetKinds) {
return annotationTargetKinds;
+ }
discoveredAnnotationTargetKinds = true;
annotationTargetKinds = null; // null means we have no idea or the
// @Target annotation hasn't been used
@@ -528,28 +552,36 @@ public class EclipseSourceType extends AbstractReferenceTypeDelegate {
// }
// return targetKind;
if (isAnnotation()) {
- List targetKinds = new ArrayList();
+ List<AnnotationTargetKind> targetKinds = new ArrayList<AnnotationTargetKind>();
- if ((binding.getAnnotationTagBits() & TagBits.AnnotationForAnnotationType) != 0)
+ if ((binding.getAnnotationTagBits() & TagBits.AnnotationForAnnotationType) != 0) {
targetKinds.add(AnnotationTargetKind.ANNOTATION_TYPE);
- if ((binding.getAnnotationTagBits() & TagBits.AnnotationForConstructor) != 0)
+ }
+ if ((binding.getAnnotationTagBits() & TagBits.AnnotationForConstructor) != 0) {
targetKinds.add(AnnotationTargetKind.CONSTRUCTOR);
- if ((binding.getAnnotationTagBits() & TagBits.AnnotationForField) != 0)
+ }
+ if ((binding.getAnnotationTagBits() & TagBits.AnnotationForField) != 0) {
targetKinds.add(AnnotationTargetKind.FIELD);
- if ((binding.getAnnotationTagBits() & TagBits.AnnotationForLocalVariable) != 0)
+ }
+ if ((binding.getAnnotationTagBits() & TagBits.AnnotationForLocalVariable) != 0) {
targetKinds.add(AnnotationTargetKind.LOCAL_VARIABLE);
- if ((binding.getAnnotationTagBits() & TagBits.AnnotationForMethod) != 0)
+ }
+ if ((binding.getAnnotationTagBits() & TagBits.AnnotationForMethod) != 0) {
targetKinds.add(AnnotationTargetKind.METHOD);
- if ((binding.getAnnotationTagBits() & TagBits.AnnotationForPackage) != 0)
+ }
+ if ((binding.getAnnotationTagBits() & TagBits.AnnotationForPackage) != 0) {
targetKinds.add(AnnotationTargetKind.PACKAGE);
- if ((binding.getAnnotationTagBits() & TagBits.AnnotationForParameter) != 0)
+ }
+ if ((binding.getAnnotationTagBits() & TagBits.AnnotationForParameter) != 0) {
targetKinds.add(AnnotationTargetKind.PARAMETER);
- if ((binding.getAnnotationTagBits() & TagBits.AnnotationForType) != 0)
+ }
+ if ((binding.getAnnotationTagBits() & TagBits.AnnotationForType) != 0) {
targetKinds.add(AnnotationTargetKind.TYPE);
+ }
if (!targetKinds.isEmpty()) {
annotationTargetKinds = new AnnotationTargetKind[targetKinds.size()];
- return (AnnotationTargetKind[]) targetKinds.toArray(annotationTargetKinds);
+ return targetKinds.toArray(annotationTargetKinds);
}
}
return annotationTargetKinds;
@@ -563,8 +595,9 @@ public class EclipseSourceType extends AbstractReferenceTypeDelegate {
annotationsResolved = true;
}
Annotation[] as = declaration.annotations;
- if (as == null)
+ if (as == null) {
return false;
+ }
for (int i = 0; i < as.length; i++) {
Annotation annotation = as[i];
if (annotation.resolvedType == null) {
@@ -597,8 +630,9 @@ public class EclipseSourceType extends AbstractReferenceTypeDelegate {
* (RetentionPolicy, Target).
*/
public AnnotationAJ[] getAnnotations() {
- if (annotations != null)
+ if (annotations != null) {
return annotations; // only do this once
+ }
getAnnotationTypes(); // forces resolution and sets resolvedAnnotations
Annotation[] as = declaration.annotations;
if (as == null || as.length == 0) {
@@ -813,8 +847,9 @@ public class EclipseSourceType extends AbstractReferenceTypeDelegate {
// ---------------------------------
public ResolvedType[] getAnnotationTypes() {
- if (resolvedAnnotations != null)
+ if (resolvedAnnotations != null) {
return resolvedAnnotations;
+ }
// Make sure they are resolved
if (!annotationsResolved) {
TypeDeclaration.resolveAnnotations(declaration.staticInitializerScope, declaration.annotations, binding);
@@ -842,8 +877,9 @@ public class EclipseSourceType extends AbstractReferenceTypeDelegate {
if (!isAnnotationStyleAspect()) {
if (declaration instanceof AspectDeclaration) {
PerClause pc = ((AspectDeclaration) declaration).perClause;
- if (pc != null)
+ if (pc != null) {
return pc;
+ }
}
return new PerSingleton();
} else {
@@ -851,8 +887,9 @@ public class EclipseSourceType extends AbstractReferenceTypeDelegate {
// real perClause
// at least try to get the right perclause
PerClause pc = null;
- if (declaration instanceof AspectDeclaration)
+ if (declaration instanceof AspectDeclaration) {
pc = ((AspectDeclaration) declaration).perClause;
+ }
if (pc == null) {
PerClause.Kind kind = getPerClauseForTypeDeclaration(declaration);
// returning a perFromSuper is enough to get the correct kind..
@@ -899,8 +936,9 @@ public class EclipseSourceType extends AbstractReferenceTypeDelegate {
// !
// it is an @Aspect(...something...)
NormalAnnotation theAnnotation = (NormalAnnotation) annotation;
- if (theAnnotation.memberValuePairs == null || theAnnotation.memberValuePairs.length < 1)
+ if (theAnnotation.memberValuePairs == null || theAnnotation.memberValuePairs.length < 1) {
return PerClause.SINGLETON;
+ }
String clause = new String(((StringLiteral) theAnnotation.memberValuePairs[0].value).source());// TODO
// cast
// safe
@@ -999,8 +1037,9 @@ public class EclipseSourceType extends AbstractReferenceTypeDelegate {
}
public TypeVariable[] getTypeVariables() {
- if (declaration.typeParameters == null)
+ if (declaration.typeParameters == null) {
return new TypeVariable[0];
+ }
TypeVariable[] typeVariables = new TypeVariable[declaration.typeParameters.length];
for (int i = 0; i < typeVariables.length; i++) {
typeVariables[i] = typeParameter2TypeVariable(declaration.typeParameters[i]);
@@ -1008,12 +1047,12 @@ public class EclipseSourceType extends AbstractReferenceTypeDelegate {
return typeVariables;
}
- private TypeVariable typeParameter2TypeVariable(TypeParameter aTypeParameter) {
- String name = new String(aTypeParameter.name);
- ReferenceBinding superclassBinding = aTypeParameter.binding.superclass;
+ private TypeVariable typeParameter2TypeVariable(TypeParameter typeParameter) {
+ String name = new String(typeParameter.name);
+ ReferenceBinding superclassBinding = typeParameter.binding.superclass;
UnresolvedType superclass = UnresolvedType.forSignature(new String(superclassBinding.signature()));
UnresolvedType[] superinterfaces = null;
- ReferenceBinding[] superInterfaceBindings = aTypeParameter.binding.superInterfaces;
+ ReferenceBinding[] superInterfaceBindings = typeParameter.binding.superInterfaces;
if (superInterfaceBindings != null) {
superinterfaces = new UnresolvedType[superInterfaceBindings.length];
for (int i = 0; i < superInterfaceBindings.length; i++) {
@@ -1022,8 +1061,8 @@ public class EclipseSourceType extends AbstractReferenceTypeDelegate {
}
// XXX what about lower binding?
TypeVariable tv = new TypeVariable(name, superclass, superinterfaces);
- tv.setDeclaringElement(factory.fromBinding(aTypeParameter.binding.declaringElement));
- tv.setRank(aTypeParameter.binding.rank);
+ tv.setDeclaringElement(factory.fromBinding(typeParameter.binding.declaringElement));
+ tv.setRank(typeParameter.binding.rank);
return tv;
}
diff --git a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/lookup/EclipseTypeMunger.java b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/lookup/EclipseTypeMunger.java
index 55ca6be2a..e2bab6b73 100644
--- a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/lookup/EclipseTypeMunger.java
+++ b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/lookup/EclipseTypeMunger.java
@@ -169,7 +169,7 @@ public class EclipseTypeMunger extends ConcreteTypeMunger {
sourceType);
SourceTypeBinding stb = (SourceTypeBinding) world.makeTypeBinding(aspectType);
- ReferenceBinding found = null;
+ // ReferenceBinding found = null;
for (int i = 0; i < stb.memberTypes.length; i++) {
ReferenceBinding rb = stb.memberTypes[i];
char[] sn = rb.sourceName;