feat(tvix/store): eliminate generics in BlobStore
To construct various stores at runtime, we need to eliminate associated types from the BlobService trait, and return Box<dyn …> instead of specific types. This also means we can't consume self in the close() method, so everything we write to is put in an Option<>, and during the first close we take from there. Change-Id: Ia523b6ab2f2a5276f51cb5d17e81a5925bce69b6 Reviewed-on: https://cl.tvl.fyi/c/depot/+/8647 Autosubmit: flokli <flokli@flokli.de> Tested-by: BuildkiteCI Reviewed-by: tazjin <tazjin@tvl.su>
This commit is contained in:
parent
5139cc45c2
commit
27ff98000b
15 changed files with 227 additions and 140 deletions
|
|
@ -1,7 +1,5 @@
|
|||
use crate::{
|
||||
blobservice::{BlobService, BlobWriter},
|
||||
proto::sync_read_into_async_read::SyncReadIntoAsyncRead,
|
||||
B3Digest,
|
||||
blobservice::BlobService, proto::sync_read_into_async_read::SyncReadIntoAsyncRead, B3Digest,
|
||||
};
|
||||
use std::{collections::VecDeque, io, pin::Pin};
|
||||
use tokio::task;
|
||||
|
|
@ -10,12 +8,12 @@ use tokio_util::io::ReaderStream;
|
|||
use tonic::{async_trait, Request, Response, Status, Streaming};
|
||||
use tracing::{instrument, warn};
|
||||
|
||||
pub struct GRPCBlobServiceWrapper<BS: BlobService> {
|
||||
blob_service: BS,
|
||||
pub struct GRPCBlobServiceWrapper {
|
||||
blob_service: Box<dyn BlobService>,
|
||||
}
|
||||
|
||||
impl<BS: BlobService> From<BS> for GRPCBlobServiceWrapper<BS> {
|
||||
fn from(value: BS) -> Self {
|
||||
impl From<Box<dyn BlobService + 'static>> for GRPCBlobServiceWrapper {
|
||||
fn from(value: Box<dyn BlobService>) -> Self {
|
||||
Self {
|
||||
blob_service: value,
|
||||
}
|
||||
|
|
@ -23,9 +21,7 @@ impl<BS: BlobService> From<BS> for GRPCBlobServiceWrapper<BS> {
|
|||
}
|
||||
|
||||
#[async_trait]
|
||||
impl<BS: BlobService + Send + Sync + Clone + 'static> super::blob_service_server::BlobService
|
||||
for GRPCBlobServiceWrapper<BS>
|
||||
{
|
||||
impl super::blob_service_server::BlobService for GRPCBlobServiceWrapper {
|
||||
// https://github.com/tokio-rs/tokio/issues/2723#issuecomment-1534723933
|
||||
type ReadStream =
|
||||
Pin<Box<dyn futures::Stream<Item = Result<super::BlobChunk, Status>> + Send + 'static>>;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue