#steam #file-format #parser #api

steam_shortcuts_util

Utilities for parsing & writing Steams shortcut.vdf file format

9 stable releases

1.1.8 May 20, 2022
1.1.7 Apr 18, 2022
1.1.5 Oct 23, 2021
1.1.4 Sep 28, 2021
1.0.0 Aug 29, 2021

#1565 in Parser implementations

Download history 9/week @ 2024-11-13 22/week @ 2024-11-20 59/week @ 2024-11-27 99/week @ 2024-12-04 41/week @ 2024-12-11 20/week @ 2024-12-18 10/week @ 2024-12-25 12/week @ 2025-01-01 48/week @ 2025-01-08 45/week @ 2025-01-15 71/week @ 2025-01-22 138/week @ 2025-01-29 175/week @ 2025-02-05 49/week @ 2025-02-12 50/week @ 2025-02-19 37/week @ 2025-02-26

369 downloads per month
Used in 2 crates

MIT/Apache

35KB
702 lines

Steam Shortcuts utility

Steam Shortcuts is a utility crate that helps you to manage your Steam shortcuts. It is a simple Rust crate that provides a simple interface to manage your Steam shortcuts.

Getting started

First include the crate in your project:

[dependencies]
steam_shortcuts_util = "1.0.0"

Then you can use it:

 use steam_shortcuts_util::parse_shortcuts;
 use steam_shortcuts_util::shortcuts_to_bytes;

 fn example() -> Result<(), Box<dyn std::error::Error>> {
     // This path should be to your steam shortcuts file
     // Usually located at $SteamDirectory/userdata/$SteamUserId/config/shortcuts.vdf
     let content = std::fs::read("src/testdata/shortcuts.vdf")?;
     let shortcuts = parse_shortcuts(content.as_slice())?;
     assert_eq!(shortcuts[0].app_name, "Celeste");
     assert_eq!(3, shortcuts[0].tags.len());

     let shortcut_bytes_vec = shortcuts_to_bytes(&shortcuts);
     assert_eq!(shortcut_bytes_vec, content);
     Ok(())
 }

Be aware that if you overwrite the shortcuts.vdf file, you will have to restart Steam for the changes to take effect.

Dependencies

~1.5MB
~24K SLoC