feat(tvix/glue): contextful derivation
We calculate the input context by performing the union of context over all input of the derivation. Then, we just pass the rest of it to the remaining machinery. Finally, we re-emit an `outPath` and a `drvPath` containing the expected contexts. Change-Id: I74905fb258b5bee8b08d1208c9eb87f51b92a890 Reviewed-on: https://cl.tvl.fyi/c/depot/+/10436 Autosubmit: raitobezarius <tvl@lahfa.xyz> Reviewed-by: tazjin <tazjin@tvl.su> Tested-by: BuildkiteCI
This commit is contained in:
parent
15309c7deb
commit
099ca6b7c0
5 changed files with 86 additions and 223 deletions
|
@ -29,7 +29,7 @@ fn interpret(code: &str) {
|
|||
let mut eval = tvix_eval::Evaluation::new_impure();
|
||||
|
||||
let known_paths: Rc<RefCell<KnownPaths>> = Default::default();
|
||||
add_derivation_builtins(&mut eval, known_paths.clone());
|
||||
add_derivation_builtins(&mut eval, known_paths);
|
||||
configure_nix_path(
|
||||
&mut eval,
|
||||
// The benchmark requires TVIX_BENCH_NIX_PATH to be set, so barf out
|
||||
|
@ -37,15 +37,12 @@ fn interpret(code: &str) {
|
|||
&Some(env::var("TVIX_BENCH_NIX_PATH").expect("TVIX_BENCH_NIX_PATH must be set")),
|
||||
);
|
||||
|
||||
eval.io_handle = Box::new(tvix_glue::tvix_io::TvixIO::new(
|
||||
known_paths.clone(),
|
||||
TvixStoreIO::new(
|
||||
BLOB_SERVICE.clone(),
|
||||
DIRECTORY_SERVICE.clone(),
|
||||
PATH_INFO_SERVICE.clone(),
|
||||
TOKIO_RUNTIME.handle().clone(),
|
||||
),
|
||||
));
|
||||
eval.io_handle = Box::new(tvix_glue::tvix_io::TvixIO::new(TvixStoreIO::new(
|
||||
BLOB_SERVICE.clone(),
|
||||
DIRECTORY_SERVICE.clone(),
|
||||
PATH_INFO_SERVICE.clone(),
|
||||
TOKIO_RUNTIME.handle().clone(),
|
||||
)));
|
||||
|
||||
let result = eval.evaluate(code, None);
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue