aboutsummaryrefslogtreecommitdiffstats
path: root/asm
diff options
context:
space:
mode:
Diffstat (limited to 'asm')
-rw-r--r--asm/src/org/aspectj/asm/AsmManager.java10
-rw-r--r--asm/src/org/aspectj/asm/IElementHandleProvider.java2
-rw-r--r--asm/src/org/aspectj/asm/IHierarchy.java1
-rw-r--r--asm/src/org/aspectj/asm/internal/AspectJElementHierarchy.java48
-rw-r--r--asm/src/org/aspectj/asm/internal/FullPathHandleProvider.java8
-rw-r--r--asm/src/org/aspectj/asm/internal/OptimizedFullPathHandleProvider.java8
-rw-r--r--asm/src/org/aspectj/asm/internal/ProgramElement.java9
7 files changed, 63 insertions, 23 deletions
diff --git a/asm/src/org/aspectj/asm/AsmManager.java b/asm/src/org/aspectj/asm/AsmManager.java
index 46f347dcf..bc63e881b 100644
--- a/asm/src/org/aspectj/asm/AsmManager.java
+++ b/asm/src/org/aspectj/asm/AsmManager.java
@@ -64,6 +64,8 @@ public class AsmManager {
private static String dumpFilename = "";
private static boolean reporting = false;
+ private static boolean completingTypeBindings = false;
+
// static {
// setReporting("c:/model.nfo",true,true,true,true);
// }
@@ -72,7 +74,7 @@ public class AsmManager {
hierarchy = new AspectJElementHierarchy();
// List relationships = new ArrayList();
mapper = new RelationshipMap(hierarchy);
- handleProvider = new FullPathHandleProvider();
+ handleProvider = new OptimizedFullPathHandleProvider();
}
public void createNewASM() {
@@ -845,5 +847,11 @@ public class AsmManager {
*/
public static boolean isCreatingModel() { return creatingModel;}
+ public static void setCompletingTypeBindings(boolean b) {
+ completingTypeBindings = b;
+ }
+
+ public static boolean isCompletingTypeBindings() { return completingTypeBindings; }
+
}
diff --git a/asm/src/org/aspectj/asm/IElementHandleProvider.java b/asm/src/org/aspectj/asm/IElementHandleProvider.java
index 97902abf9..8cef1acec 100644
--- a/asm/src/org/aspectj/asm/IElementHandleProvider.java
+++ b/asm/src/org/aspectj/asm/IElementHandleProvider.java
@@ -53,4 +53,6 @@ public interface IElementHandleProvider {
*/
public int getLineNumberForHandle(String handle);
+ public int getOffSetForHandle(String handle);
+
}
diff --git a/asm/src/org/aspectj/asm/IHierarchy.java b/asm/src/org/aspectj/asm/IHierarchy.java
index 481147cd8..02a4a18f8 100644
--- a/asm/src/org/aspectj/asm/IHierarchy.java
+++ b/asm/src/org/aspectj/asm/IHierarchy.java
@@ -91,6 +91,7 @@ public interface IHierarchy extends Serializable {
* @return a new structure node for the file if it was not found in the model
*/
public IProgramElement findElementForSourceLine(String sourceFilePath, int lineNumber);
+ public IProgramElement findElementForOffSet(String sourceFilePath, int lineNumber, int offSet);
public String getConfigFile();
diff --git a/asm/src/org/aspectj/asm/internal/AspectJElementHierarchy.java b/asm/src/org/aspectj/asm/internal/AspectJElementHierarchy.java
index 1e8c4f5dd..7839b3abd 100644
--- a/asm/src/org/aspectj/asm/internal/AspectJElementHierarchy.java
+++ b/asm/src/org/aspectj/asm/internal/AspectJElementHierarchy.java
@@ -43,11 +43,12 @@ public class AspectJElementHierarchy implements IHierarchy {
// int col = new Integer(st.nextToken()).intValue(); TODO: use column number when available
String file = AsmManager.getDefault().getHandleProvider().getFileForHandle(handle); // st.nextToken();
int line = AsmManager.getDefault().getHandleProvider().getLineNumberForHandle(handle); // st.nextToken();
+ int offSet = AsmManager.getDefault().getHandleProvider().getOffSetForHandle(handle);
String canonicalSFP = AsmManager.getDefault().getCanonicalFilePath(new File(file));
- IProgramElement ret = findNodeForSourceLineHelper(root,canonicalSFP, line);
+ IProgramElement ret = findNodeForSourceLineHelper(root,canonicalSFP, line, offSet);
if (ret!=null) {
- handleMap.put(handle,ret);
+ cache(handle,ret);
}
return ret;
}
@@ -245,7 +246,18 @@ public class AspectJElementHierarchy implements IHierarchy {
public IProgramElement findElementForSourceLine(String sourceFilePath, int lineNumber) {
String canonicalSFP = AsmManager.getDefault().getCanonicalFilePath(
new File(sourceFilePath));
- IProgramElement node = findNodeForSourceLineHelper(root, canonicalSFP, lineNumber);
+ IProgramElement node = findNodeForSourceLineHelper(root, canonicalSFP, lineNumber, -1);
+ if (node != null) {
+ return node;
+ } else {
+ return createFileStructureNode(sourceFilePath);
+ }
+ }
+
+ public IProgramElement findElementForOffSet(String sourceFilePath, int lineNumber, int offSet) {
+ String canonicalSFP = AsmManager.getDefault().getCanonicalFilePath(
+ new File(sourceFilePath));
+ IProgramElement node = findNodeForSourceLineHelper(root, canonicalSFP, lineNumber, offSet);
if (node != null) {
return node;
} else {
@@ -267,9 +279,9 @@ public class AspectJElementHierarchy implements IHierarchy {
}
- private IProgramElement findNodeForSourceLineHelper(IProgramElement node, String sourceFilePath, int lineNumber) {
- if (matches(node, sourceFilePath, lineNumber)
- && !hasMoreSpecificChild(node, sourceFilePath, lineNumber)) {
+ private IProgramElement findNodeForSourceLineHelper(IProgramElement node, String sourceFilePath, int lineNumber, int offSet) {
+ if (matches(node, sourceFilePath, lineNumber, offSet)
+ && !hasMoreSpecificChild(node, sourceFilePath, lineNumber, offSet)) {
return node;
}
@@ -278,15 +290,16 @@ public class AspectJElementHierarchy implements IHierarchy {
IProgramElement foundNode = findNodeForSourceLineHelper(
(IProgramElement)it.next(),
sourceFilePath,
- lineNumber);
+ lineNumber,
+ offSet);
if (foundNode != null) return foundNode;
}
}
return null;
}
-
- private boolean matches(IProgramElement node, String sourceFilePath, int lineNumber) {
+
+ private boolean matches(IProgramElement node, String sourceFilePath, int lineNumber, int offSet) {
// try {
// if (node != null && node.getSourceLocation() != null)
// System.err.println("====\n1: " +
@@ -296,6 +309,8 @@ public class AspectJElementHierarchy implements IHierarchy {
return node != null
&& node.getSourceLocation() != null
&& node.getSourceLocation().getSourceFile().getAbsolutePath().equals(sourceFilePath)
+ && ((offSet != -1 && node.getSourceLocation().getOffset() == offSet)
+ || offSet == -1 )
&& ((node.getSourceLocation().getLine() <= lineNumber
&& node.getSourceLocation().getEndLine() >= lineNumber)
||
@@ -307,10 +322,10 @@ public class AspectJElementHierarchy implements IHierarchy {
// }
}
- private boolean hasMoreSpecificChild(IProgramElement node, String sourceFilePath, int lineNumber) {
+ private boolean hasMoreSpecificChild(IProgramElement node, String sourceFilePath, int lineNumber, int offSet) {
for (Iterator it = node.getChildren().iterator(); it.hasNext(); ) {
IProgramElement child = (IProgramElement)it.next();
- if (matches(child, sourceFilePath, lineNumber)) return true;
+ if (matches(child, sourceFilePath, lineNumber, offSet)) return true;
}
return false;
}
@@ -336,8 +351,9 @@ public class AspectJElementHierarchy implements IHierarchy {
// TODO: use column number when available
String file = AsmManager.getDefault().getHandleProvider().getFileForHandle(handle); // st.nextToken();
int line = AsmManager.getDefault().getHandleProvider().getLineNumberForHandle(handle); // st.nextToken();
+ int offSet = AsmManager.getDefault().getHandleProvider().getOffSetForHandle(handle);
- ret = findElementForSourceLine(file, line);
+ ret = findElementForOffSet(file, line, offSet);
if (ret != null) {
cache(handle,(ProgramElement)ret);
}
@@ -371,9 +387,11 @@ public class AspectJElementHierarchy implements IHierarchy {
// }
// return null;
// }
-
- protected void cache(String handle, ProgramElement pe) {
- handleMap.put(handle,pe);
+
+ protected void cache(String handle, IProgramElement pe) {
+ if (!AsmManager.isCompletingTypeBindings()) {
+ handleMap.put(handle,pe);
+ }
}
public void flushTypeMap() {
diff --git a/asm/src/org/aspectj/asm/internal/FullPathHandleProvider.java b/asm/src/org/aspectj/asm/internal/FullPathHandleProvider.java
index 0a32af207..060cf0e5d 100644
--- a/asm/src/org/aspectj/asm/internal/FullPathHandleProvider.java
+++ b/asm/src/org/aspectj/asm/internal/FullPathHandleProvider.java
@@ -62,4 +62,12 @@ public class FullPathHandleProvider implements IElementHandleProvider {
st.nextToken(); // skip over the file
return new Integer(st.nextToken()).intValue();
}
+
+ public int getOffSetForHandle(String handle) {
+ StringTokenizer st = new StringTokenizer(handle, ID_DELIM);
+ st.nextToken(); // skip over the file
+ st.nextToken(); // skip over the line number
+ st.nextToken(); // skip over the column
+ return new Integer(st.nextToken()).intValue();
+ }
}
diff --git a/asm/src/org/aspectj/asm/internal/OptimizedFullPathHandleProvider.java b/asm/src/org/aspectj/asm/internal/OptimizedFullPathHandleProvider.java
index 5e78a1fce..b13b1755e 100644
--- a/asm/src/org/aspectj/asm/internal/OptimizedFullPathHandleProvider.java
+++ b/asm/src/org/aspectj/asm/internal/OptimizedFullPathHandleProvider.java
@@ -88,4 +88,12 @@ public class OptimizedFullPathHandleProvider implements IElementHandleProvider {
st.nextToken(); // skip over the file
return new Integer(st.nextToken()).intValue();
}
+
+ public int getOffSetForHandle(String handle) {
+ StringTokenizer st = new StringTokenizer(handle, ID_DELIM);
+ st.nextToken(); // skip over the file
+ st.nextToken(); // skip over the line number
+ st.nextToken(); // skip over the column
+ return new Integer(st.nextToken()).intValue();
+ }
}
diff --git a/asm/src/org/aspectj/asm/internal/ProgramElement.java b/asm/src/org/aspectj/asm/internal/ProgramElement.java
index b78b3bbda..3334d63fd 100644
--- a/asm/src/org/aspectj/asm/internal/ProgramElement.java
+++ b/asm/src/org/aspectj/asm/internal/ProgramElement.java
@@ -78,13 +78,11 @@ public class ProgramElement implements IProgramElement {
public ProgramElement (String name, IProgramElement.Kind kind, ISourceLocation sourceLocation,
int modifiers, String comment, List children) {
this(name, kind, children);
- this.sourceLocation = //ISourceLocation.EMPTY;
- sourceLocation;
+ this.sourceLocation = sourceLocation;
setFormalComment(comment);
// if (comment!=null && comment.length()>0) formalComment = comment;
this.modifiers = modifiers;
// this.accessibility = genAccessibility(modifiers);
- cacheByHandle();
}
/**
@@ -104,9 +102,7 @@ public class ProgramElement implements IProgramElement {
boolean member) {
this(name, kind, children);
- this.sourceLocation =
- //ISourceLocation.EMPTY;
- sourceLocation;
+ this.sourceLocation = sourceLocation;
this.kind = kind;
this.modifiers = modifiers;
// this.accessibility = accessibility;
@@ -116,7 +112,6 @@ public class ProgramElement implements IProgramElement {
// if (comment!=null && comment.length()>0) formalComment = comment;
if (relations!=null && relations.size()!=0) setRelations(relations);
// this.relations = relations;
- cacheByHandle();
}
public List getModifiers() {