5 releases

0.1.4 Jan 8, 2025
0.1.3 Jan 6, 2025
0.1.2 Jan 3, 2025
0.1.1 Jan 2, 2025
0.1.0 Jan 1, 2025

#855 in Parser implementations

Download history 366/week @ 2024-12-31 242/week @ 2025-01-07

608 downloads per month
Used in 4 crates (3 directly)

MIT license

46KB
881 lines

suika_json

Suika JSON is a JSON handling library for the Suika web stack.

Note: Suika is under active development and not intended for production use. The API is subject to change and may lack comprehensive testing and documentation.

Features

  • Parse JSON strings into JsonValue enums.
  • Supports JSON objects, arrays, strings, numbers, booleans, and null values.
  • Lightweight and easy to use.

Usage

Here's an example of how to use suika_json to parse a JSON string:

use suika_json::{parse_json, JsonValue};

fn main() {
    let json = r#"{ "key": "value", "array": [1, 2, 3], "number": 123.45, "boolean": true, "null": null }"#;
    let value = parse_json(json).unwrap();

    assert_eq!(value, JsonValue::Object(vec![
        ("key".to_string(), JsonValue::String("value".to_string())),
        ("array".to_string(), JsonValue::Array(vec![
            JsonValue::Number(1.0),
            JsonValue::Number(2.0),
            JsonValue::Number(3.0)
        ])),
        ("number".to_string(), JsonValue::Number(123.45)),
        ("boolean".to_string(), JsonValue::Boolean(true)),
        ("null".to_string(), JsonValue::Null)
    ]));
}

JsonParser Struct

The JsonParser struct is used to parse JSON strings into JsonValue enums. Here's an example of how to use JsonParser:

use suika_json::{JsonParser, JsonValue};

fn main() {
    let mut parser = JsonParser::new(r#"{ "key": "value" }"#);
    let value = parser.parse().unwrap();

    assert_eq!(value, JsonValue::Object(vec![
        ("key".to_string(), JsonValue::String("value".to_string()))
    ]));
}

JsonValue Enum

The JsonValue enum represents a JSON value and can be one of the following variants:

  • Object(Vec<(String, JsonValue)>): A JSON object represented as a vector of key-value pairs.
  • Array(Vec<JsonValue>): A JSON array represented as a vector of JsonValue elements.
  • String(String): A JSON string.
  • Number(f64): A JSON number.
  • Boolean(bool): A JSON boolean.
  • Null: A JSON null value.

Dependencies