mirror of
https://github.com/nmasur/dotfiles
synced 2024-11-22 21:35:37 +00:00
106 lines
2.7 KiB
Markdown
106 lines
2.7 KiB
Markdown
This repository contains configuration files for my NixOS, macOS, and WSL
|
|
hosts.
|
|
|
|
They are organized and managed by [Nix](https://nixos.org), so some of the
|
|
configuration may be difficult to translate to a non-Nix system.
|
|
|
|
However, some of the configurations are easier to lift directly:
|
|
|
|
- [Neovim](https://github.com/nmasur/dotfiles/tree/master/modules/neovim/lua)
|
|
- [Fish functions](https://github.com/nmasur/dotfiles/tree/master/modules/shell/fish/functions)
|
|
- [More fish aliases](https://github.com/nmasur/dotfiles/blob/master/modules/shell/fish/default.nix)
|
|
- [Git aliases](https://github.com/nmasur/dotfiles/blob/master/modules/shell/git.nix)
|
|
- [Hammerspoon](https://github.com/nmasur/dotfiles/tree/master/modules/darwin/hammerspoon)
|
|
|
|
---
|
|
|
|
# Installation
|
|
|
|
## NixOS - From Live Disk
|
|
|
|
Format drives and build system from any NixOS host, including the live
|
|
installer disk:
|
|
|
|
**This will erase your drives; use at your own risk!**
|
|
|
|
```bash
|
|
lsblk # Choose the disk you want to wipe
|
|
nix-shell -p nixVersions.stable
|
|
nix run github:nmasur/dotfiles#installer -- nvme0n1 desktop
|
|
```
|
|
|
|
## NixOS - From Existing System
|
|
|
|
If you're already running NixOS, you can switch to this configuration with the
|
|
following command:
|
|
|
|
```bash
|
|
nix-shell -p nixVersions.stable
|
|
sudo nixos-rebuild switch --flake github:nmasur/dotfiles#desktop
|
|
```
|
|
|
|
## Windows - From NixOS WSL
|
|
|
|
After [installing NixOS on
|
|
WSL](https://xeiaso.net/blog/nix-flakes-4-wsl-2022-05-01), you can switch to
|
|
the WSL configuration:
|
|
|
|
```
|
|
nix-shell -p nixVersions.stable
|
|
sudo nixos-rebuild switch --flake github:nmasur/dotfiles#wsl
|
|
```
|
|
|
|
You should also download the
|
|
[FiraCode](https://github.com/ryanoasis/nerd-fonts/releases/download/v2.2.2/FiraCode.zip)
|
|
font and install it on Windows. Install [Alacritty](https://alacritty.org/) and
|
|
move the `windows/alacritty.yml` file to
|
|
`C:\Users\<user>\AppData\Roaming\alacritty`.
|
|
|
|
## macOS
|
|
|
|
To get started on a bare macOS installation, first install Nix:
|
|
|
|
```bash
|
|
sh -c "$(curl -L https://nixos.org/nix/install)"
|
|
```
|
|
|
|
Then use Nix to build nix-darwin:
|
|
|
|
```bash
|
|
nix-build https://github.com/LnL7/nix-darwin/archive/master.tar.gz -A installer
|
|
./result/bin/darwin-installer
|
|
```
|
|
|
|
Then switch to the macOS configuration:
|
|
|
|
```bash
|
|
darwin-rebuild switch --flake github:nmasur/dotfiles#macbook
|
|
```
|
|
|
|
### Dealing with corporate MITM SSL certificates:
|
|
|
|
```bash
|
|
# Get the certificates
|
|
openssl s_client -showcerts -verify 5 -connect cache.nixos.org:443 < /dev/null
|
|
|
|
# Paste them in here
|
|
sudo nvim $NIX_SSL_CERT_FILE
|
|
```
|
|
|
|
### Dealing with Neovim issues:
|
|
|
|
Update Neovim Packer plugins: `:PackerSync`
|
|
|
|
Update TreeSitter languages: `:TSUpdateSync`
|
|
|
|
---
|
|
|
|
# Flake Templates
|
|
|
|
You can also use the [templates](./templates/) as flakes for starting new
|
|
projects:
|
|
|
|
```bash
|
|
nix flake init --template github:nmasur/dotfiles#poetry
|
|
```
|