nixos-config/modules/nixos/profiles/dev.nix

190 lines
6.1 KiB
Nix
Raw Normal View History

# The module for anything dev-related.
{ config, options, lib, pkgs, ... }:
let cfg = config.profiles.dev;
in {
options.profiles.dev = {
2021-11-25 13:45:48 +00:00
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 setup";
};
config = lib.mkIf cfg.enable (lib.mkMerge [
({
# Hey! Wanna see some of <INSERT APPLICATION'S NAME> big dark dump?
2022-07-18 23:07:53 +00:00
systemd.coredump = {
enable = true;
extraConfig = ''
ProcessSizeMax=10G
ExternalSizeMax=10G
'';
};
2022-09-25 07:24:47 +00:00
# Debugging time!
environment.enableDebugInfo = true;
2021-11-25 13:45:48 +00:00
# I want to include documentations for my own sanity, OK?
documentation = {
enable = true;
dev.enable = true;
nixos.enable = true;
man.generateCaches = true;
2021-11-25 13:45:48 +00:00
};
2021-12-08 04:18:37 +00:00
# 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"
'';
2021-12-08 04:18:37 +00:00
};
# It's a given at life to have a GPG key.
programs.gnupg.agent.enable = true;
# Instrumentate your instrument.
2022-09-25 07:24:47 +00:00
programs.systemtap.enable = true;
# Profile your whole system.
2022-09-25 07:24:47 +00:00
services.sysprof.enable = true;
2021-11-25 13:45:48 +00:00
# Convenience!
environment.localBinInPath = true;
# Additional settings for developing with nix.
nix.settings = {
keep-outputs = true;
keep-derivations = true;
};
2021-11-25 13:45:48 +00:00
# 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.
2021-11-25 13:45:48 +00:00
direnv # The power of local development environment.
gcc # The usual toolchain.
2022-09-25 07:24:47 +00:00
gdb # The usual debugger.
gnumake # The other poster boy for the hated build system.
2021-11-30 01:03:05 +00:00
moreutils # Less is more but more utilities, the merrier.
valgrind # Making sure your applications don't pee as much.
]
# Finally, a local environment for testing out GitHub workflows without
# embarassing yourself pushing a bunch of commits.
++ (lib.optional config.virtualisation.docker.enable pkgs.act)
2021-12-08 04:18:37 +00:00
# Enable all of the gud things.
++ (lib.optionals config.programs.git.enable [
github-cli # Client for GitHub.
hut # And one for Sourcehut.
]);
systemd.user.services.nix-upgrade-profile = {
description = ''
Update service for user-specific Nix profile
'';
documentation = [ "man:nix3-profile(1)" ];
script = "nix profile upgrade '.*'";
path = [ config.nix.package ];
startAt = "weekly";
};
systemd.user.timers.nix-upgrade-profile = {
description = ''
Update service for user-specific Nix profile
'';
wantedBy = [ "default.target" ];
timerConfig = {
Persistent = true;
RandomizedDelaySec = 50;
};
};
})
(lib.mkIf cfg.shell.enable {
environment.systemPackages = with pkgs; [
bandwhich # Sniffing your packets.
2021-11-25 13:45:48 +00:00
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 {
2022-06-09 05:00:07 +00:00
environment.systemPackages = with pkgs; [
distrobox # I heard you like Linux...
virt-manager # An interface for those who are lazy to read a reference manual and create a 1000-line configuration per machine.
2022-06-09 05:00:07 +00:00
];
2022-01-25 01:32:17 +00:00
2022-08-13 00:31:09 +00:00
# Enable Docker just as my main container runtime or something.
virtualisation.docker = {
enable = true;
autoPrune = {
enable = true;
dates = "weekly";
};
};
# Enable usual containers configuration.
virtualisation.containers = {
enable = true;
registries.search = [
"docker.io"
"quay.io"
"registry.opensuse.org"
];
};
# Virtual machines, son. They open in response to physical needs to
# foreign environments.
virtualisation.libvirtd = {
enable = true;
2022-01-25 01:32:17 +00:00
qemu.package = pkgs.qemu_full;
2021-11-25 13:45:48 +00:00
qemu.ovmf.enable = true;
};
})
(lib.mkIf cfg.neovim.enable {
# Easier, better, faster, stronger.
programs.neovim = {
enable = true;
defaultEditor = true;
withNodeJs = true;
withRuby = true;
# I want the BLEEDING EDGE!
package = pkgs.neovim-nightly;
};
2022-04-30 12:30:22 +00:00
environment.systemPackages = with pkgs; [
editorconfig-core-c # Consistent canonical coding conventions.
tree-sitter # It surely doesn't have a partner to kiss.
2022-04-30 12:30:22 +00:00
];
})
]);
}