mirror of
https://github.com/mamoe/mirai.git
synced 2025-01-10 18:40:15 +08:00
161 lines
6.8 KiB
Markdown
161 lines
6.8 KiB
Markdown
## mirai-core
|
||
|
||
2.12 带来以下主要更新:
|
||
|
||
- `EventChannel` 到协程 `Flow` 的对接;
|
||
- 消息链性能优化;
|
||
- 针对开发易用性的优化;
|
||
- 对调试插件的更好支持;
|
||
- 大量文档更新;
|
||
- 以及一些问题修复。
|
||
|
||
### 不兼容变更
|
||
|
||
- 弃用 `EmptyMessageChain`,以 `emptyMessageChain()` 函数替换 (#1997)
|
||
> 因为内部结构有变更,见下文。Java
|
||
可以 `MessageUtils.emptyMessageChain()` 替换。
|
||
|
||
- `MarketFace.contentToString`
|
||
现在在原本会返回空字符串的情况下会返回 `"[商城表情]"` (#2030 by
|
||
@cssxsh)
|
||
> 原本会返回空字符串是因为服务器提供的表情名称可能为空。
|
||
|
||
- 修复 `FileMessage` 的序列化名称 (#2041 by @cssxsh)
|
||
> 以前错误地使用了 `Image`,现在改为 `FileMessage`
|
||
。以前序列化的 `FileMessage` 可能会无法反序列化。
|
||
|
||
- `Image.equals` 现在会比较全部属性
|
||
> 而不是只比较 `imageId`。因为现在图片没有一些详细属性时可能无法发送。
|
||
|
||
- 弃用 `EventDisabled` 属性 (#1911)
|
||
> 它可以关闭事件功能,但这并不是明智的做法。
|
||
|
||
- 弃用 `GroupEntranceAnnouncementChangeEvent` (#1873)
|
||
> 这个事件在 2.7 增加 `Announcements` 时就已经无效了。
|
||
|
||
### 新特性
|
||
|
||
- 优化 `MessageChain` 实现的性能,现在在大量调用 `Message.plus`
|
||
构造消息链也能获得与 `MessageChainBuilder` 相当的性能。(#1997)
|
||
> 只修改了内部实现,API 及行为都没有变化。
|
||
- 优化处理合并转发消息的效率
|
||
- 新增 `EventChannel.asFlow` 获得事件通道的 `Flow<...>` (#1911)
|
||
> 协程 `Flow` 很适合承载事件广播功能,拥有更高的通用性和扩展性。(mirai
|
||
未使用是因为在
|
||
mirai `EventChannel` 设计之时 `Flow` 还未稳定)
|
||
- 新增 Java 友好的 `EventChannel.exceptionHandler()` (#1953)
|
||
- 新增 `BotConfiguration.disableAccountSecretes` 关闭 `account.secrets`
|
||
> account.secrets 保存账号的会话信息。
|
||
它可加速登录过程,也可能可以减少出现验证码的次数。如果遇到一段时间后无法接收消息通知等同步问题时可尝试禁用。
|
||
|
||
### 优化和修复
|
||
|
||
#### 消息
|
||
|
||
- 部分的消息类型的 `toString` 将包含更多属性,涉及:
|
||
- `Image`
|
||
> 现在图片没有一些详细属性时可能无法发送,因此属性也与 imageId
|
||
一样重要。更多的信息将帮助调试。
|
||
- `MessageSource`
|
||
- `QuoteReply`
|
||
- `FileMessage`
|
||
|
||
- `Image.toString` 现在将包含全部属性
|
||
|
||
- 重写消息协议层与发送消息流程 (#1997)
|
||
> 可扩展,易于测试,为将来支持频道和模块化等做准备。这不会影响现有的功能。
|
||
- 为 `ForwardMessage.BuilderNode` 实现 `toString`
|
||
|
||
#### 事件
|
||
|
||
- 优化 `EventChannel` 事件异常处理机制 (#1911)
|
||
> 现在广播方不会收到来自监听方的事件,监听方有全部责任处理自己的异常,未处理的异常会通过默认日志输出。
|
||
- 优化 `nextEvent` 和 `syncFromEvent`:
|
||
- 完善文档
|
||
- 在遇到异常时正确停止监听器
|
||
- 针对异常处理机制完善事件相关文档:`Event`、`EventChannel`、`Listener`
|
||
- 增加事件追踪日志,可由 `-Dmirai.event.trace=true` 启用
|
||
> 这将会在遇到异常时输出注册事件监听器时的 stacktrace,以及记录每一个事件的广播。
|
||
- 修复官方 macOS 客户端发送给机器人的图片后缀均为 `.mirai` 的问题 (
|
||
#1111)
|
||
|
||
#### 其他
|
||
|
||
- 更新开发文档索引
|
||
> 现在在开发介绍文档中能访问 mirai-console 相关文档,在《准备工作》中也能了解启动
|
||
console 的方式。
|
||
- 为 `Bot.close` 的自动登出增加超时
|
||
|
||
## mirai-console
|
||
|
||
[指令文档]: https://github.com/mamoe/mirai/blob/dev/mirai-console/docs/Commands.md
|
||
|
||
### 新特性
|
||
|
||
- 新增 `CommandContext`,支持在指令中获得原消息链 (#2099)
|
||
> 三种内置指令 `RawCommand`、`SimpleCommand` 和 `CompositeCommand` 的
|
||
Kotlin 以及
|
||
Java 版(`J` 前缀)都支持。参考[文档][指令文档]。
|
||
> 能获得原消息链也就能获得 `MessageMetadata` (#1835)。
|
||
- 支持在 `JSimpleCommand` 和 `JCompositeCommand`
|
||
修改 `CommandArgumentContext`
|
||
> 参考[文档][指令文档]。
|
||
- 增加 `PluginCustomCommandSender` 可供插件实现 `CommandSender` (#1964)
|
||
- 新增 `MiraiConsole.shutdown` 来*优雅*地关闭 Console (#1959, #2016)
|
||
- 修复收到 SIGINT Console 不退出的问题 (#2042)
|
||
- 关闭时有一分钟限时,超时后强制结束
|
||
> *优雅*指的是会禁用插件,依次停止各种服务并保存数据。
|
||
- 在加载配置和数据文件失败时自动备份原文件 (#2089 by @cssxsh)
|
||
- 当插件加载失败时标记其为加载失败而不关闭 Console (#2022 by @Nambers)
|
||
> 当有插件依赖这个失败的插件时,也会禁用相关插件。
|
||
> 实际上该功能可由前端选择是否开启。mirai 官方的终端前端以及 Mirai
|
||
Android 都会启用该功能。
|
||
- 相反于加载顺序卸载插件 (#1994)
|
||
> 若 A 依赖 B,现在会先卸载 A 再卸载 B。
|
||
|
||
### 优化和修复
|
||
|
||
#### 插件
|
||
|
||
- 修复插件无法使用更高版本的 Ktor 等 mirai-core 也使用的依赖的问题 (
|
||
#2051)
|
||
> 现在可以使用 Ktor 2.0
|
||
- 修复插件在引用了相同的库时,在某些的情况下会产生冲突的问题 (#2054)
|
||
- 修复在插件配置的路径中使用子路径出现的异常的问题 (#2088 by @MrXiaoM)
|
||
|
||
#### 文档
|
||
|
||
[指令参数智能解析
|
||
]: https://github.com/mamoe/mirai/blob/dev/docs/ConsoleTerminal.md#%E6%8C%87%E4%BB%A4%E5%8F%82%E6%95%B0%E6%99%BA%E8%83%BD%E8%A7%A3%E6%9E%90
|
||
|
||
[ConsoleTerminal]: https://github.com/mamoe/mirai/blob/dev/docs/ConsoleTerminal.md
|
||
|
||
- 增加关于使用日志的文档 (#2003)
|
||
- 现在 `PluginManager.getPluginDescription` 不再需要插件已被加载 (#2052)
|
||
> 这可能帮助实现 `PluginLoader`。
|
||
- 重写[指令文档]
|
||
> 增加大量示例、覆盖更多内容、用语更简单。
|
||
> 增加关于智能参数解析的文档 ([面向用户][ConsoleTerminal]
|
||
和[面向开发者][指令参数智能解析
|
||
]的都有) (#1952)
|
||
- 优化事件文档
|
||
> 警告在插件中使用 `GlobalEventChannel` 的危险性。
|
||
- 优化文档细节 (#2078 by @xtyuns, #2067 by @CauchyDOOM, #2095 by
|
||
@Hugozys)
|
||
|
||
## mirai-console-gradle
|
||
|
||
### 新特性
|
||
|
||
[调试文档]: https://github.com/mamoe/mirai/blob/155e4a6ec4cd7ede2ed5bf6d947fbc9d7f4e1aa6/mirai-console/docs/plugin/JVMPlugin.md#%E8%B0%83%E8%AF%95
|
||
|
||
- 新增任务 `runConsole` 启动模拟 `Mirai Console` 实例 (#2056, #2058)
|
||
> 解决了在 IDEA 直接运行 RunTerminal 时出现 `NoClassDefError`
|
||
等错误的问题 (#2055)。现在在
|
||
IDEA 新生成的项目可以选择 Mirai 文件夹中的 `Run Mirai Console`
|
||
来启动测试。详见 [文档][调试文档]。
|
||
|
||
### 优化和修复
|
||
|
||
- 修复 `shadowLink` 打包的依赖在其他依赖也引用时无效的问题 (#2070)
|