edn-rs

[MAYBE_STABLE] Crate to parse and emit EDN * This lib does not make effort to conform the EDN received to EDN Spec. The lib that generated this EDN should be responsible for this.

Usage

Cargo.toml toml [dependencies] edn-rs = "0.5.2"

Parse an EDN into a Edn with edn! macro: ```rust

![recursion_limit="512"]

[macro_use]

extern crate edn_rs;

fn main() { let edn = edn!((sym 1.2 3 false :f nil 3/4)); let expected = Edn::List( List::new( vec![ Edn::Symbol("sym".tostring()), Edn::Double(1.2), Edn::Int(3), Edn::Bool(false), Edn::Key("f".tostring()), Edn::Nil, Edn::Rational("3/4".to_string()) ] ) );

    assert_eq!(edn, expected);

} ```

To navigate through Edn data you can just use get and get_mut:

```rust let edn = edn!([ 1 1.2 3 {false :f nil 3/4}]);

asserteq!(edn[1], edn!(1.2)); asserteq!(edn[1], Edn::Double(1.2f64)); asserteq!(edn[3]["false"], edn!(:f)); asserteq!(edn[3]["false"], Edn::Key("f".to_string())); ```

Serializes Rust Types into EDN ```rust #![recursionlimit="512"] #[macrouse] extern crate edn_rs;

use std::collections::{HashMap, HashSet}; use crate::edn_rs::serialize::Serialize;

fn main() { serstruct!{ #[derive(Debug)] struct Edn { map: HashMap>, set: HashSet, tuples: (i32, bool, char), } }; let edn = Edn { map: map!{"this is a key".tostring() => vec!["with".tostring(), "many".tostring(), "keys".to_string()]}, set: set!{3i64, 4i64, 5i64}, tuples: (3i32, true, 'd') }; println!("{}",edn.serialize()); // { :map {:this-is-a-key ["with", "many", "keys"]}, :set #{3, 4, 5}, :tuples (3, true, \d), } } ```

Emits EDN format from a Json file ```rust use ednrs::emitedn;

fn main() { let json = String::from("{\"hello\": \"world\"}"); let edn = String::from("{:hello \"world\"}");

 assert_eq!(edn, emit_edn(json));

} ```

Current Features