Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

Packaging niri

github-actions[bot] edited this pageMay 22, 2025 ·6 revisions

Overview

When building niri, checkCargo.toml for a list of build features.For example, you can replace systemd integration with dinit integration usingcargo build --release --no-default-features --features dinit,dbus,xdp-gnome-screencast.The defaults however should work fine for most distributions.

Warning

Do NOT build with--all-features!

Some features are meant only for development use.For example, one of the features enables collection of profiling data into a memory buffer that will grow indefinitely until you run out of memory.

Theniri-visual-tests sub-crate/binary is development-only and should not be packaged.

The recommended way to package niri is so that it runs as a standalone desktop session.To do that, put files into the correct directories according to this table.

FileDestination
target/release/niri/usr/bin/
resources/niri-session/usr/bin/
resources/niri.desktop/usr/share/wayland-sessions/
resources/niri-portals.conf/usr/share/xdg-desktop-portal/
resources/niri.service (systemd)/usr/lib/systemd/user/
resources/niri-shutdown.target (systemd)/usr/lib/systemd/user/
resources/dinit/niri (dinit)/usr/lib/dinit.d/user/
resources/dinit/niri-shutdown (dinit)/usr/lib/dinit.d/user/

Doing this will make niri appear in GDM and other display managers.

Running tests

A bulk of our tests spawn niri compositor instances and test Wayland clients.This does not require a graphical session, however due to test parallelism, it can run into file descriptor limits on high core count systems.

If you run into this problem, you may need to limit not just the Rust test harness thread count, but also the Rayon thread count, since some niri tests use internal Rayon threading:

$ export RAYON_NUM_THREADS=2...proceed to run cargo test, perhaps with --test-threads=2

Don't forget to exclude the development-onlyniri-visual-tests crate when running tests.

You may also want to set theRUN_SLOW_TESTS=1 environment variable to run the slower tests.

Version string

The niri version string includes its version and commit hash:

$ niri --versionniri 25.01 (e35c630)

When building in a packaging system, there's usually no repository, so the commit hash is unavailable and the version will show "unknown commit".In this case, please set the commit hash manually:

$ export NIRI_BUILD_COMMIT="e35c630"...proceed to build niri

You can also override the version string entirely, in this case please make sure the corresponding niri version stays intact:

$ export NIRI_BUILD_VERSION_STRING="25.01-1 (e35c630)"...proceed to build niri

Remember to set this variable for bothcargo build andcargo install since the latter will rebuild niri if the environment changes.

Panics

Good panic backtraces are required for diagnosing niri crashes.Please use theniri panic command to test that your package produces good backtraces.

$ niri panicthread 'main' panicked at /builddir/build/BUILD/rust-1.83.0-build/rustc-1.83.0-src/library/core/src/time.rs:1142:31:overflow when subtracting durationsstack backtrace:   0: rust_begin_unwind             at /builddir/build/BUILD/rust-1.83.0-build/rustc-1.83.0-src/library/std/src/panicking.rs:665:5   1: core::panicking::panic_fmt             at /builddir/build/BUILD/rust-1.83.0-build/rustc-1.83.0-src/library/core/src/panicking.rs:74:14   2: core::panicking::panic_display             at /builddir/build/BUILD/rust-1.83.0-build/rustc-1.83.0-src/library/core/src/panicking.rs:264:5   3: core::option::expect_failed             at /builddir/build/BUILD/rust-1.83.0-build/rustc-1.83.0-src/library/core/src/option.rs:2021:5   4: expect<core::time::Duration>             at /builddir/build/BUILD/rust-1.83.0-build/rustc-1.83.0-src/library/core/src/option.rs:933:21   5: sub             at /builddir/build/BUILD/rust-1.83.0-build/rustc-1.83.0-src/library/core/src/time.rs:1142:31   6: cause_panic             at /builddir/build/BUILD/niri-0.0.git.1699.279c8b6a-build/niri/src/utils/mod.rs:382:13   7: main             at /builddir/build/BUILD/niri-0.0.git.1699.279c8b6a-build/niri/src/main.rs:107:27   8: call_once<fn() -> core::result::Result<(), alloc::boxed::Box<dyn core::error::Error, alloc::alloc::Global>>, ()>             at /builddir/build/BUILD/rust-1.83.0-build/rustc-1.83.0-src/library/core/src/ops/function.rs:250:5note: Some details are omitted, run with `RUST_BACKTRACE=full` for a verbose backtrace.

Important things to look for:

  • The panic message is there: "overflow when subtracting durations".
  • The backtrace goes all the way up tomain and includescause_panic.
  • The backtrace includes the file and line number forcause_panic:at /.../src/utils/mod.rs:382:13.

If possible, please ensure that your niri package on its own has good panics, i.e.without installing debuginfo or other packages.The user likely won't have debuginfo installed when their compositor first crashes, and we really want to be able to diagnose and fix all crashes right away.

Rust dependencies

Every niri release comes with a vendored dependencies archive fromcargo vendor.You can use it to build the corresponding niri release completely offline.

If you don't want to use vendored dependencies, consider following the niri release'sCargo.lock.It contains the exact dependency versions that I used when testing the release.

If you need to change the versions of some dependencies, pay extra attention tosmithay andsmithay-drm-extras commit hash.These crates don't currently have regular stable releases, so niri uses git snapshots.Upstream frequently has breaking changes (API and behavior), so you're strongly advised to use the exact commit hash from the niri release'sCargo.lock.

Clone this wiki locally

[8]ページ先頭

©2009-2025 Movatter.jp