Crate serde_json_core
source ·Expand description
serde-json
for no_std
programs
This version of serde-json
is aimed at applications that run on resource constrained
devices.
§Example
#[derive(Serialize, Deserialize)]
struct Data<'a> {
value: u32,
message: &'a str,
}
// Serialized JSON data can be easily deserialized into Rust types.
let message = b"{\"value\":10,\"message\":\"Hello, World!\"}";
let (data, _remainder) = serde_json_core::from_slice::<Data<'_>>(message).unwrap();
assert_eq!(data.value, 10);
assert_eq!(data.message, "Hello, World!");
// Structures can also be serialized into slices or strings.
let mut deserialized = [0u8; 256];
let len = serde_json_core::to_slice(&data, &mut deserialized[..]).unwrap();
assert_eq!(&deserialized[..len], message);
§Current features
- The error type is a simple C like enum (less overhead, smaller memory footprint)
- (De)serialization doesn’t require memory allocations
- Deserialization of integers doesn’t go through
u64
; instead the string is directly parsed into the requested integer type. This avoids pulling in KBs of compiler intrinsics when targeting a non 64-bit architecture. - Supports deserialization of:
bool
- Integers
- Floats
str
(This is a zero copy operation when deserializing without de-escaping strings.)Option
- Arrays
- Tuples
- Structs
- C like enums
- Supports serialization (compact format only) of:
bool
- Integers
- Floats
str
(**)Option
- Arrays
- Tuples
- Structs
- C like enums
(**) Serialization of strings doesn’t escape stuff. This simply has not been implemented yet.
§Planned features
- (De)serialization from / into IO objects once
core::io::{Read,Write}
becomes a thing.
§Non-features
This is explicitly out of scope
- Anything that involves dynamic memory allocation
- Like the dynamic
Value
type
- Like the dynamic
§Minimum Supported Rust Version (MSRV)
This crate is guaranteed to compile on stable Rust 1.65.0 and up. It might compile with older versions but that may change in any new patch release.
Re-exports§
Modules§
- Deserialize JSON data to a Rust data structure
- Serialize a Rust data structure into JSON data
- Utilities for serializing and deserializing strings.
Functions§
- Deserializes an instance of type
T
from bytes of JSON text Returns the value and the number of bytes consumed in the process - Deserializes an instance of type
T
from bytes of JSON text, using the provided buffer to unescape strings Returns the value and the number of bytes consumed in the process - Deserializes an instance of type T from a string of JSON text
- Deserializes an instance of type T from a string of JSON text, using the provided buffer to unescape strings
- Serializes the given data structure as a JSON byte vector into the provided buffer