35个版本 (8个破坏性更新)
0.9.0 | 2023年2月2日 |
---|---|
0.8.0 | 2022年12月15日 |
0.5.1 | 2022年11月13日 |
在过程宏中排名#295
83KB
2.5K SLoC
AtriPlugin
编写遵循AtriPlugin加载标准的插件
开发示例
Cargo.toml
[lib]
crate-type = ["cdylib"] # or dylib
[dependencies]
atri_plugin = "0"
首先,定义一个结构体(struct)或枚举(enum)作为插件的实例
#[atri_plugin::plugin] // 使用此宏标记其为插件
struct MyPlugin {
listener: Option<ListenerGuard>,
}
为其实现Plugin
use atri_plugin::Plugin;
impl Plugin for MyPlugin {
fn new() -> Self {
Self { listener: None }
}
fn enable(&mut self) {
info!("Enable my plugin");
let guard = Listener::listening_on_always(|e: GroupMessageEvent| async move {
let message = e.message();
if message.to_string() == "123" {
let mut chain = MessageChainBuilder::new();
chain.push_str("321")
.push_str("114514");
let _ = e.group().send_message(chain).await;
}
});
self.listener = Some(guard);
}
fn disable(&mut self) {
info!("Disable my plugin");
}
}
也可以为插件实现Drop
,将根据规则释放
最后,使用cargo build
编译得到的动态库即为插件本体
详细文档请参阅本crate源码
插件依赖
所有的插件依赖都应被放入plugins/dependencies
文件夹内,在加载插件动态库前会先加载此文件夹内所有的动态库文件