Reformat nix source file using nixfmt

This commit is contained in:
ulic-youthlic 2025-07-13 06:04:55 +08:00
parent 2e4a532958
commit 9201969c1b
Signed by: youthlic
GPG key ID: 63E86C3C14A0D721
220 changed files with 3169 additions and 2487 deletions

View file

@ -1,27 +1,32 @@
{ {
description = "A simple NixOS flakes"; description = "A simple NixOS flakes";
outputs = { outputs =
{
flake-parts, flake-parts,
flake-utils, flake-utils,
home-manager, home-manager,
treefmt-nix, treefmt-nix,
nixpkgs, nixpkgs,
... ...
} @ inputs: let }@inputs:
let
nixpkgs-lib = nixpkgs.lib; nixpkgs-lib = nixpkgs.lib;
lib = nixpkgs-lib.extend (import ./lib); lib = nixpkgs-lib.extend (import ./lib);
in in
flake-parts.lib.mkFlake { flake-parts.lib.mkFlake
{
inherit inputs; inherit inputs;
specialArgs = { specialArgs = {
inherit lib; inherit lib;
rootPath = ./.; rootPath = ./.;
}; };
} ({lib, ...}: { }
(
{ lib, ... }:
{
systems = flake-utils.lib.defaultSystems; systems = flake-utils.lib.defaultSystems;
imports = imports = [
[
home-manager.flakeModules.home-manager home-manager.flakeModules.home-manager
treefmt-nix.flakeModule treefmt-nix.flakeModule
] ]
@ -30,7 +35,8 @@
inherit lib; inherit lib;
nix.settings = { nix.settings = {
# substituters shared in home-manager and nixos configuration # substituters shared in home-manager and nixos configuration
substituters = let substituters =
let
cachix = x: "https://${x}.cachix.org"; cachix = x: "https://${x}.cachix.org";
in in
lib.flatten [ lib.flatten [
@ -40,7 +46,8 @@
]; ];
}; };
}; };
}); }
);
inputs = { inputs = {
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable"; nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";

View file

@ -4,15 +4,18 @@
flake-parts-lib, flake-parts-lib,
self, self,
... ...
}: let }:
let
inherit (self) outputs; inherit (self) outputs;
inherit (inputs) deploy-rs; inherit (inputs) deploy-rs;
mkDeployNode = { mkDeployNode =
{
hostName, hostName,
unixName ? "deploy", unixName ? "deploy",
system ? "x86_64-linux", system ? "x86_64-linux",
sshName ? hostName, sshName ? hostName,
}: { }:
{
"${hostName}" = { "${hostName}" = {
hostname = "${sshName}"; hostname = "${sshName}";
sshUser = "${unixName}"; sshUser = "${unixName}";
@ -20,14 +23,13 @@
profiles = { profiles = {
system = { system = {
user = "root"; user = "root";
path = path = deploy-rs.lib."${system}".activate.nixos outputs.nixosConfigurations."${hostName}";
deploy-rs.lib."${system}".activate.nixos
outputs.nixosConfigurations."${hostName}";
}; };
}; };
}; };
}; };
in { in
{
options = { options = {
flake = flake-parts-lib.mkSubmoduleOptions { flake = flake-parts-lib.mkSubmoduleOptions {
deploy = lib.mkOption { deploy = lib.mkOption {

View file

@ -4,7 +4,8 @@
self, self,
rootPath, rootPath,
... ...
}: let }:
let
inherit (self) outputs; inherit (self) outputs;
homeModules = homeModules =
( (
@ -25,19 +26,20 @@
default = import "${toString rootPath}/home/modules"; default = import "${toString rootPath}/home/modules";
extra = import "${toString rootPath}/home/extra"; extra = import "${toString rootPath}/home/extra";
}; };
makeHomeConfiguration = { makeHomeConfiguration =
{
hostName, hostName,
unixName ? "david", unixName ? "david",
system ? "x86_64-linux", system ? "x86_64-linux",
nixpkgs ? inputs.nixpkgs, nixpkgs ? inputs.nixpkgs,
home-manager ? inputs.home-manager, home-manager ? inputs.home-manager,
}: { }:
{
"${unixName}@${hostName}" = home-manager.lib.homeManagerConfiguration { "${unixName}@${hostName}" = home-manager.lib.homeManagerConfiguration {
pkgs = import nixpkgs { pkgs = import nixpkgs {
inherit system; inherit system;
}; };
modules = modules = [
[
(rootPath + "/home/${unixName}/configurations/${hostName}") (rootPath + "/home/${unixName}/configurations/${hostName}")
] ]
++ (with homeModules; [ ++ (with homeModules; [
@ -64,7 +66,8 @@
}; };
}; };
}; };
in { in
{
flake = { flake = {
homeConfigurations = lib.foldr (a: b: a // b) { } ( homeConfigurations = lib.foldr (a: b: a // b) { } (
[ [

View file

@ -4,20 +4,29 @@
self, self,
rootPath, rootPath,
... ...
}: let }:
let
inherit (self) outputs; inherit (self) outputs;
in { in
{
flake = { flake = {
nixosModules = { nixosModules = {
default = import (rootPath + "/nixos/modules/top-level"); default = import (rootPath + "/nixos/modules/top-level");
gui = import (rootPath + "/nixos/modules/top-level/gui.nix"); gui = import (rootPath + "/nixos/modules/top-level/gui.nix");
}; };
nixosConfigurations = let nixosConfigurations =
makeNixosConfiguration = hostName: let
makeNixosConfiguration =
hostName:
lib.nixosSystem { lib.nixosSystem {
modules = [ (rootPath + "/nixos/configurations/${hostName}") ]; modules = [ (rootPath + "/nixos/configurations/${hostName}") ];
specialArgs = { specialArgs = {
inherit inputs outputs rootPath lib; inherit
inputs
outputs
rootPath
lib
;
}; };
}; };
in in
@ -26,9 +35,6 @@ in {
"Cape" "Cape"
"Akun" "Akun"
] ]
|> ( |> (with lib; flip genAttrs makeNixosConfiguration);
with lib;
flip genAttrs makeNixosConfiguration
);
}; };
} }

View file

@ -4,10 +4,12 @@
lib, lib,
rootPath, rootPath,
... ...
}: let }:
let
inherit (self) outputs; inherit (self) outputs;
importWithArgs = lib.flip import { inherit inputs outputs; }; importWithArgs = lib.flip import { inherit inputs outputs; };
in { in
{
flake.overlays = flake.overlays =
[ [
"modifications" "modifications"

View file

@ -2,20 +2,24 @@
inputs, inputs,
rootPath, rootPath,
... ...
}: { }:
{
imports = [ imports = [
(rootPath + "/treefmt.nix") (rootPath + "/treefmt.nix")
]; ];
perSystem = { perSystem =
{
pkgs, pkgs,
system, system,
lib, lib,
self', self',
inputs', inputs',
... ...
}: let }:
let
inherit (inputs) nixpkgs; inherit (inputs) nixpkgs;
in { in
{
_module.args.pkgs = import nixpkgs { _module.args.pkgs = import nixpkgs {
inherit system; inherit system;
config = { config = {
@ -34,7 +38,8 @@
nvfetcher nvfetcher
]; ];
}; };
legacyPackages = let legacyPackages =
let
inputsScope = lib.makeScope pkgs.newScope (self: { inputsScope = lib.makeScope pkgs.newScope (self: {
inherit inputs rootPath; inherit inputs rootPath;
srcs = self.callPackage (rootPath + "/_sources/generated.nix") { }; srcs = self.callPackage (rootPath + "/_sources/generated.nix") { };
@ -47,21 +52,22 @@
inherit (inputsScope) callPackage; inherit (inputsScope) callPackage;
directory = rootPath + "/pkgs"; directory = rootPath + "/pkgs";
}; };
packages = let packages =
flattenPkgs = path: value: let
if lib.isDerivation value flattenPkgs =
then { path: value:
if lib.isDerivation value then
{
${lib.concatStringsSep "/" path} = value; ${lib.concatStringsSep "/" path} = value;
} }
else if lib.isAttrs value else if lib.isAttrs value then
then lib.concatMapAttrs (name: flattenPkgs (path ++ [name])) value lib.concatMapAttrs (name: flattenPkgs (path ++ [ name ])) value
else {}; else
{ };
in in
flattenPkgs [ ] self'.legacyPackages; flattenPkgs [ ] self'.legacyPackages;
checks = checks = lib.concatMapAttrs (name: value: {
lib.concatMapAttrs (name: value: {
"package-${name}" = value; "package-${name}" = value;
}) }) self'.packages;
self'.packages;
}; };
} }

View file

@ -3,7 +3,8 @@
lib, lib,
rootPath, rootPath,
... ...
}: { }:
{
options = { options = {
flake = flake-parts-lib.mkSubmoduleOptions { flake = flake-parts-lib.mkSubmoduleOptions {
templates = lib.mkOption { templates = lib.mkOption {

View file

@ -2,7 +2,8 @@
pkgs, pkgs,
unixName, unixName,
... ...
}: { }:
{
youthlic = { youthlic = {
xdg-dirs.enable = true; xdg-dirs.enable = true;
programs = { programs = {

View file

@ -4,15 +4,18 @@
unixName, unixName,
config, config,
... ...
}: { }:
{
imports = lib.youthlic.loadImports ./.; imports = lib.youthlic.loadImports ./.;
youthlic = { youthlic = {
xdg-dirs.enable = true; xdg-dirs.enable = true;
programs = let programs =
let
email = config.accounts.email.accounts.ulic-youthlic; email = config.accounts.email.accounts.ulic-youthlic;
inherit (email) address name; inherit (email) address name;
signKey = email.gpg.key; signKey = email.gpg.key;
in { in
{
gpg.enable = true; gpg.enable = true;
git = { git = {
inherit name signKey; inherit name signKey;

View file

@ -2,13 +2,17 @@
config, config,
inputs, inputs,
... ...
}: let }:
let
inherit (inputs.niri-flake.lib.kdl) node leaf flag; inherit (inputs.niri-flake.lib.kdl) node leaf flag;
in { in
{
david.programs.niri = { david.programs.niri = {
waybar.settings = let waybar.settings =
let
cfg = config.david.programs.niri.waybar; cfg = config.david.programs.niri.waybar;
in [(cfg.template // (cfg.helper.mkBacklight "intel_backlight") // {output = "eDP-1";})]; in
[ (cfg.template // (cfg.helper.mkBacklight "intel_backlight") // { output = "eDP-1"; }) ];
wluma.extraSettings = { wluma.extraSettings = {
output = { output = {
backlight = [ backlight = [
@ -20,10 +24,14 @@ in {
]; ];
}; };
}; };
extraConfig = let extraConfig =
let
output = node "output"; output = node "output";
in [ in
(output ["eDP-1"] [ [
(output
[ "eDP-1" ]
[
(leaf "mode" [ "1920x1200@60.018" ]) (leaf "mode" [ "1920x1200@60.018" ])
(leaf "scale" [ 1.0 ]) (leaf "scale" [ 1.0 ])
(flag "focus-at-startup") (flag "focus-at-startup")
@ -34,7 +42,8 @@ in {
} }
]) ])
(leaf "transform" [ "normal" ]) (leaf "transform" [ "normal" ])
]) ]
)
]; ];
}; };
} }

View file

@ -4,15 +4,18 @@
config, config,
unixName, unixName,
... ...
}: { }:
{
imports = lib.youthlic.loadImports ./.; imports = lib.youthlic.loadImports ./.;
youthlic = { youthlic = {
xdg-dirs.enable = true; xdg-dirs.enable = true;
programs = let programs =
let
email = config.accounts.email.accounts.ulic-youthlic; email = config.accounts.email.accounts.ulic-youthlic;
inherit (email) name address; inherit (email) name address;
signKey = email.gpg.key; signKey = email.gpg.key;
in { in
{
rustypaste-cli.enable = true; rustypaste-cli.enable = true;
gpg.enable = true; gpg.enable = true;
jujutsu = { jujutsu = {

View file

@ -1,8 +1,11 @@
{config, ...}: { { config, ... }:
{
david.programs.niri = { david.programs.niri = {
waybar.settings = let waybar.settings =
let
cfg = config.david.programs.niri.waybar; cfg = config.david.programs.niri.waybar;
in [ in
[
(cfg.template // (cfg.helper.mkBacklight "ddcci13") // { output = "DP-3"; }) (cfg.template // (cfg.helper.mkBacklight "ddcci13") // { output = "DP-3"; })
(cfg.template // (cfg.helper.mkBacklight "nvidia_0") // { output = "eDP-1"; }) (cfg.template // (cfg.helper.mkBacklight "nvidia_0") // { output = "eDP-1"; })
]; ];

View file

@ -2,7 +2,8 @@
lib, lib,
pkgs, pkgs,
... ...
}: { }:
{
imports = lib.youthlic.loadImports ./.; imports = lib.youthlic.loadImports ./.;
config = { config = {
youthlic.programs = { youthlic.programs = {

View file

@ -2,9 +2,11 @@
config, config,
lib, lib,
... ...
}: let }:
let
cfg = config.david.accounts.email; cfg = config.david.accounts.email;
in { in
{
options = { options = {
david.accounts.email = { david.accounts.email = {
enable = lib.mkEnableOption "emails"; enable = lib.mkEnableOption "emails";

View file

@ -3,9 +3,11 @@
config, config,
pkgs, pkgs,
... ...
}: let }:
let
cfg = config.david.programs.alacritty; cfg = config.david.programs.alacritty;
in { in
{
options = { options = {
david.programs.alacritty = { david.programs.alacritty = {
enable = lib.mkEnableOption "alacritty"; enable = lib.mkEnableOption "alacritty";
@ -15,9 +17,7 @@ in {
programs.alacritty = { programs.alacritty = {
enable = true; enable = true;
package = pkgs.alacritty_git; package = pkgs.alacritty_git;
settings = settings = (./alacritty.toml |> builtins.readFile |> builtins.fromTOML) // {
(./alacritty.toml |> builtins.readFile |> builtins.fromTOML)
// {
colors = lib.mkForce { }; colors = lib.mkForce { };
font.size = lib.mkForce 16; font.size = lib.mkForce 16;
window.opacity = lib.mkForce 0.8; window.opacity = lib.mkForce 0.8;

View file

@ -2,9 +2,11 @@
lib, lib,
config, config,
... ...
}: let }:
let
cfg = config.david.programs.chromium; cfg = config.david.programs.chromium;
in { in
{
options = { options = {
david.programs.chromium = { david.programs.chromium = {
enable = lib.mkEnableOption "chromium"; enable = lib.mkEnableOption "chromium";

View file

@ -3,9 +3,11 @@
lib, lib,
pkgs, pkgs,
... ...
}: let }:
let
cfg = config.david.programs.espanso; cfg = config.david.programs.espanso;
in { in
{
options = { options = {
david.programs.espanso = { david.programs.espanso = {
enable = lib.mkEnableOption "espanso"; enable = lib.mkEnableOption "espanso";

View file

@ -3,9 +3,11 @@
lib, lib,
config, config,
... ...
}: let }:
let
cfg = config.david.programs.firefox; cfg = config.david.programs.firefox;
in { in
{
options = { options = {
david.programs.firefox = { david.programs.firefox = {
enable = lib.mkEnableOption "firefox"; enable = lib.mkEnableOption "firefox";

View file

@ -2,9 +2,11 @@
config, config,
lib, lib,
... ...
}: let }:
let
cfg = config.david.programs.foot; cfg = config.david.programs.foot;
in { in
{
options = { options = {
david.programs.foot = { david.programs.foot = {
enable = lib.mkEnableOption "foot"; enable = lib.mkEnableOption "foot";

View file

@ -2,9 +2,11 @@
config, config,
lib, lib,
... ...
}: let }:
let
cfg = config.david.programs.fuzzel; cfg = config.david.programs.fuzzel;
in { in
{
options = { options = {
david.programs.fuzzel = { david.programs.fuzzel = {
enable = lib.mkEnableOption "fuzzel"; enable = lib.mkEnableOption "fuzzel";

View file

@ -3,15 +3,18 @@
config, config,
lib, lib,
... ...
}: { }:
{
options = { options = {
david.programs.ghostty = { david.programs.ghostty = {
enable = lib.mkEnableOption "ghostty"; enable = lib.mkEnableOption "ghostty";
}; };
}; };
config = let config =
let
cfg = config.david.programs.ghostty; cfg = config.david.programs.ghostty;
in (lib.mkIf cfg.enable { in
(lib.mkIf cfg.enable {
programs.ghostty = lib.mkMerge [ programs.ghostty = lib.mkMerge [
{ {
enable = true; enable = true;

View file

@ -3,9 +3,11 @@
config, config,
pkgs, pkgs,
... ...
}: let }:
let
cfg = config.david.programs.helix; cfg = config.david.programs.helix;
in { in
{
options = { options = {
david.programs.helix = { david.programs.helix = {
enable = lib.mkEnableOption "helix"; enable = lib.mkEnableOption "helix";

View file

@ -2,9 +2,11 @@
lib, lib,
config, config,
... ...
}: let }:
let
cfg = config.david.programs.kanshi; cfg = config.david.programs.kanshi;
in { in
{
options = { options = {
david.programs.kanshi = { david.programs.kanshi = {
enable = lib.mkEnableOption "kanshi"; enable = lib.mkEnableOption "kanshi";

View file

@ -2,9 +2,11 @@
lib, lib,
config, config,
... ...
}: let }:
let
cfg = config.david.programs.mpv; cfg = config.david.programs.mpv;
in { in
{
options = { options = {
david.programs.mpv = { david.programs.mpv = {
enable = lib.mkEnableOption "mpv"; enable = lib.mkEnableOption "mpv";

View file

@ -5,10 +5,10 @@
inputs, inputs,
osConfig ? null, osConfig ? null,
... ...
}: let }:
let
inherit (lib) getExe getExe'; inherit (lib) getExe getExe';
inherit inherit (inputs.niri-flake.lib.kdl)
(inputs.niri-flake.lib.kdl)
# node with args, props and children # node with args, props and children
# node:: \lambda name -> [argOrProp] -> [child] -> Output # node:: \lambda name -> [argOrProp] -> [child] -> Output
# arg: single value # arg: single value
@ -44,13 +44,31 @@ in
( (
let let
spawn = leaf "spawn"; spawn = leaf "spawn";
in [ in
[
(plain "binds" [ (plain "binds" [
(plain "Mod+V" [ (plain "Mod+V" [
(spawn [ cliphist-fuzzel-img ]) (spawn [ cliphist-fuzzel-img ])
]) ])
(plain "Mod+Shift+P" [ (plain "Mod+Shift+P" [
(spawn [swaylock "--screenshots" "--clock" "--indicator" "--indicator-radius" "100" "--indicator-thickness" "7" "--effect-blur" "7x5" "--effect-vignette" "0.5:0.5" "--grace" "2" "--fade-in" "0.5"]) (spawn [
swaylock
"--screenshots"
"--clock"
"--indicator"
"--indicator-radius"
"100"
"--indicator-thickness"
"7"
"--effect-blur"
"7x5"
"--effect-vignette"
"0.5:0.5"
"--grace"
"2"
"--fade-in"
"0.5"
])
]) ])
(plain "Mod+Shift+Slash" [ (plain "Mod+Shift+Slash" [
(flag "show-hotkey-overlay") (flag "show-hotkey-overlay")
@ -66,24 +84,59 @@ in
(plain "Mod+Space" [ (plain "Mod+Space" [
(spawn [ fuzzel ]) (spawn [ fuzzel ])
]) ])
(node "XF86AudioRaiseVolume" [{allow-when-locked = true;}] [ (node "XF86AudioRaiseVolume"
(spawn [wpctl "set-volume" "@DEFAULT_AUDIO_SINK@" "0.1+"]) [ { allow-when-locked = true; } ]
[
(spawn [
wpctl
"set-volume"
"@DEFAULT_AUDIO_SINK@"
"0.1+"
]) ])
(node "XF86AudioLowerVolume" [{allow-when-locked = true;}] [ ]
(spawn [wpctl "set-volume" "@DEFAULT_AUDIO_SINK@" "0.1-"]) )
(node "XF86AudioLowerVolume"
[ { allow-when-locked = true; } ]
[
(spawn [
wpctl
"set-volume"
"@DEFAULT_AUDIO_SINK@"
"0.1-"
]) ])
(node "XF86AudioMute" [{allow-when-locked = true;}] [ ]
(spawn [wpctl "set-volume" "@DEFAULT_AUDIO_SINK@" "toggle"]) )
(node "XF86AudioMute"
[ { allow-when-locked = true; } ]
[
(spawn [
wpctl
"set-volume"
"@DEFAULT_AUDIO_SINK@"
"toggle"
]) ])
(node "XF86AudioMicMute" [{allow-when-locked = true;}] [ ]
(spawn [wpctl "set-volume" "@DEFAULT_AUDIO_SOURCE@" "toggle"]) )
(node "XF86AudioMicMute"
[ { allow-when-locked = true; } ]
[
(spawn [
wpctl
"set-volume"
"@DEFAULT_AUDIO_SOURCE@"
"toggle"
]) ])
]
)
(plain "Mod+Q" [ (plain "Mod+Q" [
(flag "close-window") (flag "close-window")
]) ])
(node "Mod+O" [{repeat = false;}] [ (node "Mod+O"
[ { repeat = false; } ]
[
(flag "toggle-overview") (flag "toggle-overview")
]) ]
)
(plain "Mod+Left" [ (plain "Mod+Left" [
(flag "focus-column-left") (flag "focus-column-left")
]) ])
@ -228,12 +281,18 @@ in
(plain "Mod+Ctrl+I" [ (plain "Mod+Ctrl+I" [
(flag "move-workspace-up") (flag "move-workspace-up")
]) ])
(node "Mod+Shift+WheelScrollDown" [{cooldown-ms = 150;}] [ (node "Mod+Shift+WheelScrollDown"
[ { cooldown-ms = 150; } ]
[
(flag "focus-workspace-down") (flag "focus-workspace-down")
]) ]
(node "Mod+Shift+WheelScrollUp" [{cooldown-ms = 150;}] [ )
(node "Mod+Shift+WheelScrollUp"
[ { cooldown-ms = 150; } ]
[
(flag "focus-workspace-up") (flag "focus-workspace-up")
]) ]
)
(plain "Mod+WheelScrollDown" [ (plain "Mod+WheelScrollDown" [
(flag "focus-column-right") (flag "focus-column-right")
]) ])
@ -318,36 +377,60 @@ in
(plain "Mod+Period" [ (plain "Mod+Period" [
(flag "expel-window-from-column") (flag "expel-window-from-column")
]) ])
(node "Mod+R" [{repeat = false;}] [ (node "Mod+R"
[ { repeat = false; } ]
[
(flag "switch-preset-column-width") (flag "switch-preset-column-width")
]) ]
(node "Mod+Shift+R" [{repeat = false;}] [ )
(node "Mod+Shift+R"
[ { repeat = false; } ]
[
(flag "switch-preset-window-height") (flag "switch-preset-window-height")
]) ]
)
(plain "Mod+Ctrl+R" [ (plain "Mod+Ctrl+R" [
(flag "reset-window-height") (flag "reset-window-height")
]) ])
(node "Mod+M" [{repeat = false;}] [ (node "Mod+M"
[ { repeat = false; } ]
[
(flag "maximize-column") (flag "maximize-column")
]) ]
(node "Mod+Shift+M" [{repeat = false;}] [ )
(node "Mod+Shift+M"
[ { repeat = false; } ]
[
(flag "fullscreen-window") (flag "fullscreen-window")
]) ]
)
(plain "Mod+Z" [ (plain "Mod+Z" [
(flag "center-column") (flag "center-column")
]) ])
(node "Mod+Minus" [{repeat = false;}] [ (node "Mod+Minus"
[ { repeat = false; } ]
[
(leaf "set-column-width" [ "-10%" ]) (leaf "set-column-width" [ "-10%" ])
]) ]
(node "Mod+Equal" [{repeat = false;}] [ )
(node "Mod+Equal"
[ { repeat = false; } ]
[
(leaf "set-column-width" [ "+10%" ]) (leaf "set-column-width" [ "+10%" ])
]) ]
(node "Mod+Shift+Minus" [{repeat = false;}] [ )
(node "Mod+Shift+Minus"
[ { repeat = false; } ]
[
(leaf "set-window-height" [ "-10%" ]) (leaf "set-window-height" [ "-10%" ])
]) ]
(node "Mod+Shift+Equal" [{repeat = false;}] [ )
(node "Mod+Shift+Equal"
[ { repeat = false; } ]
[
(leaf "set-window-height" [ "+10%" ]) (leaf "set-window-height" [ "+10%" ])
]) ]
)
(plain "Print" [ (plain "Print" [
(flag "screenshot") (flag "screenshot")
]) ])
@ -378,7 +461,8 @@ in
++ ( ++ (
let let
spawn-at-startup = leaf "spawn-at-startup"; spawn-at-startup = leaf "spawn-at-startup";
in [ in
[
(leaf "screenshot-path" [ "${config.xdg.userDirs.pictures}/screenshots/%Y-%m-%d_%H:%M:%S.png" ]) (leaf "screenshot-path" [ "${config.xdg.userDirs.pictures}/screenshots/%Y-%m-%d_%H:%M:%S.png" ])
(plain "hotkey-overlay" [ (plain "hotkey-overlay" [
(flag "skip-at-startup") (flag "skip-at-startup")
@ -386,11 +470,26 @@ in
(flag "prefer-no-csd") (flag "prefer-no-csd")
(spawn-at-startup [ waybar ]) (spawn-at-startup [ waybar ])
(spawn-at-startup [ swaync ]) (spawn-at-startup [ swaync ])
(spawn-at-startup [waypaper "--restore"]) (spawn-at-startup [
waypaper
"--restore"
])
(spawn-at-startup [ polkit-kde-agent ]) (spawn-at-startup [ polkit-kde-agent ])
(spawn-at-startup [wl-paste "--watch" cliphist "store"]) (spawn-at-startup [
(spawn-at-startup [wl-clip-persist "--clipboard" "regular"]) wl-paste
(spawn-at-startup [fcitx5 "--replace"]) "--watch"
cliphist
"store"
])
(spawn-at-startup [
wl-clip-persist
"--clipboard"
"regular"
])
(spawn-at-startup [
fcitx5
"--replace"
])
(plain "input" [ (plain "input" [
(plain "touchpad" [ (plain "touchpad" [
(leaf "click-method" [ "clickfinger" ]) (leaf "click-method" [ "clickfinger" ])
@ -459,7 +558,8 @@ in
let let
window-rule = plain "window-rule"; window-rule = plain "window-rule";
match = leaf "match"; match = leaf "match";
in [ in
[
(window-rule [ (window-rule [
(leaf "draw-border-with-background" [ true ]) (leaf "draw-border-with-background" [ true ])
(leaf "geometry-corner-radius" [ 12.0 ]) (leaf "geometry-corner-radius" [ 12.0 ])
@ -543,7 +643,8 @@ in
let let
layer-rule = plain "layer-rule"; layer-rule = plain "layer-rule";
match = leaf "match"; match = leaf "match";
in [ in
[
(layer-rule [ (layer-rule [
(match [ { namespace = "^swaync-notification-window$"; } ]) (match [ { namespace = "^swaync-notification-window$"; } ])
(match [ { namespace = "^swaync-control-center$"; } ]) (match [ { namespace = "^swaync-control-center$"; } ])

View file

@ -6,10 +6,12 @@
osConfig ? null, osConfig ? null,
options, options,
... ...
} @ args: let }@args:
let
cfg = config.david.programs.niri; cfg = config.david.programs.niri;
niri = osConfig.programs.niri.package; niri = osConfig.programs.niri.package;
in { in
{
options = { options = {
david.programs.niri = { david.programs.niri = {
enable = lib.mkEnableOption "niri"; enable = lib.mkEnableOption "niri";
@ -40,8 +42,7 @@ in {
{ {
david.programs.niri.enable = osConfig.youthlic.gui.enabled == "niri"; david.programs.niri.enable = osConfig.youthlic.gui.enabled == "niri";
} }
( (lib.mkIf cfg.enable {
lib.mkIf cfg.enable {
home.packages = home.packages =
(with pkgs; [ (with pkgs; [
swaynotificationcenter swaynotificationcenter
@ -61,16 +62,17 @@ in {
!niri.cargoBuildNoDefaultFeatures || builtins.elem "xdp-gnome-screencast" niri.cargoBuildFeatures !niri.cargoBuildNoDefaultFeatures || builtins.elem "xdp-gnome-screencast" niri.cargoBuildFeatures
) [ pkgs.xdg-desktop-portal-gnome ]; ) [ pkgs.xdg-desktop-portal-gnome ];
}; };
xdg.configFile = let xdg.configFile =
qtctConf = let
'' qtctConf = ''
[Appearance] [Appearance]
standard_dialogs=xdgdesktopportal standard_dialogs=xdgdesktopportal
'' ''
+ lib.optionalString (config.qt.style ? name) '' + lib.optionalString (config.qt.style ? name) ''
style=${config.qt.style.name} style=${config.qt.style.name}
''; '';
in { in
{
"qt5ct/qt5ct.conf" = lib.mkForce { "qt5ct/qt5ct.conf" = lib.mkForce {
text = qtctConf; text = qtctConf;
}; };
@ -95,11 +97,9 @@ in {
}; };
programs.niri = { programs.niri = {
config = config =
(lib.toList (import ./config.nix (args // {inherit pkgs;}))) (lib.toList (import ./config.nix (args // { inherit pkgs; }))) ++ (lib.toList cfg.extraConfig);
++ (lib.toList cfg.extraConfig);
package = niri; package = niri;
}; };
} })
)
]; ];
} }

View file

@ -3,9 +3,11 @@
config, config,
lib, lib,
... ...
}: let }:
let
cfg = config.david.programs.openssh; cfg = config.david.programs.openssh;
in { in
{
options = { options = {
david.programs.openssh = { david.programs.openssh = {
enable = lib.mkEnableOption "openssh"; enable = lib.mkEnableOption "openssh";

View file

@ -3,9 +3,11 @@
config, config,
lib, lib,
... ...
}: let }:
let
cfg = config.david.programs.swaylock; cfg = config.david.programs.swaylock;
in { in
{
options = { options = {
david.programs.swaylock = { david.programs.swaylock = {
enable = lib.mkEnableOption "swaylock"; enable = lib.mkEnableOption "swaylock";

View file

@ -2,9 +2,11 @@
lib, lib,
config, config,
... ...
}: let }:
let
cfg = config.david.programs.swaync; cfg = config.david.programs.swaync;
in { in
{
options = { options = {
david.programs.swaync = { david.programs.swaync = {
enable = lib.mkEnableOption "swaync"; enable = lib.mkEnableOption "swaync";

View file

@ -2,9 +2,11 @@
config, config,
lib, lib,
... ...
}: let }:
let
cfg = config.david.programs.thunderbird; cfg = config.david.programs.thunderbird;
in { in
{
options = { options = {
david.programs.thunderbird = { david.programs.thunderbird = {
enable = lib.mkEnableOption "thunderbird"; enable = lib.mkEnableOption "thunderbird";

View file

@ -4,9 +4,11 @@
lib, lib,
options, options,
... ...
}: let }:
let
cfg = config.david.programs.waybar; cfg = config.david.programs.waybar;
in { in
{
options = { options = {
david.programs.waybar = { david.programs.waybar = {
enable = lib.mkEnableOption "waybar"; enable = lib.mkEnableOption "waybar";

View file

@ -3,16 +3,22 @@
config, config,
pkgs, pkgs,
... ...
}: let }:
let
cfg = config.david.programs.waypaper; cfg = config.david.programs.waypaper;
in { in
{
options = { options = {
david.programs.waypaper = { david.programs.waypaper = {
enable = lib.mkEnableOption "waypaper"; enable = lib.mkEnableOption "waypaper";
}; };
}; };
config = lib.mkIf cfg.enable { config = lib.mkIf cfg.enable {
home.packages = with pkgs; [waypaper socat mpvpaper]; home.packages = with pkgs; [
waypaper
socat
mpvpaper
];
systemd.user = { systemd.user = {
timers."waypaper" = { timers."waypaper" = {
Unit = { Unit = {

View file

@ -3,9 +3,11 @@
config, config,
options, options,
... ...
}: let }:
let
cfg = config.david.programs.wluma; cfg = config.david.programs.wluma;
in { in
{
options = { options = {
david.programs.wluma = { david.programs.wluma = {
enable = lib.mkEnableOption "wluma"; enable = lib.mkEnableOption "wluma";
@ -33,8 +35,7 @@ in {
config = lib.mkIf cfg.enable { config = lib.mkIf cfg.enable {
services.wluma = { services.wluma = {
enable = true; enable = true;
settings = settings = {
{
als = { als = {
webcam = { webcam = {
video = 0; video = 0;

View file

@ -3,9 +3,11 @@
config, config,
lib, lib,
... ...
}: let }:
let
cfg = config.david.programs.zed-editor; cfg = config.david.programs.zed-editor;
in { in
{
options = { options = {
david.programs.zed-editor = { david.programs.zed-editor = {
enable = lib.mkEnableOption "zed-editor"; enable = lib.mkEnableOption "zed-editor";
@ -63,7 +65,11 @@ in {
}; };
languages = { languages = {
Python = { Python = {
language_servers = ["ty" "ruff" "pyright"]; language_servers = [
"ty"
"ruff"
"pyright"
];
formatter = [ formatter = [
{ {
language_server = { language_server = {
@ -79,11 +85,13 @@ in {
]; ];
}; };
Nix = { Nix = {
language_servers = ["nixd" "nil"]; language_servers = [
"nixd"
"nil"
];
formatter = { formatter = {
external = { external = {
command = "alejandra"; command = "nixfmt";
arguments = ["--quiet" "--"];
}; };
}; };
}; };

View file

@ -3,9 +3,11 @@
config, config,
pkgs, pkgs,
... ...
}: let }:
let
cfg = config.david.wallpaper; cfg = config.david.wallpaper;
in { in
{
options = { options = {
david.wallpaper = { david.wallpaper = {
enable = lib.mkEnableOption "wallpaper"; enable = lib.mkEnableOption "wallpaper";

View file

@ -2,7 +2,8 @@
lib, lib,
inputs, inputs,
... ...
}: { }:
{
imports = imports =
(with inputs; [ (with inputs; [
niri-flake.homeModules.niri niri-flake.homeModules.niri

View file

@ -4,7 +4,8 @@
pkgs, pkgs,
inputs, inputs,
... ...
}: { }:
{
config = { config = {
nixpkgs = { nixpkgs = {
config = { config = {

View file

@ -2,7 +2,8 @@
lib, lib,
inputs, inputs,
... ...
}: { }:
{
imports = imports =
(with inputs; [ (with inputs; [
sops-nix.homeManagerModules.sops sops-nix.homeManagerModules.sops

View file

@ -2,7 +2,8 @@
osConfig ? null, osConfig ? null,
lib, lib,
... ...
}: { }:
{
config = lib.mkIf (osConfig != null) { config = lib.mkIf (osConfig != null) {
xdg.dataFile = { xdg.dataFile = {
"fcitx5/rime/default.custom.yaml".source = ./default.custom.yaml; "fcitx5/rime/default.custom.yaml".source = ./default.custom.yaml;

View file

@ -2,9 +2,11 @@
lib, lib,
config, config,
... ...
}: let }:
let
cfg = config.youthlic.programs.atuin; cfg = config.youthlic.programs.atuin;
in { in
{
options = { options = {
youthlic.programs.atuin = { youthlic.programs.atuin = {
enable = lib.mkEnableOption "atuin"; enable = lib.mkEnableOption "atuin";

View file

@ -3,9 +3,11 @@
lib, lib,
pkgs, pkgs,
... ...
}: let }:
let
cfg = config.youthlic.programs.awscli; cfg = config.youthlic.programs.awscli;
in { in
{
options = { options = {
youthlic.programs.awscli = { youthlic.programs.awscli = {
enable = lib.mkEnableOption "awscli"; enable = lib.mkEnableOption "awscli";

View file

@ -2,9 +2,11 @@
config, config,
lib, lib,
... ...
}: let }:
let
cfg = config.youthlic.programs.bash; cfg = config.youthlic.programs.bash;
in { in
{
options = { options = {
youthlic.programs.bash = { youthlic.programs.bash = {
enable = lib.mkEnableOption "bash"; enable = lib.mkEnableOption "bash";

View file

@ -3,9 +3,11 @@
lib, lib,
pkgs, pkgs,
... ...
}: let }:
let
cfg = config.youthlic.programs.doom; cfg = config.youthlic.programs.doom;
in { in
{
options = { options = {
youthlic.programs.doom = { youthlic.programs.doom = {
enable = lib.mkEnableOption "doom"; enable = lib.mkEnableOption "doom";
@ -16,8 +18,8 @@ in {
programs.doom-emacs = { programs.doom-emacs = {
enable = true; enable = true;
emacs = pkgs.emacs-pgtk; emacs = pkgs.emacs-pgtk;
extraPackages = emacsPackages: extraPackages =
with emacsPackages; [ emacsPackages: with emacsPackages; [
melpaPackages.telega melpaPackages.telega
]; ];
extraBinPackages = with pkgs; [ extraBinPackages = with pkgs; [

View file

@ -2,12 +2,14 @@
config, config,
lib, lib,
... ...
}: let }:
let
cfg = config.youthlic.programs.eza; cfg = config.youthlic.programs.eza;
fish-cfg = config.youthlic.programs.fish; fish-cfg = config.youthlic.programs.fish;
bash-cfg = config.youthlic.programs.bash; bash-cfg = config.youthlic.programs.bash;
ion-cfg = config.youthlic.programs.ion; ion-cfg = config.youthlic.programs.ion;
in { in
{
options = { options = {
youthlic.programs.eza = { youthlic.programs.eza = {
enable = lib.mkEnableOption "eza"; enable = lib.mkEnableOption "eza";

View file

@ -2,9 +2,11 @@
config, config,
lib, lib,
... ...
}: let }:
let
cfg = config.youthlic.programs.fish; cfg = config.youthlic.programs.fish;
in { in
{
options = { options = {
youthlic.programs.fish = { youthlic.programs.fish = {
enable = lib.mkEnableOption "fish"; enable = lib.mkEnableOption "fish";

View file

@ -2,11 +2,13 @@
config, config,
lib, lib,
... ...
}: let }:
let
cfg = config.youthlic.programs.fzf; cfg = config.youthlic.programs.fzf;
fish-cfg = config.youthlic.programs.fish; fish-cfg = config.youthlic.programs.fish;
bash-cfg = config.youthlic.programs.bash; bash-cfg = config.youthlic.programs.bash;
in { in
{
options = { options = {
youthlic.programs.fzf = { youthlic.programs.fzf = {
enable = lib.mkEnableOption "fzf"; enable = lib.mkEnableOption "fzf";

View file

@ -2,7 +2,8 @@
config, config,
lib, lib,
... ...
}: { }:
{
options = { options = {
youthlic.programs.git = { youthlic.programs.git = {
email = lib.mkOption { email = lib.mkOption {
@ -30,7 +31,8 @@
encrypt-credential = lib.mkEnableOption "encrypt git credential"; encrypt-credential = lib.mkEnableOption "encrypt git credential";
}; };
}; };
config = let config =
let
cfg = config.youthlic.programs.git; cfg = config.youthlic.programs.git;
in in
lib.mkMerge [ lib.mkMerge [

View file

@ -4,13 +4,15 @@
lib, lib,
outputs, outputs,
... ...
}: { }:
{
options = { options = {
youthlic.programs.gpg = { youthlic.programs.gpg = {
enable = lib.mkEnableOption "gpg"; enable = lib.mkEnableOption "gpg";
}; };
}; };
config = let config =
let
cfg = config.youthlic.programs.gpg; cfg = config.youthlic.programs.gpg;
in in
lib.mkIf cfg.enable { lib.mkIf cfg.enable {

View file

@ -3,15 +3,20 @@
pkgs, pkgs,
config, config,
... ...
}: let }:
let
cfg = config.youthlic.programs.helix; cfg = config.youthlic.programs.helix;
defaultLanguagesSettings = config.programs.helix.package.passthru.languages.language; defaultLanguagesSettings = config.programs.helix.package.passthru.languages.language;
in { in
{
options = { options = {
youthlic.programs.helix = { youthlic.programs.helix = {
enable = lib.mkEnableOption "helix"; enable = lib.mkEnableOption "helix";
languageSettings = lib.mkOption { languageSettings = lib.mkOption {
type = lib.types.attrsOf (lib.types.submodule ({...}: { type = lib.types.attrsOf (
lib.types.submodule (
{ ... }:
{
freeformType = lib.types.anything; freeformType = lib.types.anything;
options = { options = {
language-servers = lib.mkOption { language-servers = lib.mkOption {
@ -21,7 +26,9 @@ in {
apply = lib.unique; apply = lib.unique;
}; };
}; };
})); }
)
);
default = lib.pipe defaultLanguagesSettings [ default = lib.pipe defaultLanguagesSettings [
(map (lang: lib.nameValuePair lang.name (lib.removeAttrs lang [ "name" ]))) (map (lang: lib.nameValuePair lang.name (lib.removeAttrs lang [ "name" ])))
lib.listToAttrs lib.listToAttrs
@ -32,7 +39,8 @@ in {
type = lib.types.listOf lib.types.package; type = lib.types.listOf lib.types.package;
default = [ ]; default = [ ];
example = ( example = (
with pkgs; [ with pkgs;
[
deno deno
] ]
); );
@ -49,9 +57,7 @@ in {
defaultEditor = true; defaultEditor = true;
extraPackages = cfg.extraPackages; extraPackages = cfg.extraPackages;
settings = ./config.toml |> builtins.readFile |> builtins.fromTOML; settings = ./config.toml |> builtins.readFile |> builtins.fromTOML;
languages = languages = lib.recursiveUpdate {
lib.recursiveUpdate
{
language-server = { language-server = {
neocmakelsp = { neocmakelsp = {
command = "neocmakelsp"; command = "neocmakelsp";
@ -75,8 +81,7 @@ in {
command = "typos-lsp"; command = "typos-lsp";
}; };
}; };
} } { language = cfg.languageSettings; };
{language = cfg.languageSettings;};
}; };
}) })
(lib.mkIf cfg.enable { (lib.mkIf cfg.enable {
@ -88,7 +93,10 @@ in {
(lib.mkIf cfg.enable { (lib.mkIf cfg.enable {
youthlic.programs.helix.languageSettings = youthlic.programs.helix.languageSettings =
lib.recursiveUpdate lib.recursiveUpdate
(lib.pipe defaultLanguagesSettings [(map (lang: lib.nameValuePair lang.name (lib.removeAttrs lang ["name"]))) lib.listToAttrs]) (lib.pipe defaultLanguagesSettings [
(map (lang: lib.nameValuePair lang.name (lib.removeAttrs lang [ "name" ])))
lib.listToAttrs
])
{ {
cmake = { cmake = {
language-servers = [ language-servers = [
@ -115,7 +123,7 @@ in {
}; };
nix = { nix = {
formatter = { formatter = {
command = "alejandra"; command = "nixfmt";
}; };
}; };
xml = { xml = {

View file

@ -2,9 +2,11 @@
lib, lib,
config, config,
... ...
}: let }:
let
cfg = config.youthlic.programs.ion; cfg = config.youthlic.programs.ion;
in { in
{
options = { options = {
youthlic.programs.ion = { youthlic.programs.ion = {
enable = lib.mkEnableOption "ion"; enable = lib.mkEnableOption "ion";

View file

@ -3,9 +3,11 @@
config, config,
lib, lib,
... ...
}: let }:
let
cfg = config.youthlic.programs.jujutsu; cfg = config.youthlic.programs.jujutsu;
in { in
{
options = { options = {
youthlic.programs.jujutsu = { youthlic.programs.jujutsu = {
enable = lib.mkEnableOption "jujutsu"; enable = lib.mkEnableOption "jujutsu";

View file

@ -2,9 +2,11 @@
config, config,
lib, lib,
... ...
}: let }:
let
cfg = config.youthlic.programs.kvm; cfg = config.youthlic.programs.kvm;
in { in
{
options = { options = {
youthlic.programs.kvm = { youthlic.programs.kvm = {
enable = lib.mkEnableOption "kvm"; enable = lib.mkEnableOption "kvm";

View file

@ -3,9 +3,11 @@
lib, lib,
pkgs, pkgs,
... ...
}: let }:
let
cfg = config.youthlic.programs.rustypaste-cli; cfg = config.youthlic.programs.rustypaste-cli;
in { in
{
options = { options = {
youthlic.programs.rustypaste-cli = { youthlic.programs.rustypaste-cli = {
enable = lib.mkEnableOption "rustypaste-cli"; enable = lib.mkEnableOption "rustypaste-cli";

View file

@ -4,7 +4,8 @@
pkgs, pkgs,
rootPath, rootPath,
... ...
}: { }:
{
options = { options = {
youthlic.programs.sops = { youthlic.programs.sops = {
enable = lib.mkOption { enable = lib.mkOption {
@ -24,12 +25,14 @@
}; };
}; };
}; };
config = let config =
let
cfg = config.youthlic.programs.sops; cfg = config.youthlic.programs.sops;
in in
lib.mkIf cfg.enable { lib.mkIf cfg.enable {
home.packages = ( home.packages = (
with pkgs; [ with pkgs;
[
sops sops
age age
] ]

View file

@ -2,30 +2,31 @@
lib, lib,
config, config,
... ...
}: let }:
let
cfg = config.youthlic.programs.starship; cfg = config.youthlic.programs.starship;
fish-cfg = config.youthlic.programs.fish; fish-cfg = config.youthlic.programs.fish;
bash-cfg = config.youthlic.programs.bash; bash-cfg = config.youthlic.programs.bash;
ion-cfg = config.youthlic.programs.ion; ion-cfg = config.youthlic.programs.ion;
in { in
{
options = { options = {
youthlic.programs.starship = { youthlic.programs.starship = {
enable = lib.mkEnableOption "starship"; enable = lib.mkEnableOption "starship";
}; };
}; };
config = lib.mkMerge [ config = lib.mkMerge [
( (lib.mkIf cfg.enable {
lib.mkIf cfg.enable {
programs.starship = { programs.starship = {
enable = true; enable = true;
enableTransience = true; enableTransience = true;
settings = let settings =
let
config-file = builtins.readFile ./config.toml; config-file = builtins.readFile ./config.toml;
in in
builtins.fromTOML config-file; builtins.fromTOML config-file;
}; };
} })
)
(lib.mkIf (cfg.enable && fish-cfg.enable) { (lib.mkIf (cfg.enable && fish-cfg.enable) {
programs.starship.enableFishIntegration = true; programs.starship.enableFishIntegration = true;
programs.fish.functions = { programs.fish.functions = {

View file

@ -3,11 +3,13 @@
lib, lib,
pkgs, pkgs,
... ...
}: let }:
let
cfg = config.youthlic.programs.yazi; cfg = config.youthlic.programs.yazi;
fish-cfg = config.youthlic.programs.fish; fish-cfg = config.youthlic.programs.fish;
bash-cfg = config.youthlic.programs.bash; bash-cfg = config.youthlic.programs.bash;
in { in
{
options = { options = {
youthlic.programs.yazi = { youthlic.programs.yazi = {
enable = lib.mkEnableOption "yazi"; enable = lib.mkEnableOption "yazi";
@ -21,7 +23,15 @@ in {
programs.yazi = { programs.yazi = {
enable = true; enable = true;
plugins = { plugins = {
inherit (pkgs.yaziPlugins) ouch starship piper chmod smart-enter git full-border; inherit (pkgs.yaziPlugins)
ouch
starship
piper
chmod
smart-enter
git
full-border
;
}; };
initLua = initLua =
#lua #lua
@ -63,7 +73,10 @@ in {
mgr = { mgr = {
prepend_keymap = [ prepend_keymap = [
{ {
on = ["c" "m"]; on = [
"c"
"m"
];
run = "plugin chmod"; run = "plugin chmod";
desc = "Chmod on selected files"; desc = "Chmod on selected files";
} }

View file

@ -2,11 +2,13 @@
config, config,
lib, lib,
... ...
}: let }:
let
cfg = config.youthlic.programs.zoxide; cfg = config.youthlic.programs.zoxide;
fish-cfg = config.youthlic.programs.fish; fish-cfg = config.youthlic.programs.fish;
bash-cfg = config.youthlic.programs.bash; bash-cfg = config.youthlic.programs.bash;
in { in
{
options = { options = {
youthlic.programs.zoxide = { youthlic.programs.zoxide = {
enable = lib.mkEnableOption "zoxide"; enable = lib.mkEnableOption "zoxide";

View file

@ -2,9 +2,11 @@
lib, lib,
config, config,
... ...
}: let }:
let
cfg = config.youthlic.xdg-dirs; cfg = config.youthlic.xdg-dirs;
in { in
{
options = { options = {
youthlic.xdg-dirs = { youthlic.xdg-dirs = {
enable = lib.mkEnableOption "xdg-dirs"; enable = lib.mkEnableOption "xdg-dirs";

View file

@ -1,34 +1,37 @@
final: _prev: { final: _prev: {
youthlic = { youthlic = {
loadImports' = dir: f: loadImports' =
dir: f:
final.pipe dir [ final.pipe dir [
final.youthlic.loadImports final.youthlic.loadImports
f f
]; ];
loadImports = dir: loadImports =
dir:
with final; with final;
if !(pathExists dir && builtins.readFileType dir == "directory") if !(pathExists dir && builtins.readFileType dir == "directory") then
then [] [ ]
else let else
items = pipe dir [builtins.readDir attrNames]; let
items = pipe dir [
builtins.readDir
attrNames
];
in in
pipe items [ pipe items [
(concatMap (concatMap (
(name: let name:
let
path = dir + "/${name}"; path = dir + "/${name}";
type = builtins.readFileType path; type = builtins.readFileType path;
in in
if type == "directory" if type == "directory" then
then if pathExists (path + "/default.nix") then [ path ] else youthlic.loadImports path
if pathExists (path + "/default.nix") else if type == "regular" then
then [path] if hasSuffix ".nix" name then [ path ] else [ ]
else youthlic.loadImports path else
else if type == "regular" [ ]
then ))
if hasSuffix ".nix" name
then [path]
else []
else []))
(filter (name: !hasSuffix "/default.nix" (toString name))) (filter (name: !hasSuffix "/default.nix" (toString name)))
]; ];
}; };

View file

@ -4,7 +4,8 @@
lib, lib,
outputs, outputs,
... ...
}: { }:
{
imports = imports =
(with inputs.nixos-hardware.nixosModules; [ (with inputs.nixos-hardware.nixosModules; [
common-cpu-intel common-cpu-intel
@ -77,7 +78,11 @@
loader.efi.canTouchEfiVariables = true; loader.efi.canTouchEfiVariables = true;
kernelParams = [ "i915.enable_guc=2" ]; kernelParams = [ "i915.enable_guc=2" ];
}; };
nix = {settings = {system-features = ["gccarch-skylake"];};}; nix = {
settings = {
system-features = [ "gccarch-skylake" ];
};
};
hardware = { hardware = {
graphics.package = pkgs.mesa_git; graphics.package = pkgs.mesa_git;
intelgpu = { intelgpu = {

View file

@ -1,4 +1,5 @@
{...}: { { ... }:
{
youthlic.gui = { youthlic.gui = {
enabled = "niri"; enabled = "niri";
}; };

View file

@ -7,12 +7,20 @@
pkgs, pkgs,
modulesPath, modulesPath,
... ...
}: { }:
{
imports = [ imports = [
(modulesPath + "/installer/scan/not-detected.nix") (modulesPath + "/installer/scan/not-detected.nix")
]; ];
boot.initrd.availableKernelModules = ["xhci_pci" "ahci" "nvme" "usbhid" "usb_storage" "sd_mod"]; boot.initrd.availableKernelModules = [
"xhci_pci"
"ahci"
"nvme"
"usbhid"
"usb_storage"
"sd_mod"
];
boot.initrd.kernelModules = [ ]; boot.initrd.kernelModules = [ ];
boot.kernelModules = [ ]; boot.kernelModules = [ ];
boot.extraModulePackages = [ ]; boot.extraModulePackages = [ ];

View file

@ -1,4 +1,5 @@
{...}: { { ... }:
{
systemd.network = { systemd.network = {
enable = true; enable = true;
wait-online.enable = false; wait-online.enable = false;

View file

@ -2,7 +2,8 @@
pkgs, pkgs,
rootPath, rootPath,
... ...
}: { }:
{
stylix = { stylix = {
enable = true; enable = true;
image = rootPath + "/assets/wallpaper/01.png"; image = rootPath + "/assets/wallpaper/01.png";

View file

@ -2,7 +2,8 @@
lib, lib,
pkgs, pkgs,
... ...
}: { }:
{
users = { users = {
mutableUsers = true; mutableUsers = true;
users.david = { users.david = {

View file

@ -3,9 +3,9 @@
lib, lib,
outputs, outputs,
... ...
}: { }:
imports = {
[ imports = [
outputs.nixosModules.default outputs.nixosModules.default
] ]
++ (lib.youthlic.loadImports ./.); ++ (lib.youthlic.loadImports ./.);

View file

@ -1,4 +1,5 @@
{config, ...}: { { config, ... }:
{
youthlic.containers.forgejo = { youthlic.containers.forgejo = {
enable = true; enable = true;
domain = "forgejo.youthlic.social"; domain = "forgejo.youthlic.social";

View file

@ -7,12 +7,19 @@
pkgs, pkgs,
modulesPath, modulesPath,
... ...
}: { }:
{
imports = [ imports = [
(modulesPath + "/profiles/qemu-guest.nix") (modulesPath + "/profiles/qemu-guest.nix")
]; ];
boot.initrd.availableKernelModules = ["ata_piix" "uhci_hcd" "virtio_pci" "sr_mod" "virtio_blk"]; boot.initrd.availableKernelModules = [
"ata_piix"
"uhci_hcd"
"virtio_pci"
"sr_mod"
"virtio_blk"
];
boot.initrd.kernelModules = [ ]; boot.initrd.kernelModules = [ ];
boot.kernelModules = [ ]; boot.kernelModules = [ ];
boot.extraModulePackages = [ ]; boot.extraModulePackages = [ ];

View file

@ -1,4 +1,5 @@
{config, ...}: { { config, ... }:
{
sops.secrets."miniflux" = { sops.secrets."miniflux" = {
}; };
youthlic.containers.miniflux = { youthlic.containers.miniflux = {

View file

@ -1,4 +1,5 @@
{...}: { { ... }:
{
systemd.network = { systemd.network = {
enable = true; enable = true;
wait-online.enable = true; wait-online.enable = true;

View file

@ -1,4 +1,5 @@
{config, ...}: { { config, ... }:
{
sops.secrets."ssh-private-key/radicle/Cape" = { }; sops.secrets."ssh-private-key/radicle/Cape" = { };
youthlic.programs.radicle = { youthlic.programs.radicle = {
enable = true; enable = true;

View file

@ -1,4 +1,5 @@
{...}: { { ... }:
{
stylix = { stylix = {
enable = false; enable = false;
}; };

View file

@ -1,4 +1,5 @@
{pkgs, ...}: { { pkgs, ... }:
{
users.users.alice = { users.users.alice = {
initialHashedPassword = "$y$j9T$eS5zCi4W.4IPpf3P8Tb/o1$xhumXY1.PJKmTguNi/zlljLbLemNGiubWoUEc878S36"; initialHashedPassword = "$y$j9T$eS5zCi4W.4IPpf3P8Tb/o1$xhumXY1.PJKmTguNi/zlljLbLemNGiubWoUEc878S36";
isNormalUser = true; isNormalUser = true;

View file

@ -4,7 +4,8 @@
inputs, inputs,
outputs, outputs,
... ...
}: { }:
{
imports = imports =
(with inputs.nixos-hardware.nixosModules; [ (with inputs.nixos-hardware.nixosModules; [
common-hidpi common-hidpi

View file

@ -1,4 +1,5 @@
{...}: { { ... }:
{
disko.devices = { disko.devices = {
disk = { disk = {
disk1 = { disk1 = {

View file

@ -1,4 +1,5 @@
{...}: { { ... }:
{
youthlic.gui = { youthlic.gui = {
enabled = "niri"; enabled = "niri";
}; };

View file

@ -7,12 +7,19 @@
pkgs, pkgs,
modulesPath, modulesPath,
... ...
}: { }:
{
imports = [ imports = [
(modulesPath + "/installer/scan/not-detected.nix") (modulesPath + "/installer/scan/not-detected.nix")
]; ];
boot.initrd.availableKernelModules = ["xhci_pci" "thunderbolt" "nvme" "usb_storage" "sd_mod"]; boot.initrd.availableKernelModules = [
"xhci_pci"
"thunderbolt"
"nvme"
"usb_storage"
"sd_mod"
];
boot.initrd.kernelModules = [ ]; boot.initrd.kernelModules = [ ];
boot.kernelModules = [ "kvm-intel" ]; boot.kernelModules = [ "kvm-intel" ];
boot.extraModulePackages = [ ]; boot.extraModulePackages = [ ];

View file

@ -3,7 +3,8 @@
lib, lib,
config, config,
... ...
}: { }:
{
nixpkgs.config.cudaSupport = true; nixpkgs.config.cudaSupport = true;
services = { services = {
hardware.bolt.enable = true; hardware.bolt.enable = true;
@ -13,7 +14,11 @@
enableUdevRules = true; enableUdevRules = true;
}; };
}; };
nix = {settings = {system-features = ["gccarch-alderlake"];};}; nix = {
settings = {
system-features = [ "gccarch-alderlake" ];
};
};
hardware = { hardware = {
openrazer = { openrazer = {
enable = true; enable = true;
@ -36,7 +41,11 @@
}; };
boot = { boot = {
extraModulePackages = with config.boot.kernelPackages; [ ddcci-driver ]; extraModulePackages = with config.boot.kernelPackages; [ ddcci-driver ];
kernelModules = ["ddcci" "ddcci-backlight" "i2c-dev"]; kernelModules = [
"ddcci"
"ddcci-backlight"
"i2c-dev"
];
binfmt = { binfmt = {
emulatedSystems = [ emulatedSystems = [
"aarch64-linux" "aarch64-linux"
@ -52,10 +61,14 @@
conflicts = [ "shutdown.target" ]; conflicts = [ "shutdown.target" ];
serviceConfig = { serviceConfig = {
Type = "oneshot"; Type = "oneshot";
ExecStart = let ExecStart =
let
script = pkgs.writeShellApplication { script = pkgs.writeShellApplication {
name = "ddcci-handler"; name = "ddcci-handler";
runtimeInputs = with pkgs; [coreutils ddcutil]; runtimeInputs = with pkgs; [
coreutils
ddcutil
];
text = '' text = ''
echo Trying to attach ddcci to "$1" echo Trying to attach ddcci to "$1"
success=0 success=0
@ -73,7 +86,8 @@
done done
''; '';
}; };
in "${lib.getExe' script "ddcci-handler"} %i"; in
"${lib.getExe' script "ddcci-handler"} %i";
}; };
}; };
services.udev.extraRules = '' services.udev.extraRules = ''

View file

@ -1,4 +1,5 @@
{...}: { { ... }:
{
systemd.network = { systemd.network = {
enable = true; enable = true;
wait-online.enable = false; wait-online.enable = false;

View file

@ -1,4 +1,5 @@
{lib, ...}: { { lib, ... }:
{
config.specialisation.kde = { config.specialisation.kde = {
inheritParentConfig = true; inheritParentConfig = true;
configuration = { configuration = {

View file

@ -2,7 +2,8 @@
inputs, inputs,
lib, lib,
... ...
}: let }:
let
extraConfig = '' extraConfig = ''
output "DP-1" { output "DP-1" {
mode "2560x1440@169.900" mode "2560x1440@169.900"
@ -22,7 +23,8 @@
open-on-output "DP-1" open-on-output "DP-1"
} }
''; '';
in { in
{
config.specialisation.niri-hybrid = { config.specialisation.niri-hybrid = {
inheritParentConfig = true; inheritParentConfig = true;
configuration = { configuration = {

View file

@ -2,7 +2,8 @@
pkgs, pkgs,
rootPath, rootPath,
... ...
}: { }:
{
stylix = { stylix = {
enable = true; enable = true;
image = rootPath + "/assets/wallpaper/01.png"; image = rootPath + "/assets/wallpaper/01.png";

View file

@ -2,7 +2,8 @@
lib, lib,
pkgs, pkgs,
... ...
}: { }:
{
users.users.david = { users.users.david = {
initialHashedPassword = "$y$j9T$eS5zCi4W.4IPpf3P8Tb/o1$xhumXY1.PJKmTguNi/zlljLbLemNGiubWoUEc878S36"; initialHashedPassword = "$y$j9T$eS5zCi4W.4IPpf3P8Tb/o1$xhumXY1.PJKmTguNi/zlljLbLemNGiubWoUEc878S36";
isNormalUser = true; isNormalUser = true;

View file

@ -2,9 +2,11 @@
config, config,
lib, lib,
... ...
}: let }:
let
cfg = config.youthlic.containers; cfg = config.youthlic.containers;
in { in
{
imports = lib.youthlic.loadImports ./.; imports = lib.youthlic.loadImports ./.;
options = { options = {
youthlic.containers = { youthlic.containers = {

View file

@ -3,9 +3,11 @@
config, config,
lib, lib,
... ...
}: let }:
let
cfg = config.youthlic.containers.forgejo; cfg = config.youthlic.containers.forgejo;
in { in
{
options = { options = {
youthlic.containers.forgejo = { youthlic.containers.forgejo = {
enable = lib.mkEnableOption "forgejo container"; enable = lib.mkEnableOption "forgejo container";
@ -54,7 +56,9 @@ in {
} }
]; ];
config = {lib, ...}: { config =
{ lib, ... }:
{
imports = [ imports = [
./../programs/forgejo.nix ./../programs/forgejo.nix
./../programs/postgresql.nix ./../programs/postgresql.nix

View file

@ -3,9 +3,11 @@
config, config,
lib, lib,
... ...
}: let }:
let
cfg = config.youthlic.containers.miniflux; cfg = config.youthlic.containers.miniflux;
in { in
{
options = { options = {
youthlic.containers.miniflux = { youthlic.containers.miniflux = {
enable = lib.mkEnableOption "miniflux container"; enable = lib.mkEnableOption "miniflux container";
@ -36,7 +38,9 @@ in {
}; };
}; };
config = {lib, ...}: { config =
{ lib, ... }:
{
imports = [ imports = [
./../programs/miniflux.nix ./../programs/miniflux.nix
./../programs/postgresql.nix ./../programs/postgresql.nix

View file

@ -1,3 +1,6 @@
{lib, ...}: { { lib, ... }:
imports = with lib; youthlic.loadImports' ./. (filter (name: !hasSuffix "/top-level" (toString name))); {
imports =
with lib;
youthlic.loadImports' ./. (filter (name: !hasSuffix "/top-level" (toString name)));
} }

View file

@ -2,9 +2,11 @@
config, config,
lib, lib,
... ...
}: let }:
let
cfg = config.youthlic.users.deploy; cfg = config.youthlic.users.deploy;
in { in
{
options = { options = {
youthlic.users.deploy = { youthlic.users.deploy = {
enable = lib.mkEnableOption "deploy"; enable = lib.mkEnableOption "deploy";

View file

@ -6,18 +6,23 @@
}: }:
lib.mkMerge [ lib.mkMerge [
{ {
environment.systemPackages = with pkgs; [man-pages man-pages-posix]; environment.systemPackages = with pkgs; [
man-pages
man-pages-posix
];
documentation = { documentation = {
info.enable = true; info.enable = true;
nixos.enable = false; nixos.enable = false;
dev.enable = true; dev.enable = true;
}; };
} }
(let (
let
inherit (pkgs.writers) writeFish; inherit (pkgs.writers) writeFish;
cfg = config.documentation.man.man-db; cfg = config.documentation.man.man-db;
cachePath = "/var/cache/man/nixos"; cachePath = "/var/cache/man/nixos";
in { in
{
documentation.man.generateCaches = false; documentation.man.generateCaches = false;
systemd.services."man-db" = { systemd.services."man-db" = {
@ -120,5 +125,6 @@ lib.mkMerge [
rm -r "$out/share/man/man3" rm -r "$out/share/man/man3"
''; '';
}) }
)
] ]

View file

@ -2,9 +2,11 @@
config, config,
lib, lib,
... ...
}: let }:
let
cfg = config.youthlic.gui; cfg = config.youthlic.gui;
in { in
{
config = lib.mkIf (cfg.enabled == "cosmic") { config = lib.mkIf (cfg.enabled == "cosmic") {
# Enable the X11 windowing system. # Enable the X11 windowing system.
# You can disable this if you're only using the Wayland session. # You can disable this if you're only using the Wayland session.

View file

@ -3,9 +3,11 @@
lib, lib,
pkgs, pkgs,
... ...
}: let }:
let
cfg = config.youthlic.gui; cfg = config.youthlic.gui;
in { in
{
imports = with lib; youthlic.loadImports ./.; imports = with lib; youthlic.loadImports ./.;
options = { options = {
youthlic.gui = { youthlic.gui = {

View file

@ -2,9 +2,11 @@
config, config,
lib, lib,
... ...
}: let }:
let
cfg = config.youthlic.gui; cfg = config.youthlic.gui;
in { in
{
config = lib.mkIf (cfg.enabled == "kde") { config = lib.mkIf (cfg.enabled == "kde") {
services = { services = {
desktopManager.plasma6.enable = true; desktopManager.plasma6.enable = true;

View file

@ -3,9 +3,11 @@
lib, lib,
pkgs, pkgs,
... ...
}: let }:
let
cfg = config.youthlic.gui; cfg = config.youthlic.gui;
in { in
{
options = { options = {
youthlic.gui.niri = { youthlic.gui.niri = {
}; };
@ -97,7 +99,11 @@ in {
programs = { programs = {
regreet = { regreet = {
enable = true; enable = true;
cageArgs = ["-s" "-m" "last"]; cageArgs = [
"-s"
"-m"
"last"
];
}; };
niri = { niri = {
enable = true; enable = true;

View file

@ -2,9 +2,11 @@
config, config,
lib, lib,
... ...
}: let }:
let
cfg = config.youthlic.hardware; cfg = config.youthlic.hardware;
in { in
{
options = { options = {
youthlic.hardware = { youthlic.hardware = {
asus = { asus = {

View file

@ -6,7 +6,8 @@
pkgs, pkgs,
rootPath, rootPath,
... ...
}: { }:
{
options.youthlic.home-manager = { options.youthlic.home-manager = {
enable = lib.mkOption { enable = lib.mkOption {
type = lib.types.bool; type = lib.types.bool;
@ -32,7 +33,8 @@
''; '';
}; };
}; };
config = let config =
let
cfg = config.youthlic.home-manager; cfg = config.youthlic.home-manager;
unixName = cfg.unixName; unixName = cfg.unixName;
hostName = cfg.hostName; hostName = cfg.hostName;
@ -42,7 +44,8 @@
useGlobalPkgs = true; useGlobalPkgs = true;
useUserPackages = true; useUserPackages = true;
users."${cfg.unixName}" = ( users."${cfg.unixName}" = (
{...}: { { ... }:
{
imports = [ imports = [
outputs.homeModules."${unixName}" outputs.homeModules."${unixName}"
(rootPath + "/home/${unixName}/configurations/${hostName}") (rootPath + "/home/${unixName}/configurations/${hostName}")

View file

@ -3,9 +3,11 @@
lib, lib,
config, config,
... ...
}: let }:
let
cfg = config.youthlic.i18n; cfg = config.youthlic.i18n;
in { in
{
options = { options = {
youthlic.i18n = { youthlic.i18n = {
enable = lib.mkEnableOption "zh env"; enable = lib.mkEnableOption "zh env";

View file

@ -5,18 +5,22 @@
pkgs, pkgs,
lib, lib,
... ...
}: { }:
{
config = { config = {
environment.etc = environment.etc =
inputs inputs
|> lib.mapAttrs' (name: value: |> lib.mapAttrs' (
name: value:
lib.nameValuePair "nix/inputs/${name}" { lib.nameValuePair "nix/inputs/${name}" {
source = value; source = value;
}); }
);
nixpkgs = { nixpkgs = {
config = { config = {
allowUnfree = true; allowUnfree = true;
allowInsecurePredicate = p: allowInsecurePredicate =
p:
builtins.elem (lib.getName p) [ builtins.elem (lib.getName p) [
# for fluffychat and neochat # for fluffychat and neochat
"olm" "olm"
@ -44,8 +48,7 @@
"nix-community.cachix.org-1:mB9FSh9qf2dCimDSUo8Zy7bkq5CX+/rkCWyvRCYg3Fs=" "nix-community.cachix.org-1:mB9FSh9qf2dCimDSUo8Zy7bkq5CX+/rkCWyvRCYg3Fs="
]; ];
auto-optimise-store = lib.mkDefault true; auto-optimise-store = lib.mkDefault true;
experimental-features = experimental-features = [
[
"nix-command" "nix-command"
"flakes" "flakes"
] ]
@ -63,11 +66,13 @@
registry = registry =
inputs inputs
|> lib.filterAttrs (name: _value: name != "nixpkgs") |> lib.filterAttrs (name: _value: name != "nixpkgs")
|> lib.mapAttrs (_name: value: { |> lib.mapAttrs (
_name: value: {
flake = lib.mkForce { flake = lib.mkForce {
outPath = value; outPath = value;
}; };
}); }
);
}; };
}; };
} }

View file

@ -2,9 +2,11 @@
config, config,
lib, lib,
... ...
}: let }:
let
cfg = config.youthlic.programs.asusd; cfg = config.youthlic.programs.asusd;
in { in
{
options = { options = {
youthlic.programs.asusd = { youthlic.programs.asusd = {
enable = lib.mkEnableOption "asusd"; enable = lib.mkEnableOption "asusd";

View file

@ -2,9 +2,11 @@
config, config,
lib, lib,
... ...
}: let }:
let
cfg = config.youthlic.programs.bash; cfg = config.youthlic.programs.bash;
in { in
{
options = { options = {
youthlic.programs.bash = { youthlic.programs.bash = {
enable = lib.mkEnableOption "bash"; enable = lib.mkEnableOption "bash";

View file

@ -3,10 +3,12 @@
lib, lib,
pkgs, pkgs,
... ...
}: let }:
let
cfg = config.youthlic.programs.caddy.outer-wilds-text-adventure; cfg = config.youthlic.programs.caddy.outer-wilds-text-adventure;
caddy-cfg = config.youthlic.programs.caddy; caddy-cfg = config.youthlic.programs.caddy;
in { in
{
options = { options = {
youthlic.programs.caddy.outer-wilds-text-adventure = { youthlic.programs.caddy.outer-wilds-text-adventure = {
enable = lib.mkEnableOption "caddy.OuterWildsTextAdventure"; enable = lib.mkEnableOption "caddy.OuterWildsTextAdventure";

Some files were not shown because too many files have changed in this diff Show more