7 releases (4 breaking)

0.5.0 Mar 19, 2021
0.4.2 Nov 2, 2020
0.4.1 Jul 14, 2020
0.4.0 Apr 21, 2020
0.1.0 Aug 23, 2019

#1916 in Data structures


Used in 2 crates

MIT license

330KB
7K SLoC

Build Status Latest Version Rust Documentation codecov

Kurt's Self Explanatory Rust Data.

See the rs docs. Look at progress and contribute on github.

Introduction

kserd provides a data structure to represent programmatic data (mainly for Rust). Data is held in enum variants covering the basic primitives along with nested structures such as tuples, containers, sequences, and maps. kserd tries to differentiate itself by providing the data structure as the in-memory intermediary between serialized format and a programming language's structure. The serialized format is inspired by TOML to make kserd as human-readable as possible.

Getting Started

With default features enabled, using kserd is a simple as importing the root which will contain all the important items.

use kserd::*;

# #[cfg(feature = "encode")] {
// Kserd and Value are the building blocks of the data.
let mut kserd = Kserd::with_id("greeting", Value::new_str("Hello")).unwrap();

// Kserd/Value are meant to be useable in their memory form
// not just simple data holding structure!
assert_eq!(kserd.str(), Some("Hello"));

// you can mutate in place as well
kserd.str_mut().map(|s| { s.push_str(", world!"); });
assert_eq!(kserd.str(), Some("Hello, world!"));

// encode data structures that implement serde::Serialize
let kserd = Kserd::enc(&vec![0, 1, 2, 4]).unwrap();

// can format the kserd into a human-readable string
println!("{}", kserd.as_str()); // should print [0, 1, 2, 4]
# }

It is recommended to consult the api documentation as there is extensive examples and explanations.

Features

The kserd library is feature gated, but all features are enabled by default.

Feature Description Further reading
encode Convert data structures to and from Kserd. Makes use of serde Serialize and Deserialize traits. kserd::encode
format Format a Kserd to a human-readable string. kserd::format
parse Parse a string into a Kserd. kserd::parse

Dependencies

~0.3–0.8MB
~17K SLoC