gitflow-helper-maven-plugin
扩展用于我的maven构建.
因此,我想配置我的项目,以便在构建发布版本时运行一些额外的步骤,并在编译SNAPSHOT版本时跳过它们,但如果${project.version}包含-SNAPSHOT,我找不到启用配置文件的方法.
有什么建议吗?
解决方法
>使用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中删除配置文件.