-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy patherror.rs
More file actions
42 lines (32 loc) · 1.17 KB
/
error.rs
File metadata and controls
42 lines (32 loc) · 1.17 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
use datafusion::error::DataFusionError;
use thiserror::Error;
#[derive(Error, Debug)]
pub enum ZarrDataFusionError {
// Zarrs errors
#[error("Zarrs array creation error: {0}")]
ArrayCreateError(#[from] zarrs::array::ArrayCreateError),
#[error("Zarrs filesystem create error: {0}")]
FilesystemStoreCreateError(#[from] zarrs_filesystem::FilesystemStoreCreateError),
#[error("Zarrs group create error: {0}")]
GroupCreateError(#[from] zarrs::group::GroupCreateError),
#[error("Zarrs error: {0}")]
Zarrs(#[from] zarrs::array::ArrayError),
// Other errors
#[error("DataFusion error: {0}")]
DataFusion(#[from] DataFusionError),
#[error("Arrow error: {0}")]
Arrow(#[from] arrow::error::ArrowError),
#[error("Object store error: {0}")]
ObjectStore(#[from] object_store::Error),
#[error("{0}")]
Custom(String),
}
impl From<ZarrDataFusionError> for DataFusionError {
fn from(err: ZarrDataFusionError) -> Self {
match err {
ZarrDataFusionError::DataFusion(e) => e,
_ => DataFusionError::External(Box::new(err)),
}
}
}
pub type ZarrDataFusionResult<T> = Result<T, ZarrDataFusionError>;