35个版本 (8个破坏性更新)

0.9.0 2023年2月2日
0.8.0 2022年12月15日
0.5.1 2022年11月13日

过程宏中排名#295

MIT授权

83KB
2.5K SLoC

AtriPlugin

crates.io

编写遵循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文件夹内,在加载插件动态库前会先加载此文件夹内所有的动态库文件

依赖项