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 过程宏

Download history 4/week @ 2024-03-11 2/week @ 2024-03-25 28/week @ 2024-04-01 14/week @ 2024-04-15 10/week @ 2024-05-20 22/week @ 2024-06-03 57/week @ 2024-06-10 2/week @ 2024-06-17 17/week @ 2024-06-24

每月 98 次下载
4 个crate中使用 (通过 binmarshal)

MIT 许可证

27KB
606 代码行

Binmarshal

crates.io Documentation

将结构体和枚举打包和解包到和从二进制数据流中。

添加到您的项目中

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