mirai/mirai-console/tools/gradle-plugin/README.md

99 lines
3.0 KiB
Markdown
Raw Normal View History

2020-09-19 23:29:28 +08:00
# Mirai Console Gradle Plugin
2020-09-17 21:39:34 +08:00
2020-09-19 23:29:28 +08:00
Mirai Console Gradle 插件。
2021-03-21 11:35:04 +08:00
## 在构建中使用插件
2020-09-19 23:29:28 +08:00
2021-03-21 11:35:04 +08:00
参考 [ConfiguringProjects](../../docs/ConfiguringProjects.md#b使用-gradle-插件配置项目)。
2020-09-19 23:29:28 +08:00
## 功能
2021-01-14 17:21:50 +08:00
-`main` 源集配置 `mirai-core-api``mirai-console` 依赖
-`test` 源集配置 `mirai-core`, `mirai-console-terminal` 的依赖 (用于启动测试)
- 配置 Kotlin 编译目标为 1.8
2020-11-27 13:04:59 +08:00
- 配置 Kotlin 编译器 jvm-default 设置为 `all`, 即为所有接口中的默认实现生成 Java 1.8 起支持的 `default` 方法
2021-01-14 17:21:50 +08:00
- 配置 Java 编译目标为 1.8
2020-11-27 13:04:59 +08:00
- 配置 Java 编译编码为 UTF-8
- 配置插件 JAR 打包构建任务 `buildPlugin`(带依赖, 成品 JAR 可以被 Mirai Console 加载)
2020-09-19 23:29:28 +08:00
2020-11-27 13:04:59 +08:00
支持 Kotlin 多平台项目Multiplatform Projects。每个 JVM 或 Android 目标平台都会被如上配置,对应打包任务带有编译目标的名称,如 `buildPluginJvm`
2020-09-19 23:29:28 +08:00
### `buildPlugin`
用于打包插件和依赖为可以放入 Mirai Console `plugins` 目录加载的插件 JAR。
#### 执行 `buildPlugin`
```shell script
2020-11-27 13:04:59 +08:00
./gradlew buildPlugin
2020-09-19 23:29:28 +08:00
```
打包结果存放在 `build/mirai/` 目录下。
## 配置
若要修改 Mirai Console Gradle 插件的默认配置,在 `build.gradle.kts``build.gradle`
内,使用 `mirai`
2020-09-19 23:29:28 +08:00
```kotlin
mirai { // this: MiraiConsoleExtension
2020-09-19 23:29:28 +08:00
}
```
2020-11-08 09:52:29 +08:00
DSL 详见 [MiraiConsoleExtension](src/MiraiConsoleExtension.kt)。
2020-09-19 23:29:28 +08:00
### 修改 Java 编译目标
Mirai Console Gradle 会覆盖 Java 编译目标为 `1.8`. 若要修改该值, 请通过:
```kotlin
mirai { // this: MiraiConsoleExtension
jvmTarget = JavaVersion.VERSION_16
}
```
2022-01-20 22:01:25 +08:00
### 打包依赖
Mirai Console Gradle 在打包 JAR`buildPlugin` 时不会携带任何外部依赖,
而是会保存一份依赖列表,在加载插件时下载, 如果您使用了不可在 `Maven Central` 搜索到的依赖, 请使用以下配置告知
mirai-console-gradle
2022-01-20 22:01:25 +08:00
```groovy
dependencies {
implementation "org.example:test:1.0.0"
// 无需版本号
shadowLink "org.example:test"
// build.gradle.kts
"shadowLink"("org.example:test")
}
```
2021-01-14 17:21:50 +08:00
### `publishPlugin`
配置好 Bintray 参数,使用 `./gradlew publishPlugin` 可自动发布并上传插件到 Bintray。
如果仓库是公开的,上传的插件在未来可以被 [mirai-console-loader](https://github.com/iTXTech/mirai-console-loader) 自动识别并展示在社区插件列表中。
```kotlin
mirai {
publishing {
repo = "mirai"
packageName = "chat-command"
}
}
```
2021-03-21 11:35:04 +08:00
*2021/3/21 更新:* 由于 Bintray JCenter 即将关闭随着论坛的发展mirai 正在策划插件中心服务。待插件中心完成后将会提供更好的插件分发平台。
2022-01-20 22:01:25 +08:00
#### 排除依赖 (过时)
2020-09-19 23:29:28 +08:00
2022-01-20 22:01:25 +08:00
如果要在打包 JAR`buildPluginLegacy`)时排除一些依赖,请使用如下配置:
2020-09-19 23:29:28 +08:00
```kotlin
mirai {
excludeDependency("com.google.code.gson", "gson")
}
2020-09-20 00:05:46 +08:00
```
2020-11-27 13:04:59 +08:00
2021-03-21 11:35:04 +08:00
**插件一般不需要手动排除依赖**。Mirai Console 已经包含的依赖都会自动在打包过程中被排除。