From 5d9f49b5698e7b25b775300c413c69dd9ce82cf9 Mon Sep 17 00:00:00 2001 From: hoslo Date: Fri, 3 May 2024 07:37:47 -0300 Subject: [PATCH] feat(core/types): change oio::BlockingReader to Arc --- core/src/layers/type_eraser.rs | 2 +- core/src/raw/oio/read/api.rs | 8 ++++---- core/src/types/blocking_read/blocking_reader.rs | 1 - 3 files changed, 5 insertions(+), 6 deletions(-) diff --git a/core/src/layers/type_eraser.rs b/core/src/layers/type_eraser.rs index aa7e0ea8741e..72eee9d0e58d 100644 --- a/core/src/layers/type_eraser.rs +++ b/core/src/layers/type_eraser.rs @@ -88,7 +88,7 @@ impl LayeredAccess for TypeEraseAccessor { fn blocking_read(&self, path: &str, args: OpRead) -> Result<(RpRead, Self::BlockingReader)> { self.inner .blocking_read(path, args) - .map(|(rp, r)| (rp, Box::new(r) as oio::BlockingReader)) + .map(|(rp, r)| (rp, Arc::new(r) as oio::BlockingReader)) } fn blocking_write(&self, path: &str, args: OpWrite) -> Result<(RpWrite, Self::BlockingWriter)> { diff --git a/core/src/raw/oio/read/api.rs b/core/src/raw/oio/read/api.rs index 01d2d0c9d3fe..99123a8dd5e8 100644 --- a/core/src/raw/oio/read/api.rs +++ b/core/src/raw/oio/read/api.rs @@ -155,8 +155,8 @@ impl Read for Arc { } } -/// BlockingReader is a boxed dyn `BlockingRead`. -pub type BlockingReader = Box; +/// BlockingReader is a arc dyn `BlockingRead`. +pub type BlockingReader = Arc; /// Read is the trait that OpenDAL returns to callers. pub trait BlockingRead: Send + Sync { @@ -199,9 +199,9 @@ impl BlockingRead for Buffer { } } -/// `Box` won't implement `BlockingRead` automatically. +/// `Arc` won't implement `BlockingRead` automatically. /// To make BlockingReader work as expected, we must add this impl. -impl BlockingRead for Box { +impl BlockingRead for Arc { fn read_at(&self, offset: u64, limit: usize) -> Result { (**self).read_at(offset, limit) } diff --git a/core/src/types/blocking_read/blocking_reader.rs b/core/src/types/blocking_read/blocking_reader.rs index 49a5ee2dcdbc..e87528fceabf 100644 --- a/core/src/types/blocking_read/blocking_reader.rs +++ b/core/src/types/blocking_read/blocking_reader.rs @@ -22,7 +22,6 @@ use std::ops::RangeBounds; use bytes::Buf; use bytes::BufMut; -use crate::raw::oio::BlockingRead; use crate::raw::*; use crate::*;