nix-home/niten.nix

239 lines
4.2 KiB
Nix

{
doom-emacs,
niten-doom-config,
username,
user-email,
home-dir,
enable-gui,
...
}:
{ pkgs, ... }:
with pkgs.lib;
let
inherit (pkgs.stdenv) isLinux;
doom-emacs-package = pkgs.callPackage doom-emacs {
doomPrivateDir = niten-doom-config;
# extraPackages = with pkgs.emacsPackages; [
# elpher
# use-package
# ];
emacsPackagesOverlay = final: prev: {
irony = prev.irony.overrideAttrs (esuper: {
buildInputs = with pkgs;
esuper.buildInputs ++
[ cmake libclang clang ];
});
};
};
gui-packages = with pkgs; [
exodus
firefox
imagemagick
jq
minecraft
nyxt
openttd
pv
signal-desktop
spotify
] ++ (optionals isLinux [
gnome.gnome-tweaks
google-chrome
mplayer
redshift
xclip
]);
common-packages = with pkgs; [
ant
asdf
binutils
bundix
byobu
cdrtools
cargo
clojure
cmake
curl
enca
file
fortune
doom-emacs-package
git
gnutls
gnupg
guile
inetutils
ipfs
iptables
jdk
leiningen
libisofs
lispPackages.quicklisp
lsof
lshw
mkpasswd
mtr
nixfmt
nix-index
nix-prefetch-git
nmap
openldap
openssl
pciutils
pwgen
python
ruby
rustc
sbcl
stdenv
texlive.combined.scheme-basic
tmux
unzip
yubikey-manager
yubikey-personalization
youtube-dl
# Check and pick a favorite
molly-brown
ncgopher
amfora
asuka
kristall
castor
] ++ (optionals isLinux [
atop
btrfs-progs
clj2nix
opencv-java
]);
ensure-directories = [ ".emacs.d/.local/etc/eshell" ];
in {
programs = {
bash.enable = true;
git = {
enable = true;
userName = username;
userEmail = user-email;
ignores = [ "*~" ];
extraConfig.pull.rebase = false;
};
};
xresources.properties = mkIf enable-gui {
"Xft.antialias" = 1;
"Xft.autohint" = 0;
# "Xft.dpi" = 192;
"Xft.hinting" = 1;
"Xft.hintstyle" = "hintfull";
"Xft.lcdfilter" = "lcddefault";
};
services = mkIf isLinux {
emacs = {
enable = true;
package = doom-emacs-package;
client = {
enable = true;
};
};
gpg-agent.enable = true;
gnome-keyring.enable = true;
redshift = {
enable = true;
latitude = "47";
longitude = "122";
};
};
accounts.email.accounts = {
Fudo = {
primary = true;
address = "niten@fudo.org";
aliases = [ "peter@selby.ca" ];
userName = "niten";
realName = "Niten";
imap = {
host = "mail.fudo.org";
port = 993;
tls.enable = true;
};
smtp = {
host = "mail.fudo.org";
port = 587;
tls = {
enable = true;
useStartTls = true;
};
};
};
GMail = {
address = "pselby@gmail.com";
flavor = "gmail.com";
realName = "Peter Selby";
};
};
home = {
inherit username;
homeDirectory = home-dir;
packages = if enable-gui then (common-packages ++ gui-packages)
else
common-packages;
file = {
".local/share/openttd/baseset" =
mkIf enable-gui { source = "${pkgs.openttd-data}/data"; };
# For nixified emacs
".emacs.d/init.el".text = ''
(load "default.el")
(setq package-archives nil)
(package-initialize)
'';
".xsessions" = mkIf enable-gui {
executable = true;
text = ''
# -*-bash-*-
gdmauth=$XAUTHORITY
unset XAUTHORITY
export XAUTHORITY
xauth merge "$gdmauth"
if [ -f $HOME/.xinitrc ]; then
bash --login -i $HOME/.xinitrc
fi
'';
};
};
sessionVariables = {
# EDITOR = "${doom-emacs}/bin/emacsclient -t";
ALTERNATE_EDITOR = "";
DOOM_EMACS_SITE_PATH = "${niten-doom-config}/site.d";
HISTCONTROL = "ignoredups:ignorespace";
};
};
systemd.user.tmpfiles.rules = optionals isLinux
(map (dir: "d ${home-dir}/${dir} 700 niten - - -") ensure-directories);
}