adhere to nixos systems

This commit is contained in:
Wyatt J. Miller 2024-09-03 22:24:20 -04:00
parent fac5e52f36
commit 9350ff271f
12 changed files with 108 additions and 97 deletions

View File

@ -1,11 +1,11 @@
{
description = "Wyatt's nix configuration";
description = "Wyatt's nix configuration suite";
inputs = {
nixpkgs-darwin.url = "github:nixos/nixpkgs/nixpkgs-24.05-darwin";
nixpkgs.url = "github:nixos/nixpkgs/nixpkgs-24.05";
# nixpkgs-darwin.url = "github:nixos/nixpkgs/nixpkgs-24.05-darwin";
home-manager = {
url = "github:nix-community/home-manager/release-24.05";
inputs.nixpkgs.follows = "nixpkgs-darwin";
inputs.nixpkgs.follows = "nixpkgs";
};
darwin = {
url = "github:lnl7/nix-darwin";
@ -13,11 +13,6 @@
};
};
# The `outputs` function will return all the build results of the flake.
# A flake can have many use cases and different types of outputs,
# parameters in `outputs` are defined in `inputs` and can be referenced by their names.
# However, `self` is an exception, this special parameter points to the `outputs` itself (self-reference)
# The `@` syntax here is used to alias the attribute set of the inputs's parameter, making it convenient to use inside the function.
outputs = inputs @ {
self,
nixpkgs,
@ -25,37 +20,56 @@
home-manager,
...
}: let
username = "wyatt";
useremail = "wyatt@wyattjmiller.com";
system = "aarch64-darwin"; # aarch64-darwin or x86_64-darwin
hostname = "sephiroth";
userName = "wyatt";
userEmail = "wyatt@wyattjmiller.com";
# supportedSystems = ["x86_64-linux" "aarch64-darwin"];
# system = "aarch64-darwin"; # aarch64-darwin or x86_64-darwin
# hostname = "sephiroth";
# forAllSystems = nixpkgs.lib.genAttrs supportedSystems;
specialArgs =
inputs
// {
inherit username useremail hostname;
inherit userName userEmail;
};
in {
darwinConfigurations."${hostname}" = darwin.lib.darwinSystem {
inherit system specialArgs;
# Primary laptop - MacBook Pro (2023, M3)
darwinConfigurations."sephiroth" = darwin.lib.darwinSystem {
inherit specialArgs;
system = "aarch64-darwin";
modules = [
./modules/nix-core.nix
./modules/system.nix
./modules/darwinSystem.nix
./modules/apps.nix
./modules/host-users.nix
# home manager
home-manager.darwinModules.home-manager
{
home-manager.useGlobalPkgs = true;
home-manager.useUserPackages = true;
home-manager.extraSpecialArgs = specialArgs;
home-manager.users.${username} = import ./home;
home-manager.users.${userName} = import ./home;
}
];
};
# nix code formatter
formatter.${system} = nixpkgs.legacyPackages.${system}.alejandra;
# Primary desktop computer
nixosConfiguration."cloud" = nixpkgs.lib.nixosSystem {
inherit specialArgs;
system = "x86_64-linux";
modules = [
/etc/nixos/configuration.nix
./modules/nix-core.nix
# ./modules/linuxSystem.nix
./modules/host-users.nix
home-manager.nixosModules.home-manager
{
home-manager.useGlobalPkgs = true;
home-manager.useUserPackages = true;
home-manager.users.${userName} = import ./home;
}
];
};
};
}

View File

@ -1,9 +1,6 @@
{ ... }:
{
{...}: {
programs.atuin = {
enable = true;
enableFishIntegration = true;
};
}

View File

@ -9,15 +9,15 @@
p7zip
# utils
bat # a batter cat
lazygit # a git tui that's easy to use
bottom # a better top
ripgrep # recursively searches directories for a regex pattern
jq # A lightweight and flexible command-line JSON processor
yq-go # yaml processer https://github.com/mikefarah/yq
fzf # A command-line fuzzy finder
fh # flake hub command line interface
aria2 # A lightweight multi-protocol & multi-source command-line download utility
bat
lazygit
bottom
ripgrep
jq
yq-go
fzf
fh
aria2
yt-dlp
# misc
@ -41,6 +41,7 @@
nixd
deadnix
alejandra
statix
# productivity
iterm2

View File

@ -1,6 +1,11 @@
{ username, ... }:
{
pkgs,
lib,
userName,
...
}: let
username = userName;
in {
# import sub modules
imports = [
./atuin.nix
@ -15,9 +20,14 @@
# Home Manager needs a bit of information about you and the
# paths it should manage.
home = {
username = username;
home = lib.mkMerge [
(lib.mkIf pkgs.stdenv.isDarwin {
homeDirectory = "/Users/${username}";
})
(lib.mkIf pkgs.stdenv.isLinux {
homeDirectory = "/home/${username}";
})
];
# This value determines the Home Manager release that your
# configuration is compatible with. This helps avoid breakage
@ -28,7 +38,6 @@
# the Home Manager release notes for a list of state version
# changes in each release.
stateVersion = "24.05";
};
# Let Home Manager install and manage itself.
programs.home-manager.enable = true;

View File

@ -1,6 +1,4 @@
{ lib, config, ... }:
{
{...}: {
programs.direnv = {
enable = true;
nix-direnv.enable = true;

View File

@ -1,6 +1,4 @@
{ lib, config, ... }:
{
{...}: {
programs.eza = {
enable = true;
enableFishIntegration = true;

View File

@ -1,6 +1,4 @@
{ ... }:
{
{...}: {
programs.lazygit = {
enable = true;

View File

@ -1,6 +1,4 @@
{ lib, config, ... }:
{
{...}: {
programs.neovim = {
enable = true;
defaultEditor = true;

View File

@ -7,18 +7,18 @@
shellAliases = {
# ls aliases
ls = "eza --color $argv";
la = "eza -l -all --color $argv";
ll = "eza -l --color $argv";
lt = "eza -l --color --git $argv";
ls = "eza --color";
la = "eza -l -all --color";
ll = "eza -l --color";
lt = "eza -l --color --git";
# lazygit alias
lg = "lazygit";
# cat, less, more alias
cat = "bat $argv";
less = "bat $argv";
more = "bat $argv";
cat = "bat";
less = "bat";
more = "bat";
# top alias
top = "btm";

View File

@ -1,6 +1,4 @@
{ lib, config, ... }:
{
{...}: {
programs.starship = {
enable = true;
enableFishIntegration = true;

0
modules/linuxSystem.nix Normal file
View File