私は自分自身で解決策を見つけました。ちょっとしたハックですが、私にとってはうまくいきます。私は私の最初のアイデアで行くことを選びました:
含めたいアーティファクト(sources.jar)を取得し、それらを解凍して、javadocプラグインをソースディレクトリにポイントします。
このソリューションには4つの異なる部分があり、後で詳しく説明します。
- 含めたいすべてのアーティファクトにsources.jarsを生成します
- それらのsources.jarsを解凍します
- 解凍されたソースをjavadoc-pluginにポイントしてJavadocを生成します
- 生成されたapidocsをzipファイルにパッケージ化します
今より詳細に:
1.含めたいすべてのアーティファクトにsources.jarsを生成します
sources.jarを生成するには、次のようにmaven-sources-pluginを使用する必要があります。
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-source-plugin</artifactId>
<version>2.1.2</version>
<executions>
<execution>
<id>bundle-sources</id>
<phase>package</phase>
<goals>
<goal>jar</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
apidocsに含めるすべてのプロジェクト/モジュール/アーティファクトでこれを行う必要があります。
2.それらのsources.jarsを解凍します
javadocsを生成するために使用するpom.xmlで、sources.jarファイルを解凍するために次のプラグインを追加する必要があります。
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-dependency-plugin</artifactId>
<executions>
<execution>
<id>unpack-artifact-sources</id>
<phase>generate-resources</phase>
<goals>
<goal>unpack</goal>
</goals>
<configuration>
<artifactItems>
<artifactItem>
<groupId>${project.groupId}</groupId>
<artifactId><!-- your artifact here --></artifactId>
<version>${project.version}</version>
<classifier>sources</classifier>
<overWrite>true</overWrite>
</artifactItem>
</artifactItems>
<outputDirectory>${project.build.directory}/unpack_sources</outputDirectory>
</configuration>
</execution>
<!-- add more unpack-executions here -->
</executions>
</plugin>
unpack-execution-blockはいくつでも追加できます。
3. javadoc-pluginを解凍されたソースにポイントして、Javadocを生成します
今トリッキーな部分。javadoc-pluginにソースファイルを探す場所を知らせます。インポートされた定義が<sourcepath>
定義です。このセクションでは、ステップ2でソースを解凍したフォルダーを定義します。
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-javadoc-plugin</artifactId>
<version>2.7</version>
<configuration>
<sourcepath>${project.build.directory}/unpack_sources</sourcepath>
</configuration>
<executions>
<execution>
<goals>
<goal>javadoc</goal>
</goals>
<phase>process-resources</phase>
</execution>
</executions>
</plugin>
mvn clean install
この時点で電話をかけると、site
フォルダ内にtarget
フォルダができあがります。このサイトフォルダには、apidocsがあります。しかし、このビルドをすべて光沢のあるものにするために、apidocsをzipアーカイブにアセンブルしたいと思います。
4.生成されたapidocsをzipファイルにパッケージ化します
ドキュメントをアセンブルするには、maven-assembly-plugin
と追加のアセンブリファイルを使用する必要があります。まず、pom内のプラグイン定義:
<plugin>
<artifactId>maven-assembly-plugin</artifactId>
<executions>
<execution>
<id>docs-assembly</id>
<phase>package</phase>
<configuration>
<appendAssemblyId>false</appendAssemblyId>
<descriptors>
<descriptor>src/main/assembly/assemble.xml</descriptor>
</descriptors>
</configuration>
<goals>
<goal>single</goal>
</goals>
</execution>
</executions>
</plugin>
assemble.xml:
<?xml version="1.0" encoding="UTF-8"?>
<assembly>
<id>${project.build.finalName}</id>
<formats>
<format>zip</format>
</formats>
<includeBaseDirectory>false</includeBaseDirectory>
<fileSets>
<fileSet>
<directory>target/site/apidocs</directory>
<outputDirectory>/</outputDirectory>
</fileSet>
</fileSets>
</assembly>