Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

types.attrs: merge non-conflicting values only #153588

Closed
wants to merge 1 commit into from

Conversation

abbradar
Copy link
Member

@abbradar abbradar commented Jan 5, 2022

Motivation for this change

Avoid silent conflicting redefinitions of option values.

Things done
  • Built on platform(s)
    • x86_64-linux
    • aarch64-linux
    • x86_64-darwin
    • aarch64-darwin
  • For non-Linux: Is sandbox = true set in nix.conf? (See Nix manual)
  • Tested, as applicable:
  • Tested compilation of all packages that depend on this change using nix-shell -p nixpkgs-review --run "nixpkgs-review rev HEAD". Note: all changes have to be committed, also see nixpkgs-review usage
  • Tested basic functionality of all binary files (usually in ./result/bin/)
  • 22.05 Release Notes (or backporting 21.11 Release notes)
    • (Package updates) Added a release notes entry if the change is major or breaking
    • (Module updates) Added a release notes entry if the change is significant
    • (Module addition) Added a release notes entry if adding a new NixOS module
    • (Release notes changes) Ran nixos/doc/manual/md-to-db.sh to update generated release notes
  • Fits CONTRIBUTING.md.

@ofborg ofborg bot added 10.rebuild-darwin: 0 This PR does not cause any packages to rebuild on Darwin 10.rebuild-linux: 1-10 labels Jan 5, 2022
@infinisil
Copy link
Member

With the introduction of types.anything and soon types.raw, we should deprecate types.attrs. As such I don't think it makes sense to change types.attrs anymore, especially in a backwards-incompatible way.

@abbradar
Copy link
Member Author

abbradar commented Jan 5, 2022

It makes sense, yeah. I propose then to replace all usage of attrs in NixOS with attrsOf anything to safely merge conflicting values (I was actually bitten by this in production, and IMHO noone expects current behaviour), and add a deprecation warning. What do you think?

@abbradar
Copy link
Member Author

abbradar commented Jan 5, 2022

Reading more of the linked issues I see that we already have the deprecation in mind. Great news! Let's close this PR; I don't think it's relevant.

@abbradar abbradar closed this Jan 5, 2022
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
10.rebuild-darwin: 0 This PR does not cause any packages to rebuild on Darwin 10.rebuild-linux: 1-10
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants