pre-commit Coverage

cargo.io License

rust badge

Bindings to Vim objects, bindings to Vim channel commands, and a way to interact with Vim using Rust.

Using this library, you can wite standard plugins, all in Rust, which get run just like a Vim plugin would typically run.

Installation

Add this line to your dependencies section of your Cargo.toml file.

vii = "0.0"

Current interface is highly unstable.

Usage

If possible, use the examples directly from the documentation as they are more clear and tested.

Plugin

Creating a Vim plugin using Rust. Can be installed and run using the Vim plugin rust-plug.

Acts almost just like a Vim plugin would. It runs on startup, running it's code. Exceptions include adding pythonx code, the autoload directory, but it can still create functions, commands, global variables, and read from Vim itself.

Here's an example, taken from rust-plug proof of concept.

```toml

Cargo.toml

[package] name = "rust-plug-poc" version = "0.1.0" edition = "2021"

See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

[dependencies] vii = "0.0" ```

```rust // src/main.rs use std::env; use std::net::TcpStream;

use vii::plugin::Plugin; use vii::plugin::PluginConfig;

struct MyPlugin{ ip: String, port: String, }

/// Make your struct, MyPlugin, into a Plugin ready for Vim. impl Plugin for MyPlugin { fn getconfig(&self) -> PluginConfig { PluginConfig::new("127.0.0.1".tostring(), "8765".to_string()) } fn plugin(&mut self, _stream: &mut TcpStream) -> Result<(), String> { Ok(()) } }

fn main() {

// Environment Variable, to communicate with rust-plug let port = env::var("VIIPLUGINPORT").unwrap(); let mut plugin = MyPlugin { ip: "127.0.0.1".to_string(), port, };

// Run your plugin. // // Here you can run your plugin as many times as you'd like, create multiple plugins, etc. plugin.run(); } ```

Data Types

Working with Vim data types.

See documentation for supported data types.

```rust use vii::DataType;

// Using a Vim data type let vimfloat = DataType::Float(3.14); // Serializing for transmission to Vim let serializedfloat = vimfloat.tostring(); // "3.14"

let vimstring = DataType::String("Hello World!".tostring()); let serializedstring = vimstring.to_string(); // "\"Hello World!\"" ```

Vim Channels

Working with Vim channels (see :help channel.txt in Vim).

Note: This is a low-level API. The eventual, high-level API should look like let expr = Expr::from("line('$')");.

```rust use vii::channel::{ ChannelCommand, Call, Expression, };

// Number of Lines in Current Buffer // ["expr","line('$')"] let expression = ChannelCommand::Expr( Expression { expression: "line('$')".to_string(), }, None, );

// Number of Lines in Current Buffer // ["call", "line", ["$"]] let call = ChannelCommand::Call( Call { function: "line".to_string(), args: vec![DataType::String("$")], }, None, );

println!("{}", expression.tostring()); // ["expr","line('$')"] println!("{}", call.tostring()); // ["call", "line", ["$"]] ```

Contributing

If there are any features you would like added, found any potential bugs, or have any questions, then feel free to create an issue.

Testing

cargo test

Unittests are in the same file, next to the units they are testing (bottom). Integration tests are in /tests/.

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.