Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

wayland-sys 0.31.5 panic in build.rs: wayland-client required by wayland-sys not found #767

Open
emilk opened this issue Oct 31, 2024 · 5 comments

Comments

@emilk
Copy link

emilk commented Oct 31, 2024

I updated a crate that pulled in a new wayland-sys, and now I get the following error on CI:

error: failed to run custom build command for `wayland-sys v0.31.5`

Caused by:
  process didn't exit successfully: `/home/runner/work/rerun/rerun/target/debug/build/wayland-sys-973359b900b2004b/build-script-build` (exit status: 101)
  --- stdout
  cargo:rerun-if-env-changed=WAYLAND_CLIENT_NO_PKG_CONFIG
  cargo:rerun-if-env-changed=PKG_CONFIG_x86_64-unknown-linux-gnu
  cargo:rerun-if-env-changed=PKG_CONFIG_x86_64_unknown_linux_gnu
  cargo:rerun-if-env-changed=HOST_PKG_CONFIG
  cargo:rerun-if-env-changed=PKG_CONFIG
  cargo:rerun-if-env-changed=WAYLAND_CLIENT_STATIC
  cargo:rerun-if-env-changed=WAYLAND_CLIENT_DYNAMIC
  cargo:rerun-if-env-changed=PKG_CONFIG_ALL_STATIC
  cargo:rerun-if-env-changed=PKG_CONFIG_ALL_DYNAMIC
  cargo:rerun-if-env-changed=PKG_CONFIG_PATH_x86_64-unknown-linux-gnu
  cargo:rerun-if-env-changed=PKG_CONFIG_PATH_x86_64_unknown_linux_gnu
  cargo:rerun-if-env-changed=HOST_PKG_CONFIG_PATH
  cargo:rerun-if-env-changed=PKG_CONFIG_PATH
  cargo:rerun-if-env-changed=PKG_CONFIG_LIBDIR_x86_64-unknown-linux-gnu
  cargo:rerun-if-env-changed=PKG_CONFIG_LIBDIR_x86_64_unknown_linux_gnu
  cargo:rerun-if-env-changed=HOST_PKG_CONFIG_LIBDIR
  cargo:rerun-if-env-changed=PKG_CONFIG_LIBDIR
  cargo:rerun-if-env-changed=PKG_CONFIG_SYSROOT_DIR_x86_64-unknown-linux-gnu
  cargo:rerun-if-env-changed=PKG_CONFIG_SYSROOT_DIR_x86_64_unknown_linux_gnu
  cargo:rerun-if-env-changed=HOST_PKG_CONFIG_SYSROOT_DIR
  cargo:rerun-if-env-changed=PKG_CONFIG_SYSROOT_DIR

  --- stderr
thread 'main' panicked at /home/runner/.cargo/registry/src/index.crates.io-6f17d22bba15001f/wayland-sys-0.31.5/build.rs:10:47:
  called `Result::unwrap()` on an `Err` value: 
  pkg-config exited with status code 1
  > PKG_CONFIG_ALLOW_SYSTEM_LIBS=1 PKG_CONFIG_ALLOW_SYSTEM_CFLAGS=1 pkg-config --libs --cflags wayland-client

  The system library `wayland-client` required by crate `wayland-sys` was not found.
  The file `wayland-client.pc` needs to be installed and the PKG_CONFIG_PATH environment variable must contain its parent directory.
  The PKG_CONFIG_PATH environment variable is not set.

  HINT: if you have installed the library, try setting PKG_CONFIG_PATH to the directory containing `wayland-client.pc`.

The offending line is this, which unfortunately doesn't have a comment:

if std::env::var_os("CARGO_FEATURE_CLIENT").is_some() {
Config::new().probe("wayland-client").unwrap();
}

(it would be nice if the unwrap was replaced with a helpful expect).

CARGO_FEATURE_CLIENT lead me to look at the documentation for the client feature flag, but again I came up short:

[features]
dlopen = ["once_cell"]
client = []

(I can recommend https://crates.io/crates/document-features for documenting features btw)

I would appreciate any guidance I can get (I don't speak Linux) 🙏

Is the fix as simple as adding apt-get install wayland-client to my CI?

@emilk emilk changed the title panic in build.rs panic in build.rs: The system library wayland-client required by crate wayland-sys was not found Oct 31, 2024
@kchibisov
Copy link
Member

You need the libwayland-dev. You can also look into CI for winit/etc.

@emilk emilk changed the title panic in build.rs: The system library wayland-client required by crate wayland-sys was not found wayland-sys 0.31.5 panic in build.rs: wayland-client required by wayland-sys not found Oct 31, 2024
@emilk
Copy link
Author

emilk commented Oct 31, 2024

You need the libwayland-dev

Does all users of our binary need it too? That will be quite annoying for them, especially X11 users.

You can also look into CI for winit/etc.

I don't see anything special in https://github.com/rust-windowing/winit/blob/master/.github/workflows/ci.yml


This happened when updating from wayland-sys 0.31.4 to 0.31.5 btw - what changed there? Can it be undone?

@elinorbgr
Copy link
Member

The crate wayland-sys has not changed at all since its 0.31.1 release, so I don't think this update is the reason you got this error. Rather, maybe one of your dependencies pulling wayland-sys activated the cargo feature in one of its updates?

Does all users of our binary need it too?

That depends on what does your dependency using wayland-client, but assuming it uses the dlopen feature (like winit does), then that is only needed for building the project.

@kchibisov
Copy link
Member

@emilk maybe something that was using wayland-sys disabled its dlopen feature? Since dlopen is the only way to avoid the direct linking to system library. winit for example always enables it by default, but one can disable it when including winit.

@emilk
Copy link
Author

emilk commented Nov 2, 2024

I could indeed fix the problem by adding wayland-sys = { features = ["dlopen"] } to my code (rerun-io/rerun#7977). Thanks! 🙏

It might be nice to add that as a suggestion for others that hit the same unwrap in

if std::env::var_os("CARGO_FEATURE_CLIENT").is_some() {
Config::new().probe("wayland-client").unwrap();
}

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants