62 lines
2.1 KiB
Markdown
62 lines
2.1 KiB
Markdown
# Serde   [data:image/s3,"s3://crabby-images/f404d/f404d90eda5dd7b13fe59caec6c1c98e599c1088" alt="Build Status"](https://travis-ci.org/serde-rs/serde) [data:image/s3,"s3://crabby-images/adb1b/adb1be4064ae261c0e8666eff8818c5a5e25d3d2" alt="Coverage Status"](https://coveralls.io/github/serde-rs/serde?branch=master) [data:image/s3,"s3://crabby-images/8a4ec/8a4eced87346857ca473db908c296016e5440e59" alt="Latest Version"](https://crates.io/crates/serde) [data:image/s3,"s3://crabby-images/a2f13/a2f13e62e1ae7fc897a4f994e3813471ba3ece49" alt="Clippy Linting Result"](https://clippy.bashy.io/github/serde-rs/serde/master/log)
|
|
|
|
**Serde is a framework for *ser*ializing and *de*serializing Rust data structures efficiently and generically.**
|
|
|
|
---
|
|
|
|
You may be looking for:
|
|
|
|
- [An overview of Serde](http://serde.rs/)
|
|
- [Data formats supported by Serde](http://serde.rs/#data-formats)
|
|
- [Setting up `#[derive(Serialize, Deserialize)]`](http://serde.rs/codegen.html)
|
|
- [Examples](http://serde.rs/examples.html)
|
|
- [API documentation](http://docs.serde.rs/serde/)
|
|
|
|
## Serde in action
|
|
|
|
```rust
|
|
#![feature(plugin, custom_derive)]
|
|
#![plugin(serde_macros)]
|
|
|
|
extern crate serde_json;
|
|
|
|
#[derive(Serialize, Deserialize, Debug)]
|
|
struct Point {
|
|
x: i32,
|
|
y: i32,
|
|
}
|
|
|
|
fn main() {
|
|
let point = Point { x: 1, y: 2 };
|
|
|
|
// Convert the Point to a JSON string.
|
|
let serialized = serde_json::to_string(&point).unwrap();
|
|
|
|
// Prints serialized = {"x":1,"y":2}
|
|
println!("serialized = {}", serialized);
|
|
|
|
// Convert the JSON string back to a Point.
|
|
let deserialized: Point = serde_json::from_str(&serialized).unwrap();
|
|
|
|
// Prints deserialized = Point { x: 1, y: 2 }
|
|
println!("deserialized = {:?}", deserialized);
|
|
}
|
|
```
|
|
|
|
## License
|
|
|
|
Serde is licensed under either of
|
|
|
|
* Apache License, Version 2.0, ([LICENSE-APACHE](LICENSE-APACHE) or
|
|
http://www.apache.org/licenses/LICENSE-2.0)
|
|
* MIT license ([LICENSE-MIT](LICENSE-MIT) or
|
|
http://opensource.org/licenses/MIT)
|
|
|
|
at your option.
|
|
|
|
### Contribution
|
|
|
|
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.
|