1

JavaDoc Ant タスクに問題があります。java.lang.NoClassDefFoundError私が知る限り、間違いなくクラスパス上にあるクラスを私に与えています。ドキュメントによると、コンパイル中にクラスが存在するときに aNoClassDefFoundErrorがスローされますが、実行時に見つかりません。(ANoClassDefFoundErrorは ではありませClassNotFoundException。)

クラスパス項目を削除すると、期待どおりに失敗し (多くのパッケージ/シンボルが見つからないエラー)、それでも同じNoClassDefFoundError. クラスがクラスパス上にあるかどうかに関係なく、タグレットでこれが失敗するのはなぜですか?


詳細:

見つからないクラスは と呼ばれcom.github.xbn.io.SimpleDebugable、次の jar ファイルにあります。

  • jar ファイル:C:\data_jeffy\programming\sandbox\z__for_git_commit_only\codelet\z_build\jar_dependencies\xbnjava-0.1.4.2-all.jar

スクリーンショット

JavaDoc Ant タスク。上記の jar ファイルは、クラスパスの最初の項目です。

<target name="doca" description="Generates javadoc documentation.">
   <property name="jar_base_dir" value="C:\data_jeffy\programming\sandbox\z__for_git_commit_only\codelet\z_build\jar_dependencies\"/>
   <property name="taglet_jar" value="C:\data_jeffy\programming\build\codelet-0.1.4.1\download\codelet-0.1.4.1-all.jar"/>

   <javadoc
      packagenames="com.github.aliteralmind.codelet,com.github.aliteralmind.codelet.alter,com.github.aliteralmind.codelet.simplesig,com.github.aliteralmind.codelet.taglet,com.github.aliteralmind.codelet.type,com.github.aliteralmind.codelet.util"
      defaultexcludes="yes"
      destdir="C:\data_jeffy\programming\build\codelet-0.1.4.1\documentation\javadoc"
      splitindex="true"
      additionalparam="-J-Dcodelet_config_dir=C:\data_jeffy\programming\sandbox\z__for_git_commit_only\codelet\codelet_config\"
      classpath="${jar_base_dir}xbnjava-0.1.4.2-all.jar;
      C:\data_jeffy\programming\build\codelet-0.1.4.1\download\codelet-0.1.4.1-all.jar;
      ${jar_base_dir}templatefeather-0.1.1.2-all.jar;
      ${jar_base_dir}commons-io-2.4.jar;
      ${jar_base_dir}guava-16.0.1.jar;
      ${jar_base_dir}jdk_751__tools__contains_com_sun.jar"
   >
      <sourcepath>
          <pathelement path="C:\data_jeffy\programming\sandbox\z__for_git_commit_only\codelet\src"/>
      </sourcepath>
      <!-- Custom taglets-->
         <taglet name="com.github.aliteralmind.codelet.taglet.CodeletTaglet"
            path="${taglet_jar}"/>
         <taglet name="com.github.aliteralmind.codelet.taglet.CodeletDotOutTaglet"
            path="${taglet_jar}"/>
         <taglet name="com.github.aliteralmind.codelet.taglet.CodeletAndOutTaglet"
            path="${taglet_jar}"/>
         <taglet name="com.github.aliteralmind.codelet.taglet.FileTextletTaglet"
            path="${taglet_jar}"/>
   </javadoc>
</target>

その結果、次のようになります。

[javadoc] javadoc: error - In doclet class com.sun.tools.doclets.standard.Standard,
method start has thrown an exception java.lang.reflect.InvocationTargetException
[javadoc] java.lang.NoClassDefFoundError: com/github/xbn/io/SimpleDebuggable

完全な出力:

[C:\data_jeffy\programming\sandbox\z__for_git_commit_only\codelet]ant docx
Buildfile: C:\data_jeffy\programming\sandbox\z__for_git_commit_only\codelet\build.xml

docx:
  [javadoc] Generating Javadoc
  [javadoc] Javadoc execution
  [javadoc] Loading source files for package com.github.aliteralmind.codelet...
  [javadoc] Loading source files for package com.github.aliteralmind.codelet.alter...
  [javadoc] Loading source files for package com.github.aliteralmind.codelet.simplesig...
  [javadoc] Loading source files for package com.github.aliteralmind.codelet.taglet...
  [javadoc] Loading source files for package com.github.aliteralmind.codelet.type...
  [javadoc] Loading source files for package com.github.aliteralmind.codelet.util...
  [javadoc] Constructing Javadoc information...
  [javadoc] 1 error
  [javadoc] javadoc: error - In doclet class com.sun.tools.doclets.standard.Standard, method start has thrown an exception java.lang.reflect.InvocationTargetException
  [javadoc] java.lang.NoClassDefFoundError: com/github/xbn/io/SimpleDebuggable
  [javadoc]     at java.lang.ClassLoader.defineClass1(Native Method)
  [javadoc]     at java.lang.ClassLoader.defineClass(ClassLoader.java:800)
  [javadoc]     at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
  [javadoc]     at java.net.URLClassLoader.defineClass(URLClassLoader.java:449)
  [javadoc]     at java.net.URLClassLoader.access$100(URLClassLoader.java:71)
  [javadoc]     at java.net.URLClassLoader$1.run(URLClassLoader.java:361)
  [javadoc]     at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
  [javadoc]     at java.security.AccessController.doPrivileged(Native Method)
  [javadoc]     at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
  [javadoc]     at java.lang.ClassLoader.loadClass(ClassLoader.java:425)
  [javadoc]     at java.lang.ClassLoader.loadClass(ClassLoader.java:358)
  [javadoc]     at com.github.aliteralmind.codelet.CodeletBootstrap.wasLoaded(Unknown Source)
  [javadoc]     at com.github.aliteralmind.codelet.CodeletBootstrap.loadConfiguration(Unknown Source)
  [javadoc]     at com.github.aliteralmind.codelet.CodeletBootstrap.<clinit>(Unknown Source)
  [javadoc]     at com.github.aliteralmind.codelet.taglet.CodeletTaglet.<clinit>(Unknown Source)
  [javadoc]     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
  [javadoc]     at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
  [javadoc]     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
  [javadoc]     at java.lang.reflect.Method.invoke(Method.java:606)
  [javadoc]     at com.sun.tools.doclets.internal.toolkit.taglets.TagletManager.addCustomTag(TagletManager.java:219)
  [javadoc]     at com.sun.tools.doclets.internal.toolkit.Configuration.initTagletManager(Configuration.java:466)
  [javadoc]     at com.sun.tools.doclets.internal.toolkit.Configuration.setOptions(Configuration.java:437)
  [javadoc]     at com.sun.tools.doclets.internal.toolkit.Configuration.setOptions(Configuration.java:447)
  [javadoc]     at com.sun.tools.doclets.internal.toolkit.AbstractDoclet.startGeneration(AbstractDoclet.java:120)
  [javadoc]     at com.sun.tools.doclets.internal.toolkit.AbstractDoclet.start(AbstractDoclet.java:83)
  [javadoc]     at com.sun.tools.doclets.formats.html.HtmlDoclet.start(HtmlDoclet.java:63)
  [javadoc]     at com.sun.tools.doclets.standard.Standard.start(Standard.java:39)
  [javadoc]     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
  [javadoc]     at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
  [javadoc]     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
  [javadoc]     at java.lang.reflect.Method.invoke(Method.java:606)
  [javadoc]     at com.sun.tools.javadoc.DocletInvoker.invoke(DocletInvoker.java:280)
  [javadoc]     at com.sun.tools.javadoc.DocletInvoker.start(DocletInvoker.java:160)
  [javadoc]     at com.sun.tools.javadoc.Start.parseAndExecute(Start.java:397)
  [javadoc]     at com.sun.tools.javadoc.Start.begin(Start.java:167)
  [javadoc]     at com.sun.tools.javadoc.Main.execute(Main.java:59)
  [javadoc]     at com.sun.tools.javadoc.Main.main(Main.java:49)
  [javadoc] Caused by: java.lang.ClassNotFoundException: com.github.xbn.io.SimpleDebuggable
  [javadoc]     at java.net.URLClassLoader$1.run(URLClassLoader.java:366)
  [javadoc]     at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
  [javadoc]     at java.security.AccessController.doPrivileged(Native Method)
  [javadoc]     at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
  [javadoc]     at java.lang.ClassLoader.loadClass(ClassLoader.java:425)
  [javadoc]     at java.lang.ClassLoader.loadClass(ClassLoader.java:358)
  [javadoc]     ... 37 more

BUILD SUCCESSFUL
Total time: 1 second

クラスパスからjarファイルを完全に削除すると、期待どおりに失敗し、数百package com.github.xbn.... does not existsymbol not foundエラーが発生します。これは、クラスパス要素が明らかに「機能している」ことを意味します。では、なぜタグレットで機能しないのでしょうか?

クラスパスにないjarの出力:

[C:\data_jeffy\programming\sandbox\z__for_git_commit_only\codelet]ant docx
Buildfile: C:\data_jeffy\programming\sandbox\z__for_git_commit_only\codelet\build.xml

docx:
  [javadoc] Generating Javadoc
  [javadoc] Javadoc execution
  [javadoc] Loading source files for package com.github.aliteralmind.codelet...
  [javadoc] Loading source files for package com.github.aliteralmind.codelet.alter...
  [javadoc] Loading source files for package com.github.aliteralmind.codelet.simplesig...
  [javadoc] Loading source files for package com.github.aliteralmind.codelet.taglet...
  [javadoc] Loading source files for package com.github.aliteralmind.codelet.type...
  [javadoc] Loading source files for package com.github.aliteralmind.codelet.util...
  [javadoc] Constructing Javadoc information...
  [javadoc] C:\data_jeffy\programming\sandbox\z__for_git_commit_only\codelet\src\com\github\aliteralmind\codelet\BasicCustomizers.java:18: error: package com.github.xbn.linefilter.alter does not exist

  [javadoc]     import  com.github.xbn.linefilter.alter.TextLineAlterer;
  [javadoc]                                            ^
  [javadoc] C:\data_jeffy\programming\sandbox\z__for_git_commit_only\codelet\src\com\github\aliteralmind\codelet\BasicCustomizers.java:19: error: package com.github.xbn.linefilter does not exist
  [javadoc]     import  com.github.xbn.linefilter.FilteredLineIterator;
  [javadoc]                                      ^
  [javadoc] C:\data_jeffy\programming\sandbox\z__for_git_commit_only\codelet\src\com\github\aliteralmind\codelet\BasicCustomizers.java:20: error: package com.github.xbn.analyze.alter does not exist
  [javadoc]     import  com.github.xbn.analyze.alter.ExpirableElements;
  [javadoc]                                         ^
  [javadoc] C:\data_jeffy\programming\sandbox\z__for_git_commit_only\codelet\src\com\github\aliteralmind\codelet\BasicCustomizers.java:21: error: package com.github.xbn.analyze.alter does not exist
  [javadoc]     import  com.github.xbn.analyze.alter.MultiAlterType;
  [javadoc]                                         ^
  [javadoc] C:\data_jeffy\programming\sandbox\z__for_git_commit_only\codelet\src\com\github\aliteralmind\codelet\BasicCustomizers.java:22: error: package com.github.xbn.array does not exist
  [javadoc]     import  com.github.xbn.array.NullElement;
  [javadoc]                                 ^
  [javadoc] C:\data_jeffy\programming\sandbox\z__for_git_commit_only\codelet\src\com\github\aliteralmind\codelet\BasicCustomizers.java:23: error: package com.github.xbn.lang does not exist
  [javadoc]     import  com.github.xbn.lang.IllegalArgumentStateException;
  [javadoc]                                ^

続き (~1,500 行削除):

  [javadoc]     import  com.github.xbn.linefilter.FilteredLineIterator;
  [javadoc]                                      ^
  [javadoc] C:\data_jeffy\programming\sandbox\z__for_git_commit_only\codelet\src\com\github\aliteralmind\codelet\util\zCodeletCustomizers.java:25: error: package com.github.xbn.analyze.alter does notexist
  [javadoc]     import  com.github.xbn.analyze.alter.ExpirableElements;
  [javadoc]                                         ^
  [javadoc] C:\data_jeffy\programming\sandbox\z__for_git_commit_only\codelet\src\com\github\aliteralmind\codelet\util\zCodeletCustomizers.java:26: error: package com.github.xbn.analyze.alter does notexist
  [javadoc]     import  com.github.xbn.analyze.alter.MultiAlterType;
  [javadoc]                                         ^
  [javadoc] C:\data_jeffy\programming\sandbox\z__for_git_commit_only\codelet\src\com\github\aliteralmind\codelet\util\zCodeletCustomizers.java:27: error: package com.github.xbn.array does not exist
  [javadoc] 1 error
  [javadoc]     import  com.github.xbn.array.NullElement;
  [javadoc] 371 warnings
  [javadoc]                                 ^

続き: ここでは最後に、jarがクラスパスにあったときと同じエラーが発生します。

  [javadoc] javadoc: error - In doclet class com.sun.tools.doclets.standard.Standard,
  method start has thrown an exception java.lang.reflect.InvocationTargetException
  [javadoc] java.lang.NoClassDefFoundError: com/github/xbn/io/SimpleDebuggable
  [javadoc]     at java.lang.ClassLoader.defineClass1(Native Method)
  [javadoc]     at java.lang.ClassLoader.defineClass(ClassLoader.java:800)
  [javadoc]     at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
  [javadoc]     at java.net.URLClassLoader.defineClass(URLClassLoader.java:449)
  [javadoc]     at java.net.URLClassLoader.access$100(URLClassLoader.java:71)
  [javadoc]     at java.net.URLClassLoader$1.run(URLClassLoader.java:361)
  [javadoc]     at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
  [javadoc]     at java.security.AccessController.doPrivileged(Native Method)
  [javadoc]     at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
  [javadoc]     at java.lang.ClassLoader.loadClass(ClassLoader.java:425)
  [javadoc]     at java.lang.ClassLoader.loadClass(ClassLoader.java:358)
  [javadoc]     at com.github.aliteralmind.codelet.CodeletBootstrap.wasLoaded(Unknown Source)
  [javadoc]     at com.github.aliteralmind.codelet.CodeletBootstrap.loadConfiguration(Unknown Source)
  [javadoc]     at com.github.aliteralmind.codelet.CodeletBootstrap.<clinit>(Unknown Source)
  [javadoc]     at com.github.aliteralmind.codelet.taglet.CodeletTaglet.<clinit>(Unknown Source)
  [javadoc]     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
  [javadoc]     at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
  [javadoc]     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
  [javadoc]     at java.lang.reflect.Method.invoke(Method.java:606)
  [javadoc]     at com.sun.tools.doclets.internal.toolkit.taglets.TagletManager.addCustomTag(TagletManager.java:219)
  [javadoc]     at com.sun.tools.doclets.internal.toolkit.Configuration.initTagletManager(Configuration.java:466)
  [javadoc]     at com.sun.tools.doclets.internal.toolkit.Configuration.setOptions(Configuration.java:437)
  [javadoc]     at com.sun.tools.doclets.internal.toolkit.Configuration.setOptions(Configuration.java:447)
  [javadoc]     at com.sun.tools.doclets.internal.toolkit.AbstractDoclet.startGeneration(AbstractDoclet.java:120)
  [javadoc]     at com.sun.tools.doclets.internal.toolkit.AbstractDoclet.start(AbstractDoclet.java:83)
  [javadoc]     at com.sun.tools.doclets.formats.html.HtmlDoclet.start(HtmlDoclet.java:63)
  [javadoc]     at com.sun.tools.doclets.standard.Standard.start(Standard.java:39)
  [javadoc]     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
  [javadoc]     at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
  [javadoc]     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
  [javadoc]     at java.lang.reflect.Method.invoke(Method.java:606)
  [javadoc]     at com.sun.tools.javadoc.DocletInvoker.invoke(DocletInvoker.java:280)
  [javadoc]     at com.sun.tools.javadoc.DocletInvoker.start(DocletInvoker.java:160)
  [javadoc]     at com.sun.tools.javadoc.Start.parseAndExecute(Start.java:397)
  [javadoc]     at com.sun.tools.javadoc.Start.begin(Start.java:167)
  [javadoc]     at com.sun.tools.javadoc.Main.execute(Main.java:59)
  [javadoc]     at com.sun.tools.javadoc.Main.main(Main.java:49)
  [javadoc] Caused by: java.lang.ClassNotFoundException: com.github.xbn.io.SimpleDebuggable
  [javadoc]     at java.net.URLClassLoader$1.run(URLClassLoader.java:366)
  [javadoc]     at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
  [javadoc]     at java.security.AccessController.doPrivileged(Native Method)
  [javadoc]     at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
  [javadoc]     at java.lang.ClassLoader.loadClass(ClassLoader.java:425)
  [javadoc]     at java.lang.ClassLoader.loadClass(ClassLoader.java:358)
  [javadoc]     ... 37 more

BUILD SUCCESSFUL
Total time: 1 second

元の (上記の) ターゲットでは、タグレットのパスは jar ファイルを指しています。以下では、タグレット クラス ファイルを jar からディレクトリに抽出し (これら 4 つのタグレット クラスのみが抽出され、それ以外はすべて jar に残ります)、タグレット パスをルート ディレクトリに変更しました。

<property name="jar_base_dir" value="C:\data_jeffy\programming\sandbox\z__for_git_commit_only\codelet\z_build\jar_dependencies\"/>
<property name="taglet_base_dir" value="C:\data_jeffy\programming\sandbox\z__for_git_commit_only\codelet\bin\com\github\aliteralmind\codelet\taglet"/>
  <javadoc
  packagenames="com.github.aliteralmind.codelet,com.github.aliteralmind.codelet.alter,com.github.aliteralmind.codelet.simplesig,com.github.aliteralmind.codelet.taglet,com.github.aliteralmind.codelet.type,com.github.aliteralmind.codelet.util"
  defaultexcludes="yes"
  destdir="C:\data_jeffy\programming\build\codelet-0.1.4.1\documentation\javadoc"
  splitindex="true"
  additionalparam="-J-Dcodelet_config_dir=${dir_sandbox}${codelet.config.dir}${fs}"
  classpath="${jar_base_dir}xbnjava-0.1.4.2-all.jar;
  C:\data_jeffy\programming\build\codelet-0.1.4.1\download\codelet-0.1.4.1-all.jar;
  ${jar_base_dir}templatefeather-0.1.1.2-all.jar;
  ${jar_base_dir}commons-io-2.4.jar;
  ${jar_base_dir}guava-16.0.1.jar;
  ${jar_base_dir}jdk_751__tools__contains_com_sun.jar"
>
  <sourcepath>
    <pathelement path="C:\data_jeffy\programming\sandbox\z__for_git_commit_only\codelet\src"/>
  </sourcepath>
  <!-- Custom taglets-->
    <taglet name="com.github.aliteralmind.codelet.taglet.CodeletTaglet"
      path="${taglet_base_dir}"/>
    <taglet name="com.github.aliteralmind.codelet.taglet.CodeletDotOutTaglet"
      path="${taglet_base_dir}"/>
    <taglet name="com.github.aliteralmind.codelet.taglet.CodeletAndOutTaglet"
      path="${taglet_base_dir}"/>
    <taglet name="com.github.aliteralmind.codelet.taglet.FileTextletTaglet"
      path="${taglet_base_dir}"/>
</javadoc>

そして今、それNoClassDefFoundErrorは起こりません。代わりに

javadoc: error - Error - Exception java.lang.ClassNotFoundException
thrown while trying to register Taglet com.github.aliteralmind.codelet.taglet.CodeletTaglet...

問題は、このエラーが JavaDoc によって「飲み込まれている」ように見えることです。その痕跡はどう見てもわからないjava.lang.ClassNotFoundException

完全な出力:

docb:
  [javadoc] Generating Javadoc
  [javadoc] Javadoc execution
  [javadoc] Loading source files for package com.github.aliteralmind.codelet...
  [javadoc] Loading source files for package com.github.aliteralmind.codelet.alter...
  [javadoc] Loading source files for package com.github.aliteralmind.codelet.simplesig...
  [javadoc] Loading source files for package com.github.aliteralmind.codelet.taglet...
  [javadoc] Loading source files for package com.github.aliteralmind.codelet.type...
  [javadoc] Loading source files for package com.github.aliteralmind.codelet.util...
  [javadoc] Constructing Javadoc information...
  [javadoc] javadoc: error - Error - Exception java.lang.ClassNotFoundException
  thrown while trying to register Taglet com.github.aliteralmind.codelet.taglet.CodeletTaglet...
  [javadoc] javadoc: error - Error - Exception java.lang.ClassNotFoundException
  thrown while trying to register Taglet com.github.aliteralmind.codelet.taglet.CodeletDotOutTaglet...
  [javadoc] javadoc: error - Error - Exception java.lang.ClassNotFoundException
  thrown while trying to register Taglet com.github.aliteralmind.codelet.taglet.CodeletAndOutTaglet...
  [javadoc] Standard Doclet version 1.7.0_72
  [javadoc] javadoc: error - Error - Exception java.lang.ClassNotFoundException thrown while trying to register Taglet com.github.aliteralmind.codelet.taglet.FileTextletTaglet...
  [javadoc] Building tree for all the packages and classes...
  [javadoc] C:\data_jeffy\programming\sandbox\z__for_git_commit_only\codelet\src\com\github\aliteralmind\codelet\BasicCustomizers.java:90:
  warning - @.codelet is an unknown tag.

  ...lots of lines deleted...

  [javadoc] C:\data_jeffy\programming\sandbox\z__for_git_commit_only\codelet\src\com\github\aliteralmind\codelet\util\JavaDocUtil.java:185:
  warning - @.codelet.and.out is an unknown tag.
  [javadoc] C:\data_jeffy\programming\sandbox\z__for_git_commit_only\codelet\src\com\github\aliteralmind\codelet\util\JavaDocUtil.java:185:
  warning - @.codelet.and.out is an unknown tag.
  [javadoc] Building index for all the packages and classes...
  [javadoc] Building index for all classes...
  [javadoc] Generating C:\data_jeffy\programming\build\codelet-0.1.4.1\documentation\javadoc\help-doc.html...
  [javadoc] 4 errors
  [javadoc] 57 warnings

BUILD SUCCESSFUL
Total time: 2 seconds

また、詳細な出力: http://dpaste.com/3T0B40X

4

1 に答える 1