serde/README.md

112 lines
4.0 KiB
Markdown
Raw Normal View History

# Serde   [![Build Status]][actions] [![Latest Version]][crates.io] [![serde: rustc 1.13+]][Rust 1.13] [![serde_derive: rustc 1.31+]][Rust 1.31]
2017-04-16 20:44:27 -07:00
[Build Status]: https://img.shields.io/github/workflow/status/serde-rs/serde/CI/master
[actions]: https://github.com/serde-rs/serde/actions?query=branch%3Amaster
2017-04-16 20:44:27 -07:00
[Latest Version]: https://img.shields.io/crates/v/serde.svg
[crates.io]: https://crates.io/crates/serde
2019-08-18 18:31:40 -07:00
[serde: rustc 1.13+]: https://img.shields.io/badge/serde-rustc_1.13+-lightgray.svg
[serde_derive: rustc 1.31+]: https://img.shields.io/badge/serde_derive-rustc_1.31+-lightgray.svg
[Rust 1.13]: https://blog.rust-lang.org/2016/11/10/Rust-1.13.html
[Rust 1.31]: https://blog.rust-lang.org/2018/12/06/Rust-1.31-and-rust-2018.html
2014-09-07 01:30:58 -07:00
2016-08-18 01:01:48 -04:00
**Serde is a framework for *ser*ializing and *de*serializing Rust data structures efficiently and generically.**
2014-09-07 01:30:58 -07:00
2016-08-18 01:01:48 -04:00
---
2015-03-31 22:16:15 -07:00
2016-08-18 01:01:48 -04:00
You may be looking for:
2015-08-09 16:37:01 -07:00
2016-08-18 17:08:05 -04:00
- [An overview of Serde](https://serde.rs/)
- [Data formats supported by Serde](https://serde.rs/#data-formats)
- [Setting up `#[derive(Serialize, Deserialize)]`](https://serde.rs/derive.html)
2016-08-18 17:08:05 -04:00
- [Examples](https://serde.rs/examples.html)
- [API documentation](https://docs.serde.rs/serde/)
2016-12-22 21:52:37 -05:00
- [Release notes](https://github.com/serde-rs/serde/releases)
2015-08-09 16:37:01 -07:00
2016-08-18 01:01:48 -04:00
## Serde in action
2017-10-31 21:47:30 -07:00
<details>
<summary>
Click to show Cargo.toml.
<a href="https://play.rust-lang.org/?edition=2018&gist=72755f28f99afc95e01d63174b28c1f5" target="_blank">Run this code in the playground.</a>
2017-10-31 21:47:30 -07:00
</summary>
```toml
[dependencies]
2017-10-31 21:47:30 -07:00
# The core APIs, including the Serialize and Deserialize traits. Always
# required when using Serde. The "derive" feature is only required when
# using #[derive(Serialize, Deserialize)] to make Serde work with structs
# and enums defined in your crate.
serde = { version = "1.0", features = ["derive"] }
2017-10-31 21:47:30 -07:00
# Each data format lives in its own crate; the sample code below uses JSON
# but you may be using a different one.
serde_json = "1.0"
```
2017-10-31 21:47:30 -07:00
</details>
<p></p>
```rust
use serde::{Serialize, Deserialize};
#[derive(Serialize, Deserialize, Debug)]
struct Point {
x: i32,
y: i32,
}
fn main() {
let point = Point { x: 1, y: 2 };
2016-08-18 01:01:48 -04:00
// Convert the Point to a JSON string.
let serialized = serde_json::to_string(&point).unwrap();
2015-04-01 21:59:37 -07:00
2016-08-18 01:01:48 -04:00
// Prints serialized = {"x":1,"y":2}
println!("serialized = {}", serialized);
2016-08-18 01:01:48 -04:00
// Convert the JSON string back to a Point.
let deserialized: Point = serde_json::from_str(&serialized).unwrap();
2016-08-18 01:01:48 -04:00
// Prints deserialized = Point { x: 1, y: 2 }
println!("deserialized = {:?}", deserialized);
}
2015-03-31 22:16:15 -07:00
```
2016-08-18 10:56:41 -04:00
## Getting help
2020-05-09 23:34:38 -07:00
Serde is one of the most widely used Rust libraries so any place that Rustaceans
congregate will be able to help you out. For chat, consider trying the
[#general] or [#beginners] channels of the unofficial community Discord, the
[#rust-usage] channel of the official Rust Project Discord, or the
[#general][zulip] stream in Zulip. For asynchronous, consider the [\[rust\] tag
on StackOverflow][stackoverflow], the [/r/rust] subreddit which has a pinned
weekly easy questions post, or the Rust [Discourse forum][discourse]. It's
acceptable to file a support issue in this repo but they tend not to get as many
eyes as any of the above and may get closed without a response after some time.
[#general]: https://discord.com/channels/273534239310479360/274215136414400513
[#beginners]: https://discord.com/channels/273534239310479360/273541522815713281
[#rust-usage]: https://discord.com/channels/442252698964721669/443150878111694848
[zulip]: https://rust-lang.zulipchat.com/#narrow/stream/122651-general
[stackoverflow]: https://stackoverflow.com/questions/tagged/rust
[/r/rust]: https://www.reddit.com/r/rust
[discourse]: https://users.rust-lang.org
2016-08-18 10:56:41 -04:00
2019-05-18 17:35:18 -07:00
<br>
2019-05-18 17:35:18 -07:00
#### License
2019-05-18 17:35:18 -07:00
<sup>
Licensed under either of <a href="LICENSE-APACHE">Apache License, Version
2.0</a> or <a href="LICENSE-MIT">MIT license</a> at your option.
</sup>
2019-05-18 17:35:18 -07:00
<br>
2019-05-18 17:35:18 -07:00
<sub>
2016-08-18 01:01:48 -04:00
Unless you explicitly state otherwise, any contribution intentionally submitted
for inclusion in Serde by you, as defined in the Apache-2.0 license, shall be
dual licensed as above, without any additional terms or conditions.
2019-05-18 17:35:18 -07:00
</sub>