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
43
use crate::datatypes::DataType;
use parquet2::statistics::BooleanStatistics as ParquetBooleanStatistics;
use std::any::Any;
use super::Statistics;
#[derive(Debug, Clone, PartialEq)]
pub struct BooleanStatistics {
pub null_count: Option<i64>,
pub distinct_count: Option<i64>,
pub min_value: Option<bool>,
pub max_value: Option<bool>,
}
impl Statistics for BooleanStatistics {
fn data_type(&self) -> &DataType {
&DataType::Boolean
}
fn as_any(&self) -> &dyn Any {
self
}
fn null_count(&self) -> Option<i64> {
self.null_count
}
}
impl From<&ParquetBooleanStatistics> for BooleanStatistics {
fn from(stats: &ParquetBooleanStatistics) -> Self {
Self {
null_count: stats.null_count,
distinct_count: stats.distinct_count,
min_value: stats.min_value,
max_value: stats.max_value,
}
}
}