Task: moved hardware options into the niksos.hardware suboptions.

This commit is contained in:
Jurn Wubben 2025-07-09 00:22:25 +02:00
parent 0924f9c267
commit 678c3cb4f7
15 changed files with 99 additions and 82 deletions

View file

@ -4,9 +4,7 @@
pkgs,
...
}: {
options.niksos.bluetooth = lib.mkEnableOption "bluetooth related stuff.";
config = lib.mkIf config.niksos.bluetooth {
config = lib.mkIf config.niksos.hardware.bluetooth {
hardware.bluetooth = {
enable = true;
input.General.ClassicBondedOnly = false;

View file

@ -1,5 +1,7 @@
{
hardware.enableRedistributableFirmware = true;
{lib, ...}: let
mkEO = lib.mkEnableOption;
in {
config.hardware.enableRedistributableFirmware = true;
imports = [
./bluetooth.nix
@ -9,4 +11,32 @@
./joycond.nix
./power.nix
];
options.niksos.hardware = {
bluetooth = mkEO "bluetooth related stuff.";
fingerprint = mkEO "fingerprint support.";
graphics = {
enable = mkEO "core graphics";
intel = mkEO "additional intel drivers";
nvidia = mkEO "additoinal nvidia drivers";
};
joycond = mkEO "support for nintendo switch controllers.";
portable = {
enable = mkEO "battery optimisers";
hyprland = let
gen = mode:
lib.mkOption {
default = "";
description = "Shell commands to run when switching to ${mode} mode.";
type = lib.types.lines;
};
in {
powerSaver = gen "power-saver";
performance = gen "performance";
};
};
};
}

View file

@ -4,13 +4,12 @@
pkgs,
...
}: let
inherit (config.niksos) fingerprint desktop;
inherit (config.niksos) hardware desktop;
inherit (lib) mkIf mkEnableOption;
uwsm = lib.getExe pkgs.uwsm;
foot = lib.getExe pkgs.foot;
in {
options.niksos.fingerprint = mkEnableOption "fingerprint support.";
config = mkIf fingerprint {
config = mkIf hardware.fingerprint {
services = {
fprintd.enable = true;
logind.extraConfig = mkIf desktop.hyprland ''

View file

@ -5,20 +5,14 @@
...
}: let
inherit (lib) optionals mkEnableOption mkDefault;
inherit (config.niksos) graphics;
inherit (graphics) enable;
inherit (config.niksos.hardware) graphics;
inherit (graphics) enable nvidia intel;
nvidia = graphics.enable && graphics.nvidia;
intel = graphics.enable && graphics.intel;
Nvidia = enable && nvidia;
Intel = enable && intel;
in {
options.niksos.graphics = {
enable = mkEnableOption "core graphics";
intel = mkEnableOption "additional intel drivers";
nvidia = mkEnableOption "additoinal nvidia drivers";
};
config = {
niksos.graphics.enable = mkDefault true;
niksos.hardware.graphics.enable = mkDefault true;
hardware.graphics = {
inherit enable;
@ -29,10 +23,10 @@ in {
vaapiVdpau
libvdpau-va-gl
]
++ optionals intel [
++ optionals Intel [
pkgs.intel-media-driver
]
++ optionals nvidia [
++ optionals Nvidia [
nvidia-vaapi-driver
];
extraPackages32 = with pkgs.pkgsi686Linux;
@ -41,18 +35,18 @@ in {
vaapiVdpau
libvdpau-va-gl
]
++ optionals intel [
++ optionals Intel [
pkgs.pkgsi686Linux.intel-media-driver
]
++ optionals nvidia [
++ optionals Nvidia [
pkgs.pkgsi686Linux.nvidia-vaapi-driver
];
};
hardware.nvidia = {
modesetting.enable = nvidia;
modesetting.enable = Nvidia;
open = false;
};
services.xserver.videoDrivers = optionals nvidia ["nvidia"];
services.xserver.videoDrivers = optionals Nvidia ["nvidia"];
};
}

View file

@ -3,9 +3,7 @@
lib,
...
}: {
options.niksos.joycond = lib.mkEnableOption "support for nintendo switch controllers.";
config.services = lib.mkIf config.niksos.joycond {
config.services = lib.mkIf config.niksos.hardware.joycond {
usbmuxd.enable = true;
joycond.enable = true;
};

View file

@ -5,22 +5,8 @@
...
}: let
inherit (config) niksos;
cfg = niksos.portable;
cfg = niksos.hardware.portable;
in {
options.niksos.portable = {
enable = lib.mkEnableOption "battery optimisers";
hyprland = let
gen = mode:
lib.mkOption {
default = "";
description = "Shell commands to run when switching to ${mode} mode.";
type = lib.types.lines;
};
in {
powerSaver = gen "power-saver";
performance = gen "performance";
};
};
config = {
services = lib.mkIf cfg.enable {
logind = {