mirror of
https://github.com/nmasur/dotfiles
synced 2024-11-26 16:35:36 +00:00
108 lines
2.9 KiB
Markdown
108 lines
2.9 KiB
Markdown
# System Configurations
|
|
|
|
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/common/neovim/config)
|
|
- [Fish functions](https://github.com/nmasur/dotfiles/tree/master/modules/common/shell/fish/functions)
|
|
- [More fish aliases](https://github.com/nmasur/dotfiles/blob/master/modules/common/shell/fish/default.nix)
|
|
- [Git aliases](https://github.com/nmasur/dotfiles/blob/master/modules/common/shell/git.nix)
|
|
- [Hammerspoon](https://github.com/nmasur/dotfiles/tree/master/modules/darwin/hammerspoon)
|
|
|
|
Try out my Neovim config (requires [nix](https://nixos.org/download.html)):
|
|
|
|
```bash
|
|
nix run github:nmasur/dotfiles#neovim
|
|
```
|
|
|
|
Or build it as a package (requires [nix](https://nixos.org/download.html)):
|
|
|
|
```bash
|
|
nix build github:nmasur/dotfiles#neovim
|
|
```
|
|
|
|
If you already have a Neovim configuration, you may need to move it out of
|
|
`~/.config/nvim` or set `XDG_CONFIG_HOME` to another value; otherwise both
|
|
configs might conflict with each other.
|
|
|
|
---
|
|
|
|
# Full 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 tempest
|
|
```
|
|
|
|
## 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#tempest
|
|
```
|
|
|
|
## 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#hydra
|
|
```
|
|
|
|
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#lookingglass
|
|
```
|
|
|
|
---
|
|
|
|
# Flake Templates
|
|
|
|
You can also use the [templates](./templates/) as flakes for starting new
|
|
projects:
|
|
|
|
```bash
|
|
nix flake init --template github:nmasur/dotfiles#poetry
|
|
```
|