feat(tvix/nix-compat): Use StorePath
in Output
https: //b.tvl.fyi/issues/264 Change-Id: Icb09be9643245cc68d09f01d7723af2d44d6bd1a Reviewed-on: https://cl.tvl.fyi/c/depot/+/11001 Autosubmit: Peter Kolloch <info@eigenvalue.net> Reviewed-by: flokli <flokli@flokli.de> Tested-by: BuildkiteCI
This commit is contained in:
parent
035f617b7f
commit
fde488ec6d
11 changed files with 119 additions and 82 deletions
|
@ -116,7 +116,7 @@ fn handle_fixed_output(
|
|||
drv.outputs.insert(
|
||||
"out".to_string(),
|
||||
Output {
|
||||
path: "".to_string(),
|
||||
path: None,
|
||||
ca_hash: match hash_mode_str.as_deref() {
|
||||
None | Some("flat") => Some(nixhash::CAHash::Flat(nixhash)),
|
||||
Some("recursive") => Some(nixhash::CAHash::Nar(nixhash)),
|
||||
|
@ -486,7 +486,7 @@ pub(crate) mod derivation_builtins {
|
|||
(
|
||||
name.clone(),
|
||||
(
|
||||
output.path,
|
||||
output.path.unwrap().to_absolute_path(),
|
||||
Some(
|
||||
NixContextElement::Single {
|
||||
name,
|
||||
|
|
|
@ -74,14 +74,8 @@ impl KnownPaths {
|
|||
// For all output paths, update our lookup table.
|
||||
// We only write into the lookup table once.
|
||||
for output in drv.outputs.values() {
|
||||
// We assume derivations to be passed validated, so ignoring rest
|
||||
// and expecting parsing is ok.
|
||||
// TODO: b/264
|
||||
let (output_path, _rest) =
|
||||
StorePath::from_absolute_path_full(&output.path).expect("parse output path");
|
||||
|
||||
self.outputs_to_drvpath
|
||||
.entry(output_path)
|
||||
.entry(output.path.as_ref().expect("missing store path").clone())
|
||||
.or_insert(drv_path.to_owned());
|
||||
}
|
||||
|
||||
|
|
|
@ -52,7 +52,7 @@ pub(crate) fn derivation_to_build_request(
|
|||
let mut output_paths: Vec<String> = derivation
|
||||
.outputs
|
||||
.values()
|
||||
.map(|e| e.path[1..].to_owned())
|
||||
.map(|e| e.path_str()[1..].to_owned())
|
||||
.collect();
|
||||
|
||||
// Sort the outputs. We can use sort_unstable, as these are unique strings.
|
||||
|
|
|
@ -4,10 +4,7 @@ use async_recursion::async_recursion;
|
|||
use bytes::Bytes;
|
||||
use futures::Stream;
|
||||
use futures::{StreamExt, TryStreamExt};
|
||||
use nix_compat::{
|
||||
nixhash::CAHash,
|
||||
store_path::{StorePath, StorePathRef},
|
||||
};
|
||||
use nix_compat::{nixhash::CAHash, store_path::StorePath};
|
||||
use std::{
|
||||
cell::RefCell,
|
||||
collections::BTreeSet,
|
||||
|
@ -153,16 +150,14 @@ impl TvixStoreIO {
|
|||
let output_paths: Vec<StorePath> = output_names
|
||||
.iter()
|
||||
.map(|output_name| {
|
||||
let output_path = &input_drv
|
||||
input_drv
|
||||
.outputs
|
||||
.get(output_name)
|
||||
.expect("missing output_name")
|
||||
.path;
|
||||
|
||||
// since Derivation is validated, we this can be parsed.
|
||||
StorePathRef::from_absolute_path(output_path.as_bytes())
|
||||
.expect("invalid output path")
|
||||
.to_owned()
|
||||
.path
|
||||
.as_ref()
|
||||
.expect("missing output path")
|
||||
.clone()
|
||||
})
|
||||
.collect();
|
||||
// For each output, ask for the castore node.
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue