Skip to content

Commit

Permalink
Initialize FileMetadata using OnceCell
Browse files Browse the repository at this point in the history
  • Loading branch information
fqaiser94 committed Jan 26, 2025
1 parent 1f54293 commit 8752ce4
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 14 deletions.
5 changes: 2 additions & 3 deletions crates/iceberg/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ license = { workspace = true }
keywords = ["iceberg"]

[features]
default = ["storage-memory", "storage-fs", "storage-s3", "tokio"]
default = ["storage-memory", "storage-fs", "storage-s3"]
storage-all = ["storage-memory", "storage-fs", "storage-s3", "storage-gcs"]

storage-memory = ["opendal/services-memory"]
Expand All @@ -38,7 +38,6 @@ storage-s3 = ["opendal/services-s3"]
storage-gcs = ["opendal/services-gcs"]

async-std = ["dep:async-std"]
tokio = ["dep:tokio"]

[dependencies]
anyhow = { workspace = true }
Expand Down Expand Up @@ -78,7 +77,7 @@ serde_derive = { workspace = true }
serde_json = { workspace = true }
serde_repr = { workspace = true }
serde_with = { workspace = true }
tokio = { workspace = true, optional = true }
tokio = { workspace = true, features = ["sync"] }
typed-builder = { workspace = true }
url = { workspace = true }
uuid = { workspace = true }
Expand Down
21 changes: 10 additions & 11 deletions crates/iceberg/src/puffin/reader.rs
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,8 @@
// specific language governing permissions and limitations
// under the License.

use tokio::sync::OnceCell;

use crate::io::{FileRead, InputFile};
use crate::puffin::blob::Blob;
use crate::puffin::metadata::{BlobMetadata, FileMetadata};
Expand All @@ -23,26 +25,23 @@ use crate::Result;
/// Puffin reader
pub(crate) struct PuffinReader {
input_file: InputFile,
file_metadata: Option<FileMetadata>,
file_metadata: OnceCell<FileMetadata>,
}

impl PuffinReader {
/// Returns a new Puffin reader
pub(crate) fn new(input_file: InputFile) -> Self {
Self {
input_file,
file_metadata: None,
file_metadata: OnceCell::new(),
}
}

/// Returns file metadata
pub(crate) async fn file_metadata(&mut self) -> Result<&FileMetadata> {
if let Some(ref file_metadata) = self.file_metadata {
Ok(file_metadata)
} else {
let file_metadata = FileMetadata::read(&self.input_file).await?;
Ok(self.file_metadata.insert(file_metadata))
}
pub(crate) async fn file_metadata(&self) -> Result<&FileMetadata> {
self.file_metadata
.get_or_try_init(|| FileMetadata::read(&self.input_file))
.await
}

/// Returns blob
Expand Down Expand Up @@ -77,7 +76,7 @@ mod tests {
#[tokio::test]
async fn test_puffin_reader_uncompressed_metric_data() {
let input_file = java_uncompressed_metric_input_file();
let mut puffin_reader = PuffinReader::new(input_file);
let puffin_reader = PuffinReader::new(input_file);

let file_metadata = puffin_reader.file_metadata().await.unwrap().clone();
assert_eq!(file_metadata, uncompressed_metric_file_metadata());
Expand All @@ -102,7 +101,7 @@ mod tests {
#[tokio::test]
async fn test_puffin_reader_zstd_compressed_metric_data() {
let input_file = java_zstd_compressed_metric_input_file();
let mut puffin_reader = PuffinReader::new(input_file);
let puffin_reader = PuffinReader::new(input_file);

let file_metadata = puffin_reader.file_metadata().await.unwrap().clone();
assert_eq!(file_metadata, zstd_compressed_metric_file_metadata());
Expand Down

0 comments on commit 8752ce4

Please sign in to comment.