#ion #object #notation #format #class #intuitive #ser-deser

ions

ION(s) | intuitive object notation (ser/deser) ion is a data format designed to be user friendly, easy to pick up and easy on the eyes. this library is a serde implementation of the ion data format

10 releases

0.1.9 Mar 23, 2021
0.1.8 Mar 23, 2021

#2327 in Encoding

Download history 109/week @ 2024-07-29 22/week @ 2024-09-23

52 downloads per month
Used in iont

MIT license

22KB
557 lines

ION

# ion(s) | intuitive object notation (ser/deser)
College MIT
Grades {
    Student1 92
    Student2 95
    Student3 93
    Student4 98
}
Classes [
    History
    Math
    Biology
    CS
    Classics
]
#[derive(Serialize, Deserialize, Debug)]
pub struct Docs {
    College: String,
    Grades: Grades,
    Classes: Vec<String>,
}

#[derive(Serialize, Deserialize, Debug)]
pub struct Grades {
    Student1: i64,
    Student2: i64,
    Student3: i64,
    Student4: i64,
}

// the current way of deserializing a struct in ion is weird since
// a deserializer hasn't been implemented yet.
// but, since ion and json are similar, ion is transpiled to json
// and can then be deserialized correctly.
// a deserializer is in progress

use std::fs::read_to_string;
use ion::ion_to_json;

fn main() {
    let docs = read_to_string("docs.ion").unwrap();
    let docs = ion_to_json(&docs).unwrap();
    println!("ion as json {}", docs);
    let docs: Docs = serde_json::from_str(&docs).unwrap();
    println!("{:#?}", docs);
}

Dependencies

~2.5–3.5MB
~73K SLoC