diff options
4 files changed, 20 insertions, 10 deletions
diff --git a/weaver/src/org/aspectj/weaver/MemberImpl.java b/weaver/src/org/aspectj/weaver/MemberImpl.java index 0f257f59a..14b7fde02 100644 --- a/weaver/src/org/aspectj/weaver/MemberImpl.java +++ b/weaver/src/org/aspectj/weaver/MemberImpl.java @@ -213,6 +213,15 @@ public class MemberImpl implements Comparable, AnnotatedElement,Member { Object[] pair = signatureToTypes(signature,false); return method(declaring, mods, (UnresolvedType) pair[0], name, (UnresolvedType[]) pair[1]); } + + public static MemberImpl monitorEnter() { + return new MemberImpl(MONITORENTER,UnresolvedType.OBJECT,Modifier.STATIC,ResolvedType.VOID,"<lock>",UnresolvedType.ARRAY_WITH_JUST_OBJECT); + } + + public static MemberImpl monitorExit() { + return new MemberImpl(MONITOREXIT,UnresolvedType.OBJECT,Modifier.STATIC,ResolvedType.VOID,"<unlock>",UnresolvedType.ARRAY_WITH_JUST_OBJECT); + } + public static Member pointcut(UnresolvedType declaring, String name, String signature) { Object[] pair = signatureToTypes(signature,false); return pointcut(declaring, 0, (UnresolvedType) pair[0], name, (UnresolvedType[]) pair[1]); diff --git a/weaver/src/org/aspectj/weaver/asm/AjASMAttribute.java b/weaver/src/org/aspectj/weaver/asm/AjASMAttribute.java index 59903ca40..444ac9a10 100644 --- a/weaver/src/org/aspectj/weaver/asm/AjASMAttribute.java +++ b/weaver/src/org/aspectj/weaver/asm/AjASMAttribute.java @@ -57,7 +57,7 @@ class AjASMAttribute extends Attribute { public AjAttribute unpack(AsmDelegate relatedDelegate) { if (unpacked) throw new BCException("Don't unpack an attribute twice!"); - AjAttribute attr = AjAttribute.read(relatedDelegate.weaverVersion,type,data,relatedDelegate.getSourceContext(),relatedDelegate.getWorld().getMessageHandler()); + AjAttribute attr = AjAttribute.read(relatedDelegate.weaverVersion,type,data,relatedDelegate.getSourceContext(),relatedDelegate.getWorld()); unpacked=true; return attr; } diff --git a/weaver/src/org/aspectj/weaver/bcel/BcelAttributes.java b/weaver/src/org/aspectj/weaver/bcel/BcelAttributes.java index 5487fbda5..5eb7eaaf8 100644 --- a/weaver/src/org/aspectj/weaver/bcel/BcelAttributes.java +++ b/weaver/src/org/aspectj/weaver/bcel/BcelAttributes.java @@ -19,10 +19,10 @@ import java.util.List; import org.aspectj.apache.bcel.classfile.Attribute; import org.aspectj.apache.bcel.classfile.Unknown; import org.aspectj.apache.bcel.generic.ConstantPoolGen; -import org.aspectj.bridge.IMessageHandler; import org.aspectj.weaver.AjAttribute; import org.aspectj.weaver.BCException; import org.aspectj.weaver.ISourceContext; +import org.aspectj.weaver.World; import org.aspectj.weaver.AjAttribute.WeaverVersionInfo; @@ -35,7 +35,7 @@ class BcelAttributes { * list contains the AspectJ attributes identified and unpacked to 'AjAttribute' objects. */ public static List readAjAttributes(String classname,Attribute[] as, ISourceContext context, - IMessageHandler msgHandler,AjAttribute.WeaverVersionInfo version) { + World w,AjAttribute.WeaverVersionInfo version) { List l = new ArrayList(); // first pass, look for version @@ -48,7 +48,7 @@ class BcelAttributes { if (name.charAt(0)=='o') { // 'o'rg.aspectj if (name.startsWith(AjAttribute.AttributePrefix)) { if (name.endsWith(WeaverVersionInfo.AttributeName)) { - version = (AjAttribute.WeaverVersionInfo)AjAttribute.read(version,name,u.getBytes(),context,msgHandler); + version = (AjAttribute.WeaverVersionInfo)AjAttribute.read(version,name,u.getBytes(),context,w); if (version.getMajorVersion() > WeaverVersionInfo.getCurrentWeaverMajorVersion()) { throw new BCException("Unable to continue, this version of AspectJ supports classes built with weaver version "+ WeaverVersionInfo.toCurrentVersionString()+" but the class "+classname+" is version "+version.toString()); @@ -63,7 +63,7 @@ class BcelAttributes { for (int i = forSecondPass.size()-1; i >= 0; i--) { Unknown a = (Unknown)forSecondPass.get(i); String name = a.getName(); - AjAttribute attr = AjAttribute.read(version,name,a.getBytes(),context,msgHandler); + AjAttribute attr = AjAttribute.read(version,name,a.getBytes(),context,w); if (attr!=null) l.add(attr); } return l; @@ -78,4 +78,4 @@ class BcelAttributes { } -} +}
\ No newline at end of file diff --git a/weaver/src/org/aspectj/weaver/patterns/Pointcut.java b/weaver/src/org/aspectj/weaver/patterns/Pointcut.java index a4af8a495..2f4e583ec 100644 --- a/weaver/src/org/aspectj/weaver/patterns/Pointcut.java +++ b/weaver/src/org/aspectj/weaver/patterns/Pointcut.java @@ -313,10 +313,11 @@ public abstract class Pointcut extends PatternNode { } public void check(ISourceContext ctx,World world) { - PoliceExtensionUse pointcutPolice = new PoliceExtensionUse(world,this); - this.accept(pointcutPolice, null); - if (pointcutPolice.synchronizationDesignatorEncountered()) - world.setSynchronizationPointcutsInUse(); + // this is a quick visitor... + PoliceExtensionUse pointcutPolice = new PoliceExtensionUse(world,this); + this.accept(pointcutPolice, null); + if (pointcutPolice.synchronizationDesignatorEncountered()) + world.setSynchronizationPointcutsInUse(); } |