libxm

Crates.iolibxm
lib.rslibxm
version1.1.1
sourcesrc
created_at2015-02-10 22:33:25.030127
updated_at2024-10-25 00:59:51.800031
descriptionA binding of libxm for Rust. A small XM (FastTracker II Extended Module) player library. Designed for easy integration in demos and such, and provides timing functions for easy sync against specific instruments, samples or channels.
homepage
repositoryhttps://github.com/nukep/libxm-rs
max_upload_size
id1373
size617,010
Danny Spencer (nukep)

documentation

https://docs.rs/libxm/

README

libxm-rs

Crates.io version Docs

A binding of libxm for Rust.

A small XM (FastTracker II Extended Module) player library. Designed for easy integration in demos and such, and provides timing functions for easy sync against specific instruments, samples or channels.

As with libxm, this library is released under the WTFPL license.

Documentation

Documentation is hosted here: https://docs.rs/libxm/

Build requirements

If libxm is built locally (this is the default!), you must have a C compiler on your system that supports the C11 standard. If you don't wish to build locally, a shared library that you have pre-built can be provided by following the steps below.

Linking to a shared version of libxm

By default, libxm-rs statically links and compiles libxm. This is to allow users to get started with the library more quickly.

If you wish to provide your own shared or custom version of libxm, you can override the build step for xm in a .cargo/config file (see https://doc.rust-lang.org/cargo/reference/build-scripts.html#overriding-build-scripts).

[target.x86_64-unknown-linux-gnu.xm]
rustc-flags = "-l xm"
Commit count: 30

cargo fmt