Created
June 16, 2024 23:32
-
-
Save davidlee/7a31964474f73450a2f00c94aff423cc to your computer and use it in GitHub Desktop.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
davidlee ~/.config 09:30 | |
tree nix* | |
nix | |
└── nix.conf | |
nix-darwin | |
├── flake.lock | |
└── flake.nix | |
2 directories, 3 files | |
davidlee ~/.config 09:30 | |
cat nix/nix.conf | |
experimental-features = nix-command flakes | |
davidlee ~/.config 09:30 | |
cat nix-darwin/flake.nix | |
{ | |
description = "Example Darwin system flake"; | |
inputs = { | |
nixpkgs.url = "github:NixOS/nixpkgs/nixpkgs-unstable"; | |
nix-darwin.url = "github:LnL7/nix-darwin"; | |
nix-darwin.inputs.nixpkgs.follows = "nixpkgs"; | |
}; | |
outputs = inputs@{ self, nix-darwin, nixpkgs }: | |
let | |
configuration = { pkgs, ... }: { | |
# List packages installed in system profile. To search by name, run: | |
# $ nix-env -qaP | grep wget | |
environment.systemPackages = | |
[ pkgs.vim | |
]; | |
# Auto upgrade nix package and the daemon service. | |
services.nix-daemon.enable = true; | |
# nix.package = pkgs.nix; | |
# Necessary for using flakes on this system. | |
nix.settings.experimental-features = "nix-command flakes"; | |
# Create /etc/zshrc that loads the nix-darwin environment. | |
programs.zsh.enable = true; # default shell on catalina | |
# programs.fish.enable = true; | |
# Set Git commit hash for darwin-version. | |
system.configurationRevision = self.rev or self.dirtyRev or null; | |
# Used for backwards compatibility, please read the changelog before changing. | |
# $ darwin-rebuild changelog | |
system.stateVersion = 4; | |
# The platform the configuration will be used on. | |
nixpkgs.hostPlatform = "aarch64-darwin"; | |
}; | |
in | |
{ | |
# Build darwin flake using: | |
# $ darwin-rebuild build --flake .#fusillade | |
darwinConfigurations."fusillade" = nix-darwin.lib.darwinSystem { | |
modules = [ configuration ]; | |
}; | |
# Expose the package set, including overlays, for convenience. | |
darwinPackages = self.darwinConfigurations."fusillade".pkgs; | |
}; | |
} | |
davidlee ~/.config 09:31 | |
ls home-manager | |
flake.lock flake.nix home.nix | |
davidlee ~/.config 09:31 | |
cat home-manager/flake.nix | |
{ | |
description = "Home Manager configuration of davidlee"; | |
inputs = { | |
# Specify the source of Home Manager and Nixpkgs. | |
nixpkgs.url = "github:nixos/nixpkgs/nixos-unstable"; | |
home-manager = { | |
url = "github:nix-community/home-manager"; | |
inputs.nixpkgs.follows = "nixpkgs"; | |
}; | |
}; | |
outputs = { nixpkgs, home-manager, ... }: | |
let | |
system = "aarch64-darwin"; | |
pkgs = nixpkgs.legacyPackages.${system}; | |
in { | |
homeConfigurations."davidlee" = home-manager.lib.homeManagerConfiguration { | |
inherit pkgs; | |
# Specify your home configuration modules here, for example, | |
# the path to your home.nix. | |
modules = [ ./home.nix ]; | |
# Optionally use extraSpecialArgs | |
# to pass through arguments to home.nix | |
}; | |
}; | |
} | |
davidlee ~/.config 09:31 | |
cat home-manager/home.nix | |
{ config, pkgs, ... }: | |
{ | |
# Home Manager needs a bit of information about you and the paths it should | |
# manage. | |
home.username = "davidlee"; | |
home.homeDirectory = "/Users/davidlee"; | |
# This value determines the Home Manager release that your configuration is | |
# compatible with. This helps avoid breakage when a new Home Manager release | |
# introduces backwards incompatible changes. | |
# | |
# You should not change this value, even if you update Home Manager. If you do | |
# want to update the value, then make sure to first check the Home Manager | |
# release notes. | |
home.stateVersion = "24.05"; # Please read the comment before changing. | |
# The home.packages option allows you to install Nix packages into your | |
# environment. | |
home.packages = [ | |
# # Adds the 'hello' command to your environment. It prints a friendly | |
# # "Hello, world!" when run. | |
pkgs.hello | |
pkgs.nerdfonts | |
pkgs.helix | |
pkgs.direnv | |
pkgs.ripgrep | |
pkgs.fzf | |
pkgs.marksman | |
pkgs.tmux | |
pkgs.neovim | |
pkgs.emacs | |
pkgs.gh | |
pkgs.fd | |
# pkgs.ncdu | |
# pkgs.zig | |
pkgs.starship | |
pkgs.nethack | |
pkgs.taskwarrior | |
pkgs.kakoune | |
pkgs.wget | |
pkgs.zellij | |
pkgs.jq | |
pkgs.nnn | |
pkgs.d2 | |
pkgs.antidote | |
pkgs.qmk | |
pkgs.ranger | |
pkgs.sketchybar | |
pkgs.jankyborders | |
pkgs.nushell | |
pkgs.htop | |
pkgs.delta | |
pkgs.zoxide | |
pkgs.yazi | |
# # It is sometimes useful to fine-tune packages, for example, by applying | |
# # overrides. You can do that directly here, just don't forget the | |
# # parentheses. Maybe you want to install Nerd Fonts with a limited number of | |
# # fonts? | |
# (pkgs.nerdfonts.override { fonts = [ "FantasqueSansMono" ]; }) | |
# # You can also create simple shell scripts directly inside your | |
# # configuration. For example, this adds a command 'my-hello' to your | |
# # environment: | |
# (pkgs.writeShellScriptBin "my-hello" '' | |
# echo "Hello, ${config.home.username}!" | |
# '') | |
]; | |
# Home Manager is pretty good at managing dotfiles. The primary way to manage | |
# plain files is through 'home.file'. | |
home.file = { | |
# # Building this configuration will create a copy of 'dotfiles/screenrc' in | |
# # the Nix store. Activating the configuration will then make '~/.screenrc' a | |
# # symlink to the Nix store copy. | |
# ".screenrc".source = dotfiles/screenrc; | |
# # You can also set the file content immediately. | |
# ".gradle/gradle.properties".text = '' | |
# org.gradle.console=verbose | |
# org.gradle.daemon.idletimeout=3600000 | |
# ''; | |
}; | |
# Home Manager can also manage your environment variables through | |
# 'home.sessionVariables'. These will be explicitly sourced when using a | |
# shell provided by Home Manager. If you don't want to manage your shell | |
# through Home Manager then you have to manually source 'hm-session-vars.sh' | |
# located at either | |
# | |
# ~/.nix-profile/etc/profile.d/hm-session-vars.sh | |
# | |
# or | |
# | |
# ~/.local/state/nix/profiles/profile/etc/profile.d/hm-session-vars.sh | |
# | |
# or | |
# | |
# /etc/profiles/per-user/davidlee/etc/profile.d/hm-session-vars.sh | |
# | |
home.sessionVariables = { | |
# EDITOR = "emacs"; | |
}; | |
# Let Home Manager install and manage itself. | |
programs.home-manager.enable = true; | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment