docs(tvix/[ca]store): improve docstrings, remove wildcard imports

Extend the docstrings of `add_default_services`, and add one for
`addrs_to_configs` as well as the module-wide one at
`tvix_store::composition`.

Change-Id: Ie9b449988eb210cd65b19b174094bbe0c4af2fd6
Reviewed-on: https://cl.tvl.fyi/c/depot/+/12748
Tested-by: BuildkiteCI
Reviewed-by: yuka <yuka@yuka.dev>
This commit is contained in:
Florian Klink 2024-11-09 14:20:03 +00:00 committed by flokli
parent e71a857ec8
commit a9f453f6da
4 changed files with 31 additions and 14 deletions

View file

@ -270,9 +270,10 @@ pub static REG: LazyLock<&'static Registry> = LazyLock::new(|| {
// ---------- End of generic registry code --------- // // ---------- End of generic registry code --------- //
/// Register the builtin services of tvix_castore with the given registry. /// Register the builtin services of tvix_castore (blob services and directory
/// This is useful for creating your own registry with the builtin types _and_ /// services) with the given registry.
/// extra third party types. /// This can be used outside to create your own registry with the builtin types
/// _and_ extra third party types.
pub fn add_default_services(reg: &mut Registry) { pub fn add_default_services(reg: &mut Registry) {
crate::blobservice::register_blob_services(reg); crate::blobservice::register_blob_services(reg);
crate::directoryservice::register_directory_services(reg); crate::directoryservice::register_directory_services(reg);

View file

@ -1,6 +1,13 @@
//! This module provides a registry knowing about {Blob,Directory,PathInfo}
//! Services, as well as the [add_default_services] helper to seed new
//! registries with everything known here.
//! The composition machinery itself is defined in
//! [tvix_castore::composition], which works generically with different kinds
//! of services.
use std::sync::LazyLock; use std::sync::LazyLock;
pub use tvix_castore::composition::*; use tvix_castore::composition::Registry;
/// The provided registry of tvix_store, which has all the builtin /// The provided registry of tvix_store, which has all the builtin
/// tvix_castore (BlobStore/DirectoryStore) and tvix_store /// tvix_castore (BlobStore/DirectoryStore) and tvix_store
@ -12,9 +19,11 @@ pub static REG: LazyLock<&'static Registry> = LazyLock::new(|| {
Box::leak(Box::new(reg)) Box::leak(Box::new(reg))
}); });
/// Register the builtin services of tvix_castore and tvix_store with the given /// Register the builtin services of tvix_castore (blob services and directory
/// registry. This is useful for creating your own registry with the builtin /// services), as well as the ones from tvix_store (PathInfo service) with the
/// types _and_ extra third party types. /// given registry.
/// This can be used outside to create your own registry with the builtin types
/// _and_ extra third party types.
pub fn add_default_services(reg: &mut Registry) { pub fn add_default_services(reg: &mut Registry) {
tvix_castore::composition::add_default_services(reg); tvix_castore::composition::add_default_services(reg);
crate::pathinfoservice::register_pathinfo_services(reg); crate::pathinfoservice::register_pathinfo_services(reg);

View file

@ -1,9 +1,10 @@
use super::PathInfoService; use super::PathInfoService;
use crate::composition::{ use crate::composition::REG;
with_registry, CompositionContext, DeserializeWithRegistry, ServiceBuilder, REG,
};
use std::sync::Arc; use std::sync::Arc;
use tvix_castore::composition::{
with_registry, CompositionContext, DeserializeWithRegistry, ServiceBuilder,
};
use tvix_castore::Error; use tvix_castore::Error;
use url::Url; use url::Url;
@ -56,11 +57,12 @@ pub async fn from_addr(
#[cfg(test)] #[cfg(test)]
mod tests { mod tests {
use super::from_addr; use super::from_addr;
use crate::composition::{Composition, DeserializeWithRegistry, ServiceBuilder, REG}; use crate::composition::REG;
use rstest::rstest; use rstest::rstest;
use std::sync::LazyLock; use std::sync::LazyLock;
use tempfile::TempDir; use tempfile::TempDir;
use tvix_castore::blobservice::{BlobService, MemoryBlobServiceConfig}; use tvix_castore::blobservice::{BlobService, MemoryBlobServiceConfig};
use tvix_castore::composition::{Composition, DeserializeWithRegistry, ServiceBuilder};
use tvix_castore::directoryservice::{DirectoryService, MemoryDirectoryServiceConfig}; use tvix_castore::directoryservice::{DirectoryService, MemoryDirectoryServiceConfig};
static TMPDIR_REDB_1: LazyLock<TempDir> = LazyLock::new(|| TempDir::new().unwrap()); static TMPDIR_REDB_1: LazyLock<TempDir> = LazyLock::new(|| TempDir::new().unwrap());

View file

@ -9,11 +9,12 @@ use tokio::io::{self, AsyncWrite};
use tvix_castore::{blobservice::BlobService, directoryservice::DirectoryService}; use tvix_castore::{blobservice::BlobService, directoryservice::DirectoryService};
use url::Url; use url::Url;
use crate::composition::{ use crate::composition::REG;
with_registry, Composition, DeserializeWithRegistry, ServiceBuilder, REG,
};
use crate::nar::{NarCalculationService, SimpleRenderer}; use crate::nar::{NarCalculationService, SimpleRenderer};
use crate::pathinfoservice::PathInfoService; use crate::pathinfoservice::PathInfoService;
use tvix_castore::composition::{
with_registry, Composition, DeserializeWithRegistry, ServiceBuilder,
};
#[derive(serde::Deserialize, Default)] #[derive(serde::Deserialize, Default)]
pub struct CompositionConfigs { pub struct CompositionConfigs {
@ -127,6 +128,10 @@ impl From<ServiceUrlsMemory> for ServiceUrls {
} }
} }
/// Deserializes service addresses into composition config, configuring each
/// service as the single "root".
/// If the `xp-composition-cli` feature is enabled, and a file specified in the
/// `--experimental-store-composition` parameter, this is used instead.
pub async fn addrs_to_configs( pub async fn addrs_to_configs(
urls: impl Into<ServiceUrls>, urls: impl Into<ServiceUrls>,
) -> Result<CompositionConfigs, Box<dyn std::error::Error + Send + Sync>> { ) -> Result<CompositionConfigs, Box<dyn std::error::Error + Send + Sync>> {