#plugin #anyrun #plugin-api

anyrun-plugin

为 Anyrun 构建插件的包

1 个不稳定版本

0.1.0 2023年8月21日

43#plugin-api

Download history 22/week @ 2024-04-19 20/week @ 2024-04-26 17/week @ 2024-05-03 19/week @ 2024-05-10 18/week @ 2024-05-17 22/week @ 2024-05-24 25/week @ 2024-05-31 21/week @ 2024-06-07 56/week @ 2024-06-14 59/week @ 2024-06-21 84/week @ 2024-06-28 26/week @ 2024-07-05 19/week @ 2024-07-12 23/week @ 2024-07-19 28/week @ 2024-07-26 15/week @ 2024-08-02

87 每月下载量

GPL-3.0 许可证

14KB

anyrun-plugin

创建 Anyrun 插件的主要简单易用的包。

用法

插件 API 设计得非常简单易用。以下是创建插件所需的所有内容

Cargo.toml:

#[package] omitted
[lib]
crate-type = ["cdylib"] # Required to build a dynamic library that can be loaded by anyrun

[dependencies]
anyrun-plugin = { git = "https://github.com/Kirottu/anyrun" }
abi_stable = "0.11.1"
# Any other dependencies you may have

lib.rs:

use abi_stable::std_types::{RString, RVec, ROption};
use anyrun_plugin::*;

#[init]
fn init(config_dir: RString) {
  // Your initialization code. This is run in another thread.
  // The return type is the data you want to share between functions
}

#[info]
fn info() -> PluginInfo {
  PluginInfo {
    name: "Demo".into(),
    icon: "help-about".into(), // Icon from the icon theme
  }
}

#[get_matches]
fn get_matches(input: RString) -> RVec<Match> {
  // The logic to get matches from the input text in the `input` argument.
  // The `data` is a mutable reference to the shared data type later specified.
  vec![Match {
    title: "Test match".into(),
    icon: ROption::RSome("help-about".into()),
    use_pango: false,
    description: ROption::RSome("Test match for the plugin API demo".into()),
    id: ROption::RNone, // The ID can be used for identifying the match later, is not required
  }].into()
}

#[handler]
fn handler(selection: Match) -> HandleResult {
  // Handle the selected match and return how anyrun should proceed
  HandleResult::Close
}

依赖项

~4–10MB
~99K SLoC