Spring 项目里内建 Gradle 插件-ApiHug准备-工具篇-008

本文介绍了如何使用ApiHug工具链,特别是如何利用Gradle的buildSrc功能,避免频繁发布插件版本,同时详细讲解了SpringBoot内置的optionalDependencies插件及其在项目配置中的作用。

  🤗 ApiHug × {Postman|Swagger|Api...} = 快↑ 准√ 省↓

  1. GitHub - apihug/apihug.com: All abou the Apihug   
  2. apihug.com: 有爱,有温度,有质量,有信任
  3. ApiHug - API design Copilot - IntelliJ IDEs Plugin | Marketplace

ApiHug 整个工具链基于 Gradle, 使用 ApiHug 准备工作最先需要学习的就是 gradle. 工欲善其事,必先利其器

ApiHug 核心工具栏  wire + stub 也是 利用 gradle 插件, 给大家提供丝绸般丝滑体验。 

概要

pugin文档源码备注
org.springframework.boot2.7.0DOCopen in new window源码open in new window
io.spring.dependency-management1.0.11.REALEASEDOCopen in new window源码open in new window

Spring 有上面两个在公共库的插件, 一个Gradle插件的开发、发布是个比较冗长的过程,那如果我们在插件的代码编写阶段,总不能修改一点点代码,就发布一个版本,然后重新运用吧?

有人可能会说,那就不发布到maven仓库,而是发布到本地仓库呗,然而这样至多发布时节省一点点时间,仍然太麻烦。

内置

幸好有 buildSrc! 在buildSrc中定义的插件,可以直接在其他module中运用,可以参考spring, spring-boot 中的buildSrcopen in new window逻辑,所有在项目中使用的 org.springframework.boot* 开头插件都是以这样方式提供的。


gradlePlugin {
	plugins {
		bomPlugin {
			id = "org.springframework.boot.bom"
			implementationClass = "org.springframework.boot.build.bom.BomPlugin"
		}
}

独立

引用和使用任何第三方插件一样:


plugins {
	id "org.springframework.boot.bom"
	id "org.springframework.boot.conventions"
	id "org.springframework.boot.deployed"
}

即直接apply具体的类,而不是其发布名称,这样的话,不管做什么修改,都能马上体现,而不需要等到重新发布版本。

spring boot 大概提供了10几个代码里面内带的 plugin spring 只扩展了三个: org.springframework.build.api-difforg.springframework.build.compileorg.springframework.build.optional-dependencies

分析个 org.springframework.build.optional.OptionalDependenciesPlugin

spring-boot > OptionalDependenciesPluginopen in new window

spring-framework > OptionalDependenciesPluginopen in new window

两个实现的方式基本一样的 optional


public class OptionalDependenciesPlugin implements Plugin<Project> {

	/**
	 * Name of the {@code optional} configuration.
	 */
	public static final String OPTIONAL_CONFIGURATION_NAME = "optional";

	@Override
	public void apply(Project project) {
		Configuration optional = project.getConfigurations().create("optional");
		optional.setCanBeConsumed(false);
		optional.setCanBeResolved(false);
		project.getPlugins().withType(JavaPlugin.class, (javaPlugin) -> {
			SourceSetContainer sourceSets = project.getExtensions().getByType(JavaPluginExtension.class)
					.getSourceSets();
			sourceSets.all((sourceSet) -> {
				project.getConfigurations().getByName(sourceSet.getCompileClasspathConfigurationName()).extendsFrom(optional);
				project.getConfigurations().getByName(sourceSet.getRuntimeClasspathConfigurationName()).extendsFrom(optional);
			});
		});
	}

}

optional 作为 compileOnly 一个替代, 在 compile 和 runtime classpath 里面但是不会增加到 依赖里面。 但是 compileOnly 其实会导致测试的 classpath 无法满足, 所以你会看到比较笨的解决方案:

dependencies {
    compileOnly "org.slf4j:slf4j-api"
    testImplementation "org.slf4j:slf4j-api"
}

我们

api-hug-contact

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ApiHug

God Bless U

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值