Crates.io | rsexp |
lib.rs | rsexp |
version | 0.2.3 |
source | src |
created_at | 2021-10-09 11:17:23.22739 |
updated_at | 2022-01-02 19:42:20.449367 |
description | S-expression manipulation. |
homepage | |
repository | https://github.com/LaurentMazare/rsexp |
max_upload_size | |
id | 462774 |
size | 92,489 |
S-expression library for Rust.
This implemantion aims at being compatible with OCaml's sexplib. The main type for S-expression is as follows:
pub enum Sexp {
Atom(Vec<u8>),
List(Vec<Sexp>),
}
Reading a sexp file can be done by first reading the whole
file content and then converting the resulting slice into
a Sexp
object as follows:
let contents = std::fs::read(input_filename)?;
let sexp = rsexp::from_slice(&contents)?;
Writing a sexp file can be done by first serializing the data
to a buffer then writing this buffer out. Alternatively, the
sexp.write(w)?
function can be used to directly output the
data to a w
object that implements the Write
trait.
let data = sexp.to_bytes();
std::fs::write(output_filename, data)?;
The OfSexp
and SexpOf
traits define some functions to
convert a given type from/to a Sexp
. These traits are implemented
for most basic types, including maps. Two associated derive macros
can be used to define these traits on structs and enums.
#[derive(OfSexp, SexpOf)]
struct StructXYZ {
x: i64,
y: Option<(i32, i32)>,
z: String,
}
#[derive(OfSexp, SexpOf)]
enum Abc {
A(StructXYZ),
B { x: i64, z: String },
C,
}
let sexp = abc.sexp_of();
let abc: Abc = sexp.of_sexp()?;