nex
Package manager for nix-darwin, NixOS, and homebrew. nex.styrene.io
Quick Start
# Install nex
|
# Bootstrap nix-darwin + homebrew (macOS) or NixOS (Linux)
# Start using it
Or clone an existing config: nex init --from https://github.com/your-org/macos-nix
Usage
Packages
nex install htop # Auto-resolves nix vs cask vs brew
nex install --cask slack # Force Homebrew cask (GUI app)
nex install --brew rustup # Force Homebrew formula
nex install --nix htop # Force Nix (skip resolution)
nex remove htop # Remove from wherever it's declared
nex search "http" # Search nixpkgs
nex list # Show all declared packages
System
nex init # Bootstrap nix + homebrew + system config
nex switch # Rebuild and activate
nex update # Update flake inputs + switch
nex rollback # Revert to previous generation
nex doctor # Check and fix config issues
nex relocate # Move system config to user-writable directory
Profiles
nex profile apply user/repo # Apply a machine profile from GitHub
nex forge user/profile # Burn a bootable NixOS USB with profile baked in
nex polymerize # Interactive NixOS installer (on target machine)
nex build-image user/profile # Build an OCI container from a profile
Development
nex develop ./path/to/flake # Enter a flake dev shell
nex dev user/repo # Dev shell + omegon AI agent
nex try htop # Ephemeral nix shell (no install)
nex diff # Preview what would change
nex gc # Garbage collect nix store
nex self-update # Update nex itself
Global flags: --dry-run, --repo <path>, --hostname <name>
How It Works
nex install slack checks nixpkgs and Homebrew, compares versions (semver-aware), detects GUI apps vs CLI tools, and recommends the right source:
slack found in multiple sources:
nixpkgs 4.41.97
* brew cask 4.42.3
recommended: brew cask is 4.42.3 (nix has 4.41.97)
For CLI tools found only in nixpkgs, it just installs -- no prompt needed.
Every edit is backed up before rebuild. If the build fails, your config is restored automatically.
Profiles
Define a machine with a TOML file:
[]
= ["htop", "bat", "eza", "ripgrep"]
= ["firefox", "kitty"]
[]
= { = "eza -la", = "bat" }
[]
= "Your Name"
= "you@example.com"
[]
= true
= true
Profiles compose via extends for team/personal layering. Apply with nex profile apply user/repo.
Installation
|
Configuration
nex auto-discovers the config repo by walking up from CWD or checking well-known paths. Override with:
NEX_REPOenvironment variable--repoflag~/.config/nex/config.toml:= "/path/to/config-repo" = "My-MacBook" = true
Development
License
MIT OR Apache-2.0