9 releases
0.1.8 | May 28, 2024 |
---|---|
0.1.7 | Nov 16, 2023 |
0.1.6 | Sep 22, 2023 |
0.1.5 | Apr 24, 2023 |
0.1.0 | Jun 28, 2022 |
#39 in Procedural macros
9,180 downloads per month
Used in 38 crates
(31 directly)
22KB
473 lines
databake
This crate allows data to write itself into Rust code (bake itself in).
Types that implement the Bake
trait can be written into Rust expressions,
which allows using Rust code itself as a zero-overhead "serialization" strategy.
Example
use databake::*;
use alloc::borrow::Cow;
let data = [Some((18, Cow::Borrowed("hi")))];
assert_eq!(
data.bake(&Default::default()).to_string(),
r#"[Some ((18i32 , alloc :: borrow :: Cow :: Borrowed ("hi")))]"#,
);
Derive
Bake
can be automatically derived if the derive
Cargo feature is enabled.
use databake::*;
#[derive(Bake)]
#[databake(path = my_crate)]
struct MyStruct {
number: u32,
string: &'static str,
slice: &'static [bool],
}
#[derive(Bake)]
#[databake(path = my_crate)]
struct AnotherOne(MyStruct, char);
Testing
The test_bake
macro can be used to assert that a particular expression is a Bake
fixed point.
test_bake!(
AnotherOne,
const: crate::AnotherOne(
crate::MyStruct {
number: 17u32,
string: "foo",
slice: &[true, false],
},
'b',
),
my_crate,
);
More Information
For more information on development, authorship, contributing etc. please visit ICU4X home page
.
Dependencies
~180KB