You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

PointcutSubWriter.java 7.3KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227
  1. /* -*- Mode: JDE; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
  2. *
  3. * This file is part of the debugger and core tools for the AspectJ(tm)
  4. * programming language; see http://aspectj.org
  5. *
  6. * The contents of this file are subject to the Mozilla Public License
  7. * Version 1.1 (the "License"); you may not use this file except in
  8. * compliance with the License. You may obtain a copy of the License at
  9. * either http://www.mozilla.org/MPL/ or http://aspectj.org/MPL/.
  10. *
  11. * Software distributed under the License is distributed on an "AS IS" basis,
  12. * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
  13. * for the specific language governing rights and limitations under the
  14. * License.
  15. *
  16. * The Original Code is AspectJ.
  17. *
  18. * The Initial Developer of the Original Code is Xerox Corporation. Portions
  19. * created by Xerox Corporation are Copyright (C) 1999-2002 Xerox Corporation.
  20. * All Rights Reserved.
  21. */
  22. package org.aspectj.tools.doclets.standard;
  23. import org.aspectj.ajdoc.PointcutDoc;
  24. import com.sun.javadoc.ClassDoc;
  25. import com.sun.javadoc.MemberDoc;
  26. import com.sun.javadoc.ParamTag;
  27. import com.sun.javadoc.Parameter;
  28. import com.sun.javadoc.ProgramElementDoc;
  29. import com.sun.javadoc.SeeTag;
  30. import com.sun.javadoc.Tag;
  31. import com.sun.javadoc.Type;
  32. import com.sun.tools.doclets.Util;
  33. import java.util.List;
  34. public class PointcutSubWriter extends AbstractSubWriter {
  35. protected Class delegateClass() {
  36. return null;
  37. }
  38. public PointcutSubWriter
  39. (com.sun.tools.doclets.standard.SubWriterHolderWriter writer,
  40. ClassDoc classdoc)
  41. {
  42. super(writer, classdoc);
  43. }
  44. public PointcutSubWriter
  45. (com.sun.tools.doclets.standard.SubWriterHolderWriter writer)
  46. {
  47. super(writer);
  48. }
  49. protected final String keyName() { return "Pointcut"; }
  50. // public void printInheritedSummaryAnchor(ClassDoc cd) {
  51. // writer.anchor("pointcuts_inherited_from_class_" + cd.qualifiedName());
  52. // }
  53. // public void printInheritedSummaryLabel(ClassDoc cd) {
  54. // String classlink = writer.getPreQualifiedClassLink(cd);
  55. // writer.bold();
  56. // writer.printText("doclet.Pointcuts_Inherited_From",
  57. // Statics.type(cd),
  58. // classlink);
  59. // writer.boldEnd();
  60. // }
  61. void printSignature(MemberDoc member) {
  62. PointcutDoc pcd = (PointcutDoc)member;
  63. writer.displayLength = 0;
  64. writer.pre();
  65. printModifiers(pcd);
  66. bold(pcd.name());
  67. printParameters(pcd);
  68. printResultType(pcd);
  69. writer.preEnd();
  70. }
  71. void printResultType(PointcutDoc pcd) {
  72. Type result = pcd.resultType();
  73. if (result != null) {
  74. writer.code();
  75. print(" returns ");
  76. printTypeLink(result);
  77. writer.codeEnd();
  78. }
  79. }
  80. protected void printSummaryLink(ClassDoc cd, ProgramElementDoc member) {
  81. PointcutDoc pcd = (PointcutDoc)member;
  82. String name = member.name();
  83. writer.bold();
  84. writer.printClassLink(cd, name + pcd.signature(), name, false);
  85. writer.boldEnd();
  86. writer.displayLength = name.length();
  87. printParameters(pcd);
  88. printResultType(pcd);
  89. }
  90. protected void printInheritedSummaryLink(ClassDoc cd,
  91. ProgramElementDoc member) {
  92. PointcutDoc pcd = (PointcutDoc)member;
  93. String name = member.name();
  94. writer.printClassLink(cd, name + pcd.signature(), name, false);
  95. }
  96. protected void printSummaryType(ProgramElementDoc member) {
  97. PointcutDoc pcd = (PointcutDoc)member;
  98. writer.printTypeSummaryHeader();
  99. printModifier(pcd);
  100. writer.printTypeSummaryFooter();
  101. }
  102. protected void printBodyHtmlEnd(ClassDoc cd) {
  103. }
  104. protected void nonfinalPrintMember(ProgramElementDoc member) {
  105. PointcutDoc pcd = (PointcutDoc)member;
  106. writer.anchor(pcd.name() + pcd.signature());
  107. printHead(pcd);
  108. printSignature(pcd);
  109. printFullComment(pcd);
  110. }
  111. protected void printDeprecatedLink(ProgramElementDoc member) {
  112. writer.printClassLink(member.containingClass(),
  113. member.name(),
  114. ((PointcutDoc)member).qualifiedName());
  115. }
  116. protected List getMembers(ClassDoc cd) {
  117. return Util.asList(((org.aspectj.ajdoc.ClassDoc)cd).pointcuts());
  118. }
  119. protected void printParameters(PointcutDoc member) {
  120. print('(');
  121. Parameter[] params = member.parameters();
  122. for (int i = 0; i < params.length; i++) {
  123. printParam(params[i]);
  124. if (i < params.length-1) {
  125. writer.print(',');
  126. writer.print(' ');
  127. }
  128. }
  129. writer.print(')');
  130. }
  131. protected void printParam(Parameter param) {
  132. printTypedName(param.type(), param.name());
  133. }
  134. protected void printParamTags(ParamTag[] params) {
  135. if (params.length > 0) {
  136. writer.dt();
  137. writer.boldText("doclet.Parameters");
  138. for (int i = 0; i < params.length; ++i) {
  139. ParamTag pt = params[i];
  140. writer.dd();
  141. writer.code();
  142. print(pt.parameterName());
  143. writer.codeEnd();
  144. print(" - ");
  145. writer.printInlineComment(pt);
  146. }
  147. }
  148. }
  149. protected void printReturnTag(Tag[] returnsTag) {
  150. if (returnsTag.length > 0) {
  151. writer.dt();
  152. writer.boldText("doclet.Returns");
  153. writer.dd();
  154. writer.printInlineComment(returnsTag[0]);
  155. }
  156. }
  157. protected void printOverridden(ClassDoc overridden, PointcutDoc pcd) {
  158. if (overridden != null) {
  159. String name = pcd.name();
  160. writer.dt();
  161. writer.boldText("doclet.Overrides");
  162. writer.dd();
  163. writer.printText("doclet.in_class",
  164. writer.codeText
  165. (writer.getClassLink(overridden,
  166. name + pcd.signature(),
  167. name, false)),
  168. writer.codeText
  169. (writer.getClassLink(overridden)));
  170. }
  171. }
  172. protected void printTags(ProgramElementDoc member) {
  173. PointcutDoc pcd = (PointcutDoc)member;
  174. ParamTag[] params = pcd.paramTags();
  175. Tag[] returnsTag = pcd.tags("return");
  176. Tag[] sinces = pcd.tags("since");
  177. SeeTag[] sees = pcd.seeTags();
  178. ClassDoc[] intfacs = member.containingClass().interfaces();
  179. ClassDoc overridden = pcd.overriddenClass();
  180. if (intfacs.length > 0 || overridden != null) {
  181. writer.dd();
  182. writer.dl();
  183. printOverridden(overridden, pcd);
  184. writer.dlEnd();
  185. writer.ddEnd();
  186. }
  187. if (params.length +
  188. returnsTag.length +
  189. sinces.length +
  190. sees.length > 0) {
  191. writer.dd();
  192. writer.dl();
  193. printParamTags(params);
  194. printReturnTag(returnsTag);
  195. writer.printSinceTag(pcd);
  196. writer.printSeeTags(pcd);
  197. writer.dlEnd();
  198. writer.ddEnd();
  199. }
  200. }
  201. }