summaryrefslogtreecommitdiffstats
path: root/weaver/src
diff options
context:
space:
mode:
authormkersten <mkersten>2003-08-16 03:14:36 +0000
committermkersten <mkersten>2003-08-16 03:14:36 +0000
commiteb12f56518d08c54fc17047749a5d2d66b3c4181 (patch)
tree40dd436a6848d69b5db2cfb0741a76fcfecfc194 /weaver/src
parent466cb82c3ba6cf23e28bb8b8e8da0e54a90486b2 (diff)
downloadaspectj-eb12f56518d08c54fc17047749a5d2d66b3c4181.tar.gz
aspectj-eb12f56518d08c54fc17047749a5d2d66b3c4181.zip
Added spacewar project for testing.
Diffstat (limited to 'weaver/src')
-rw-r--r--weaver/src/org/aspectj/weaver/AsmRelationshipProvider.java (renamed from weaver/src/org/aspectj/weaver/AsmAdviceRelationshipProvider.java)35
-rw-r--r--weaver/src/org/aspectj/weaver/Shadow.java2
2 files changed, 30 insertions, 7 deletions
diff --git a/weaver/src/org/aspectj/weaver/AsmAdviceRelationshipProvider.java b/weaver/src/org/aspectj/weaver/AsmRelationshipProvider.java
index 59f65ed8d..b6ce56445 100644
--- a/weaver/src/org/aspectj/weaver/AsmAdviceRelationshipProvider.java
+++ b/weaver/src/org/aspectj/weaver/AsmRelationshipProvider.java
@@ -13,24 +13,47 @@
package org.aspectj.weaver;
-import java.util.*;
+import java.util.ArrayList;
+import java.util.Iterator;
import org.aspectj.asm.*;
import org.aspectj.asm.internal.ProgramElement;
-import org.aspectj.bridge.*;
+import org.aspectj.bridge.ISourceLocation;
+import org.aspectj.bridge.SourceLocation;
-public class AsmAdviceRelationshipProvider {
+public class AsmRelationshipProvider {
public static final String ADVISES = "advises";
public static final String ADVISED_BY = "advised by";
public static final String DECLARES_ON = "declares on";
public static final String DECLAREDY_BY = "declared by";
+ public static final String MATCHED_BY = "matched by";
+ public static final String MATCHES_DECLARE = "matches declare";
- public static void checkerMunger(IHierarchy model, Shadow shadow) {
-// System.err.println("> " + shadow.getThisVar() + " to " + shadow.getTargetVar());
+ public static void checkerMunger(IHierarchy model, Shadow shadow, Checker checker) {
+ if (shadow.getSourceLocation() == null || checker == null) return;
+
+ String sourceHandle = ProgramElement.createHandleIdentifier(
+ checker.getSourceLocation().getSourceFile(),
+ checker.getSourceLocation().getLine(),
+ checker.getSourceLocation().getColumn());
+
+ String targetHandle = ProgramElement.createHandleIdentifier(
+ shadow.getSourceLocation().getSourceFile(),
+ shadow.getSourceLocation().getLine(),
+ shadow.getSourceLocation().getColumn());
+
+ IRelationshipMap mapper = AsmManager.getDefault().getRelationshipMap();
+ if (sourceHandle != null && targetHandle != null) {
+ IRelationship foreward = mapper.get(sourceHandle, IRelationship.Kind.DECLARE, MATCHED_BY);
+ foreward.getTargets().add(targetHandle);
+
+ IRelationship back = mapper.get(targetHandle, IRelationship.Kind.DECLARE, MATCHES_DECLARE);
+ back.getTargets().add(sourceHandle);
+ }
}
- public static void nodeMunger(IHierarchy model, Shadow shadow, ShadowMunger munger) {
+ public static void adviceMunger(IHierarchy model, Shadow shadow, ShadowMunger munger) {
if (munger instanceof Advice) {
Advice advice = (Advice)munger;
if (advice.getKind().isPerEntry() || advice.getKind().isCflow()) {
diff --git a/weaver/src/org/aspectj/weaver/Shadow.java b/weaver/src/org/aspectj/weaver/Shadow.java
index a8a1ebd94..029a16d69 100644
--- a/weaver/src/org/aspectj/weaver/Shadow.java
+++ b/weaver/src/org/aspectj/weaver/Shadow.java
@@ -341,7 +341,7 @@ public abstract class Shadow {
munger.implementOn(this);
if (world.getModel() != null) {
//System.err.println("munger: " + munger + " on " + this);
- AsmAdviceRelationshipProvider.nodeMunger(world.getModel(), this, munger);
+ AsmRelationshipProvider.adviceMunger(world.getModel(), this, munger);
}
}
}