vortex_array/aggregate_fn/
erased.rs1use std::fmt::Debug;
7use std::fmt::Display;
8use std::fmt::Formatter;
9use std::hash::Hash;
10use std::hash::Hasher;
11use std::sync::Arc;
12
13use vortex_error::VortexExpect;
14use vortex_error::VortexResult;
15use vortex_utils::debug_with::DebugWith;
16
17use crate::aggregate_fn::AccumulatorRef;
18use crate::aggregate_fn::AggregateFnId;
19use crate::aggregate_fn::AggregateFnSatisfaction;
20use crate::aggregate_fn::AggregateFnVTable;
21use crate::aggregate_fn::GroupedAccumulatorRef;
22use crate::aggregate_fn::options::AggregateFnOptions;
23use crate::aggregate_fn::typed::AggregateFnInner;
24use crate::aggregate_fn::typed::DynAggregateFn;
25use crate::dtype::DType;
26
27#[derive(Clone)]
35pub struct AggregateFnRef(pub(super) Arc<dyn DynAggregateFn>);
36
37impl AggregateFnRef {
38 pub fn id(&self) -> AggregateFnId {
40 self.0.id()
41 }
42
43 pub fn is<V: AggregateFnVTable>(&self) -> bool {
45 self.0.as_any().is::<AggregateFnInner<V>>()
46 }
47
48 pub fn as_opt<V: AggregateFnVTable>(&self) -> Option<&V::Options> {
50 self.downcast_inner::<V>().map(|inner| &inner.options)
51 }
52
53 pub fn vtable_ref<V: AggregateFnVTable>(&self) -> Option<&V> {
55 self.downcast_inner::<V>().map(|inner| &inner.vtable)
56 }
57
58 fn downcast_inner<V: AggregateFnVTable>(&self) -> Option<&AggregateFnInner<V>> {
60 self.0.as_any().downcast_ref::<AggregateFnInner<V>>()
61 }
62
63 pub fn as_<V: AggregateFnVTable>(&self) -> &V::Options {
69 self.as_opt::<V>()
70 .vortex_expect("Aggregate function options type mismatch")
71 }
72
73 pub fn options(&self) -> AggregateFnOptions<'_> {
75 AggregateFnOptions { inner: &*self.0 }
76 }
77
78 pub fn can_satisfy(&self, requested: &AggregateFnRef) -> AggregateFnSatisfaction {
80 self.0.can_satisfy(requested)
81 }
82
83 pub fn coerce_args(&self, input_dtype: &DType) -> VortexResult<DType> {
85 self.0.coerce_args(input_dtype)
86 }
87
88 pub fn return_dtype(&self, input_dtype: &DType) -> Option<DType> {
92 self.0.return_dtype(input_dtype)
93 }
94
95 pub fn state_dtype(&self, input_dtype: &DType) -> Option<DType> {
99 self.0.state_dtype(input_dtype)
100 }
101
102 pub fn accumulator(&self, input_dtype: &DType) -> VortexResult<AccumulatorRef> {
104 self.0.accumulator(input_dtype)
105 }
106
107 pub fn accumulator_grouped(&self, input_dtype: &DType) -> VortexResult<GroupedAccumulatorRef> {
109 self.0.accumulator_grouped(input_dtype)
110 }
111}
112
113impl Debug for AggregateFnRef {
114 fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
115 f.debug_struct("AggregateFnRef")
116 .field("vtable", &self.0.id())
117 .field("options", &DebugWith(|fmt| self.0.options_debug(fmt)))
118 .finish()
119 }
120}
121
122impl Display for AggregateFnRef {
123 fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
124 write!(f, "{}(", self.0.id())?;
125 self.0.options_display(f)?;
126 write!(f, ")")
127 }
128}
129
130impl PartialEq for AggregateFnRef {
131 fn eq(&self, other: &Self) -> bool {
132 self.0.id() == other.0.id() && self.0.options_eq(other.0.options_any())
133 }
134}
135impl Eq for AggregateFnRef {}
136
137impl Hash for AggregateFnRef {
138 fn hash<H: Hasher>(&self, state: &mut H) {
139 self.0.id().hash(state);
140 self.0.options_hash(state);
141 }
142}