diff options
author | Florian Klink <flokli@flokli.de> | 2024-08-13T17·04+0300 |
---|---|---|
committer | clbot <clbot@tvl.fyi> | 2024-08-13T18·39+0000 |
commit | c7845f3c882d0f1b215813bf0ef8231c2c03d7b6 (patch) | |
tree | 681774cbfa98e5021aa68b361bc937b88881b5c8 /tvix/glue | |
parent | 2f4185ff1a54e1bdbaa062a9e4e1c8137d141762 (diff) |
refactor(tvix/castore): move *Node and Directory to crate root r/8486
*Node and Directory are types of the tvix-castore model, not the tvix DirectoryService model. A DirectoryService only happens to send Directories. Move types into individual files in a nodes/ subdirectory, as it's gotten too cluttered in a single file, and (re-)export all types from the crate root. This has the effect that we now cannot poke at private fields directly from other files inside `crate::directoryservice` (as it's not all in the same file anymore), but that's a good thing, it now forces us to go through the proper accessors. For the same reasons, we currently also need to introduce the `rename` functions on each *Node directly. A followup is gonna move the names out of the individual enum kinds, so we can better represent "unnamed nodes". Change-Id: Icdb34dcfe454c41c94f2396e8e99973d27db8418 Reviewed-on: https://cl.tvl.fyi/c/depot/+/12199 Reviewed-by: yuka <yuka@yuka.dev> Autosubmit: flokli <flokli@flokli.de> Tested-by: BuildkiteCI
Diffstat (limited to 'tvix/glue')
-rw-r--r-- | tvix/glue/src/builtins/derivation.rs | 2 | ||||
-rw-r--r-- | tvix/glue/src/builtins/import.rs | 3 | ||||
-rw-r--r-- | tvix/glue/src/fetchers/mod.rs | 4 | ||||
-rw-r--r-- | tvix/glue/src/tvix_build.rs | 4 | ||||
-rw-r--r-- | tvix/glue/src/tvix_store_io.rs | 3 |
5 files changed, 7 insertions, 9 deletions
diff --git a/tvix/glue/src/builtins/derivation.rs b/tvix/glue/src/builtins/derivation.rs index 9074d418422e..27ae2e1d6925 100644 --- a/tvix/glue/src/builtins/derivation.rs +++ b/tvix/glue/src/builtins/derivation.rs @@ -179,7 +179,7 @@ pub(crate) mod derivation_builtins { use nix_compat::nixhash::CAHash; use nix_compat::store_path::{build_ca_path, hash_placeholder}; use sha2::Sha256; - use tvix_castore::directoryservice::{FileNode, Node}; + use tvix_castore::{FileNode, Node}; use tvix_eval::generators::Gen; use tvix_eval::{NixContext, NixContextElement, NixString}; use tvix_store::proto::{NarInfo, PathInfo}; diff --git a/tvix/glue/src/builtins/import.rs b/tvix/glue/src/builtins/import.rs index aa0d0d54fc8a..1cf4145427b8 100644 --- a/tvix/glue/src/builtins/import.rs +++ b/tvix/glue/src/builtins/import.rs @@ -2,9 +2,8 @@ use crate::builtins::errors::ImportError; use std::path::Path; -use tvix_castore::directoryservice::FileNode; -use tvix_castore::directoryservice::Node; use tvix_castore::import::ingest_entries; +use tvix_castore::{FileNode, Node}; use tvix_eval::{ builtin_macros::builtins, generators::{self, GenCo}, diff --git a/tvix/glue/src/fetchers/mod.rs b/tvix/glue/src/fetchers/mod.rs index 9cab1adc04a3..88d6da9f1e3c 100644 --- a/tvix/glue/src/fetchers/mod.rs +++ b/tvix/glue/src/fetchers/mod.rs @@ -11,9 +11,7 @@ use tokio_util::io::{InspectReader, InspectWriter}; use tracing::{instrument, warn, Span}; use tracing_indicatif::span_ext::IndicatifSpanExt; use tvix_castore::{ - blobservice::BlobService, - directoryservice::{DirectoryService, FileNode, Node}, - ValidateNodeError, + blobservice::BlobService, directoryservice::DirectoryService, FileNode, Node, ValidateNodeError, }; use tvix_store::{nar::NarCalculationService, pathinfoservice::PathInfoService, proto::PathInfo}; use url::Url; diff --git a/tvix/glue/src/tvix_build.rs b/tvix/glue/src/tvix_build.rs index 0f930bfe5099..7fff0b9cf337 100644 --- a/tvix/glue/src/tvix_build.rs +++ b/tvix/glue/src/tvix_build.rs @@ -10,7 +10,7 @@ use tvix_build::proto::{ build_request::{AdditionalFile, BuildConstraints, EnvVar}, BuildRequest, }; -use tvix_castore::directoryservice::Node; +use tvix_castore::Node; /// These are the environment variables that Nix sets in its sandbox for every /// build. @@ -197,8 +197,8 @@ mod test { build_request::{AdditionalFile, BuildConstraints, EnvVar}, BuildRequest, }; - use tvix_castore::directoryservice::{DirectoryNode, Node}; use tvix_castore::fixtures::DUMMY_DIGEST; + use tvix_castore::{DirectoryNode, Node}; use crate::tvix_build::NIX_ENVIRONMENT_VARS; diff --git a/tvix/glue/src/tvix_store_io.rs b/tvix/glue/src/tvix_store_io.rs index c92a9c57e0c7..8c5631382844 100644 --- a/tvix/glue/src/tvix_store_io.rs +++ b/tvix/glue/src/tvix_store_io.rs @@ -20,7 +20,8 @@ use tvix_store::nar::NarCalculationService; use tvix_castore::{ blobservice::BlobService, - directoryservice::{self, DirectoryService, NamedNode, Node}, + directoryservice::{self, DirectoryService}, + {NamedNode, Node}, }; use tvix_store::{pathinfoservice::PathInfoService, proto::PathInfo}; |