| //! An example of implementing `serde::Serialize` and `serde::Deserialize`. |
| //! The `#[serde(transparent)]` attribute is recommended to serialize directly |
| //! to the underlying bits type without wrapping it in a `serde` newtype. |
| #[cfg(feature = "serde")] |
| #[derive(Serialize, Deserialize, Debug, PartialEq, Eq)] |
| let flags = Flags::A | Flags::B; |
| let serialized = serde_json::to_string(&flags).unwrap(); |
| println!("{:?} -> {}", flags, serialized); |
| assert_eq!(serialized, r#""A | B""#); |
| let deserialized: Flags = serde_json::from_str(&serialized).unwrap(); |
| println!("{} -> {:?}", serialized, flags); |
| assert_eq!(deserialized, flags); |
| #[cfg(not(feature = "serde"))] |