#cec #libcec #hdmi

sys libcec-sys

FFI bindings to libcec

25 stable releases (7 major)

7.0.6 Dec 22, 2024
6.0.1 Dec 14, 2024
5.0.1 Nov 30, 2024
4.0.4 Oct 12, 2024
0.2.1 Nov 30, 2019

#164 in Hardware support

Download history 51/week @ 2024-09-25 8/week @ 2024-10-02 278/week @ 2024-10-09 26/week @ 2024-10-16 7/week @ 2024-10-23 11/week @ 2024-10-30 28/week @ 2024-11-06 25/week @ 2024-11-13 9/week @ 2024-11-20 196/week @ 2024-11-27 82/week @ 2024-12-04 790/week @ 2024-12-11 374/week @ 2024-12-18 135/week @ 2024-12-25 90/week @ 2025-01-01 148/week @ 2025-01-08

807 downloads per month
Used in 4 crates (via cec-rs)

GPL-2.0 license

6.5MB
60K SLoC

Rust 24K SLoC // 0.0% comments C++ 15K SLoC // 0.1% comments C# 10K SLoC // 0.3% comments .NET Resource 7.5K SLoC // 0.1% comments Python 1.5K SLoC // 0.1% comments Batch 1K SLoC C 444 SLoC // 0.1% comments Visual Studio Project 368 SLoC Shell 243 SLoC // 0.1% comments SWIG 144 SLoC // 0.0% comments Visual Studio Solution 96 SLoC

Contains (DOS exe, 1MB) p8-usbcec-bootloader-driver-installer.exe, (DOS exe, 1MB) p8-usbcec-bootloader-driver-installer.exe, (DOS exe, 620KB) p8-usbcec-driver-installer.exe, (DOS exe, 620KB) p8-usbcec-driver-installer.exe, (Windows DLL, 68KB) libusb0.dll, (Windows DLL, 68KB) vendor/support/windows/libusb0.dll

libcec-sys

Crates.io Docs.rs CI

FFI bindings for the libcec

Finding libcec

This crate works with libcec v4.x, v5.x and v6.x (latest version as time of writing). During the build we try to find libcec system library installation using pkg-config and compilation using default C compiler (cc crate).

As a fallback, static pre-built libcec (v6.0.2) is downloaded from ssalonen/libcec-static-builds. Most common targets are supported.

There are vendored and static feature to allow more explicit control. There are also LIBCEC_VENDORED and LIBCEC_STATIC environment variables, just set them to value 1.

The crate is tested mainly with Linux and Windows but could work with other platforms as well. PRs welcome.

Linux (general)

On Linux, for most convenient build process, it is recommended to install pkg-config, libcec-dev (headers and pkg-config configuration), libcec6 (dynamic library), libp8-platform-dev and libp8-platform2 from your package distribution before installing this crate. Exact package names vary between distributions and package managers.

In addition libudev-dev might be needed.

With debian based distributions, you can simply

sudo apt-get install libudev-dev libp8-platform2 libp8-platform-dev libcec-dev pkg-config libcec6

If your environment lacks the needed dependencies, most easy option might be to fallback to static build.

Raspberry Pi OS

NOTE: new versions of Raspberry Pi OS should support standard linux API for CEC control. Static builds used by this library have the linux API enabled.

Windows

On Windows, probably easiest is to let the libcec-sys fallback to statically pre-built library. One can request this explicitly by using LIBCEC_STATIC=1 environment variable or by using static feature.

For dynamic linking: On Windows, it is recommended to install libcec via the installer and add cec.dll to the PATH environment variable.

For a vendored build: libcec-sys will dynamically link to the compiled cec.dll. This means you must package your standalone executable with the compiled dynamic library.

Vendored Build Prerequisites:

  • Visual Studio 2019 w/ Desktop Development with C++ and Universal Windows Platform development
  • CMake 3.12+
  • Python 3.6+ with Debug Binaries

Static build of libcec

Static build has been adapted from great work from @opeik in https://github.com/ssalonen/cec-rs/issues/52

See https://github.com/ssalonen/libcec-static-builds

License

This repo contains content distributed under three different licenses.

  1. Main package, licensed under GNU General Public License version 2, (LICENSE or https://opensource.org/licenses/GPL-2.0)

  2. The CI/CD setup in .github/ is based on rust-github/template, and therefore licensed under either of

    at your option.

  3. The CI uses sccache build cache tooling as shared in Cross repository wiki. The Cross repo itself is licensed under either of

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

See CONTRIBUTING.md.

Releasing

cargo release --no-publish --dev-version --execute and let the github CD pipeline do the rest.

Dependencies