mirror of
https://github.com/hyprwm/hyprland-wiki.git
synced 2025-01-12 10:09:49 +01:00
62 lines
1.6 KiB
Markdown
62 lines
1.6 KiB
Markdown
---
|
|
title: Options & Overrides
|
|
---
|
|
|
|
You can override the package through the `.override` or `.overrideAttrs`
|
|
mechanisms. This is easily achievable on [NixOS](../Hyprland-on-NixOS) or
|
|
[Home Manager](../Hyprland-on-Home-Manager).
|
|
|
|
## Package options
|
|
|
|
These are the default options that the Hyprland package is built with. These can
|
|
be changed by setting the appropriate option to `true`/`false`.
|
|
|
|
### Package
|
|
|
|
```nix
|
|
(pkgs.hyprland.override { # or inputs.hyprland.packages.${pkgs.stdenv.hostPlatform.system}.hyprland
|
|
enableXWayland = true; # whether to enable XWayland
|
|
legacyRenderer = false; # whether to use the legacy renderer (for old GPUs)
|
|
withSystemd = true; # whether to build with systemd support
|
|
})
|
|
```
|
|
|
|
### NixOS & HM modules
|
|
|
|
```nix
|
|
{
|
|
programs.hyprland = { # or wayland.windowManager.hyprland
|
|
enable = true;
|
|
xwayland.enable = true;
|
|
};
|
|
}
|
|
```
|
|
|
|
## Options descriptions
|
|
|
|
### XWayland
|
|
|
|
XWayland is enabled by default in the Nix package. You can disable it either in
|
|
the package itself, or through the module options.
|
|
|
|
## Using Nix repl
|
|
|
|
If you're using Nix (and not NixOS or Home Manager) and you want to override,
|
|
you can do it like this:
|
|
|
|
```nix
|
|
$ nix repl
|
|
nix-repl> :lf git+https://github.com/hyprwm/Hyprland?submodules=1
|
|
nix-repl> :bl outputs.packages.x86_64-linux.hyprland.override { /* flag here */ }
|
|
```
|
|
|
|
Then you can run Hyprland from the built path.
|
|
|
|
You can also use `overrideAttrs` to override `mkDerivation`'s arguments, such as
|
|
`cmakeBuildType`:
|
|
|
|
```nix
|
|
$ nix repl
|
|
nix-repl> :lf git+https://github.com/hyprwm/Hyprland?submodules=1
|
|
nix-repl> :bl outputs.packages.x86_64-linux.hyprland.overrideAttrs (self: super: { cmakeBuildType = "debug" })
|
|
```
|