Maven 的 Scaladoc 选项
Scaladoc options with Maven
我正在为 Maven 寻求 scala-maven-plugin
方面的帮助。我想生成我的 Scaladoc,但我遇到了一些问题。
我实际上可以通过输入以下命令来创建我的 Scaladoc:
mvn scala:doc
现在的问题是我想在生成Scaladoc的时候添加一些选项,比如-no-link-warnings
.
有人知道怎么做吗?我找到了一种方法(下面的代码有效),但我认为这不是我应该做的。
我的 pom 文件是:
<build>
...
<plugins>
<plugin>
<!-- see http://davidb.github.com/scala-maven-plugin -->
<groupId>net.alchim31.maven</groupId>
<artifactId>scala-maven-plugin</artifactId>
<version>3.2.1</version>
<configuration>
<args>
<arg>-no-link-warnings</arg>
</args>
</configuration>
<executions>
<execution>
<id>Compile</id>
<goals>
<goal>compile</goal>
<goal>testCompile</goal>
</goals>
<configuration>
<args>
<arg>-dependencyfile</arg>
<arg>${project.build.directory}/.scala_dependencies</arg>
</args>
</configuration>
</execution>
</executions>
</plugin>
...
</plugins>
编辑
Tunaki 用户在第一个回复中提出了更好的方法,您可以在那里查看代码。
你的配置是完全正确的,虽然你可以写得有点不同。目前(忘记编译源代码的部分),你有:
<plugin>
<groupId>net.alchim31.maven</groupId>
<artifactId>scala-maven-plugin</artifactId>
<version>3.2.1</version>
<configuration>
<args>
<arg>-no-link-warnings</arg>
</args>
</configuration>
</plugin>
使用这样的配置,您声明 scala-maven-plugin
的每次执行都将具有附加参数 -no-link-warnings
。这是因为您在全局配置元素中声明它。你可以有一个特定于插件执行的配置,就像你在编译部分所拥有的一样:
<execution>
<id>Compile</id>
<goals>
<goal>compile</goal>
<goal>testCompile</goal>
</goals>
<configuration>
<args>
<arg>-dependencyfile</arg>
<arg>${project.build.directory}/.scala_dependencies</arg>
</args>
</configuration>
</execution>
只有在调用执行 Compile
时才会考虑此配置。
因此,最好将配置更改为特定于插件的执行,因为参数 -no-link-warnings
确实特定于生成 Scaladoc。
这将是最终的插件声明:
<plugin>
<groupId>net.alchim31.maven</groupId>
<artifactId>scala-maven-plugin</artifactId>
<version>3.2.1</version>
<executions>
<execution>
<id>Scaladoc</id>
<goals>
<goal>doc</goal>
</goals>
<phase>prepare-package</phase>
<configuration>
<args>
<arg>-no-link-warnings</arg>
</args>
</configuration>
</execution>
<execution>
<id>Compile</id>
<goals>
<goal>compile</goal>
<goal>testCompile</goal>
</goals>
<configuration>
<args>
<arg>-dependencyfile</arg>
<arg>${project.build.directory}/.scala_dependencies</arg>
</args>
</configuration>
</execution>
</executions>
</plugin>
然后,当您使用 mvn package
打包您的项目时,Scaladoc 将使用正确的参数自动生成。
我正在为 Maven 寻求 scala-maven-plugin
方面的帮助。我想生成我的 Scaladoc,但我遇到了一些问题。
我实际上可以通过输入以下命令来创建我的 Scaladoc:
mvn scala:doc
现在的问题是我想在生成Scaladoc的时候添加一些选项,比如-no-link-warnings
.
有人知道怎么做吗?我找到了一种方法(下面的代码有效),但我认为这不是我应该做的。
我的 pom 文件是:
<build>
...
<plugins>
<plugin>
<!-- see http://davidb.github.com/scala-maven-plugin -->
<groupId>net.alchim31.maven</groupId>
<artifactId>scala-maven-plugin</artifactId>
<version>3.2.1</version>
<configuration>
<args>
<arg>-no-link-warnings</arg>
</args>
</configuration>
<executions>
<execution>
<id>Compile</id>
<goals>
<goal>compile</goal>
<goal>testCompile</goal>
</goals>
<configuration>
<args>
<arg>-dependencyfile</arg>
<arg>${project.build.directory}/.scala_dependencies</arg>
</args>
</configuration>
</execution>
</executions>
</plugin>
...
</plugins>
编辑
Tunaki 用户在第一个回复中提出了更好的方法,您可以在那里查看代码。
你的配置是完全正确的,虽然你可以写得有点不同。目前(忘记编译源代码的部分),你有:
<plugin>
<groupId>net.alchim31.maven</groupId>
<artifactId>scala-maven-plugin</artifactId>
<version>3.2.1</version>
<configuration>
<args>
<arg>-no-link-warnings</arg>
</args>
</configuration>
</plugin>
使用这样的配置,您声明 scala-maven-plugin
的每次执行都将具有附加参数 -no-link-warnings
。这是因为您在全局配置元素中声明它。你可以有一个特定于插件执行的配置,就像你在编译部分所拥有的一样:
<execution>
<id>Compile</id>
<goals>
<goal>compile</goal>
<goal>testCompile</goal>
</goals>
<configuration>
<args>
<arg>-dependencyfile</arg>
<arg>${project.build.directory}/.scala_dependencies</arg>
</args>
</configuration>
</execution>
只有在调用执行 Compile
时才会考虑此配置。
因此,最好将配置更改为特定于插件的执行,因为参数 -no-link-warnings
确实特定于生成 Scaladoc。
这将是最终的插件声明:
<plugin>
<groupId>net.alchim31.maven</groupId>
<artifactId>scala-maven-plugin</artifactId>
<version>3.2.1</version>
<executions>
<execution>
<id>Scaladoc</id>
<goals>
<goal>doc</goal>
</goals>
<phase>prepare-package</phase>
<configuration>
<args>
<arg>-no-link-warnings</arg>
</args>
</configuration>
</execution>
<execution>
<id>Compile</id>
<goals>
<goal>compile</goal>
<goal>testCompile</goal>
</goals>
<configuration>
<args>
<arg>-dependencyfile</arg>
<arg>${project.build.directory}/.scala_dependencies</arg>
</args>
</configuration>
</execution>
</executions>
</plugin>
然后,当您使用 mvn package
打包您的项目时,Scaladoc 将使用正确的参数自动生成。