#binary-data #binary-format #binary #data-model #format #serde #tokio

tycho

一个围绕 Rust 和 serde 数据模型设计的最小化、自描述和可遍历的二进制数据格式

6 个版本

0.1.2 2021 年 5 月 6 日
0.1.1 2021 年 3 月 30 日
0.0.6 2021 年 2 月 10 日

#2349 in 编码


布局 中使用

MIT 许可证

190KB
3.5K SLoC

Tycho 二进制格式

一个围绕 Rust 和 serde 数据模型设计的最小化、自描述和可遍历的数据格式。

crates.io badge docs.rs badge Downloads badge

设计特点

  • 小存储尺寸
  • 可遍历
  • 自描述
  • 映射到 Rust/Serde 数据模型
  • 支持 128 位数字
  • 编码/解码简单/快速
  • 能够包含单个非终止值。

规范

仓库

文档

示例

--- JSON ---
{ "foo": "Hello World", "bar": 10, "baz": true }
------ JSON BYTES ------
7b 22 66 6f 6f 22 3a 22 48 65 6c 6c 6f 20 57 6f 72 6c 64 22 2c 22 62 61 72 22 3a 31 30 2c 22 62 61 7a 22 3a 74 72 75 65 7d
------ BSON ------
29 00 00 00 02 66 6f 6f 00 0c 00 00 00 48 65 6c 6c 6f 20 57 6f 72 6c 64 00 10 62 61 72 00 0a 00 00 00 08 62 61 7a 00 01 00
------ TYCHO ------
05 21 62 61 7a 00 01 01 01 62 61 72 00 01 04 01 0a 66 6f 6f 00 01 02 0b 48 65 6c 6c 6f 20 57 6f 72 6c 64
------ TYCHO VERBOSE -----
Struct({"baz": Value(Boolean(true)), "bar": Value(Number(Unsigned8(10))), "foo": Value(String("Hello World"))})

解构

05 - Structure
    21 - (33 bytes length)
    [Field 0]
        66 - "f"
        6f - "o"
        6f - "o"
        00 - NULL/EOS
        01 - Value
            02 - String
                0b - (11 bytes length)
                48 - "H"
                65 - "e" 
                6c - "l"
                6c - "l"
                6f - "o"
                20 - " "
                57 - "W"
                6f - "o"
                72 - "r"
                6c - "l"
                64 - "d"
    [Field 1]
        62 - "b"
        61 - "a"
        72 - "r"
        00 - NULL/EOS
        01 - Value
            04 - Number
                01 - Unsigned 8
                    10 - #10
    [Field 2]
        62 - "b"
        61 - "a"
        7a - "z"
        00 - NULL/EOS
        01 - Value
            01 - Boolean
                01 - true

依赖项

~0.7–2.4MB
~42K SLoC