feat(tvix/cli): add replacement strings tracking to KnownPaths

Replacement strings are some weird internal feature of Nix that is
required for calculating derivation hashes. We need to track these
like other paths, as they need to be re-used on builds with
dependencies on values from previous builds.

Change-Id: Ie955b3fb5ae3685cfadfbe4d06ea6b5e219590c7
Reviewed-on: https://cl.tvl.fyi/c/depot/+/7828
Reviewed-by: flokli <flokli@flokli.de>
Tested-by: BuildkiteCI
This commit is contained in:
Vincent Ambo 2023-01-14 01:45:57 +03:00 committed by tazjin
parent 499e72c1cb
commit 79e54f46ce

View file

@ -33,6 +33,12 @@ pub enum PathType {
pub struct KnownPaths { pub struct KnownPaths {
/// All known paths, and their associated [`PathType`]. /// All known paths, and their associated [`PathType`].
paths: HashMap<String, PathType>, paths: HashMap<String, PathType>,
/// All known replacement strings for derivations.
///
/// Keys are derivation paths, values are the opaque replacement
/// strings.
replacements: HashMap<String, String>,
} }
impl Index<&str> for KnownPaths { impl Index<&str> for KnownPaths {
@ -112,4 +118,27 @@ impl KnownPaths {
let candidates = self.paths.keys().map(Clone::clone).collect(); let candidates = self.paths.keys().map(Clone::clone).collect();
ReferenceScanner::new(candidates) ReferenceScanner::new(candidates)
} }
/// Fetch the opaque "replacement string" for a given derivation path.
pub fn get_replacement_string(&self, drv: &str) -> String {
// TODO: we rely on an invariant that things *should* have
// been calculated if we get this far.
self.replacements[drv].clone()
}
pub fn add_replacement_string<D: ToString>(&mut self, drv: D, replacement_str: &str) {
let old = self
.replacements
.insert(drv.to_string(), replacement_str.to_owned());
#[cfg(debug_assertions)]
{
if let Some(old) = old {
debug_assert!(
old == replacement_str,
"replacement string for a given derivation should always match"
);
}
}
}
} }