atri_plugin

Crates.ioatri_plugin
lib.rsatri_plugin
version0.9.0
sourcesrc
created_at2022-08-21 10:30:36.855204
updated_at2023-02-02 03:36:51.331529
descriptionAtriPlugin
homepagehttps://atrikawaii.github.io/atri_doc/
repositoryhttps://github.com/AtriKawaii/atri_rust
max_upload_size
id649730
size62,369
tsudzuki (LaoLittle)

documentation

README

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

Commit count: 84

cargo fmt