mirror of
https://github.com/logos-messaging/libchat.git
synced 2026-04-01 17:13:13 +00:00
Implement a `client` crate that wraps the `libchat` context behind a simple `ChatClient<D>` API. The delivery strategy is pluggable via a `DeliveryService` trait, with two implementations provided: - `InProcessDelivery` — shared `MessageBus` for single-process tests - `CDelivery` — C function-pointer callback for the FFI layer Add a `client-ffi` crate that exposes the client as a C API via `safer-ffi`. A `generate-headers` binary produces the companion C header. Include two runnable examples: - `examples/in-process` — Alice/Bob exchange using in-process delivery - `examples/c-ffi` — same exchange written entirely in C; smoketested under valgrind (to catch memory leaks) in CI iterates: #71
16 lines
334 B
Rust
16 lines
334 B
Rust
use libchat::ChatError;
|
|
|
|
#[derive(Debug)]
|
|
pub enum ClientError<D> {
|
|
Chat(ChatError),
|
|
/// Crypto state advanced but at least one envelope failed delivery.
|
|
/// Caller decides whether to retry.
|
|
Delivery(D),
|
|
}
|
|
|
|
impl<D> From<ChatError> for ClientError<D> {
|
|
fn from(e: ChatError) -> Self {
|
|
Self::Chat(e)
|
|
}
|
|
}
|