.. | ||
Commands.md | ||
Extensions.md | ||
FrontEnd.md | ||
Permissions.md | ||
PluginData.md | ||
Plugins.md | ||
QA.md | ||
README.md | ||
Run.md |
Mirai Console
欢迎来到 mirai-console 开发文档!
目录
后端插件开发基础
- 插件 - Plugin 模块
- 指令 - Command 模块
- 存储 - PluginData 模块
- 权限 - Permission 模块
后端插件开发进阶
- 扩展 - Extension 模块和扩展点
实现前端
准备工作
如果跳过本节内容,你很可能遇到无法解决的问题。
环境要求
不接受降低最低版本要求的建议
- JDK 11
- Android:Android SDK 26+ (Android 8.0)
- Kotlin: 1.4
Mirai Console 需要的 Kotlin 版本会与 Kotlin 最新稳定版本同步。
开发插件的准备工作
- 安装并配置 JDK 11
若使用 Java,或要修改 Mirai Console:
- 使用 IntelliJ IDEA (或
Android Studio
)。 - IDE 需装有 Kotlin Jvm Blocking Bridge 插件 (先启动你的 IDE,再点击 一键安装)
若使用 Kotlin,无特别要求。
前置知识
要学习为 mirai-console 开发原生支持的插件, 需要:
- 掌握 Java 基础
- 至少粗略了解 Kotlin 基础语法(30 分钟):
- 对于 Java 使用者,请阅读 Java 用户的使用指南,在 Java 使用 Mirai Console 中的 Kotlin
suspend
函数 - 对于 Kotlin 使用者,请熟知 Kotlin
1.4
版本带来的新特性
附录
Java 用户的使用指南
- Java 中的「方法」在 Kotlin 中均被称为「函数」。
- Kotlin 默认的访问权限是
public
。如 Kotlinclass Test
相当于 Java 的public class Test {}
- Kotlin 的函数定义
fun test(int: Int): String
相当于 Java 的方法定义public String test(int int)
在 Java 使用 Mirai Console 中的 Kotlin suspend
函数
什么是 suspend
函数
suspend
函数中文是「挂起函数」,是 Kotlin 「协程」的一部分。
Kotlin 协程是语言级特性,函数的修饰符 suspend
会在编译阶段被处理。
对于一个挂起函数:
suspend fun test(): String
它会被编译为 public Object test(Continuation<String> $completion)
。
这是因为 Kotlin 对所有挂起函数都有这样的内部变化,并在编译时实现了协程的一些特性。
Java 用户无法调用这样的方法,因为 Continuation
的实现很复杂。
Mamoe 为此开发了 Kotlin 编译器插件 Kotlin Jvm Blocking Bridge,通过 @JvmBlockingBridge
注解,在编译期额外生成一个供 Java 使用的方法,让 Java 用户可以使用拥有源码内相同的函数签名的方法。
要获取详细信息,参考 Kotlin Jvm Blocking Bridge 编译器插件
Mirai Console 使用的 Kotlin 1.4
版本的新特性
在官方文档的 语言特性与改进 基础上,Mirai Console 的一些设计基于 Kotlin 1.4 的更多新特性。
object
内的扩展函数的自动引用
对于如下定义:
package org.example
object Obj {
fun String.foo()
}
在 Kotlin 1.3
,要调用 foo
,必须使用:
Obj.run {
"str".foo()
}
因为 IDE 不会自动为 String.foo
添加 import
。
Kotlin 1.4
解决了这个问题。在使用 "str".foo
时 Kotlin 会自动添加 org.example.Obj.foo
的引用。
Mirai Console 很多单例对象都设计为 interface + companion object INSTANCE
的接口与实现模式,需要这样的新特性。例如:
interface MiraiConsole {
companion object INSTANCE : MiraiConsole by MiraiConsoleImpl // MiraiConsoleImpl 是内部实现,不公开
}
Mirai Console 演进
Mirai Console 是不断前进的框架,将来必定会发生 API 弃用和重构。
维护者会严谨地推进每一项修改,并提供迁移周期(至少 2 个次版本)。
版本规范
Mirai Console 的版本号遵循 语义化版本 2.0.0 规范。
在日常开发中, Mirai Console 会以 -dev-1
,-dev-2
等版本后缀发布开发预览版本。这些版本仅用于兼容性测试等目的,无稳定性保证。
在大版本开发过程中,Mirai Console 会以 -M1
, -M2
等版本后缀发布里程碑预览版本。代表一系列功能的完成,但还不稳定。
这些版本里新增的 API 仍可能还会在下一个 Milestone 版本变化,因此请按需使用。
在大版本即将发布前,Mirai Console 会以 -RC
版本后缀发布最终的预览版本。
RC
表示新版本 API 已经确定,离稳定版发布只差最后的一些内部优化或 bug 修复。
版本选择
稳定性:稳定 (x.y.z
) > 发布预览 (-RC
) > 里程碑预览 (-M
) > 开发 (-dev
)。
目的 | 推荐至少更新到版本 |
---|---|
生产环境 | x.y.z |
希望尽早体验稳定新特性的插件作者 | -RC |
无论如何都想体验新特性的插件作者 | -M |
前端实现者, 底层插件作者 | -M |
为 Mirai Console 提交 PR | -dev |
其中,‘底层插件’ 表示提供扩展等的插件。如权限系统,其他语言插件加载器等。
更新兼容性
对于 x.y.z
版本号:
- 当
z
增加时,只会有 bug 修复,和必要的新函数添加(为了解决某一个问题),不会有破坏性变化。 - 当
y
增加时,可能有新 API 的引入,和旧 API 的弃用。但这些弃用会经过一个弃用周期后才被删除(隐藏)。向下兼容得到保证。 - 当
x
增加时,任何 API 都可能会有变化。无兼容性保证。
弃用周期
一个计划被删除的 API,将会在下一个次版本开始经历弃用周期。
如一个 API 在 1.1.0
起被弃用,它首先会是 WARNING
(使用时会得到一个编译警告)弃用级别。
在 1.2.0
上升为 ERROR
(使用时会得到一个编译错误);
在 1.3.0
上升为 HIDDEN
(使用者无法看到这些 API)。
HIDDEN
的 API 仍然会保留在代码中并正常编译,以提供二进制兼容性,直到下一个主版本更新。