Selaa lähdekoodia

247742:c27

tags/V1_6_2
aclement 15 vuotta sitten
vanhempi
commit
8c738a60c2

+ 107
- 207
asm/src/org/aspectj/asm/AsmManager.java Näytä tiedosto

@@ -42,11 +42,9 @@ import org.aspectj.asm.internal.RelationshipMap;
import org.aspectj.bridge.ISourceLocation;

/**
* The Abstract Structure Model (ASM) represents the containment hierarchy and
* crossccutting structure map for AspectJ programs. It is used by IDE views
* such as the document outline, and by other tools such as ajdoc to show both
* AspectJ declarations and crosscutting links, such as which advice affects
* which join point shadows.
* The Abstract Structure Model (ASM) represents the containment hierarchy and crossccutting structure map for AspectJ programs. It
* is used by IDE views such as the document outline, and by other tools such as ajdoc to show both AspectJ declarations and
* crosscutting links, such as which advice affects which join point shadows.
*
* @author Mik Kersten
*/
@@ -128,8 +126,7 @@ public class AsmManager {
/**
* Constructs map each time it's called.
*/
public HashMap getInlineAnnotations(String sourceFile,
boolean showSubMember, boolean showMemberAndType) {
public HashMap getInlineAnnotations(String sourceFile, boolean showSubMember, boolean showMemberAndType) {

if (!hierarchy.isValid())
return null;
@@ -141,8 +138,7 @@ public class AsmManager {
} else {
IProgramElement fileNode = node;
ArrayList peNodes = new ArrayList();
getAllStructureChildren(fileNode, peNodes, showSubMember,
showMemberAndType);
getAllStructureChildren(fileNode, peNodes, showSubMember, showMemberAndType);
for (Iterator it = peNodes.iterator(); it.hasNext();) {
IProgramElement peNode = (IProgramElement) it.next();
List entries = new ArrayList();
@@ -161,8 +157,7 @@ public class AsmManager {
}
}

private void getAllStructureChildren(IProgramElement node, List result,
boolean showSubMember, boolean showMemberAndType) {
private void getAllStructureChildren(IProgramElement node, List result, boolean showSubMember, boolean showMemberAndType) {
List children = node.getChildren();
if (node.getChildren() == null)
return;
@@ -170,13 +165,11 @@ public class AsmManager {
IProgramElement next = (IProgramElement) it.next();
List rels = AsmManager.getDefault().getRelationshipMap().get(next);
if (next != null
&& ((next.getKind() == IProgramElement.Kind.CODE && showSubMember) || (next
.getKind() != IProgramElement.Kind.CODE && showMemberAndType))
&& ((next.getKind() == IProgramElement.Kind.CODE && showSubMember) || (next.getKind() != IProgramElement.Kind.CODE && showMemberAndType))
&& rels != null && rels.size() > 0) {
result.add(next);
}
getAllStructureChildren(next, result, showSubMember,
showMemberAndType);
getAllStructureChildren(next, result, showSubMember, showMemberAndType);
}
}

@@ -222,15 +215,14 @@ public class AsmManager {
fos.close();
s.close();
} catch (Exception e) {
//System.err.println("AsmManager: Unable to write structure model: "
// System.err.println("AsmManager: Unable to write structure model: "
// +configFilePath+" because of:");
// e.printStackTrace();
}
}

/**
* @param configFilePath
* path to an ".lst" file
* @param configFilePath path to an ".lst" file
*/
public void readStructureModel(String configFilePath) {
boolean hierarchyReadOK = false;
@@ -252,14 +244,12 @@ public class AsmManager {
} catch (EOFException eofe) {
// Might be an old format sym file that is missing its relationships
if (!hierarchyReadOK) {
System.err
.println("AsmManager: Unable to read structure model: "
+ configFilePath + " because of:");
System.err.println("AsmManager: Unable to read structure model: " + configFilePath + " because of:");
eofe.printStackTrace();
hierarchy.setRoot(IHierarchy.NO_STRUCTURE);
}
} catch (Exception e) {
//System.err.println("AsmManager: Unable to read structure model: "+
// System.err.println("AsmManager: Unable to read structure model: "+
// configFilePath+" because of:");
// e.printStackTrace();
hierarchy.setRoot(IHierarchy.NO_STRUCTURE);
@@ -271,8 +261,7 @@ public class AsmManager {
private String genExternFilePath(String configFilePath) {
// sometimes don't have ".lst"
if (configFilePath.lastIndexOf(".lst") != -1) {
configFilePath = configFilePath.substring(0, configFilePath
.lastIndexOf(".lst"));
configFilePath = configFilePath.substring(0, configFilePath.lastIndexOf(".lst"));
}
return configFilePath + ".ajsym";
}
@@ -386,8 +375,7 @@ public class AsmManager {
}

// SECRETAPI
public static void setReporting(String filename, boolean dModel,
boolean dRels, boolean dDeltaProcessing, boolean deletefile) {
public static void setReporting(String filename, boolean dModel, boolean dRels, boolean dDeltaProcessing, boolean deletefile) {
reporting = true;
dumpModel = dModel;
dumpRelationships = dRels;
@@ -397,8 +385,7 @@ public class AsmManager {
dumpFilename = filename;
}

public static void setReporting(String filename, boolean dModel,
boolean dRels, boolean dDeltaProcessing, boolean deletefile,
public static void setReporting(String filename, boolean dModel, boolean dRels, boolean dDeltaProcessing, boolean deletefile,
IModelFilter aFilter) {
setReporting(filename, dModel, dRels, dDeltaProcessing, deletefile);
modelFilter = aFilter;
@@ -427,23 +414,19 @@ public class AsmManager {
FileWriter fw = new FileWriter(dumpFilename, true);
BufferedWriter bw = new BufferedWriter(fw);
if (dumpModel) {
bw.write("=== MODEL STATUS REPORT ========= " + reasonForReport
+ "\n");
dumptree(bw, AsmManager.getDefault().getHierarchy().getRoot(),
0);
bw.write("=== MODEL STATUS REPORT ========= " + reasonForReport + "\n");
dumptree(bw, AsmManager.getDefault().getHierarchy().getRoot(), 0);

bw.write("=== END OF MODEL REPORT =========\n");
}
if (dumpRelationships) {
bw.write("=== RELATIONSHIPS REPORT ========= "
+ reasonForReport + "\n");
bw.write("=== RELATIONSHIPS REPORT ========= " + reasonForReport + "\n");
dumprels(bw);
bw.write("=== END OF RELATIONSHIPS REPORT ==\n");
}
Properties p = ModelInfo.summarizeModel().getProperties();
Enumeration pkeyenum = p.keys();
bw
.write("=== Properties of the model and relationships map =====\n");
bw.write("=== Properties of the model and relationships map =====\n");
while (pkeyenum.hasMoreElements()) {
String pkey = (String) pkeyenum.nextElement();
bw.write(pkey + "=" + p.getProperty(pkey) + "\n");
@@ -451,14 +434,12 @@ public class AsmManager {
bw.flush();
fw.close();
} catch (IOException e) {
System.err
.println("InternalError: Unable to report model information:");
System.err.println("InternalError: Unable to report model information:");
e.printStackTrace();
}
}

public static void dumptree(Writer w, IProgramElement node, int indent)
throws IOException {
public static void dumptree(Writer w, IProgramElement node, int indent) throws IOException {
for (int i = 0; i < indent; i++)
w.write(" ");
String loc = "";
@@ -469,17 +450,14 @@ public class AsmManager {
loc = modelFilter.processFilelocation(loc);
}
}
w.write(node + " ["
+ (node == null ? "null" : node.getKind().toString()) + "] "
+ loc + "\n");
w.write(node + " [" + (node == null ? "null" : node.getKind().toString()) + "] " + loc + "\n");
if (node != null)
for (Iterator i = node.getChildren().iterator(); i.hasNext();) {
dumptree(w, (IProgramElement) i.next(), indent + 2);
}
}

public static void dumptree(IProgramElement node, int indent)
throws IOException {
public static void dumptree(IProgramElement node, int indent) throws IOException {
for (int i = 0; i < indent; i++)
System.out.print(" ");
String loc = "";
@@ -487,16 +465,14 @@ public class AsmManager {
if (node.getSourceLocation() != null)
loc = node.getSourceLocation().toString();
}
System.out.println(node + " ["
+ (node == null ? "null" : node.getKind().toString()) + "] "
+ loc);
System.out.println(node + " [" + (node == null ? "null" : node.getKind().toString()) + "] " + loc);
if (node != null)
for (Iterator i = node.getChildren().iterator(); i.hasNext();) {
dumptree((IProgramElement) i.next(), indent + 2);
}
}

private void dumprels(Writer w) throws IOException {
public void dumprels(Writer w) throws IOException {
IRelationshipMap irm = AsmManager.getDefault().getRelationshipMap();
int ctr = 1;
Set entries = irm.getEntries();
@@ -506,14 +482,12 @@ public class AsmManager {
for (Iterator iterator = rels.iterator(); iterator.hasNext();) {
IRelationship ir = (IRelationship) iterator.next();
List targets = ir.getTargets();
for (Iterator iterator2 = targets.iterator(); iterator2
.hasNext();) {
for (Iterator iterator2 = targets.iterator(); iterator2.hasNext();) {
String thid = (String) iterator2.next();
StringBuffer sb = new StringBuffer();
if (modelFilter == null || modelFilter.wantsHandleIds())
sb.append("Hid:" + (ctr++) + ":");
sb.append("(targets=" + targets.size() + ") " + hid + " ("
+ ir.getName() + ") " + thid + "\n");
sb.append("(targets=" + targets.size() + ") " + hid + " (" + ir.getName() + ") " + thid + "\n");
w.write(sb.toString());
}
}
@@ -531,12 +505,10 @@ public class AsmManager {
for (Iterator iterator = rels.iterator(); iterator.hasNext();) {
IRelationship ir = (IRelationship) iterator.next();
List targets = ir.getTargets();
for (Iterator iterator2 = targets.iterator(); iterator2
.hasNext();) {
for (Iterator iterator2 = targets.iterator(); iterator2.hasNext();) {
String thid = (String) iterator2.next();
System.err.println("Hid:" + (ctr++) + ":(targets="
+ targets.size() + ") " + hid + " (" + ir.getName()
+ ") " + thid);
System.err.println("Hid:" + (ctr++) + ":(targets=" + targets.size() + ") " + hid + " (" + ir.getName() + ") "
+ thid);
}
}
}
@@ -547,11 +519,9 @@ public class AsmManager {
// ==========//

/**
* Removes the hierarchy structure for the specified files from the
* structure model. Returns true if it deleted anything
* Removes the hierarchy structure for the specified files from the structure model. Returns true if it deleted anything
*/
public boolean removeStructureModelForFiles(Writer fw, Collection files)
throws IOException {
public boolean removeStructureModelForFiles(Writer fw, Collection files) throws IOException {

IHierarchy model = AsmManager.getDefault().getHierarchy();

@@ -560,24 +530,19 @@ public class AsmManager {
Set deletedNodes = new HashSet();
for (Iterator iter = files.iterator(); iter.hasNext();) {
File fileForCompilation = (File) iter.next();
String correctedPath = AsmManager.getDefault()
.getCanonicalFilePath(fileForCompilation);
IProgramElement progElem = (IProgramElement) model
.findInFileMap(correctedPath);
String correctedPath = AsmManager.getDefault().getCanonicalFilePath(fileForCompilation);
IProgramElement progElem = (IProgramElement) model.findInFileMap(correctedPath);
if (progElem != null) {
// Found it, let's remove it
if (dumpDeltaProcessing) {
fw.write("Deleting " + progElem + " node for file "
+ fileForCompilation + "\n");
fw.write("Deleting " + progElem + " node for file " + fileForCompilation + "\n");
}
removeNode(progElem);
lastBuildChanges.add(fileForCompilation);
deletedNodes.add(getCanonicalFilePath(progElem
.getSourceLocation().getSourceFile()));
deletedNodes.add(getCanonicalFilePath(progElem.getSourceLocation().getSourceFile()));
if (!model.removeFromFileMap(correctedPath))
throw new RuntimeException(
"Whilst repairing model, couldn't remove entry for file: "
+ correctedPath + " from the filemap");
throw new RuntimeException("Whilst repairing model, couldn't remove entry for file: " + correctedPath
+ " from the filemap");
modelModified = true;
}
}
@@ -588,8 +553,7 @@ public class AsmManager {

// This code is *SLOW* but it isnt worth fixing until we address the
// bugs in binary weaving.
public void fixupStructureModel(Writer fw, List filesToBeCompiled,
Set files_added, Set files_deleted) throws IOException {
public void fixupStructureModel(Writer fw, List filesToBeCompiled, Set files_added, Set files_deleted) throws IOException {
// Three kinds of things to worry about:
// 1. New files have been added since the last compile
// 2. Files have been deleted since the last compile
@@ -606,26 +570,20 @@ public class AsmManager {
Set filesToRemoveFromStructureModel = new HashSet(filesToBeCompiled);
filesToRemoveFromStructureModel.addAll(files_deleted);
Set deletedNodes = new HashSet();
for (Iterator iter = filesToRemoveFromStructureModel.iterator(); iter
.hasNext();) {
for (Iterator iter = filesToRemoveFromStructureModel.iterator(); iter.hasNext();) {
File fileForCompilation = (File) iter.next();
String correctedPath = AsmManager.getDefault()
.getCanonicalFilePath(fileForCompilation);
IProgramElement progElem = (IProgramElement) model
.findInFileMap(correctedPath);
String correctedPath = AsmManager.getDefault().getCanonicalFilePath(fileForCompilation);
IProgramElement progElem = (IProgramElement) model.findInFileMap(correctedPath);
if (progElem != null) {
// Found it, let's remove it
if (dumpDeltaProcessing) {
fw.write("Deleting " + progElem + " node for file "
+ fileForCompilation + "\n");
fw.write("Deleting " + progElem + " node for file " + fileForCompilation + "\n");
}
removeNode(progElem);
deletedNodes.add(getCanonicalFilePath(progElem
.getSourceLocation().getSourceFile()));
deletedNodes.add(getCanonicalFilePath(progElem.getSourceLocation().getSourceFile()));
if (!model.removeFromFileMap(correctedPath))
throw new RuntimeException(
"Whilst repairing model, couldn't remove entry for file: "
+ correctedPath + " from the filemap");
throw new RuntimeException("Whilst repairing model, couldn't remove entry for file: " + correctedPath
+ " from the filemap");
modelModified = true;
}
}
@@ -635,8 +593,7 @@ public class AsmManager {
}
}

public void processDelta(Collection files_tobecompiled, Set files_added,
Set files_deleted) {
public void processDelta(Collection files_tobecompiled, Set files_added, Set files_deleted) {

try {
Writer fw = null;
@@ -646,17 +603,14 @@ public class AsmManager {
FileWriter filew = new FileWriter(dumpFilename, true);
fw = new BufferedWriter(filew);
fw.write("=== Processing delta changes for the model ===\n");
fw.write("Files for compilation:#" + files_tobecompiled.size()
+ ":" + files_tobecompiled + "\n");
fw.write("Files added :#" + files_added.size() + ":"
+ files_added + "\n");
fw.write("Files deleted :#" + files_deleted.size() + ":"
+ files_deleted + "\n");
fw.write("Files for compilation:#" + files_tobecompiled.size() + ":" + files_tobecompiled + "\n");
fw.write("Files added :#" + files_added.size() + ":" + files_added + "\n");
fw.write("Files deleted :#" + files_deleted.size() + ":" + files_deleted + "\n");
}

long stime = System.currentTimeMillis();

//fixupStructureModel(fw,filesToBeCompiled,files_added,files_deleted
// fixupStructureModel(fw,filesToBeCompiled,files_added,files_deleted
// );
// Let's remove all the files that are deleted on this compile
removeStructureModelForFiles(fw, files_deleted);
@@ -672,8 +626,7 @@ public class AsmManager {

if (dumpDeltaProcessing) {
fw.write("===== Delta Processing timing ==========\n");
fw.write("Hierarchy=" + (etime1 - stime)
+ "ms Relationshipmap=" + (etime2 - etime1) + "ms\n");
fw.write("Hierarchy=" + (etime1 - stime) + "ms Relationshipmap=" + (etime2 - etime1) + "ms\n");
fw.write("===== Traversal ========================\n");
// fw.write("Source handles processed="+srchandlecounter+"\n");
// fw.write("Target handles processed="+tgthandlecounter+"\n");
@@ -694,20 +647,17 @@ public class AsmManager {
*
* A affects B B affectedBy A
*
* Both of these relationships are added when 'B' is modified. Concrete
* examples are 'advises/advisedby' or 'annotates/annotatedby'.
* Both of these relationships are added when 'B' is modified. Concrete examples are 'advises/advisedby' or
* 'annotates/annotatedby'.
*
* What we need to do is when 'B' is going to be woven, remove all
* relationships that may reoccur when it is woven. So - remove 'affects'
* relationships where the target is 'B', remove all 'affectedBy'
* relationships where the source is 'B'.
* What we need to do is when 'B' is going to be woven, remove all relationships that may reoccur when it is woven. So - remove
* 'affects' relationships where the target is 'B', remove all 'affectedBy' relationships where the source is 'B'.
*
*/
public void removeRelationshipsTargettingThisType(String typename) {
boolean debug = false;
if (debug)
System.err.println(">>removeRelationshipsTargettingThisType "
+ typename);
System.err.println(">>removeRelationshipsTargettingThisType " + typename);
String pkg = null;
String type = typename;
int lastSep = typename.lastIndexOf('.');
@@ -740,8 +690,7 @@ public class AsmManager {
// worth continuing as there may be a relationship to remove
relationshipsToRemove.clear();
List relationships = mapper.get(hid);
for (Iterator reliter = relationships.iterator(); reliter
.hasNext();) {
for (Iterator reliter = relationships.iterator(); reliter.hasNext();) {
IRelationship rel = (IRelationship) reliter.next();
if (rel.getKind() == IRelationship.Kind.USES_POINTCUT)
continue; // these relationships are added at compile
@@ -777,9 +726,8 @@ public class AsmManager {
// If the relationship was hanging off a 'code' node, delete it.
if (ipe.getKind().equals(IProgramElement.Kind.CODE)) {
if (debug)
System.err
.println(" source handle: it was code node, removing that as well... code="
+ ipe + " parent=" + ipe.getParent());
System.err.println(" source handle: it was code node, removing that as well... code=" + ipe + " parent="
+ ipe.getParent());
removeSingleNode(ipe);
}
}
@@ -794,13 +742,11 @@ public class AsmManager {
dumprelsStderr("before processing 'affects'");
// Iterate over the source handles in the relationships map
sourcehandlesSet = mapper.getEntries();
for (Iterator keyiter = sourcehandlesSet.iterator(); keyiter
.hasNext();) {
for (Iterator keyiter = sourcehandlesSet.iterator(); keyiter.hasNext();) {
String hid = (String) keyiter.next();
relationshipsToRemove.clear();
List relationships = mapper.get(hid);
for (Iterator reliter = relationships.iterator(); reliter
.hasNext();) {
for (Iterator reliter = relationships.iterator(); reliter.hasNext();) {
IRelationship rel = (IRelationship) reliter.next();
if (rel.getKind() == IRelationship.Kind.USES_POINTCUT)
continue; // these relationships are added at compile
@@ -812,14 +758,11 @@ public class AsmManager {

// find targets that target the type we are interested in,
// they need removing
for (Iterator targetsIter = targets.iterator(); targetsIter
.hasNext();) {
for (Iterator targetsIter = targets.iterator(); targetsIter.hasNext();) {
String targethid = (String) targetsIter.next();
// Does this point to the same type?
IProgramElement existingTarget = hierarchy
.getElement(targethid);
if (existingTarget == null
|| sameType(targethid, existingTarget, typeNode))
IProgramElement existingTarget = hierarchy.getElement(targethid);
if (existingTarget == null || sameType(targethid, existingTarget, typeNode))
targetsToRemove.add(targethid);
}

@@ -828,8 +771,7 @@ public class AsmManager {
relationshipsToRemove.add(rel);
else {
// Remove all the targets that are no longer valid
for (Iterator targsIter = targetsToRemove
.iterator(); targsIter.hasNext();) {
for (Iterator targsIter = targetsToRemove.iterator(); targsIter.hasNext();) {
String togo = (String) targsIter.next();
targets.remove(togo);
}
@@ -850,8 +792,7 @@ public class AsmManager {
}
}
// Remove sources that have no valid relationships any more
for (Iterator srciter = sourcesToRemove.iterator(); srciter
.hasNext();) {
for (Iterator srciter = sourcesToRemove.iterator(); srciter.hasNext();) {
String hid = (String) srciter.next();
// System.err.println(
// " source handle: all relationships have gone for "+hid);
@@ -862,11 +803,8 @@ public class AsmManager {
// it.
if (ipe.getKind().equals(IProgramElement.Kind.CODE)) {
if (debug)
System.err
.println(" source handle: it was code node, removing that as well... code="
+ ipe
+ " parent="
+ ipe.getParent());
System.err.println(" source handle: it was code node, removing that as well... code=" + ipe
+ " parent=" + ipe.getParent());
removeSingleNode(ipe);
}
}
@@ -882,8 +820,7 @@ public class AsmManager {
/**
* Return true if the target element is in the type specified.
*/
private boolean sameType(String hid, IProgramElement target,
IProgramElement type) {
private boolean sameType(String hid, IProgramElement target, IProgramElement type) {
IProgramElement containingType = target;
if (target == null)
throw new RuntimeException("target can't be null!");
@@ -910,8 +847,7 @@ public class AsmManager {
return false;
if (type.getSourceLocation().getSourceFile() == null)
return false;
return (target.getSourceLocation().getSourceFile().equals(type
.getSourceLocation().getSourceFile()));
return (target.getSourceLocation().getSourceFile().equals(type.getSourceLocation().getSourceFile()));
}
while (!containingType.getKind().isType()) {
// System.err.println("Checked: "+containingType.getKind()+" "+
@@ -922,9 +858,8 @@ public class AsmManager {
}

/**
* Go through all the relationships in the model, if any endpoints no longer
* exist (the node it points to has been deleted from the model) then delete
* the relationship.
* Go through all the relationships in the model, if any endpoints no longer exist (the node it points to has been deleted from
* the model) then delete the relationship.
*/
private void repairRelationships(Writer fw) {
try {
@@ -958,9 +893,7 @@ public class AsmManager {
// We better check if it actually exists
IProgramElement existingElement = model.getElement(hid);
if (dumpDeltaProcessing)
fw.write("Looking for handle [" + hid
+ "] in model, found: " + existingElement
+ "\n");
fw.write("Looking for handle [" + hid + "] in model, found: " + existingElement + "\n");

// Did we find it?
if (existingElement == null) {
@@ -973,36 +906,28 @@ public class AsmManager {
List relationshipsToRemove = new ArrayList();
// Iterate through the relationships against this source
// handle
for (Iterator reliter = relationships.iterator(); reliter
.hasNext();) {
for (Iterator reliter = relationships.iterator(); reliter.hasNext();) {
IRelationship rel = (IRelationship) reliter.next();
List targets = rel.getTargets();
List targetsToRemove = new ArrayList();

// Iterate through the targets for this relationship
for (Iterator targetIter = targets.iterator(); targetIter
.hasNext();) {
for (Iterator targetIter = targets.iterator(); targetIter.hasNext();) {
String targethid = (String) targetIter.next();
tgthandlecounter++;
// Do we already know it doesn't exist?
if (nonExistingHandles.contains(targethid)) {
if (dumpDeltaProcessing)
fw.write("Target handle [" + targethid
+ "] for srchid[" + hid
+ "]rel[" + rel.getName()
fw.write("Target handle [" + targethid + "] for srchid[" + hid + "]rel[" + rel.getName()
+ "] does not exist\n");
targetsToRemove.add(targethid);
} else {
// We better check
IProgramElement existingTarget = model
.getElement(targethid);
IProgramElement existingTarget = model.getElement(targethid);
if (existingTarget == null) {
if (dumpDeltaProcessing)
fw.write("Target handle ["
+ targethid
+ "] for srchid[" + hid
+ "]rel[" + rel.getName()
+ "] does not exist\n");
fw.write("Target handle [" + targethid + "] for srchid[" + hid + "]rel["
+ rel.getName() + "] does not exist\n");
targetsToRemove.add(targethid);
nonExistingHandles.add(targethid);
}
@@ -1015,18 +940,13 @@ public class AsmManager {
// relationship (i.e. removing the relationship)
if (targetsToRemove.size() == targets.size()) {
if (dumpDeltaProcessing)
fw
.write("No targets remain for srchid["
+ hid
+ "] rel["
+ rel.getName()
+ "]: removing it\n");
fw.write("No targets remain for srchid[" + hid + "] rel[" + rel.getName()
+ "]: removing it\n");
relationshipsToRemove.add(rel);
} else {
// Remove all the targets that are no longer
// valid
for (Iterator targsIter = targetsToRemove
.iterator(); targsIter.hasNext();) {
for (Iterator targsIter = targetsToRemove.iterator(); targsIter.hasNext();) {
String togo = (String) targsIter.next();
targets.remove(togo);
}
@@ -1034,12 +954,8 @@ public class AsmManager {
// but lets double check ...
if (targets.size() == 0) {
if (dumpDeltaProcessing)
fw
.write("No targets remain for srchid["
+ hid
+ "] rel["
+ rel.getName()
+ "]: removing it\n");
fw.write("No targets remain for srchid[" + hid + "] rel[" + rel.getName()
+ "]: removing it\n");
relationshipsToRemove.add(rel); // TODO
// Should
// only
@@ -1060,22 +976,17 @@ public class AsmManager {
if (relationshipsToRemove.size() > 0) {
// Are we removing *all* of the relationships for
// this source handle?
if (relationshipsToRemove.size() == relationships
.size()) {
if (relationshipsToRemove.size() == relationships.size()) {
// We know they are all going to go, so just
// delete the source handle.
sourcesToRemove.add(hid);
} else {
// MEMORY LEAK - we don't remove the
// relationships !!
for (int i = 0; i < relationshipsToRemove
.size(); i++) {
IRelationship irel = (IRelationship) relationshipsToRemove
.get(i);
verifyAssumption(irm.remove(hid, irel),
"Failed to remove relationship "
+ irel.getName()
+ " for shid " + hid);
for (int i = 0; i < relationshipsToRemove.size(); i++) {
IRelationship irel = (IRelationship) relationshipsToRemove.get(i);
verifyAssumption(irm.remove(hid, irel), "Failed to remove relationship " + irel.getName()
+ " for shid " + hid);
}
List rels = irm.get(hid);
if (rels == null || rels.size() == 0)
@@ -1086,8 +997,7 @@ public class AsmManager {
}
}
// Remove sources that have no valid relationships any more
for (Iterator srciter = sourcesToRemove.iterator(); srciter
.hasNext();) {
for (Iterator srciter = sourcesToRemove.iterator(); srciter.hasNext();) {
String hid = (String) srciter.next();
irm.removeAll(hid);
IProgramElement ipe = model.getElement(hid);
@@ -1107,9 +1017,8 @@ public class AsmManager {
}

/**
* Removes a specified program element from the structure model. We go to
* the parent of the program element, ask for all its children and remove
* the node we want to delete from the list of children.
* Removes a specified program element from the structure model. We go to the parent of the program element, ask for all its
* children and remove the node we want to delete from the list of children.
*/
private void removeSingleNode(IProgramElement progElem) {
verifyAssumption(progElem != null);
@@ -1127,15 +1036,13 @@ public class AsmManager {
}

/**
* Removes a specified program element from the structure model. Two
* processing stages:
* Removes a specified program element from the structure model. Two processing stages:
* <p>
* First: We go to the parent of the program element, ask for all its
* children and remove the node we want to delete from the list of children.
* First: We go to the parent of the program element, ask for all its children and remove the node we want to delete from the
* list of children.
* <p>
* Second:We check if that parent has any other children. If it has no other
* children and it is either a CODE node or a PACKAGE node, we delete it
* too.
* Second:We check if that parent has any other children. If it has no other children and it is either a CODE node or a PACKAGE
* node, we delete it too.
*/
private void removeNode(IProgramElement progElem) {

@@ -1163,8 +1070,7 @@ public class AsmManager {
// Are there any kids left for this node?
if (parent.getChildren().size() == 0
&& parent.getParent() != null
&& (parent.getKind().equals(IProgramElement.Kind.CODE) || parent
.getKind().equals(IProgramElement.Kind.PACKAGE))) {
&& (parent.getKind().equals(IProgramElement.Kind.CODE) || parent.getKind().equals(IProgramElement.Kind.PACKAGE))) {
// This node is on its own, we should trim it too *as long as
// its not a structural node* which we currently check by
// making sure its a code node
@@ -1201,8 +1107,7 @@ public class AsmManager {
// ==========//

/**
* A ModelInfo object captures basic information about the structure model.
* It is used for testing and producing debug info.
* A ModelInfo object captures basic information about the structure model. It is used for testing and producing debug info.
*/
public static class ModelInfo {
private final Hashtable nodeTypeCount = new Hashtable();
@@ -1211,10 +1116,8 @@ public class AsmManager {
private ModelInfo(IHierarchy hierarchy, IRelationshipMap relationshipMap) {
IProgramElement ipe = hierarchy.getRoot();
walkModel(ipe);
recordStat("FileMapSize", new Integer(hierarchy
.getFileMapEntrySet().size()).toString());
recordStat("RelationshipMapSize", new Integer(relationshipMap
.getEntries().size()).toString());
recordStat("FileMapSize", new Integer(hierarchy.getFileMapEntrySet().size()).toString());
recordStat("RelationshipMapSize", new Integer(relationshipMap.getEntries().size()).toString());
}

private void walkModel(IProgramElement ipe) {
@@ -1273,22 +1176,20 @@ public class AsmManager {
}

public static ModelInfo summarizeModel() {
return new ModelInfo(AsmManager.getDefault().getHierarchy(),
AsmManager.getDefault().getRelationshipMap());
return new ModelInfo(AsmManager.getDefault().getHierarchy(), AsmManager.getDefault().getRelationshipMap());
}
}

/**
* Set to indicate whether we are currently building a structure model,
* should be set up front.
* Set to indicate whether we are currently building a structure model, should be set up front.
*/
public static void setCreatingModel(boolean b) {
creatingModel = b;
}

/**
* returns true if we are currently generating a structure model, enables
* guarding of expensive operations on an empty/null model.
* returns true if we are currently generating a structure model, enables guarding of expensive operations on an empty/null
* model.
*/
public static boolean isCreatingModel() {
return creatingModel;
@@ -1315,8 +1216,7 @@ public class AsmManager {
}

/**
* @return the Set of files for which the structure model was modified (they
* may have been removed or otherwise rebuilt)
* @return the Set of files for which the structure model was modified (they may have been removed or otherwise rebuilt)
*/
public Set getModelChangesOnLastBuild() {
return lastBuildChanges;

+ 22
- 28
asm/src/org/aspectj/asm/internal/HandleProviderDelimiter.java Näytä tiedosto

@@ -34,8 +34,7 @@ public class HandleProviderDelimiter {
public static final HandleProviderDelimiter PACKAGEDECLARATION = new HandleProviderDelimiter('%');
public static final HandleProviderDelimiter LOCALVARIABLE = new HandleProviderDelimiter('@');
public static final HandleProviderDelimiter TYPE_PARAMETER = new HandleProviderDelimiter(']');

// AspectJ specific ones
public static final HandleProviderDelimiter ASPECT_CU = new HandleProviderDelimiter('*');
public static final HandleProviderDelimiter ADVICE = new HandleProviderDelimiter('&');
@@ -44,26 +43,23 @@ public class HandleProviderDelimiter {
public static final HandleProviderDelimiter ITD = new HandleProviderDelimiter(')');
public static final HandleProviderDelimiter DECLARE = new HandleProviderDelimiter('`');
public static final HandleProviderDelimiter POINTCUT = new HandleProviderDelimiter('+');

private static char empty = ' ';
private final char delim;
private HandleProviderDelimiter(char delim) {
this.delim = delim;
}

/**
* Returns the delimiter for the HandleProviderDelimiter,
* for example ASPECT returns '*' and METHOD returns '~'
* Returns the delimiter for the HandleProviderDelimiter, for example ASPECT returns '*' and METHOD returns '~'
*/
public char getDelimiter() {
return delim;
}
/**
* Returns the delimiter for the given IProgramElement for example
* if the IProgramElement is an aspect returns '*' and if the
* Returns the delimiter for the given IProgramElement for example if the IProgramElement is an aspect returns '*' and if the
* IProgramElement is a method returns '~'
*/
public static char getDelimiter(IProgramElement ipe) {
@@ -76,40 +72,32 @@ public class HandleProviderDelimiter {
if (ipe.getName().endsWith(".aj")) {
return ASPECT_CU.getDelimiter();
} else {
return COMPILATIONUNIT.getDelimiter();
return COMPILATIONUNIT.getDelimiter();
}
} else if (kind.equals(IProgramElement.Kind.FILE_ASPECTJ)) {
return ASPECT_CU.getDelimiter();
} else if (kind.equals(IProgramElement.Kind.IMPORT_REFERENCE)) {
return IMPORTDECLARATION.getDelimiter();
} else if (kind.equals(IProgramElement.Kind.CLASS)
|| kind.equals(IProgramElement.Kind.INTERFACE)
|| kind.equals(IProgramElement.Kind.ENUM)
|| kind.equals(IProgramElement.Kind.ANNOTATION)) {
} else if (kind.equals(IProgramElement.Kind.CLASS) || kind.equals(IProgramElement.Kind.INTERFACE)
|| kind.equals(IProgramElement.Kind.ENUM) || kind.equals(IProgramElement.Kind.ANNOTATION)) {
return TYPE.getDelimiter();
} else if (kind.equals(IProgramElement.Kind.ASPECT)) {
return ASPECT_TYPE.getDelimiter();
} else if (kind.equals(IProgramElement.Kind.INITIALIZER)) {
return INITIALIZER.getDelimiter();
} else if (kind.equals(IProgramElement.Kind.INTER_TYPE_FIELD)
|| kind.equals(IProgramElement.Kind.INTER_TYPE_METHOD)
|| kind.equals(IProgramElement.Kind.INTER_TYPE_CONSTRUCTOR)
|| kind.equals(IProgramElement.Kind.INTER_TYPE_PARENT)) {
} else if (kind.equals(IProgramElement.Kind.INTER_TYPE_FIELD) || kind.equals(IProgramElement.Kind.INTER_TYPE_METHOD)
|| kind.equals(IProgramElement.Kind.INTER_TYPE_CONSTRUCTOR) || kind.equals(IProgramElement.Kind.INTER_TYPE_PARENT)) {
return ITD.getDelimiter();
} else if (kind.equals(IProgramElement.Kind.CONSTRUCTOR)
|| kind.equals(IProgramElement.Kind.METHOD)) {
} else if (kind.equals(IProgramElement.Kind.CONSTRUCTOR) || kind.equals(IProgramElement.Kind.METHOD)) {
return METHOD.getDelimiter();
} else if (kind.equals(IProgramElement.Kind.FIELD)
|| kind.equals(IProgramElement.Kind.ENUM_VALUE)) {
} else if (kind.equals(IProgramElement.Kind.FIELD) || kind.equals(IProgramElement.Kind.ENUM_VALUE)) {
return FIELD.getDelimiter();
} else if (kind.equals(IProgramElement.Kind.POINTCUT)) {
return POINTCUT.getDelimiter();
} else if (kind.equals(IProgramElement.Kind.ADVICE)) {
return ADVICE.getDelimiter();
} else if (kind.equals(IProgramElement.Kind.DECLARE_PARENTS)
|| kind.equals(IProgramElement.Kind.DECLARE_WARNING)
|| kind.equals(IProgramElement.Kind.DECLARE_ERROR)
|| kind.equals(IProgramElement.Kind.DECLARE_SOFT)
} else if (kind.equals(IProgramElement.Kind.DECLARE_PARENTS) || kind.equals(IProgramElement.Kind.DECLARE_WARNING)
|| kind.equals(IProgramElement.Kind.DECLARE_ERROR) || kind.equals(IProgramElement.Kind.DECLARE_SOFT)
|| kind.equals(IProgramElement.Kind.DECLARE_PRECEDENCE)
|| kind.equals(IProgramElement.Kind.DECLARE_ANNOTATION_AT_CONSTRUCTOR)
|| kind.equals(IProgramElement.Kind.DECLARE_ANNOTATION_AT_FIELD)
@@ -118,8 +106,14 @@ public class HandleProviderDelimiter {
return DECLARE.getDelimiter();
} else if (kind.equals(IProgramElement.Kind.CODE)) {
return CODEELEMENT.getDelimiter();
}
} else if (kind == IProgramElement.Kind.FILE) {
if (ipe.getName().endsWith(".class")) {
return CLASSFILE.getDelimiter();
} else {
return empty;
}
}
return empty;
}
}

+ 4
- 0
asm/src/org/aspectj/asm/internal/JDTLikeHandleProvider.java Näytä tiedosto

@@ -86,7 +86,11 @@ public class JDTLikeHandleProvider implements IElementHandleProvider {
// format: 'new Runnable() {..}' but its anon-y-mouse
// dont append anything, there may be a count to follow though (!<n>)
} else {
// if (ipe.getKind() == IProgramElement.Kind.PACKAGE && ipe.getName().equals("DEFAULT")) {
// // the delimiter will be in there, but skip the word DEFAULT as it is just a placeholder
// } else {
handle.append(ipe.getName()).append(getParameters(ipe));
// }
}
}
// add the count, for example '!2' if its the second ipe of its

Loading…
Peruuta
Tallenna