Skip to content

Rust SDK

The Rust crate is the canonical reference implementation for Twilic v2. It provides the highest performance and is the foundation for the JavaScript SDK (N-API and WASM builds).

Requirements

  • Rust stable (edition 2024)

Install

From GitHub:

toml
[dependencies]
twilic = { git = "https://github.com/twilic/twilic-rust.git" }

From crates.io (when published):

toml
[dependencies]
twilic = "0.1"

Quick Start

rust
use twilic::{decode, encode, Value};

fn main() -> Result<(), Box<dyn std::error::Error>> {
let value = Value::Map(vec![
("id".to_string(), Value::U64(1001)),
("name".to_string(), Value::String("alice".to_string())),
("score".to_string(), Value::F64(98.6)),
]);

let bytes = encode(&value)?;
let decoded = decode(&bytes)?;

assert_eq!(value, decoded);
println!("encoded {} bytes", bytes.len());
Ok(())
}

Value Model

rust
pub enum Value {
Null,
Bool(bool),
U8(u8),
U16(u16),
U32(u32),
U64(u64),
I8(i8),
I16(i16),
I32(i32),
I64(i64),
F64(f64),
String(String),
Binary(Vec<u8>),
Array(Vec<Value>),
Map(Vec<(String, Value)>),
}

Type mapping from Rust primitives

Rust typeTwilic ValueNotes
boolValue::Bool-
u8..u64Value::U8..Value::U64Encoder picks smallest width automatically
i8..i64Value::I8..Value::I64-
f32Value::F64Upcast — no f32 tag in v2
f64Value::F64-
String / &strValue::String-
Vec<u8> / &[u8]Value::BinaryRaw bytes, no base64
Option<T>Value::Null or inner value-
Vec<Value>Value::Array-
Vec<(String, Value)>Value::MapOrder is preserved

API Reference

Dynamic Encoding

rust
// Encode any Value to bytes (Dynamic Profile)
pub fn encode(value: &Value) -> Result<Vec<u8>, TwilicError>

// Decode bytes to a Value
pub fn decode(bytes: &[u8]) -> Result<Value, TwilicError>

Schema-Aware Encoding

rust
// Encode using Bound Profile with a shared schema
pub fn encode_with_schema(value: &Value, schema: &Schema) -> Result<Vec<u8>, TwilicError>

Batch Encoding

rust
// Encode a slice of same-shape records as row_batch or col_batch
pub fn encode_batch(records: &[Value]) -> Result<Vec<u8>, TwilicError>

Session Encoder

For stateful streams — maintains key/shape/string interning state across messages:

rust
use twilic::SessionEncoder;

let mut encoder = SessionEncoder::new();

// First call emits full message + intern table registrations
let bytes = encoder.encode(&value)?;

// Subsequent calls use key_ref / shape_ref / str_ref automatically
let bytes = encoder.encode(&next_value)?;

// Encode a micro-batch
let bytes = encoder.encode_micro_batch(&records)?;

// Encode only changed fields (state_patch)
let bytes = encoder.encode_patch(&updated_value)?;

// Reset all session state — next encode is a full stateless message
encoder.reset();

Error Handling

rust
use twilic::{decode, encode, TwilicError, Value};

match decode(bytes) {
Ok(value) => { /* use value */ }
Err(TwilicError::UnknownKeyRef(id)) => {
// key_ref referenced an ID not defined in this message
eprintln!("unknown key_ref: {id}");
}
Err(TwilicError::UnknownShapeRef(id)) => {
// shape_ref referenced an ID not defined in this message
}
Err(TwilicError::UnknownStrRef(id)) => {
// str_ref referenced an ID not defined in this message
}
Err(TwilicError::InvalidTag(byte)) => {
// Unrecognized first byte
}
Err(TwilicError::UnexpectedEof) => {
// Buffer truncated
}
Err(e) => eprintln!("decode error: {e}"),
}

All decode errors are hard failures — unknown references are never silently accepted per the v2 spec.

Building with Cargo Features

toml
[dependencies]
twilic = { git = "https://github.com/twilic/twilic-rust.git", features = ["session", "schema"] }
FeatureDescription
sessionEnables SessionEncoder and stateful forms
schemaEnables encode_with_schema and Bound Profile
batchEnables encode_batch, col_batch, row_batch
serdeEnables serde::Serialize/Deserialize derive for Value

Project Layout

text
twilic-rust/
src/
lib.rs # public API
value.rs # Value enum
encode/ # encoder (dynamic, bound, batch, session)
decode/ # decoder
codec/ # vector codecs (bitpack, RLE, delta, XOR)
session/ # SessionEncoder, state patch, template batch
schema/ # Schema, FieldType, presence bitmap
tests/ # spec conformance and interop tests
scripts/ # interop fixture generation
docs/

Source

github.com/twilic/twilic-rust

Released under the CC-BY-4.0 License.