From eb62fd466e7f548d4f9ed380e44d72a6bcf42764 Mon Sep 17 00:00:00 2001 From: James Inlow <38221700+jinlow@users.noreply.github.com> Date: Wed, 6 Jan 2021 21:01:52 -0600 Subject: [PATCH] Adding coerce filesize functionality to math avg median (#2848) * Adding coerce filesize functionality to math avg median * Updating initial value creating in Math Summation Reducer * Update reducers.rs Co-authored-by: Jonathan Turner --- crates/nu-cli/src/commands/math/median.rs | 3 ++- crates/nu-cli/src/commands/math/reducers.rs | 19 +++++++++++++++++-- 2 files changed, 19 insertions(+), 3 deletions(-) diff --git a/crates/nu-cli/src/commands/math/median.rs b/crates/nu-cli/src/commands/math/median.rs index da7ada1eba..c0da9a3180 100644 --- a/crates/nu-cli/src/commands/math/median.rs +++ b/crates/nu-cli/src/commands/math/median.rs @@ -128,8 +128,9 @@ fn compute_average(values: &[Value], name: impl Into) -> Result Box) -> Result + Send + Sync + 'static> { match command { - Reduce::Summation | Reduce::Default => Box::new(formula( + Reduce::Default => Box::new(formula( UntaggedValue::int(0).into_untagged_value(), Box::new(sum), )), + Reduce::Summation => Box::new(|_, values| sum(values)), Reduce::Minimum => Box::new(|_, values| min(values)), Reduce::Maximum => Box::new(|_, values| max(values)), Reduce::Product => Box::new(|_, values| product(values)), } } +#[allow(dead_code)] pub enum Reduce { Summation, Minimum, @@ -60,7 +62,20 @@ pub enum Reduce { } pub fn sum(data: Vec) -> Result { - let mut acc = UntaggedValue::int(0).into_untagged_value(); + let first_value = data + .get(0) + .ok_or_else(|| ShellError::unexpected(ERR_EMPTY_DATA))?; + + // Generate the initial accumulator value, of the correct type for + // the incoming data, this will be used in conjunction with the + // sum aggregator. Currently this is only handling, filesize, + // and other types are defaulting to an integer. + let mut acc = if first_value.is_filesize() { + UntaggedValue::filesize(0u64).into_untagged_value() + } else { + UntaggedValue::int(0).into_untagged_value() + }; + for value in data { match value.value { UntaggedValue::Primitive(_) => {