2023-01-31 17:43:33 +01:00
|
|
|
use sha2::{Digest, Sha256};
|
|
|
|
|
2023-01-31 14:45:42 +01:00
|
|
|
pub mod derivation;
|
2023-01-31 15:08:25 +01:00
|
|
|
pub mod nar;
|
2023-01-31 12:18:03 +01:00
|
|
|
pub mod nixbase32;
|
|
|
|
pub mod store_path;
|
2023-01-31 17:43:33 +01:00
|
|
|
|
|
|
|
/// Nix placeholders (i.e. values returned by `builtins.placeholder`)
|
|
|
|
/// are used to populate outputs with paths that must be
|
|
|
|
/// string-replaced with the actual placeholders later, at runtime.
|
|
|
|
///
|
|
|
|
/// The actual placeholder is basically just a SHA256 hash encoded in
|
|
|
|
/// cppnix format.
|
|
|
|
pub fn hash_placeholder(name: &str) -> String {
|
|
|
|
let digest = {
|
|
|
|
let mut hasher = Sha256::new();
|
|
|
|
hasher.update(format!("nix-output:{}", name));
|
|
|
|
hasher.finalize()
|
|
|
|
};
|
|
|
|
|
|
|
|
format!("/{}", nixbase32::encode(&digest))
|
|
|
|
}
|