From dd1203a376d6b0dcc865735cf50288a83e710b05 Mon Sep 17 00:00:00 2001 From: aclement Date: Fri, 13 Jan 2006 17:07:57 +0000 Subject: more ajdoc changes - see pr121711 - from Helen. --- .../src/org/aspectj/tools/ajdoc/HtmlDecorator.java | 169 +++++++++++++++++---- .../src/org/aspectj/tools/ajdoc/StructureUtil.java | 49 +++++- 2 files changed, 183 insertions(+), 35 deletions(-) (limited to 'ajdoc/src') diff --git a/ajdoc/src/org/aspectj/tools/ajdoc/HtmlDecorator.java b/ajdoc/src/org/aspectj/tools/ajdoc/HtmlDecorator.java index db148e599..ba68dc299 100644 --- a/ajdoc/src/org/aspectj/tools/ajdoc/HtmlDecorator.java +++ b/ajdoc/src/org/aspectj/tools/ajdoc/HtmlDecorator.java @@ -15,6 +15,7 @@ package org.aspectj.tools.ajdoc; import java.io.BufferedReader; +import java.io.DataInputStream; import java.io.File; import java.io.FileOutputStream; import java.io.FileReader; @@ -29,6 +30,7 @@ import java.util.StringTokenizer; import org.aspectj.asm.AsmManager; import org.aspectj.asm.IProgramElement; import org.aspectj.asm.IRelationship; +import org.aspectj.util.TypeSafeEnum; /** * @author Mik Kersten @@ -226,7 +228,7 @@ class HtmlDecorator { int secondClassStartIndex = fileContents.toString().indexOf("class "); if (secondClassStartIndex != -1) { String name = decl.toSignatureString(); - int classEndIndex = fileContents.indexOf(name + "
"); + int classEndIndex = fileContents.indexOf(name + "
"); if (secondClassStartIndex != -1 && classEndIndex != -1) { StringBuffer sb = new StringBuffer(fileContents.toString(). substring(secondClassStartIndex,classEndIndex)); @@ -283,6 +285,21 @@ class HtmlDecorator { insertDeclarationsSummary(fileBuffer, advice, ADVICE_SUMMARY, index); insertDeclarationsDetails(fileBuffer, advice, ADVICE_DETAIL, index); } + // add the 'aspect declarations' information against the type + List parentsDeclaredOn = StructureUtil.getDeclareInterTypeTargets(node, IProgramElement.Kind.DECLARE_PARENTS); + if (parentsDeclaredOn != null && parentsDeclaredOn.size() > 0) { + decorateDocWithRel(node,fileBuffer,index,parentsDeclaredOn,HtmlRelationshipKind.ASPECT_DECLARATIONS); + } + // add the 'annotated by' information against the type + List annotatedBy = StructureUtil.getTargets(node,IRelationship.Kind.DECLARE_INTER_TYPE,"annotated by"); + if (annotatedBy != null && annotatedBy.size() > 0) { + decorateDocWithRel(node,fileBuffer,index,annotatedBy,HtmlRelationshipKind.ANNOTATED_BY); + } + // add the 'advised by' information against the type + List advisedBy = StructureUtil.getTargets(node, IRelationship.Kind.ADVICE); + if (advisedBy != null && advisedBy.size() > 0) { + decorateDocWithRel(node,fileBuffer,index,advisedBy,HtmlRelationshipKind.ADVISED_BY); + } } // static void addIntroductionDocumentation(IProgramElement decl, @@ -335,7 +352,7 @@ class HtmlDecorator { entry += comment + "

"; } entry += - generateAffects(decl, false) + "" + + generateAffects(decl) + "" + "\n"; } else if ( kind.equals( POINTCUT_SUMMARY ) ) { @@ -362,7 +379,7 @@ class HtmlDecorator { "" + "" + "" + decl.toLabelString() + "

" + - generateAffects(decl, true); + generateAffects(decl); } else if ( kind.equals( ITD_FIELD_SUMMARY ) || kind.equals( ITD_METHOD_SUMMARY)) { @@ -456,7 +473,7 @@ class HtmlDecorator { "" + generateSignatures(decl) + "\n" + "

" + generateDetailsComment(decl) + "

" + - generateAffects(decl, false); + generateAffects(decl); } else if (kind.equals(POINTCUT_DETAIL)) { entry += @@ -477,7 +494,7 @@ class HtmlDecorator { if (!decl.getKind().isDeclare()) { entry += generateSignatures(decl) + "

"; } - entry += generateAffects(decl, true) + + entry += generateAffects(decl) + generateDetailsComment(decl); } @@ -530,15 +547,18 @@ class HtmlDecorator { return index; } } - - static void decorateMemberDocumentation(IProgramElement node, - StringBuffer fileContentsBuffer, - int index ) { - List targets = StructureUtil.getTargets(node, IRelationship.Kind.ADVICE); + + static void decorateDocWithRel( + IProgramElement node, + StringBuffer fileContentsBuffer, + int index, + List targets, + HtmlRelationshipKind relKind) { if (targets != null && !targets.isEmpty()) { - String adviceDoc - = "" + - "
 Advised by:"; + String adviceDoc = "" + + "
" + + relKind.toString() + + ""; String relativePackagePath = getRelativePathFromHere( @@ -546,8 +566,16 @@ class HtmlDecorator { List addedNames = new ArrayList(); for (Iterator it = targets.iterator(); it.hasNext(); ) { - String currHandle = (String)it.next(); - IProgramElement currDecl = AsmManager.getDefault().getHierarchy().findElementForHandle(currHandle); + Object o = it.next(); + IProgramElement currDecl = null; + if (o instanceof String) { + String currHandle = (String)o; + currDecl = AsmManager.getDefault().getHierarchy().findElementForHandle(currHandle); + } else if (o instanceof IProgramElement){ + currDecl = (IProgramElement)o; + } else { + return; + } String packagePath = ""; if (currDecl.getPackageName() != null && !currDecl.getPackageName().equals("")) { @@ -565,12 +593,16 @@ class HtmlDecorator { hrefName = currDecl.getPackageName().replace('.', '/'); // hrefLink = "";//+ currDecl.getPackageName() + Config.DIR_SEP_CHAR; } + // use the currDecl.toLabelString rather than currDecl.getName() + // because two distinct advice blocks can have the same + // currDecl.getName() and wouldn't both appear in the ajdoc hrefName += Config.DIR_SEP_CHAR + - currDecl.getParent().toLinkLabelString() - + "." + currDecl.getName(); + currDecl.getParent().toLinkLabelString() + + "." + currDecl.toLabelString(); + // need to replace " with quot; otherwise the links wont work hrefLink += currDecl.getParent().toLinkLabelString() + ".html" - + "#" + currDecl.toLabelString(); + + "#" + currDecl.toLabelString().replaceAll("\"","quot;"); if (!addedNames.contains(hrefName)) { adviceDoc = adviceDoc + @@ -585,6 +617,22 @@ class HtmlDecorator { fileContentsBuffer.insert( index, adviceDoc ); } } + + static void decorateMemberDocumentation(IProgramElement node, + StringBuffer fileContentsBuffer, + int index ) { + List targets = StructureUtil.getTargets(node, IRelationship.Kind.ADVICE); + decorateDocWithRel(node,fileContentsBuffer,index,targets,HtmlRelationshipKind.ADVISED_BY); + + List warnings = StructureUtil.getTargets(node,IRelationship.Kind.DECLARE,"matches declare"); + decorateDocWithRel(node,fileContentsBuffer,index,warnings,HtmlRelationshipKind.MATCHES_DECLARE); + + List softenedBy = StructureUtil.getTargets(node,IRelationship.Kind.DECLARE,"softened by"); + decorateDocWithRel(node,fileContentsBuffer,index,softenedBy,HtmlRelationshipKind.SOFTENED_BY); + + List annotatedBy = StructureUtil.getTargets(node,IRelationship.Kind.DECLARE_INTER_TYPE,"annotated by"); + decorateDocWithRel(node,fileContentsBuffer,index,annotatedBy,HtmlRelationshipKind.ANNOTATED_BY); + } /** * pr119453 - adding "declared by" relationship @@ -626,20 +674,39 @@ class HtmlDecorator { /** * TODO: probably want to make this the same for intros and advice. */ - static String generateAffects(IProgramElement decl, boolean isIntroduction) { + static String generateAffects(IProgramElement decl) { List targets = null; - if (isIntroduction) { - targets = StructureUtil.getDeclareTargets(decl); - } else { - targets = StructureUtil.getTargets(decl, IRelationship.Kind.ADVICE); - } + if (decl.getKind().isDeclare() || decl.getKind().isInterTypeMember()) { + targets = StructureUtil.getDeclareTargets(decl); + } else { + targets = StructureUtil.getTargets(decl, IRelationship.Kind.ADVICE); + } if (targets == null) return ""; String entry = ""; - if (!isIntroduction) { - entry += "
 Advises:"; - } else { - entry += " Declared on:"; - } + + IProgramElement.Kind kind = decl.getKind(); + if (kind.equals(IProgramElement.Kind.ADVICE)) { + entry += "" + + HtmlRelationshipKind.ADVISES.toString() + + ""; + } else if (kind.equals(IProgramElement.Kind.DECLARE_WARNING) + || kind.equals(IProgramElement.Kind.DECLARE_ERROR)) { + entry += "" + + HtmlRelationshipKind.MATCHED_BY.toString() + + ""; + } else if (kind.isDeclareAnnotation()) { + entry += "" + + HtmlRelationshipKind.ANNOTATES.toString() + + ""; + } else if (kind.equals(IProgramElement.Kind.DECLARE_SOFT)) { + entry += "" + + HtmlRelationshipKind.SOFTENS.toString() + + ""; + } else { + entry += "" + + HtmlRelationshipKind.DECLARED_ON.toString() + + ""; + } String relativePackagePath = getRelativePathFromHere( @@ -867,4 +934,48 @@ class HtmlDecorator { } return formattedComment; } + + /** + * TypeSafeEnum for the entries which need to be put in the html doc + */ + public static class HtmlRelationshipKind extends TypeSafeEnum { + + public HtmlRelationshipKind(String name, int key) { + super(name, key); + + } + + public static HtmlRelationshipKind read(DataInputStream s) throws IOException { + int key = s.readByte(); + switch(key) { + case 1: return ADVISES; + case 2: return ADVISED_BY; + case 3: return MATCHED_BY; + case 4: return MATCHES_DECLARE; + case 5: return DECLARED_ON; + case 6: return ASPECT_DECLARATIONS; + case 7: return SOFTENS; + case 8: return SOFTENED_BY; + case 9: return ANNOTATES; + case 10: return ANNOTATED_BY; + case 11: return USES_POINTCUT; + case 12: return POINTCUT_USED_BY; + } + throw new Error("weird relationship kind " + key); + } + + public static final HtmlRelationshipKind ADVISES = new HtmlRelationshipKind(" Advises:", 1); + public static final HtmlRelationshipKind ADVISED_BY = new HtmlRelationshipKind(" Advised by:", 2); + public static final HtmlRelationshipKind MATCHED_BY = new HtmlRelationshipKind(" Matched by:", 3); + public static final HtmlRelationshipKind MATCHES_DECLARE = new HtmlRelationshipKind(" Matches declare:", 4); + public static final HtmlRelationshipKind DECLARED_ON = new HtmlRelationshipKind(" Declared on:", 5); + public static final HtmlRelationshipKind ASPECT_DECLARATIONS = new HtmlRelationshipKind(" Aspect declarations:", 6); + public static final HtmlRelationshipKind SOFTENS = new HtmlRelationshipKind(" Softens:", 7); + public static final HtmlRelationshipKind SOFTENED_BY = new HtmlRelationshipKind(" Softened by:", 8); + public static final HtmlRelationshipKind ANNOTATES = new HtmlRelationshipKind(" Annotates:", 9); + public static final HtmlRelationshipKind ANNOTATED_BY = new HtmlRelationshipKind(" Annotated by:", 10); + public static final HtmlRelationshipKind USES_POINTCUT = new HtmlRelationshipKind(" Uses pointcut:", 11); + public static final HtmlRelationshipKind POINTCUT_USED_BY = new HtmlRelationshipKind(" Pointcut used by:", 12); + + } } diff --git a/ajdoc/src/org/aspectj/tools/ajdoc/StructureUtil.java b/ajdoc/src/org/aspectj/tools/ajdoc/StructureUtil.java index 42568837b..df063f2bd 100644 --- a/ajdoc/src/org/aspectj/tools/ajdoc/StructureUtil.java +++ b/ajdoc/src/org/aspectj/tools/ajdoc/StructureUtil.java @@ -25,21 +25,58 @@ import org.aspectj.asm.IRelationship; */ public class StructureUtil { - /** + * Calculate the targets for a given IProgramElement (and it's + * immediate children if its not a type or if the child is + * CODE) and relationship kind + * * @return null if a relationship of that kind is not found */ public static List /*String*/ getTargets(IProgramElement node, IRelationship.Kind kind) { - List relations = AsmManager.getDefault().getRelationshipMap().get(node); + return getTargets(node,kind,null); + } + + /** + * Calculate the targets for a given IProgramElement (and it's immediate + * children if its not a type or if the child is CODE) and relationship + * kind with the specified relationship name. + * + * @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); + 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 + // we want to get the relationships for this child - this means that the + // correct relationships appear against the type in the ajdoc + if (!node.getKind().isType() + || 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); + } + } + } + } List targets = null; - if (relations == null) return null; + if (relations == null || relations.isEmpty()) return null; for (Iterator it = relations.iterator(); it.hasNext(); ) { IRelationship rtn = (IRelationship)it.next(); - if (rtn.getKind().equals(kind)) { - targets = rtn.getTargets(); + if (rtn.getKind().equals(kind) + && ((relName != null && relName.equals(rtn.getName())) + || relName == null)){ + if (targets == null) { + targets = rtn.getTargets(); + } else { + targets.addAll(rtn.getTargets()); + } } } - return targets; + return targets; } static List /*IProgramElement */ getDeclareInterTypeTargets(IProgramElement node, IProgramElement.Kind kind) { -- cgit v1.2.3