summaryrefslogtreecommitdiff
path: root/shared/nixos-and-darwin
diff options
context:
space:
mode:
authorLinnnus <[email protected]>2025-01-18 13:14:31 +0100
committerLinnnus <[email protected]>2025-01-18 13:14:31 +0100
commitf5fc33abb93e058b943e5ef0dc8c8a3c02255804 (patch)
tree4457684b5ea69d493ea4af5db59195d637e62c9d /shared/nixos-and-darwin
parente92e5baa7b23c696241bc0d7cfa6d952ca8578d4 (diff)
Move NixOS-specific options from shared/{nixos-and-darwin => nixos}
Diffstat (limited to 'shared/nixos-and-darwin')
-rw-r--r--shared/nixos-and-darwin/common-nix-settings/default.nix78
-rw-r--r--shared/nixos-and-darwin/common-shell-settings/default.nix80
2 files changed, 69 insertions, 89 deletions
diff --git a/shared/nixos-and-darwin/common-nix-settings/default.nix b/shared/nixos-and-darwin/common-nix-settings/default.nix
index 92e14f3..3681946 100644
--- a/shared/nixos-and-darwin/common-nix-settings/default.nix
+++ b/shared/nixos-and-darwin/common-nix-settings/default.nix
@@ -1,8 +1,5 @@
# This module sets common settings related to Nix such as enabling flakes and
-# using overlays everywhere..
-#
-# NOTE: This lives under `shared/nixos-and-darwin`. The configuration in here
-# should be compatible with both nixos and nix-darwin!!
+# using overlays everywhere.
{
pkgs,
lib,
@@ -10,50 +7,43 @@
flakeInputs,
flakeOutputs,
...
-}:
-lib.mkMerge [
- {
- # Enable de facto stable features.
- nix.settings.experimental-features = ["nix-command" "flakes"];
+}: {
+ # Enable de facto stable features.
+ nix.settings.experimental-features = ["nix-command" "flakes"];
- nixpkgs.overlays = [
- # Use local overlays.
- flakeOutputs.overlays.additions
- flakeOutputs.overlays.modifications
+ nixpkgs.overlays = [
+ # Use local overlays.
+ flakeOutputs.overlays.additions
+ flakeOutputs.overlays.modifications
- # Add unstable nixpkgs.
- (final: prev: {unstable = flakeInputs.nixpkgs-unstable.legacyPackages.${pkgs.system};})
- ];
+ # Add unstable nixpkgs.
+ (final: prev: {unstable = flakeInputs.nixpkgs-unstable.legacyPackages.${pkgs.system};})
+ ];
- # I'm not *that* vegan.
- nixpkgs.config.allowUnfree = true;
+ # I'm not *that* vegan.
+ nixpkgs.config.allowUnfree = true;
- # This will add each flake input as a registry
- # To make nix3 commands consistent with your flake
- nix.registry = lib.mapAttrs (_: value: {flake = value;}) flakeInputs;
+ # This will add each flake input as a registry
+ # To make nix3 commands consistent with your flake
+ nix.registry = lib.mapAttrs (_: value: {flake = value;}) flakeInputs;
- nix.nixPath =
- [
- # Use overlays from this repo for building system configuration as well as system-wide.
- # See: https://nixos.wiki/wiki/Overlays#Using_nixpkgs.overlays_from_configuration.nix_as_.3Cnixpkgs-overlays.3E_in_your_NIX_PATH
- "nixpkgs-overlays=${flakeInputs.self}/overlays/compat.nix"
- ]
- # This will additionally add out inputs to the system's legacy channels
- # Making legacy nix commands consistent as well, awesome!
- ++ lib.mapAttrsToList (key: value: "${key}=${value.to.path}") config.nix.registry;
+ nix.nixPath =
+ [
+ # Use overlays from this repo for building system configuration as well as system-wide.
+ # See: https://nixos.wiki/wiki/Overlays#Using_nixpkgs.overlays_from_configuration.nix_as_.3Cnixpkgs-overlays.3E_in_your_NIX_PATH
+ "nixpkgs-overlays=${flakeInputs.self}/overlays/compat.nix"
+ ]
+ # This will additionally add out inputs to the system's legacy channels
+ # Making legacy nix commands consistent as well, awesome!
+ ++ lib.mapAttrsToList (key: value: "${key}=${value.to.path}") config.nix.registry;
- # Add shell-utilities which are only relevant if Nix is enabled.
- environment.systemPackages = with pkgs; [
- # For running programs easily.
- nix-index # Also includes nix-locate
- flakeInputs.comma.packages.${system}.default
+ # Add shell-utilities which are only relevant if Nix is enabled.
+ environment.systemPackages = with pkgs; [
+ # For running programs easily.
+ nix-index # Also includes nix-locate
+ flakeInputs.comma.packages.${system}.default
- # For editing secrets.
- flakeInputs.agenix.packages.${system}.default
- ];
- }
- (lib.mkIf pkgs.stdenv.isLinux {
- # There is not nix-darwin equivalent to this NixOS option.
- nix.enable = true;
- })
-]
+ # For editing secrets.
+ flakeInputs.agenix.packages.${system}.default
+ ];
+}
diff --git a/shared/nixos-and-darwin/common-shell-settings/default.nix b/shared/nixos-and-darwin/common-shell-settings/default.nix
index 1fcb05e..982296d 100644
--- a/shared/nixos-and-darwin/common-shell-settings/default.nix
+++ b/shared/nixos-and-darwin/common-shell-settings/default.nix
@@ -3,52 +3,42 @@
#
# NOTE: This lives under `shared/nixos-and-darwin`. The configuration in here
# should be compatible with both nixos and nix-darwin!!
+{pkgs, ...}: {
+ # Set ZSH as the shell.
+ # https://nixos.wiki/wiki/Command_Shell#Changing_default_shelltrue
+ programs.zsh.enable = true;
+ environment.shells = [pkgs.zsh];
-{pkgs, lib, ...}:
+ # Very basic system administration tools.
+ environment.systemPackages = with pkgs; [
+ curl
+ jq
+ moreutils
+ neovim
+ tree
+ ];
-lib.mkMerge [
- {
- # Set ZSH as the shell.
- # https://nixos.wiki/wiki/Command_Shell#Changing_default_shelltrue
- programs.zsh.enable = true;
- environment.shells = [pkgs.zsh];
+ # Aliases that are burned into my muscle memory.
+ environment.shellAliases = {
+ "mv" = "mv -i";
+ "rm" = "rm -i";
+ "cp" = "cp -i";
+ "ls" = "ls -F -G -A --color=auto";
+ "grep" = "grep --color=auto";
+ "file" = "file --no-dereference";
+ "tree" = "tree --dirsfirst --gitignore";
- # Very basic system administration tools.
- environment.systemPackages = with pkgs; [
- curl
- jq
- moreutils
- neovim
- tree
- ];
+ # See: https://github.com/NixOS/nix/issues/5858
+ "nix" = "nix --print-build-logs";
- # Aliases that are burned into my muscle memory.
- environment.shellAliases = {
- "mv" = "mv -i";
- "rm" = "rm -i";
- "cp" = "cp -i";
- "ls" = "ls -F -G -A --color=auto";
- "grep" = "grep --color=auto";
- "file" = "file --no-dereference";
- "tree" = "tree --dirsfirst --gitignore";
-
- # See: https://github.com/NixOS/nix/issues/5858
- "nix" = "nix --print-build-logs";
-
- ".." = "cd ../";
- "..." = "cd ../../";
- "...." = "cd ../../../";
- "....." = "cd ../../../../";
- "......" = "cd ../../../../../";
- "......." = "cd ../../../../../../";
- "........" = "cd ../../../../../../../";
- "........." = "cd ../../../../../../../../";
- ".........." = "cd ../../../../../../../../../";
- };
- }
- (lib.mkIf pkgs.stdenv.isLinux {
- # There is not nix-darwin equivalent to this NixOS option.
- # The default shell on MacOS is already ZSH.
- users.defaultUserShell = pkgs.zsh;
- })
-]
+ ".." = "cd ../";
+ "..." = "cd ../../";
+ "...." = "cd ../../../";
+ "....." = "cd ../../../../";
+ "......" = "cd ../../../../../";
+ "......." = "cd ../../../../../../";
+ "........" = "cd ../../../../../../../";
+ "........." = "cd ../../../../../../../../";
+ ".........." = "cd ../../../../../../../../../";
+ };
+}