diff options
Diffstat (limited to 'weaver')
4 files changed, 19 insertions, 6 deletions
diff --git a/weaver/src/org/aspectj/weaver/CrosscuttingMembers.java b/weaver/src/org/aspectj/weaver/CrosscuttingMembers.java index 22e73efb7..aedffd0b6 100644 --- a/weaver/src/org/aspectj/weaver/CrosscuttingMembers.java +++ b/weaver/src/org/aspectj/weaver/CrosscuttingMembers.java @@ -29,8 +29,9 @@ import org.aspectj.bridge.*; * up before the inter-type declaration weaving stage (unsurprisingly). * * All members are concrete. + * + * @author Jim Hugunin */ - public class CrosscuttingMembers { private ResolvedTypeX inAspect; private World world; @@ -153,12 +154,14 @@ public class CrosscuttingMembers { public boolean replaceWith(CrosscuttingMembers other) { boolean changed = false; + //XXX what if perClause is null if (!perClause.equals(other.perClause)) { changed = true; perClause = other.perClause; } //XXX all of the below should be set equality rather than list equality + //System.err.println("old: " + shadowMungers + " new: " + other.shadowMungers); if (!shadowMungers.equals(other.shadowMungers)) { changed = true; shadowMungers = other.shadowMungers; diff --git a/weaver/src/org/aspectj/weaver/CrosscuttingMembersSet.java b/weaver/src/org/aspectj/weaver/CrosscuttingMembersSet.java index ceebbfeb6..a7e9f5748 100644 --- a/weaver/src/org/aspectj/weaver/CrosscuttingMembersSet.java +++ b/weaver/src/org/aspectj/weaver/CrosscuttingMembersSet.java @@ -23,8 +23,9 @@ import org.aspectj.bridge.*; /** * This holds on to all CrosscuttingMembers for a world. It handles * management of change. + * + * @author Jim Hugunin */ - public class CrosscuttingMembersSet { private World world; private Map members = new HashMap(); @@ -59,9 +60,10 @@ public class CrosscuttingMembersSet { } } - public void deleteAspect(TypeX aspectType) { - members.remove(aspectType); + public boolean deleteAspect(TypeX aspectType) { + boolean isAspect = members.remove(aspectType) != null; clearCaches(); + return isAspect; } //XXX only for testing diff --git a/weaver/src/org/aspectj/weaver/bcel/BcelObjectType.java b/weaver/src/org/aspectj/weaver/bcel/BcelObjectType.java index 303e12561..e02410a7b 100644 --- a/weaver/src/org/aspectj/weaver/bcel/BcelObjectType.java +++ b/weaver/src/org/aspectj/weaver/bcel/BcelObjectType.java @@ -196,6 +196,9 @@ public class BcelObjectType extends ResolvedTypeX.Name { this.perClause = null; this.weaverState = null; this.lazyClassGen = null; + + isObject = (javaClass.getSuperclassNameIndex() == 0); + unpackAspectAttributes(); //XXX is clearing these caches sufficient } diff --git a/weaver/src/org/aspectj/weaver/bcel/BcelWeaver.java b/weaver/src/org/aspectj/weaver/bcel/BcelWeaver.java index c0e475cbd..f22bec950 100644 --- a/weaver/src/org/aspectj/weaver/bcel/BcelWeaver.java +++ b/weaver/src/org/aspectj/weaver/bcel/BcelWeaver.java @@ -19,6 +19,7 @@ import java.util.zip.*; import org.apache.bcel.classfile.*; import org.apache.bcel.classfile.JavaClass; +import org.aspectj.bridge.IMessage; import org.aspectj.util.FileUtil; import org.aspectj.weaver.*; @@ -157,6 +158,7 @@ public class BcelWeaver implements IWeaver { UnwovenClassFile jc = (UnwovenClassFile)i.next(); String name = jc.getClassName(); ResolvedTypeX type = world.resolve(name); + //System.err.println("added: " + type + " aspect? " + type.isAspect()); if (type.isAspect()) { needToReweaveWorld |= xcutSet.addOrReplaceAspect(type); } @@ -164,8 +166,7 @@ public class BcelWeaver implements IWeaver { for (Iterator i = deletedTypenames.iterator(); i.hasNext(); ) { String name = (String)i.next(); - xcutSet.deleteAspect(TypeX.forName(name)); - needToReweaveWorld = true; + if (xcutSet.deleteAspect(TypeX.forName(name))) needToReweaveWorld = true; } shadowMungerList = xcutSet.getShadowMungers(); @@ -211,6 +212,7 @@ public class BcelWeaver implements IWeaver { public Collection weave() throws IOException { prepareForWeave(); Collection filesToWeave; + if (needToReweaveWorld) { filesToWeave = sourceJavaClasses.values(); } else { @@ -218,6 +220,9 @@ public class BcelWeaver implements IWeaver { } Collection wovenClassNames = new ArrayList(); + world.showMessage(IMessage.INFO, "might need to weave " + filesToWeave + + "(world=" + needToReweaveWorld + ")", null, null); + //XXX this isn't quite the right place for this... for (Iterator i = filesToWeave.iterator(); i.hasNext(); ) { |