1
0
Fork 0
mirror of https://github.com/LnL7/nix-darwin.git synced 2024-12-14 11:57:34 +00:00
nix-darwin/modules
Emily f9724c4543 eval-config: rationalize handling of Nixpkgs
This is a big change that disentangles a lot of mistaken assumptions
about mixing multiple versions of Nixpkgs, treating external flake
inputs as gospel for the source of Nixpkgs and nix-darwin, etc.;
the end result should be much simpler conceptually, but it will be a
breaking change for anyone using `eval-config.nix` directly. Hopefully
that shouldn't be a big issue, as it is more of an internal API and
it's quite likely that existing uses may have been broken in the same
way the internal ones were.

It was previously easy to get into a state where your `lib` comes
from nix-darwin's `nixpkgs` input or a global channel and your
`pkgs` comes from another major version of Nixpkgs. This is pretty
fundamentally broken due to the coupling of `pkgs` to its corresponding
`lib`, but the brokenness was hidden much of the time until something
surfaced it. Now there is exactly one mandatory `lib` input to system
evaluation, and the handling of various additional options like `pkgs`
and `system` can be done modularly; maintaining backwards compatibility
with the previous calling convention is punted to the `default.nix`
and `lib.darwinSystem` entry points. `inputs` is no longer read by
nix-darwin or special in any way, merely a convention for user code,
and the argument is retained in the entry points only for backwards
compatibility.

All correct invocations of the entry points should keep working
after this change, and some previously-broken ones should be fixed
too. The documentation and template have been adjusted to show the
newly-recommended modular way of specifying various things, but no
deprecation warnings have been introduced yet by this change.

There is one potential, mostly cosmetic regression:
`system.nixpkgsRevision` and related options are less likely to be
set than before, in cases where it is not possible to determine the
origin of the package set. Setting `nixpkgs.source` explicitly will
make this work again, and I hope to look into sending changes upstream
to Nixpkgs to make `lib.trivial.revisionWithDefault` behave properly
under flakes, which would fix this regression and potentially allow
reducing some of the complexity.

Fixes: #669
2023-07-09 11:21:40 +01:00
..
documentation version: default Git revision options to null 2023-07-09 07:26:00 +01:00
environment treewide: convert all option docs to Markdown 2023-06-24 10:48:55 +01:00
examples eval-config: rationalize handling of Nixpkgs 2023-07-09 11:21:40 +01:00
fonts treewide: convert all option docs to Markdown 2023-06-24 10:48:55 +01:00
launchd treewide: convert all option docs to Markdown 2023-06-24 10:48:55 +01:00
lib treewide: convert all option docs to Markdown 2023-06-24 10:48:55 +01:00
misc treewide: convert all option docs to Markdown 2023-06-24 10:48:55 +01:00
networking treewide: convert all option docs to Markdown 2023-06-24 10:48:55 +01:00
nix nixpkgs: rebase module on latest NixOS 2023-07-08 22:39:19 +01:00
programs treewide: convert all option docs to Markdown 2023-06-24 10:48:55 +01:00
security treewide: convert all option docs to Markdown 2023-06-24 10:48:55 +01:00
services tailscale: improve MagicDNS setup 2023-06-27 01:38:51 +10:00
system eval-config: rationalize handling of Nixpkgs 2023-07-09 11:21:40 +01:00
time treewide: convert all option docs to Markdown 2023-06-24 10:48:55 +01:00
users treewide: convert all option docs to Markdown 2023-06-24 10:48:55 +01:00
alias.nix Update def and implementation of nix.package to match NixOS module 2022-08-16 10:41:51 -07:00
homebrew.nix treewide: convert all option docs to Markdown 2023-06-24 10:48:55 +01:00
meta.nix treewide: convert all option docs to Markdown 2023-06-24 10:48:55 +01:00
module-list.nix add ipfs service 2023-06-18 00:44:04 -05:00