|
|
||
|---|---|---|
| .github | ||
| .vscode | ||
| src | ||
| test | ||
| .envrc | ||
| .gitignore | ||
| Cargo.lock | ||
| Cargo.toml | ||
| fix.sh | ||
| flake.lock | ||
| flake.nix | ||
| LICENSE | ||
| package.nix | ||
| README.md | ||
| rustfmt.toml | ||
| shell.nix | ||
nh
Because the name "yet-another-nix-helper" was too long to type...
What does it do?
Nh is a modern helper utility that is a take at reimplementing some commands from the NixOS ecosystem. We aim to provide more features and better ergonomics than the existing commands.
We provide several subcommands, such as:
os, which reimplementsnixos-rebuild, with a tree of builds, diff and confirmation.home, which reimplementshome-manager.darwin, which reimplementsdarwin-rebuildsearch, a super-fast package searching tool (powered by a ElasticSearch client).clean, my own take at cleaning GC roots from a NixOS system.
This wouldn't be possible without the programs that nh runs under the hood:
- Tree of builds with nix-output-monitor.
- Visualization of the upgrade diff with nvd.
- And of course, all the crates we depend on.
Installation
The latest, tagged version will is available in Nixpkgs as Nh stable. This repository provides the latest development version of Nh, which you can get from the flake outputs.
nix shell nixpkgs#nh # stable
nix shell github:viperML/nh # dev
NixOS
We provide a NixOS module that integrates nh clean as a service. To enable it,
set the following configuration:
{ config, pkgs, ... }:
{
programs.nh = {
enable = true;
clean.enable = true;
clean.extraArgs = "--keep-since 4d --keep 3";
flake = "/home/user/my-nixos-config";
};
}
Nh supports both Flakes and classical NixOS configurations:
- For flakes, the command is
nh os switch /path/to/flake - For a classical configuration:
nh os switch -f '<nixpkgs/nixos>', ornh os switch -f '<nixpkgs/nixos>' -- -I nixos-config=/path/to/configuration.nixif using a different location than the default.
You might want to check nh os --help for other values and the defaults from
environment variables.
Specialisations support
Nh is capable of detecting which specialisation you are running, so it runs the
proper activation script. To do so, you need to give Nh some information of the
spec that is currently running by writing its name to /etc/specialisation. The
config would look like this:
{config, pkgs, ...}: {
specialisation."foo".configuration = {
environment.etc."specialisation".text = "foo";
# ..rest of config
};
specialisation."bar".configuration = {
environment.etc."specialisation".text = "bar";
# ..rest of config
};
}
Home-Manager
Home specialisations are read from ~/.local/share/home-manager/specialisation.
The config would look like this:
{config, pkgs, ...}: {
specialisation."foo".configuration = {
xdg.dataFile."home-manager/specialisation".text = "foo";
# ..rest of config
};
specialisation."bar".configuration = {
xdg.dataFile."home-manager/specialisation".text = "bar";
# ..rest of config
};
}
Status
Hacking
Just clone and nix develop. We also provide a .envrc for Direnv.