Crates.io | adapter-mlua |
lib.rs | adapter-mlua |
version | 0.2.0 |
source | src |
created_at | 2024-07-17 22:04:02.626542 |
updated_at | 2024-07-18 22:56:12.225821 |
description | An Adapter for adapting the mlua library to the Adapter API. |
homepage | https://github.com/sjcobb2022/adapter |
repository | https://github.com/sjcobb2022/adapter |
max_upload_size | |
id | 1306640 |
size | 5,074 |
[!WARNING]
This library is in no way production ready.
Adapter is a library meant for providing a standard interface for which one can communicate with a variety of interfaces or plugins. It was created from a desire to be able to configure programs with a variety of different languages.
To see the thought process behind this, see RAMBLINGS.md.
The key concept of this library is the Adapter trait. It hinges on the idea that communicating with a foreign interface should be as simple as a function that has an input and an output. We use an identifier to determine the "endpoint" that we want to access.
pub trait Adapter<'a, Input, Output, Identifier, Error> {
fn call(&'a mut self, identifier: Identifier, input: Input) -> Result<Output, Error>;
}
An adapter is generic over the input, output, identifier and error that is uses. It takes in an identifier and an input, and returns a result with the output or an error. By being generic, we can require stricter traits be applied to our inputs and outputs.