risinglight 0.2.0

An OLAP database system for educational purpose
Documentation
// Copyright 2022 RisingLight Project Authors. Licensed under Apache-2.0.

use super::*;
use crate::array::ArrayImpl;

/// The executor of simple aggregation.
pub struct SimpleAggExecutor {
    /// A list of aggregations.
    ///
    /// e.g. `(list (sum #0) (count #1))`
    pub aggs: RecExpr,
}

impl SimpleAggExecutor {
    #[try_stream(boxed, ok = DataChunk, error = ExecutorError)]
    pub async fn execute(self, child: BoxedExecutor) {
        let mut states = Evaluator::new(&self.aggs).init_agg_states::<Vec<_>>();
        #[for_await]
        for chunk in child {
            let chunk = chunk?;
            Evaluator::new(&self.aggs).eval_agg_list(&mut states, &chunk)?;
        }
        yield states.iter().map(ArrayImpl::from).collect();
    }
}