18个版本 (3个稳定版)
1.1.3 | 2024年1月5日 |
---|---|
1.0.0 | 2024年1月2日 |
0.2.7 | 2023年12月24日 |
0.1.10 | 2023年11月25日 |
#1081 in 过程宏
每月 98 次下载
在 4 个crate中使用 (通过 binmarshal)
27KB
606 代码行
Binmarshal
将结构体和枚举打包和解包到和从二进制数据流中。
添加到您的项目中
cargo add binmarshal
打包结构体和枚举
use binmarshal::*;
#[derive(Debug, Clone, BinMarshal)]
#[marshal(tag_type = u8)]
enum MyEnum {
#[marshal(tag = "0")]
Variant1,
#[marshal(tag = "1")]
Variant2 {
#[marshal(bits = 4)]
a: u8,
#[marshal(align = 1)]
b: u16,
c: LengthTaggedVec<u8, i32>
}
}
fn main() {
let v = MyEnum::Variant2 {
a: 13,
b: 5192,
c: LengthTaggedVec::new(vec![ -12, -242, 12034 ])
};
// Packing
let mut bytes = [0u8; 256];
let mut writer = BufferBitWriter::new(&mut bytes);
v.write(&mut writer, ());
let slice = writer.slice(); // Gives you a &[u8] reference of the appropriate length, as a subset of "bytes"
// Unpacking
let v = MyEnum::read(&mut BitView::new(slice), ()).unwrap();
}
使用上下文
上下文允许您在结构体和枚举之间传递变量,主要用于标记枚举。如果您使用带上下文的标记枚举,必须在写入之前调用 .update()
use binmarshal::*;
#[derive(Clone)]
struct MyContext {
tag: u8
}
#[derive(Debug, Clone, BinMarshal)]
#[marshal(ctx = MyContext, tag_type = u8, tag = "ctx.tag")]
enum MyEnum {
#[marshal(tag = "1")]
Variant1,
#[marshal(tag = "2")]
Variant2,
}
#[derive(Debug, Clone, BinMarshal)]
struct MyStruct {
variant: u8,
#[marshal(ctx = "construct", ctx_member(field = "tag", member = "variant"))]
inner: MyEnum
}
示例
更复杂的示例请参阅 examples
依赖项
~0.6–1MB
~25K SLoC