diff options
author | aclement <aclement> | 2010-04-23 00:10:18 +0000 |
---|---|---|
committer | aclement <aclement> | 2010-04-23 00:10:18 +0000 |
commit | 279239d196c0fc29152832956d54e38e79ead40a (patch) | |
tree | 6c378784cca8fe7ba0a8c9a91ebfff17ff26f61b | |
parent | cee6b8b8cb6c7f4e6501d1cb054d6586f7ff128b (diff) | |
download | aspectj-279239d196c0fc29152832956d54e38e79ead40a.tar.gz aspectj-279239d196c0fc29152832956d54e38e79ead40a.zip |
307120: more damn fixes
-rw-r--r-- | org.aspectj.matcher/src/org/aspectj/weaver/CrosscuttingMembers.java | 9 | ||||
-rw-r--r-- | org.aspectj.matcher/src/org/aspectj/weaver/PrivilegedAccessMunger.java | 17 |
2 files changed, 21 insertions, 5 deletions
diff --git a/org.aspectj.matcher/src/org/aspectj/weaver/CrosscuttingMembers.java b/org.aspectj.matcher/src/org/aspectj/weaver/CrosscuttingMembers.java index 5ada3efc9..97d42e7fa 100644 --- a/org.aspectj.matcher/src/org/aspectj/weaver/CrosscuttingMembers.java +++ b/org.aspectj.matcher/src/org/aspectj/weaver/CrosscuttingMembers.java @@ -206,7 +206,14 @@ public class CrosscuttingMembers { public void addPrivilegedAccesses(Collection<ResolvedMember> accessedMembers) { int version = inAspect.getCompilerVersion(); for (ResolvedMember member : accessedMembers) { - PrivilegedAccessMunger privilegedAccessMunger = new PrivilegedAccessMunger(member, + // Looking it up ensures we get the annotations - the accessedMembers are just retrieved from the attribute and + // don't have that information + ResolvedMember resolvedMember = world.resolve(member); + if (resolvedMember == null) { + // can happen for ITDs - are there many privileged access ITDs?? + resolvedMember = member; + } + PrivilegedAccessMunger privilegedAccessMunger = new PrivilegedAccessMunger(resolvedMember, version >= WeaverVersionInfo.WEAVER_VERSION_AJ169); ConcreteTypeMunger concreteTypeMunger = world.getWeavingSupport().concreteTypeMunger(privilegedAccessMunger, inAspect); addTypeMunger(concreteTypeMunger); diff --git a/org.aspectj.matcher/src/org/aspectj/weaver/PrivilegedAccessMunger.java b/org.aspectj.matcher/src/org/aspectj/weaver/PrivilegedAccessMunger.java index 5083a304b..3e5a3be50 100644 --- a/org.aspectj.matcher/src/org/aspectj/weaver/PrivilegedAccessMunger.java +++ b/org.aspectj.matcher/src/org/aspectj/weaver/PrivilegedAccessMunger.java @@ -33,6 +33,7 @@ public class PrivilegedAccessMunger extends ResolvedTypeMunger { this.shortSyntax = shortSyntax; } + @Override public void write(DataOutputStream s) throws IOException { throw new RuntimeException("should not be serialized"); } @@ -41,28 +42,34 @@ public class PrivilegedAccessMunger extends ResolvedTypeMunger { return getSignature(); } + @Override public ResolvedMember getMatchingSyntheticMember(Member member, ResolvedType aspectType) { ResolvedMember ret; // assert if shortSyntax then aspectType.getCompilerVersion()>=169 if (getSignature().getKind() == Member.FIELD) { ret = AjcMemberMaker.privilegedAccessMethodForFieldGet(aspectType, getSignature(), shortSyntax); - if (ResolvedType.matches(ret, member)) + if (ResolvedType.matches(ret, member)) { return getSignature(); + } ret = AjcMemberMaker.privilegedAccessMethodForFieldSet(aspectType, getSignature(), shortSyntax); - if (ResolvedType.matches(ret, member)) + if (ResolvedType.matches(ret, member)) { return getSignature(); + } } else { // System.err.println("sig: " + getSignature()); ret = AjcMemberMaker.privilegedAccessMethodForMethod(aspectType, getSignature()); - if (ResolvedType.matches(ret, member)) + if (ResolvedType.matches(ret, member)) { return getSignature(); + } } return null; } + @Override public boolean equals(Object other) { - if (!(other instanceof PrivilegedAccessMunger)) + if (!(other instanceof PrivilegedAccessMunger)) { return false; + } PrivilegedAccessMunger o = (PrivilegedAccessMunger) other; return kind.equals(o.kind) && ((o.signature == null) ? (signature == null) : signature.equals(o.signature)) @@ -71,6 +78,7 @@ public class PrivilegedAccessMunger extends ResolvedTypeMunger { .equals(o.typeVariableAliases)); } + @Override public int hashCode() { int result = 17; result = 37 * result + kind.hashCode(); @@ -80,6 +88,7 @@ public class PrivilegedAccessMunger extends ResolvedTypeMunger { return result; } + @Override public boolean existsToSupportShadowMunging() { return true; } |