Little CMS bindings for Rust
Makes LCMS C API available in Rust. There's also a higher-level wrapper.
It's up to date with version 2.16, and works with older versions too. Linux, macOS and Windows are supported. Other platforms may work, too.
The crate requires Rust 1.65 or later.
Differences from the C API
This crate improves bindgen's bindings to be a bit more Rust-friendly:
- Type names don't have the
cms
prefix, e.g.cmsColorSpace
isColorSpace
.- All C function names remained the same (with the prefix, e.g.
fn cmsReadTag()
).
- All C function names remained the same (with the prefix, e.g.
- Enum values don't have the
cmsSig
prefix, e.g.cmsSigLabData
isLabData
. - Some arguments use more specific types, e.g.
Intent::Perceptual
enum instead ofINTENT_PERCEPTUAL
integer.
Dynamic vs static linking configuration
If LCMS2_LIB_DIR
environmental variable is set, and the path contains either a static or dynamic library, this libary will be used regardless of other settings.
If LCMS2_STATIC
environmental variable is set, it will prefer static linking instead.
The package supports "static" and "dynamic" Cargo features. If "dynamic" is enabled (the default) then it will link to system-wide LCMS2 shared library if pkg-config
is installed and working correctly. Typically you will also need a lcms2-dev
or similar package installed on the system.
If pkg-config
doesn't work (e.g. on Windows), or the "static" feature is enabled, it will build bundled LCMS 2.15 from source instead.
For Rust build scripts using this sys crate as a dependency, Cargo will set DEP_LCMS2_INCLUDE
env var to joined paths of include dirs where lcms2.h
may be found. This is only relevant if you compile C code using the library directly.
Contributing
This repo uses git submodules, which can be annoying. Make sure you clone with git clone --recursive
, or run: