#deserialize-json #serde-json #serialize-deserialize #null #undefined #value #variant

js_option

An Option-like type with separate null and undefined variants

2 releases

0.1.1 Jun 18, 2022
0.1.0 May 10, 2021

#811 in Encoding

Download history 1717/week @ 2024-10-22 2157/week @ 2024-10-29 1946/week @ 2024-11-05 2220/week @ 2024-11-12 2544/week @ 2024-11-19 3460/week @ 2024-11-26 3213/week @ 2024-12-03 2552/week @ 2024-12-10 2637/week @ 2024-12-17 1663/week @ 2024-12-24 1593/week @ 2024-12-31 3403/week @ 2025-01-07 3426/week @ 2025-01-14 3121/week @ 2025-01-21 3896/week @ 2025-01-28 3349/week @ 2025-02-04

14,265 downloads per month
Used in 49 crates (4 directly)

MIT license

10KB
139 lines

js_option

This crate provides a type JsOption that is very similar to the standard library's Option type except that it has three variants:

  • Some(value): Like Option::Some
  • Null: Explicitly not some value
  • Undefined: Implicitly not some value

This type can be useful when you want to deserialize JSON to a Rust struct and not loose information: A regular Option deserializes to None from both an explicit null or a missing field (this is due to special casing of Option in the Deserialize and Serialize derive macros, for other types a missing field will make deserialization fail unless there is a #[serde(skip)], #[serde(skip_deserializing)] or #[serde(default)] attribute).

Example:

# extern crate serde_crate as serde;
use serde::{Deserialize, Serialize};

#[derive(Serialize, Deserialize)]
struct MyStruct {
    #[serde(default, skip_serializing_if = "JsOption::is_undefined")]
    my_field: JsOption<String>,
}

License

MIT

Dependencies

~155KB