Skip to main content

SumFn

Struct SumFn 

Source
pub struct SumFn;

Trait Implementations§

Source§

impl Debug for SumFn

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Function for SumFn

Adds numeric values across scalars and ranges.

SUM evaluates all arguments, coercing text to numbers where possible, and returns the total. Blank cells and logical values in ranges are ignored.

§Remarks

  • If any argument evaluates to an error, SUM propagates the first error it encounters.
  • Unparseable text literals (e.g., "foo") will result in a #VALUE! error.

§Examples

title: "Basic scalar addition"
formula: "=SUM(10, 20, 5)"
expected: 35
title: "Summing a range"
grid:
  A1: 10
  A2: 20
  A3: "N/A"
formula: "=SUM(A1:A3)"
expected: 30
related:
  - SUMIF
  - SUMIFS
  - SUMPRODUCT
  - AVERAGE
faq:
  - q: "Why does SUM return #VALUE! for some text arguments?"
    a: "Direct scalar text that cannot be parsed as a number raises #VALUE! during coercion."
  - q: "Do text and logical values inside ranges get added?"
    a: "No. In ranged inputs, only numeric cells contribute to the total."

[formualizer-docgen:schema:start] Name: SUM Type: SumFn Min args: 0 Max args: variadic Variadic: true Signature: SUM(arg1…: number@range) Arg schema: arg1{kinds=number,required=true,shape=range,by_ref=false,coercion=NumberLenientText,max=None,repeating=None,default=false} Caps: PURE, REDUCTION, NUMERIC_ONLY, STREAM_OK, PARALLEL_ARGS [formualizer-docgen:schema:end]

Source§

fn caps(&self) -> FnCaps

Capability flags for this function
Source§

fn name(&self) -> &'static str

Source§

fn min_args(&self) -> usize

Source§

fn variadic(&self) -> bool

Source§

fn arg_schema(&self) -> &'static [ArgSchema]

Source§

fn eval<'a, 'b, 'c>( &self, args: &'c [ArgumentHandle<'a, 'b>], ctx: &dyn FunctionContext<'b>, ) -> Result<CalcValue<'b>, ExcelError>

The unified evaluation path. Read more
Source§

fn namespace(&self) -> &'static str

Source§

fn volatile(&self) -> bool

Source§

fn aliases(&self) -> &'static [&'static str]

Optional list of additional alias names (case-insensitive) that should resolve to this function. Default: empty slice. Implementors can override to expose legacy names. Returned slice must have ’static lifetime (typically a static array reference).
Source§

fn function_salt(&self) -> u64

Source§

fn eval_reference<'a, 'b, 'c>( &self, _args: &'c [ArgumentHandle<'a, 'b>], _ctx: &dyn FunctionContext<'b>, ) -> Option<Result<ReferenceType, ExcelError>>

Optional reference result path. Only called by the interpreter/engine when the callsite expects a reference (e.g., range combinators, by-ref argument positions, or spill sources). Read more
Source§

fn dispatch<'a, 'b, 'c>( &self, args: &'c [ArgumentHandle<'a, 'b>], ctx: &dyn FunctionContext<'b>, ) -> Result<CalcValue<'b>, ExcelError>

Dispatch to the unified evaluation path with automatic argument validation.

Auto Trait Implementations§

§

impl Freeze for SumFn

§

impl RefUnwindSafe for SumFn

§

impl Send for SumFn

§

impl Sync for SumFn

§

impl Unpin for SumFn

§

impl UnsafeUnpin for SumFn

§

impl UnwindSafe for SumFn

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> Allocation for T
where T: RefUnwindSafe + Send + Sync,