query/datafusion/
error.rs1use std::any::Any;
16
17use common_error::ext::ErrorExt;
18use common_error::status_code::StatusCode;
19use common_macro::stack_trace_debug;
20use datafusion::error::DataFusionError;
21use snafu::{Location, Snafu};
22
23#[derive(Snafu)]
25#[snafu(visibility(pub))]
26#[stack_trace_debug]
27pub enum InnerError {
28 #[snafu(display("DataFusion error"))]
29 Datafusion {
30 #[snafu(source)]
31 error: DataFusionError,
32 #[snafu(implicit)]
33 location: Location,
34 },
35
36 #[snafu(display("Failed to convert DataFusion's recordbatch stream"))]
37 ConvertDfRecordBatchStream {
38 #[snafu(implicit)]
39 location: Location,
40 source: common_recordbatch::error::Error,
41 },
42}
43
44impl ErrorExt for InnerError {
45 fn status_code(&self) -> StatusCode {
46 use InnerError::*;
47
48 match self {
49 Datafusion { .. } => StatusCode::EngineExecuteQuery,
51 ConvertDfRecordBatchStream { source, .. } => source.status_code(),
52 }
53 }
54
55 fn as_any(&self) -> &dyn Any {
56 self
57 }
58}