mirror of
https://github.com/hyprwm/hyprland-wiki.git
synced 2024-12-28 12:29:48 +01:00
105 lines
2.4 KiB
Markdown
105 lines
2.4 KiB
Markdown
The NixOS module enables critical components needed to run Hyprland properly,
|
|
such as: polkit,
|
|
[xdg-desktop-portal-hyprland](https://github.com/hyprwm/xdg-desktop-portal-hyprland),
|
|
graphics drivers, fonts, dconf, xwayland, and adding a proper Desktop Entry to
|
|
your Display Manager.
|
|
|
|
Make sure to check out the options of the
|
|
[NixOS module](https://search.nixos.org/options?channel=unstable&from=0&size=50&sort=relevance&type=packages&query=hyprland).
|
|
|
|
## From Nixpkgs
|
|
|
|
```nix
|
|
# configuration.nix
|
|
|
|
{pkgs, ...}: {
|
|
programs.hyprland.enable = true;
|
|
}
|
|
```
|
|
|
|
### Using unstable Hyprland
|
|
|
|
In case you want to use the module from Nixpkgs, but also want the development
|
|
version of Hyprland, you can add it like this:
|
|
|
|
```nix
|
|
# flake.nix
|
|
|
|
{
|
|
inputs.hyprland.url = "github:hyprwm/Hyprland";
|
|
# ...
|
|
|
|
outputs = {nixpkgs, ...} @ inputs: {
|
|
nixosConfigurations.HOSTNAME = nixpkgs.lib.nixosSystem {
|
|
specialArgs = {inherit inputs;}; # this is the important part
|
|
modules = [./configuration.nix];
|
|
};
|
|
}
|
|
}
|
|
|
|
# configuration.nix
|
|
|
|
{inputs, pkgs, ...}: {
|
|
programs.hyprland.package = inputs.hyprland.packages.${pkgs.stdenv.hostPlatform.system}.hyprland;
|
|
}
|
|
```
|
|
|
|
## From the Flake
|
|
|
|
```nix
|
|
# flake.nix
|
|
{
|
|
inputs = {
|
|
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
|
|
hyprland.url = "github:hyprwm/Hyprland";
|
|
};
|
|
|
|
outputs = {nixpkgs, hyprland, ...}: {
|
|
nixosConfigurations.HOSTNAME = nixpkgs.lib.nixosSystem {
|
|
modules = [
|
|
hyprland.nixosModules.default
|
|
{programs.hyprland.enable = true;}
|
|
# ...
|
|
];
|
|
};
|
|
};
|
|
}
|
|
```
|
|
|
|
Don't forget to replace `HOSTNAME` with your hostname!
|
|
|
|
## From the Flake, on Nix stable
|
|
|
|
{{< hint >}}
|
|
If you're using Hyprland through an overlay, set
|
|
`programs.hyprland.package = pkgs.hyprland;`. This also means the `xwayland`
|
|
and `nvidiaPatches` options no longer apply.
|
|
{{< /hint >}}
|
|
|
|
```nix
|
|
# configuration.nix
|
|
|
|
{pkgs, ...}: let
|
|
flake-compat = builtins.fetchTarball "https://github.com/edolstra/flake-compat/archive/master.tar.gz";
|
|
|
|
hyprland = (import flake-compat {
|
|
src = builtins.fetchTarball "https://github.com/hyprwm/Hyprland/archive/master.tar.gz";
|
|
}).defaultNix;
|
|
in {
|
|
imports = [hyprland.nixosModules.default];
|
|
|
|
programs.hyprland = {
|
|
enable = true;
|
|
|
|
# default options, you don't need to set them
|
|
package = hyprland.packages.${pkgs.system}.default;
|
|
|
|
xwayland = {
|
|
enable = true;
|
|
hidpi = false;
|
|
};
|
|
|
|
nvidiaPatches = false;
|
|
};
|
|
}
|
|
```
|