16 releases (9 breaking)

0.11.0 Dec 17, 2024
0.10.0 Sep 30, 2024
0.9.0 Apr 5, 2024
0.8.0 Nov 21, 2023
0.2.5 Nov 12, 2022

#478 in Parser implementations

Download history 12/week @ 2024-09-21 214/week @ 2024-09-28 25/week @ 2024-10-05 15/week @ 2024-10-12 5/week @ 2024-10-19 1/week @ 2024-10-26 10/week @ 2024-11-02 3/week @ 2024-11-09 11/week @ 2024-11-16 6/week @ 2024-11-23 75/week @ 2024-11-30 272/week @ 2024-12-07 240/week @ 2024-12-14 38/week @ 2024-12-21 43/week @ 2024-12-28 53/week @ 2025-01-04

383 downloads per month
Used in gvas2json

MIT license

5MB
5K SLoC

gvas

The gvas crate is a Rust library that allows parsing of gvas save files.

Documentation

Crate documentation is published to docs.rs/gvas.

Save files

A gvas save file is a binary file format used by the Unreal Engine 4/5 (UE4/UE5) game engine to store persistent data such as player progress, game settings, and other game-related information.

Usage

The crate can be added to a Rust project as a dependency by running the command cargo add gvas.

Serde Support

This crate supports serde deserialization and serialization. To use serde with gvas, the serde feature must be enabled by running cargo add gvas --features serde.

Examples

The example code below demonstrates how to use the gvas crate to read a gvas save file. The GvasFile struct's read() method is used to parse the data from the file and produce a GvasFile struct.

use gvas::GvasFile;
use std::fs::File;

let mut file = File::open("save.sav")?;
let gvas_file = GvasFile::read(&mut file, GameVersion::Default);

println!("{:#?}", gvas_file);

The tests directory contains several tests that demonstrate how to use the crate to read and write gvas files.

Contributing

Please see the CONTRIBUTING document for guidelines on how to contribute to this project.

License

This library is distributed under the terms of the MIT license. See the LICENSE file for details.

Dependencies