7 releases

0.2.3 Jan 2, 2022
0.2.2 Nov 14, 2021
0.2.0 Oct 20, 2021
0.1.2 Oct 11, 2021

#773 in Encoding

Download history 14/week @ 2024-01-22 20/week @ 2024-02-12 38/week @ 2024-02-19 139/week @ 2024-02-26 106/week @ 2024-03-04 104/week @ 2024-03-11 115/week @ 2024-03-18 242/week @ 2024-03-25 275/week @ 2024-04-01

740 downloads per month
Used in timens

MIT/Apache

34KB
898 lines

rsexp

S-expression library for Rust.

Build Status Latest version Documentation License

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 and Writing Sexp Files

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)?;

Conversion to/from Native Types

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()?;

No runtime deps