nixos-config/modules/nixos/profiles/dev.nix
2022-10-10 11:40:19 +08:00

147 lines
4.6 KiB
Nix

# The module for anything dev-related.
{ config, options, lib, pkgs, ... }:
let cfg = config.profiles.dev;
in {
options.profiles.dev = {
enable = lib.mkEnableOption
"configurations of foo-dogsquared's barebones requirement for a development environment.";
shell.enable = lib.mkEnableOption
"installation of the shell utilities foo-dogsquared rely on";
virtualization.enable =
lib.mkEnableOption "virtualization-related stuff for development";
neovim.enable = lib.mkEnableOption "Neovim";
};
config = lib.mkIf cfg.enable (lib.mkMerge [
({
systemd.coredump = {
enable = true;
extraConfig = ''
ProcessSizeMax=10G
ExternalSizeMax=10G
'';
};
# Debugging time!
environment.enableDebugInfo = true;
# I want to include documentations for my own sanity, OK?
documentation = {
enable = true;
dev.enable = true;
nixos.enable = true;
man.generateCaches = true;
};
# Install Git, our favorite version control system.
# In this case, we want ALL OF THE EXTENSIONS!
programs.git = {
enable = true;
lfs.enable = true;
package = pkgs.gitFull;
config.difftool.prompt = false;
# Yeah, let's use this oversized diff tool, shall we?
# Also, this config is based from this tip.
# https://lists.reproducible-builds.org/pipermail/diffoscope/2016-April/000193.html
config.difftool."diffoscope".cmd = ''
"if [ $LOCAL = /dev/null ]; then diffoscope --new-file $REMOTE; else diffoscope $LOCAL $REMOTE; fi"
'';
config.difftool."diffoscope-html".cmd = ''
"if [ $LOCAL = /dev/null ]; then diffoscope --new-file $REMOTE --html - | cat; else diffoscope $LOCAL $REMOTE --html - | cat; fi"
'';
};
programs.gnupg = { agent.enable = true; };
programs.systemtap.enable = true;
services.sysprof.enable = true;
# Convenience!
environment.localBinInPath = true;
# This is set as our system packages for the sake of convenience.
services.lorri.enable = true;
environment.systemPackages = with pkgs; [
cachix # Compile no more by using someone's binary cache!
curl # Our favorite network client.
cmake # The poster boy for the hated build system.
diffoscope # Oversized caffeine grinder.
direnv # The power of local development environment.
gcc # The usual toolchain.
gdb # The usual debugger.
gnumake # Make your life easier with GNU Make.
moreutils # Less is more but more utilities, the merrier.
valgrind # Memory leaks.
# I SAID ALL OF THE GIT EXTENSIONS!
git-crypt
github-cli # Client for GitHub.
hut # And one for Sourcehut.
act # Finally, a local environment for testing GitHub workflows.
];
systemd.user.services.upgrade-nix-profile = {
description = ''
Update packages installed through 'nix profile'.
'';
script = "nix profile upgrade '.*'";
path = [ config.nix.package ];
startAt = "weekly";
};
})
(lib.mkIf cfg.shell.enable {
environment.systemPackages = with pkgs; [
bandwhich # Sniffing your packets.
lazygit # Git interface for the lazy.
fd # Oh nice, a more reliable `find`.
ripgrep # On nice, a more reliable `grep`.
exa # Oh nice, a shinier `ls`.
bat # dog > bat > cat
fzf # A fuzzy finder that enables fuzzy finding not furry finding, a common misconception.
gopass # An improved version of the password manager for hipsters.
zoxide # Gain teleportation abilities!
];
})
# !!! Please add your user to the "libvirtd" group.
(lib.mkIf cfg.virtualization.enable {
# virt-manager as my frontend.
environment.systemPackages = with pkgs; [
distrobox
virt-manager
];
# Enable Docker just as my main container runtime or something.
virtualisation.docker.enable = true;
# Enable libvirt for muh qemu.
virtualisation.libvirtd = {
enable = true;
qemu.package = pkgs.qemu_full;
qemu.ovmf.enable = true;
};
})
(lib.mkIf cfg.neovim.enable {
programs.neovim = {
enable = true;
defaultEditor = true;
withNodeJs = true;
withRuby = true;
# I want the BLEEDING EDGE!
package = pkgs.neovim-nightly;
};
environment.systemPackages = with pkgs; [
editorconfig-core-c
tree-sitter
];
})
]);
}