java – 如何在构建版本不是-SNAPSHOT时启用maven配置文件?

前端之家收集整理的这篇文章主要介绍了java – 如何在构建版本不是-SNAPSHOT时启用maven配置文件?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在尝试将 gitflow-helper-maven-plugin扩展用于我的maven构建.

因此,我想配置我的项目,以便在构建发布版本时运行一些额外的步骤,并在编译SNAPSHOT版本时跳过它们,但如果${project.version}包含-SNAPSHOT,我找不到启用配置文件方法.

有什么建议吗?

解决方法

下面是一个可能的方法,你可以总是模拟Maven构建中的if语句:

>使用buid-helper-maven-plugin及其regex-property目标来解析默认的${project.version}属性,并创建一个值为true或${的新${only.when.is.snapshot.used}属性.找到SNAPSHOT后缀的project.version}.
>使用其skipSource选项配置maven-source-plugin以使用特殊配置执行其jar目标,并向其传递新的(动态)${only.when.is.snapshot.used}属性:如果是快照,它将valuetruehence跳过执行,否则将有${project.version}值,它将被用作false,因此不会跳过此执行
>使用其skip选项为maven-javadoc-plugin配置与上述相同的内容

上述方法的一个示例是:

<plugin>
    <groupId>org.codehaus.mojo</groupId>
    <artifactId>build-helper-maven-plugin</artifactId>
    <version>1.10</version>
    <executions>
        <execution>
            <!-- sets the only.when.is.snapshot.used property to true if SNAPSHOT was used,to the project version otherwise -->
            <id>build-helper-regex-is-snapshot-used</id>
            <phase>validate</phase>
            <goals>
                <goal>regex-property</goal>
            </goals>
            <configuration>
                <name>only.when.is.snapshot.used</name>
                <value>${project.version}</value>
                <regex>.*-SNAPSHOT</regex>
                <replacement>true</replacement>
                <failIfNoMatch>false</failIfNoMatch>
            </configuration>
        </execution>
    </executions>
</plugin>

<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-source-plugin</artifactId>
    <version>3.0.1</version>
    <executions>
        <execution>
            <id>create-sources</id>
            <phase>package</phase>
            <goals>
                <goal>jar</goal>
            </goals>
            <configuration>
                <!-- skip when version is SNAPSHOT -->
                <skipSource>${only.when.is.snapshot.used}</skipSource>
            </configuration>
        </execution>
    </executions>
</plugin>
<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-javadoc-plugin</artifactId>
    <version>2.10.4</version>
    <executions>
        <execution>
            <id>create-javadoc</id>
            <phase>package</phase>
            <goals>
                <goal>jar</goal>
            </goals>
            <configuration>
                <!-- skip when version is SNAPSHOT -->
                <skip>${only.when.is.snapshot.used}</skip>
            </configuration>
        </execution>
    </executions>
</plugin>

也就是说,不需要配置文件,只有在将使用非SNAPSHOT版本时才会启用此配置,动态且无需任何进一步配置(命令行选项或任何其他).

作为一个提醒,您还可以查看maven-release-plugin,它将有效地调用源和javadoc插件,仅在performing发布时没有上述方法的附加(次要)复杂性.

否则,您可以简单地使用来自Maven Super POM的默认配置文件,该配置文件实际上会调用相同的源和javadoc插件,并且可以通过属性performRelease设置为值true来激活.也就是说,在任何Maven项目中,您可以调用以下内容

mvn clean package -DperformRelease=true

要么

mvn clean package -Prelease-profile

并且您将自动受益于默认超级配置文件生成源和javadoc jar,尽管此方法应该用作最后一个选项,因为在将来的版本中可以从超级pom中删除配置文件.

猜你在找的Java相关文章