lib_game_detector

Crates.iolib_game_detector
lib.rslib_game_detector
version
sourcesrc
created_at2023-09-09 19:22:27.530885+00
updated_at2025-03-29 21:55:49.158234+00
descriptionA Rust library for detecting and parsing data about games installed on the system
homepage
repositoryhttps://github.com/rolv-apneseth/lib_game_detector/
max_upload_size
id968311
Cargo.toml error:TOML parse error at line 18, column 1 | 18 | autolib = false | ^^^^^^^ unknown field `autolib`, expected one of `name`, `version`, `edition`, `authors`, `description`, `readme`, `license`, `repository`, `homepage`, `documentation`, `build`, `resolver`, `links`, `default-run`, `default_dash_run`, `rust-version`, `rust_dash_version`, `rust_version`, `license-file`, `license_dash_file`, `license_file`, `licenseFile`, `license_capital_file`, `forced-target`, `forced_dash_target`, `autobins`, `autotests`, `autoexamples`, `autobenches`, `publish`, `metadata`, `keywords`, `categories`, `exclude`, `include`
size0
Rolv Apneseth (Rolv-Apneseth)

documentation

README

lib_game_detector

Docs Crate Downloads Dependency status License

A Rust library for detecting and parsing data about games installed on the system. Currently only supports Linux.

Description

This is a Rust library intended to be used for programs which need information on currently installed games, such as a games launcher, or mod manager. It can provide information such as what games are installed across multiple launchers (such as Steam and Heroic Games Launcher), where those games are installed, what command will launch them, and more.

Quick start

Install with:

cargo add lib_game_detector

Usage

use lib_game_detector::{data::SupportedLaunchers, get_detector};

let detector = get_detector();
let detected_launchers = detector.get_detected_launchers();
let all_games = detector.get_all_detected_games();
let all_games_by_launcher = detector.get_all_detected_games_per_launcher();
let all_games_from_steam = detector.get_all_detected_games_from_specific_launcher(SupportedLaunchers::Steam);

Examples

  • See rofi-games for an example which uses this library to find games and their box art to use for displaying in a launcher
  • Check the examples folder

Currently supported game sources

  • Steam
    • Non-Steam games added as shortcuts are also supported. Make sure to restart Steam at least once for new shortcuts to be detected
  • Heroic Games Launcher (Legendary, Nile, GOG, and manually added games)
  • Lutris
  • Bottles
    • Only lists entries included in the Library
  • Modded Minecraft (Prism Launcher, ATLauncher)
    • Titles are given as Minecraft - {instance name}

License

AGPL-3.0

Commit count: 87

cargo fmt