mirror of
https://github.com/hyprwm/Hyprland
synced 2024-12-27 19:09:48 +01:00
16d05a5c8b
Simplify and add more info to the docs.
151 lines
5.1 KiB
Nix
151 lines
5.1 KiB
Nix
self: {
|
|
config,
|
|
lib,
|
|
pkgs,
|
|
...
|
|
}: let
|
|
cfg = config.wayland.windowManager.hyprland;
|
|
defaultHyprlandPackage = self.packages.${pkgs.stdenv.hostPlatform.system}.default.override {
|
|
enableXWayland = cfg.xwayland.enable;
|
|
hidpiXWayland = cfg.xwayland.hidpi;
|
|
inherit (cfg) nvidiaPatches;
|
|
};
|
|
in {
|
|
meta.maintainers = [lib.maintainers.fufexan];
|
|
|
|
options.wayland.windowManager.hyprland = {
|
|
enable =
|
|
lib.mkEnableOption null
|
|
// {
|
|
description = lib.mdDoc ''
|
|
Whether to enable Hyprland, the dynamic tiling Wayland compositor
|
|
that doesn't sacrifice on its looks.
|
|
|
|
You can manually launch Hyprland by executing {command}`Hyprland` on
|
|
a TTY.
|
|
|
|
See <https://wiki.hyprland.org> for more information.
|
|
'';
|
|
};
|
|
|
|
package = lib.mkOption {
|
|
type = with lib.types; nullOr package;
|
|
default = defaultHyprlandPackage;
|
|
defaultText = lib.literalExpression ''
|
|
hyprland.packages.''${pkgs.stdenv.hostPlatform.system}.default.override {
|
|
enableXWayland = config.wayland.windowManager.hyprland.xwayland.enable;
|
|
hidpiXWayland = config.wayland.windowManager.hyprland.xwayland.hidpi;
|
|
inherit (config.wayland.windowManager.hyprland) nvidiaPatches;
|
|
}
|
|
'';
|
|
description = lib.mdDoc ''
|
|
Hyprland package to use. Will override the 'xwayland' and
|
|
'nvidiaPatches' options.
|
|
|
|
Defaults to the one provided by the flake. Set it to
|
|
{package}`pkgs.hyprland` to use the one provided by nixpkgs or
|
|
if you have an overlay.
|
|
|
|
Set to null to not add any Hyprland package to your path. This should
|
|
be done if you want to use the NixOS module to install Hyprland.
|
|
'';
|
|
};
|
|
|
|
systemdIntegration = lib.mkOption {
|
|
type = lib.types.bool;
|
|
default = pkgs.stdenv.isLinux;
|
|
description = lib.mdDoc ''
|
|
Whether to enable {file}`hyprland-session.target` on
|
|
hyprland startup. This links to {file}`graphical-session.target`.
|
|
Some important environment variables will be imported to systemd
|
|
and dbus user environment before reaching the target, including
|
|
- {env}`DISPLAY`
|
|
- {env}`HYPRLAND_INSTANCE_SIGNATURE`
|
|
- {env}`WAYLAND_DISPLAY`
|
|
- {env}`XDG_CURRENT_DESKTOP`
|
|
'';
|
|
};
|
|
|
|
disableAutoreload =
|
|
lib.mkEnableOption null
|
|
// {
|
|
description = lib.mdDoc ''
|
|
Whether to disable automatically reloading Hyprland's configuration when
|
|
rebuilding the Home Manager profile.
|
|
'';
|
|
};
|
|
|
|
xwayland = {
|
|
enable = lib.mkEnableOption (lib.mdDoc "XWayland") // {default = true;};
|
|
hidpi =
|
|
lib.mkEnableOption null
|
|
// {
|
|
description = lib.mdDoc ''
|
|
Enable HiDPI XWayland, based on [XWayland MR 733](https://gitlab.freedesktop.org/xorg/xserver/-/merge_requests/733).
|
|
See <https://wiki.hyprland.org/Nix/Options-Overrides/#xwayland-hidpi> for more info.
|
|
'';
|
|
};
|
|
};
|
|
|
|
nvidiaPatches = lib.mkEnableOption (lib.mdDoc "patching wlroots for better Nvidia support.");
|
|
|
|
extraConfig = lib.mkOption {
|
|
type = lib.types.nullOr lib.types.lines;
|
|
default = "";
|
|
description = lib.mdDoc ''
|
|
Extra configuration lines to add to {file}`~/.config/hypr/hyprland.conf`.
|
|
'';
|
|
};
|
|
|
|
recommendedEnvironment =
|
|
lib.mkEnableOption null
|
|
// {
|
|
description = lib.mdDoc ''
|
|
Whether to set the recommended environment variables.
|
|
'';
|
|
};
|
|
};
|
|
|
|
config = lib.mkIf cfg.enable {
|
|
home.packages =
|
|
lib.optional (cfg.package != null) cfg.package
|
|
++ lib.optional cfg.xwayland.enable pkgs.xwayland;
|
|
|
|
home.sessionVariables =
|
|
lib.mkIf cfg.recommendedEnvironment {NIXOS_OZONE_WL = "1";};
|
|
|
|
xdg.configFile."hypr/hyprland.conf" = lib.mkIf (cfg.extraConfig != null) {
|
|
text =
|
|
(lib.optionalString cfg.systemdIntegration ''
|
|
exec-once=${pkgs.dbus}/bin/dbus-update-activation-environment --systemd DISPLAY WAYLAND_DISPLAY HYPRLAND_INSTANCE_SIGNATURE XDG_CURRENT_DESKTOP && systemctl --user start hyprland-session.target
|
|
'')
|
|
+ cfg.extraConfig;
|
|
|
|
onChange = let
|
|
hyprlandPackage =
|
|
if cfg.package == null
|
|
then defaultHyprlandPackage
|
|
else cfg.package;
|
|
in
|
|
lib.mkIf (!cfg.disableAutoreload) ''
|
|
( # execute in subshell so that `shopt` won't affect other scripts
|
|
shopt -s nullglob # so that nothing is done if /tmp/hypr/ does not exist or is empty
|
|
for instance in /tmp/hypr/*; do
|
|
HYPRLAND_INSTANCE_SIGNATURE=''${instance##*/} ${hyprlandPackage}/bin/hyprctl reload config-only \
|
|
|| true # ignore dead instance(s)
|
|
done
|
|
)
|
|
'';
|
|
};
|
|
|
|
systemd.user.targets.hyprland-session = lib.mkIf cfg.systemdIntegration {
|
|
Unit = {
|
|
Description = "hyprland compositor session";
|
|
Documentation = ["man:systemd.special(7)"];
|
|
BindsTo = ["graphical-session.target"];
|
|
Wants = ["graphical-session-pre.target"];
|
|
After = ["graphical-session-pre.target"];
|
|
};
|
|
};
|
|
};
|
|
}
|