refactor(tazjin/nixos): pick correct Emacs from a NixOS option

This gives me the ability to override the Emacs per-machine easily.

Change-Id: Id480889c108833b0a11c377a9b1e946900c5aba1
Reviewed-on: https://cl.tvl.fyi/c/depot/+/9166
Reviewed-by: tazjin <tazjin@tvl.su>
Autosubmit: tazjin <tazjin@tvl.su>
Tested-by: BuildkiteCI
This commit is contained in:
Vincent Ambo 2023-08-29 17:10:11 +03:00 committed by tazjin
parent 804b7fbe73
commit d4c8840c57
2 changed files with 93 additions and 81 deletions

View file

@ -1,5 +1,5 @@
# EXWM and other desktop configuration. # EXWM and other desktop configuration.
{ depot, lib, pkgs, ... }: { config, depot, lib, pkgs, ... }:
{ {
services = { services = {
@ -29,7 +29,7 @@
windowManager.session = lib.singleton { windowManager.session = lib.singleton {
name = "exwm"; name = "exwm";
start = "${depot.users.tazjin.emacs}/bin/tazjins-emacs"; start = "${config.tazjin.emacs}/bin/tazjins-emacs";
}; };
}; };
}; };

View file

@ -1,91 +1,103 @@
# Default configuration settings for physical machines that I use. # Default configuration settings for physical machines that I use.
{ lib, pkgs, depot, ... }: { lib, pkgs, config, depot, ... }:
let let
pass-otp = pkgs.pass.withExtensions (e: [ e.pass-otp ]); pass-otp = pkgs.pass.withExtensions (e: [ e.pass-otp ]);
in in
{ {
# Install all the default software. options = with lib; {
environment.systemPackages = tazjin.emacs = mkOption {
# programs from the depot type = types.package;
(with depot; [ default = depot.users.tazjin.emacs;
users.tazjin.screenLock description = ''
users.tazjin.emacs Derivation with my Emacs package, with configuration included.
third_party.agenix.cli '';
third_party.josh };
]) ++ };
# programs from nixpkgs config = {
(with pkgs; [ # Install all the default software.
(aspellWithDicts (d: [ d.ru ])) environment.systemPackages =
amber # programs from the depot
bat (with depot; [
curl users.tazjin.screenLock
ddcutil config.tazjin.emacs
direnv third_party.agenix.cli
dnsutils third_party.josh
electrum ]) ++
emacs-unstable # emacsclient
exa
fd
file
gdb
gh
git
gnupg
gtk3 # for gtk-launch
htop
hyperfine
iftop
imagemagick
jq
lieer
maim
man-pages
moreutils
mosh
msmtp
mullvad-vpn
networkmanagerapplet
nix-prefetch-github
nmap
notmuch
openssh
openssl
pass-otp
pavucontrol
pinentry
pinentry-emacs
pulseaudio # for pactl
pwgen
quasselClient
rink
ripgrep
rust-analyzer
rustup
screen
thunderbird
tig
tokei
tree
unzip
vlc
volumeicon
whois
xclip
xsecurelock
zoxide
]);
# Run services & configure programs for all machines. # programs from nixpkgs
services.fwupd.enable = true; (with pkgs; [
(aspellWithDicts (d: [ d.ru ]))
amber
bat
curl
ddcutil
direnv
dnsutils
electrum
config.tazjin.emacs.emacs # emacsclient
exa
fd
file
gdb
gh
git
gnupg
gtk3 # for gtk-launch
htop
hyperfine
iftop
imagemagick
jq
lieer
maim
man-pages
moreutils
mosh
msmtp
mullvad-vpn
networkmanagerapplet
nix-prefetch-github
nmap
notmuch
openssh
openssl
pass-otp
pavucontrol
pinentry
pinentry-emacs
pulseaudio # for pactl
pwgen
quasselClient
rink
ripgrep
rust-analyzer
rustup
screen
thunderbird
tig
tokei
tree
unzip
vlc
volumeicon
whois
xclip
xsecurelock
zoxide
]);
# Disable the broken NetworkManager-wait-online.service # Run services & configure programs for all machines.
systemd.services.NetworkManager-wait-online.enable = lib.mkForce false; services.fwupd.enable = true;
programs = { # Disable the broken NetworkManager-wait-online.service
fish.enable = true; systemd.services.NetworkManager-wait-online.enable = lib.mkForce false;
mosh.enable = true;
ssh.startAgent = true; programs = {
fish.enable = true;
mosh.enable = true;
ssh.startAgent = true;
};
}; };
} }