serde_big_array/
lib.rs

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
/*!
Big array helper for serde.
The purpose of this crate is to make (de-)serializing arrays of sizes > 32 easy.
This solution is needed until [serde adopts const generics support](https://github.com/serde-rs/serde/issues/1937).

This crates provides you with two tools to use big arrays in your crate:

* The first tool is the [`BigArray`] trait. You can use it together with the
  `serde_derive` macro and an `#[serde(with = "BigArray")]` next to your data declaration.
* The second tool is the [`Array`] struct. It requires you to change your datastructures,
  and some of the code accessing your array, but it allows for nested use cases,
  which [`BigArray`] struggles with.

We recommended using the [`BigArray`] trait in most cases, and using the
[`Array`] struct only if [`BigArray`] doesn't work.

[`BigArray`]: self::BigArray
[`Array`]: self::Array

## Example
```
extern crate serde;
#[macro_use]
extern crate serde_derive;
extern crate serde_json;
extern crate serde_big_array;

use serde_big_array::BigArray;

#[derive(Serialize, Deserialize)]
struct S {
    #[serde(with = "BigArray")]
    arr: [u8; 64],
}

#[test]
fn test() {
    let s = S { arr: [1; 64] };
    let j = serde_json::to_string(&s).unwrap();
    let s_back = serde_json::from_str::<S>(&j).unwrap();
    assert!(&s.arr[..] == &s_back.arr[..]);
    assert!(false);
}

# fn main() {}
```
*/
#![no_std]

mod array;
pub(crate) mod const_generics;
pub use array::Array;
pub use const_generics::BigArray;