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:
parent
e71a857ec8
commit
a9f453f6da
4 changed files with 31 additions and 14 deletions
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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());
|
||||||
|
|
|
@ -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>> {
|
||||||
|
|
Loading…
Reference in a new issue