微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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中删除配置文件.

原文地址:https://www.jb51.cc/java/126846.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐