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 插件。
|
|
|
|
|
|
|
|
|
|
## 使用
|
|
|
|
|
|
2020-11-08 09:52:29 +08:00
|
|
|
|
参考 [ConfiguringProjects](../../docs/ConfiguringProjects.md)
|
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 加载)
|
2021-01-14 17:21:50 +08:00
|
|
|
|
- 配置插件 JAR 发布任务 `publishPlugin`(到 Bintray)
|
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`:
|
|
|
|
|
```kotlin
|
|
|
|
|
mirai { // this: MiraiConsoleExtension
|
2021-01-14 17:21:50 +08:00
|
|
|
|
// 配置,例如
|
|
|
|
|
coreVersion = "2.0-RC" // 修改 mirai-core 版本
|
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
|
|
|
|
|
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"
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
2020-09-19 23:29:28 +08:00
|
|
|
|
#### 排除依赖
|
|
|
|
|
|
|
|
|
|
如果要在打包 JAR(`buildPlugin`)时排除一些依赖,请使用如下配置:
|
|
|
|
|
|
|
|
|
|
```kotlin
|
|
|
|
|
mirai {
|
|
|
|
|
excludeDependency("com.google.code.gson", "gson")
|
|
|
|
|
}
|
2020-09-20 00:05:46 +08:00
|
|
|
|
```
|
2020-11-27 13:04:59 +08:00
|
|
|
|
|
|
|
|
|
插件一般不需要手动排除依赖。Mirai Console 已经包含的依赖都会自动在打包过程中被排除。
|