4

我正在scala-maven-plugin为 Maven 寻求帮助。我想生成我的 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 在第一次回复中建议了一种更好的方法,您可以在此处查看代码。

4

1 回答 1

7

你的配置是完全正确的,虽然你可以写得有点不同。目前(忘记关于编译源代码的部分),你有:

<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。

于 2016-01-09T14:23:10.043 回答