diff options
4 files changed, 65 insertions, 17 deletions
diff --git a/ajde/testdata/examples/figures-coverage/figures/Main.java b/ajde/testdata/examples/figures-coverage/figures/Main.java index bbb2869b7..189f05cee 100644 --- a/ajde/testdata/examples/figures-coverage/figures/Main.java +++ b/ajde/testdata/examples/figures-coverage/figures/Main.java @@ -42,6 +42,8 @@ class Main { } privileged aspect Test { + pointcut testptct(): call(* *.*(..)); + before(Point p, int newval): target(p) && set(int Point.xx) && args(newval) { System.err.println("> new value of x is: " + p.x + ", setting to: " + newval); } diff --git a/ajde/testsrc/org/aspectj/ajde/StructureModelTest.java b/ajde/testsrc/org/aspectj/ajde/StructureModelTest.java index eb5834dd4..adf926665 100644 --- a/ajde/testsrc/org/aspectj/ajde/StructureModelTest.java +++ b/ajde/testsrc/org/aspectj/ajde/StructureModelTest.java @@ -76,6 +76,28 @@ public class StructureModelTest extends AjdeTestCase { // assertTrue("matches", foundNode.getParent() == fieldNode.getParent()); // } + + public void testRootForSourceFile() throws IOException { + File testFile = createFile("figures-coverage/figures/Figure.java"); + StructureNode node = Ajde.getDefault().getStructureModelManager().getStructureModel().findRootNodeForSourceFile( + testFile.getCanonicalPath()); + assertTrue("find result", node != null) ; + ProgramElementNode pNode = (ProgramElementNode)node; + assertTrue("found child", ((StructureNode)pNode.getChildren().get(0)).getName().equals("Figure")); + } + + public void testPointcutName() throws IOException { + File testFile = createFile("figures-coverage/figures/Main.java"); + StructureNode node = Ajde.getDefault().getStructureModelManager().getStructureModel().findRootNodeForSourceFile( + testFile.getCanonicalPath()); + assertTrue("find result", node != null) ; + ProgramElementNode pNode = (ProgramElementNode)((ProgramElementNode)node).getChildren().get(1); + ProgramElementNode pointcut = (ProgramElementNode)pNode.getChildren().get(0); + assertTrue("kind", pointcut.getProgramElementKind().equals(ProgramElementNode.Kind.POINTCUT)); + assertTrue("found node: " + pointcut.getName(), pointcut.getName().equals("testptct")); + + } + public void testFileNodeFind() throws IOException { File testFile = createFile("testdata/examples/figures-coverage/figures/Main.java"); StructureNode node = Ajde.getDefault().getStructureModelManager().getStructureModel().findNodeForSourceLine( diff --git a/asm/src/org/aspectj/asm/StructureModel.java b/asm/src/org/aspectj/asm/StructureModel.java index e58159087..263a32853 100644 --- a/asm/src/org/aspectj/asm/StructureModel.java +++ b/asm/src/org/aspectj/asm/StructureModel.java @@ -114,18 +114,22 @@ public class StructureModel implements Serializable { * @param sourceFilePath modified to '/' delimited path for consistency * @return a new structure node for the file if it was not found in the model */ - public StructureNode findRootNodeForSourceFile(String sourceFilePath) { - if (!isValid() || sourceFilePath == null) { - return StructureModel.NO_STRUCTURE; - } else { - String correctedPath = sourceFilePath;//.replace('\\', '/'); - StructureNode node = (StructureNode)getFileMap().get(correctedPath);//findFileNode(filePath, model); - if (node != null) { - return node; - } else { - return createFileStructureNode(sourceFilePath); - } - } + public StructureNode findRootNodeForSourceFile(String sourceFile) { + try { + if (!isValid() || sourceFile == null) { + return StructureModel.NO_STRUCTURE; + } else { + String correctedPath = new File(sourceFile).getCanonicalPath();//.replace('\\', '/'); + StructureNode node = (StructureNode)getFileMap().get(correctedPath);//findFileNode(filePath, model); + if (node != null) { + return node; + } else { + return createFileStructureNode(correctedPath); + } + } + } catch (Exception e) { + return StructureModel.NO_STRUCTURE; + } } /** @@ -175,6 +179,12 @@ public class StructureModel implements Serializable { private boolean matches(StructureNode node, String sourceFilePath, int lineNumber) { try { +// if (node != null && node.getSourceLocation() != null) +// System.err.println("====\n1: " + +// sourceFilePath + "\n2: " + +// node.getSourceLocation().getSourceFile().getCanonicalPath().equals(sourceFilePath) +// ); + return node != null && node.getSourceLocation() != null && node.getSourceLocation().getSourceFile().getCanonicalPath().equals(sourceFilePath) diff --git a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/core/builder/AsmBuilder.java b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/core/builder/AsmBuilder.java index e705748f2..83be0af50 100644 --- a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/core/builder/AsmBuilder.java +++ b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/core/builder/AsmBuilder.java @@ -14,6 +14,7 @@ package org.aspectj.ajdt.internal.core.builder; import java.io.File; +import java.io.IOException; import java.text.CollationElementIterator; import java.util.*; import java.util.List; @@ -91,10 +92,12 @@ public class AsmBuilder extends AbstractSyntaxTreeVisitorAdapter { stack.push(cuNode); unit.traverse(this, unit.scope); - StructureModelManager.INSTANCE.getStructureModel().getFileMap().put( - file.getAbsolutePath().replace('\\', '/'), - cuNode - ); + try { + StructureModelManager.INSTANCE.getStructureModel().getFileMap().put( + file.getCanonicalPath(),//.replace('\\', '/'), + cuNode + ); + } catch (IOException ioe) { } // if (currImports != null) peNode.addChild(0, currImports); // currImports = null; } @@ -205,6 +208,7 @@ public class AsmBuilder extends AbstractSyntaxTreeVisitorAdapter { label = translateAdviceName(label); } else if (methodDeclaration instanceof PointcutDeclaration) { kind = ProgramElementNode.Kind.POINTCUT; + label = translatePointcutName(label); } else if (methodDeclaration instanceof DeclareDeclaration) { DeclareDeclaration declare = (DeclareDeclaration)methodDeclaration; label = translateDeclareName(declare.toString()); @@ -240,7 +244,6 @@ public class AsmBuilder extends AbstractSyntaxTreeVisitorAdapter { return true; } - public void endVisit(MethodDeclaration methodDeclaration, ClassScope scope) { stack.pop(); } @@ -373,4 +376,15 @@ public class AsmBuilder extends AbstractSyntaxTreeVisitorAdapter { } } + // !!! move or replace + private String translatePointcutName(String name) { + int index = name.indexOf("$$")+2; + int endIndex = name.lastIndexOf('$'); + if (index != -1 && endIndex != -1) { + return name.substring(index, endIndex); + } else { + return name; + } + } + } |