From c3f3a995af26e148d4dd497ed0eff4ebb0787d83 Mon Sep 17 00:00:00 2001 From: aclement Date: Fri, 31 Mar 2006 14:38:58 +0000 Subject: test and fix for 134063 --- .../src/org/aspectj/tools/ajdoc/StructureUtil.java | 28 ++++++++++++++-------- 1 file changed, 18 insertions(+), 10 deletions(-) (limited to 'ajdoc/src') diff --git a/ajdoc/src/org/aspectj/tools/ajdoc/StructureUtil.java b/ajdoc/src/org/aspectj/tools/ajdoc/StructureUtil.java index df063f2bd..9ac03867f 100644 --- a/ajdoc/src/org/aspectj/tools/ajdoc/StructureUtil.java +++ b/ajdoc/src/org/aspectj/tools/ajdoc/StructureUtil.java @@ -44,7 +44,11 @@ public class StructureUtil { * @return null if a relationship of that kind is not found */ public static List /*String*/ getTargets(IProgramElement node, IRelationship.Kind kind, String relName) { - List relations = AsmManager.getDefault().getRelationshipMap().get(node); + List relations = new ArrayList(); + List rels = AsmManager.getDefault().getRelationshipMap().get(node); + if (rels != null) { + relations.addAll(rels); + } for (Iterator iter = node.getChildren().iterator(); iter.hasNext();) { IProgramElement child = (IProgramElement) iter.next(); // if we're not a type, or if we are and the child is code, then @@ -54,25 +58,29 @@ public class StructureUtil { || child.getKind().equals(IProgramElement.Kind.CODE) ) { List childRelations = AsmManager.getDefault().getRelationshipMap().get(child); if (childRelations != null) { - if (relations == null) { - relations = childRelations; - } else { - relations.addAll(childRelations); + for (Iterator iterator = childRelations.iterator(); iterator + .hasNext();) { + IRelationship rel = (IRelationship) iterator.next(); + if (!relations.contains(rel)) { + relations.add(rel); + } } } } } - List targets = null; if (relations == null || relations.isEmpty()) return null; + List targets = new ArrayList(); for (Iterator it = relations.iterator(); it.hasNext(); ) { IRelationship rtn = (IRelationship)it.next(); if (rtn.getKind().equals(kind) && ((relName != null && relName.equals(rtn.getName())) || relName == null)){ - if (targets == null) { - targets = rtn.getTargets(); - } else { - targets.addAll(rtn.getTargets()); + List targs = rtn.getTargets(); + for (Iterator iter = targs.iterator(); iter.hasNext();) { + String element = (String) iter.next(); + if (!targets.contains(element)) { + targets.add(element); + } } } } -- cgit v1.2.3