Documentation: docs.rs
Fast (or trying to be!) deserializer and parser for Minecraft: Java Edition's NBT format.
Includes
struct
s.The derserializer allows you to avoid allocations where possible. Strings can be
deserialized to &'a str
where 'a
is the lifetime of the data being
deserialized. This can also be done for lists of any integral type into
&'a [u8]
. The same applies to the Array types in NBT.
You can then parse the &[u8]
only when you need it. The fastanvil
crate has
a PackedBits
type that can do this for you.
See the examples
directory for more examples.
toml
[dependencies]
fastnbt = "0.11"
If you only need the unstructured parser and do not need to use the serde deserializer, you can save on compile time by disabling default features.
toml
[dependencies]
fastnbt = { version="0.11", default_features=false }
This example shows retrieving a players inventory from the palyer.dat file found in the world/playerdata directory.
In particular we are avoiding allocating a new string for every inventory slot by instead having a &str with a lifetime tied to the input data.
```rust use fastnbt::de::from_bytes; use fastnbt::error::Result; use flate2::read::GzDecoder; use serde::Deserialize; use std::io::Read;
struct PlayerDat<'a> { data_version: i32,
#[serde(borrow)]
inventory: Vec<InventorySlot<'a>>,
ender_items: Vec<InventorySlot<'a>>,
}
struct InventorySlot<'a> { id: &'a str, // we avoid allocating a string here. }
fn main() { let args: Vec<_> = std::env::args().skip(1).collect(); let file = std::fs::File::open(args[0].clone()).unwrap();
// Player dat files are compressed with GZip.
let mut decoder = GzDecoder::new(file);
let mut data = vec![];
decoder.read_to_end(&mut data).unwrap();
let player: Result<PlayerDat> = from_bytes(data.as_slice());
println!("{:?}", player);
} ```
There are other crates for NBT out there, this tries to give an honest comparison to them.
| Feature | fastnbt
| Hematite nbt
| note |
| ------- | --------- | -------------- | ---- |
| Benchmark world render* | 23.8+-0.7s | 31.6+-0.9s | making fastnbt
33% faster in this test |
| Deserialization | yes | yes | |
| Serialization | no | yes | |
| Partial deserializations | no | yes | |
| Long Array (MC 1.12+) | yes | yes | |
| Minecraft specialized unicode | no** | yes | |
| Deserialize from reader | no | yes | |
| WASM compatible | yes | ? | |
*see 01-11-2020.md in benchmarks directory
**intended feature