Загрузка класса в пользовательском теге JavaDoc?
Я пишу пользовательский тег JavaDoc и хочу загрузить и создать экземпляр класса, для которого обрабатывается JavaDoc. Вот код, который у меня есть (открытый класс CDKIOOptionsTaglet реализует Taglet):
public String toString(Tag tag) {
return "<DT><B>IO options: </B><DD>"
+ expand(tag) + "</DD>\n";
}
public String toString(Tag[] tags) {
if (tags.length == 0) {
return null;
} else {
return toString(tags[0]);
}
}
private String expand(Tag tag) {
// create a table with IOOptions
StringBuffer tableContent = new StringBuffer();
SourcePosition file = tag.position();
String pathAndFile = file.file().toString();
pathAndFile = pathAndFile.replaceAll("/", ".");
pathAndFile = pathAndFile.substring(pathAndFile.indexOf("src.main") + 9);
pathAndFile = pathAndFile.substring(0, pathAndFile.indexOf(".java"));
try {
Class ioClass = Class.forName(pathAndFile);
Object ioInstance = ioClass.newInstance();
if (ioInstance instanceof IChemObjectIO) {
IChemObjectIO objectIO = (IChemObjectIO)ioInstance;
tableContent.append("<table>");
for (IOSetting setting : objectIO.getIOSettings()) {
tableContent.append("<tr>");
tableContent.append("<td>" + setting.getName() + "</td>");
tableContent.append("<td></td>");
tableContent.append("</tr>");
}
tableContent.append("</table>");
}
} catch (Exception e) {
e.printStackTrace();
return "";
}
return tableContent.toString();
}
И это скрипт Ant, включающий jar-файлы, в которые загружаемый класс добавляется в путь к классам, используемый во время вызова:
<classpath>
<pathelement location="." />
<fileset dir="dist/jar">
<include name="*.jar" />
</fileset>
<javadoc ...>
</classpath>
Банки, где находятся классы, для которых я создаю JavaDoc, находятся в dist/jar. Для полноты (и по запросу) вот полный звонок:
<javadoc destdir="${javadoc.dir}"
author="true" version="true" use="true"
public="true"
windowtitle="CDK API - version ${TODAY_SVN}">
<classpath>
<pathelement location="." />
<fileset dir="dist/jar">
<include name="*.jar" />
</fileset>
<fileset dir="jar">
<include name="*.jar" />
</fileset>
<fileset dir="jar/jena">
<include name="*.jar" />
</fileset>
<dirset dir="src/main">
<include name="net/**/*"/>
</dirset>
</classpath>
<tag name="cdk.set" scope="all" description="Belongs to the set:" />
<tag name="cdk.keyword" scope="all" description="Keywords:" />
<tag name="cdk.created" scope="all" description="Created on:" />
<tag name="cdk.require" scope="all" description="Requires:" />
<tag name="cdk.depends" scope="all" description="Required library to be able to run this class:" />
<tag name="cdk.builddepends" scope="all" description="Required library to be able to compile this class:" />
<tag name="cdk.todo" scope="all" description="To do:" />
<tag name="cdk.license" scope="all" description="License:" />
<taglet name="net.sf.cdk.tools.doclets.CDKCiteTaglet" path="jar/xom-1.1.jar:src/main" />
<taglet name="net.sf.cdk.tools.doclets.CDKModuleTaglet" path="jar/xom-1.1.jar:src/main" />
<taglet name="net.sf.cdk.tools.doclets.CDKBugTaglet" path="jar/xom-1.1.jar:src/main" />
<taglet name="net.sf.cdk.tools.doclets.CDKDictRefTaglet" path="jar/xom-1.1.jar:src/main" />
<taglet name="net.sf.cdk.tools.doclets.CDKInChITaglet" path="jar/xom-1.1.jar:src/main" />
<taglet name="net.sf.cdk.tools.doclets.CDKThreadSafeTaglet" path="jar/xom-1.1.jar:src/main" />
<taglet name="net.sf.cdk.tools.doclets.CDKThreadNonSafeTaglet" path="jar/xom-1.1.jar:src/main" />
<taglet name="net.sf.cdk.tools.doclets.CDKGitTaglet" path="jar/xom-1.1.jar:src/main" />
<taglet name="net.sf.cdk.tools.doclets.CDKIOOptionsTaglet" path="jar/xom-1.1.jar:src/main" />
<packageset dir="${src}/main" defaultexcludes="yes">
<include name="org/openscience/cdk/**" />
</packageset>
<link href="${javaURL}"/>
</javadoc>
Я подтвердил с помощью "ant -v", что соответствующий jar-файл действительно содержит загружаемый класс. Тем не менее, я получаю эту трассировку стека:
[javadoc] java.lang.ClassNotFoundException: org.openscience.cdk.Atom
[javadoc] at java.net.URLClassLoader$1.run(URLClassLoader.java:217)
[javadoc] at java.security.AccessController.doPrivileged(Native Method)
[javadoc] at java.net.URLClassLoader.findClass(URLClassLoader.java:205)
[javadoc] at java.lang.ClassLoader.loadClass(ClassLoader.java:321)
[javadoc] at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:294)
[javadoc] at java.lang.ClassLoader.loadClass(ClassLoader.java:266)
[javadoc] at net.sf.cdk.tools.doclets.CDKIOOptionsTaglet.expand(CDKIOOptionsTaglet.java:104)
[javadoc] at net.sf.cdk.tools.doclets.CDKIOOptionsTaglet.toString(CDKIOOptionsTaglet.java:83)
[javadoc] at net.sf.cdk.tools.doclets.CDKIOOptionsTaglet.toString(CDKIOOptionsTaglet.java:91)
[javadoc] at com.sun.tools.doclets.internal.toolkit.taglets.LegacyTaglet.getTagletOutput(LegacyTaglet.java:130)
[javadoc] at com.sun.tools.doclets.internal.toolkit.taglets.TagletWriter.genTagOuput(TagletWriter.java:185)
[javadoc] at com.sun.tools.doclets.formats.html.HtmlDocletWriter.printTags(HtmlDocletWriter.java:230)
[javadoc] at com.sun.tools.doclets.formats.html.ClassWriterImpl.writeClassTagInfo(ClassWriterImpl.java:246)
[javadoc] at com.sun.tools.doclets.internal.toolkit.builders.ClassBuilder.buildClassTagInfo(ClassBuilder.java:287)
Как я могу получить Taglet для загрузки класса, для которого он создает JavaDoc, чтобы я мог использовать отражение (и т. Д.), Чтобы узнать больше об этом классе и вернуть его как часть вывода Taglet?
1 ответ
<classpath>
конфигурация не является подходящим местом для объявления классов, которые создаются. Поскольку тэглеты создают экземпляры ваших классов, вам нужно добавить эти классы в пути к тэглетам:
<taglet name="net.sf.cdk.tools.doclets.CDKCiteTaglet">
<path>
<pathelement location="." />
<fileset dir="dist/jar">
<include name="*.jar" />
</fileset>
</path>
</taglet>
В командной строке это должно выглядеть примерно так:
javadoc \
...
-taglet 'net.sf.cdk.tools.doclets.CDKCiteTaglet' \
-tagletpath '/.../jar/xom-1.1.jar:/.../jar/my-lib1.jar:/.../jar/my-lib2.jar:...' \
...