A parser for VDF
  • Rust 99.6%
  • Nix 0.4%
Find a file
Robin Appelman 455e855cea
Some checks failed
CI / checks (push) Successful in 59s
CI / semver (push) Failing after 59s
0.3.3
2026-01-03 17:07:49 +01:00
.forgejo/workflows workflow updates 2025-06-02 19:53:42 +02:00
examples add support for deserializing a map with int keys as a sequence 2025-06-05 22:17:30 +02:00
src clippy fixes 2026-01-03 17:06:02 +01:00
tests dont attempt to deserialize bracketed strings as arrays if they contain more brackets 2026-01-03 17:02:47 +01:00
.envrc init 2023-12-15 15:51:53 +01:00
.gitignore statements 2023-12-15 16:26:16 +01:00
app.vdf move to serde_core 2025-10-22 21:46:43 +02:00
Cargo.lock 0.3.3 2026-01-03 17:07:49 +01:00
Cargo.toml 0.3.3 2026-01-03 17:07:49 +01:00
flake.lock flake update 2026-01-03 16:05:52 +01:00
flake.nix flake update 2026-01-03 16:05:52 +01:00
README.md dont attempt to deserialize bracketed strings as arrays if they contain more brackets 2026-01-03 17:02:47 +01:00

vdf-reader

A parser for Valve's Data Format v1 (VDF) also known as KeyValues.

The parser focuses on being able to deal with all the various weird forms vdf takes in the wild and providing access to the data stream instead of always requiring parsing the file in full.

Serde

This crate implements a deserializer for serde, but because VDF doesn't map that well only the serde data model not every type might deserialize properly.

Limitations

  • Because the boolean values 0 and 1 can't be distinguished from numbers, it is not possible to use booleans in untagged enums.

  • When deserializing arrays by setting the same key multiple times, the keys have to be consecutive.

    key: 1
    key: 2
    other: 3
    

    will work, but

    key: 1
    other: 3
    key: 2
    

    will not.

Tagged enum root

To help deserialize some common vdf formats, you can use a tagged enum as the root element instead of a struct.

"Variant1" {
    content 1
}

or

"Variant2" {
    other foo
}

can be deserialized into a

enum Data {
    Variant1 {
        content: bool,
    },
    Variant2 {
        other: String,
    }
}