-
-
Notifications
You must be signed in to change notification settings - Fork 1.6k
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
Make output paths/hashes indifferent to possible CA/FOD origin of sources #9259
Comments
Yeah I've wanted this for a bit. Note that it can/should apply to all content-addressed outputs too; that is also non-fixed ones. |
The logic should also apply to CA realisation ( |
@roberth I've also been thinking about whether we can put the caching of this stuff in the derivation itself. Right now needing to recompute everything from the roots is annoying/slow. It would be cool if you could resume it from any derivation. (Of course, for verifying the store it would be good to still retain the ability to check it from scratch.) |
Lines 583 to 614 in c8458bd
If we make that inputSrcs vs inputDrvs never influences the output path then we get:
The algorithm is very simple (works for the dynamic derivations definition too):
|
Probably best to start with That will give us the language to describe the new hashing scheme more effectively. |
#6877 wanted to get to that :) |
Is your feature request related to a problem? Please describe.
We can't currently swap out an
inputSrcs
derivation input for aninputDrvs
input derivation input and get the same output path, despite no observable differences (with the possible exception of introspective features such as exportReferencesGraph, which we could force to be mutually exclusive with this improved hashing feature).nix repl
session illustrating how it currently works, and what this improvement entailsCurrently we have some equivalence between FOD output paths and sources:
However, as expected, the string contexts are different:
In itself, this is not a problem. Fact is that they need to be built differently. One involves an FOD. The other was added to the store during instantiation.
That being the case, we can expect dependents to have different derivation hashes, representing the different build graph.
So far so good, but now we observe a difference in output paths, which is not necessary.
By implementing this proposal (and enabling it in Nixpkgs), both output paths would have the value
/nix/store/56phdxcpdv7d8zz4cj0a28iwz5akcpcz-derived
.Describe the solution you'd like
Instantiation works the same, except for the hashing of certain input-addressed outputs.
Specifically, when a derivation attribute flag such as
__derivationAgnosticOutputHashing
is enabled, inputs from FODs are ignored for the purpose of hashing; instead interpreting their output paths asinputSrcs
.Ignore
__derivationAgnosticOutputHashing
when the build could perceive the difference, e.g. when it has flags that would let it introspect its dependencies. I don't think it could useexportReferencesGraph
on itself, so this may not even be a problem. I just haven't checked whether that was everything that needs to be controlled. TBD.Describe alternatives you've considered
Fail instead of ignoring
__derivationAgnosticOutputHashing
. In practice this would mean thatmkDerivation
has to be clever about when to set the flag, which seems rather convoluted, pointless, and ever so slightly slower.Additional context
Priorities
Add 👍 to issues you find important.
The text was updated successfully, but these errors were encountered: