Created
August 10, 2022 08:09
-
-
Save jahav/52acd013247d9b14e721eb843d6b246b to your computer and use it in GitHub Desktop.
An implementation of a SUM function for ClosedXml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
ce.RegisterFunction("SUM", 1, int.MaxValue, Sum, FunctionFlags.Range, AllowRange.All); | |
private static AnyValue Sum(CalcContext ctx, Span<AnyValue?> args) | |
{ | |
var sum = 0.0; | |
foreach (var nullableArg in args) | |
{ | |
if (!nullableArg.HasValue) | |
continue; | |
var arg = nullableArg.Value; | |
if (arg.TryPickScalar(out var scalar, out var collection)) | |
{ | |
var conversionResult = ctx.Converter.CovertToNumber(in scalar); | |
if (!conversionResult.TryPickT0(out var number, out var error)) | |
return error; | |
sum += number; | |
} | |
else | |
{ | |
var valuesIterator = collection.TryPickT0(out var array, out var reference) | |
? array | |
: reference.GetCellsValues(ctx); | |
foreach (var value in valuesIterator) | |
{ | |
// collections ignore strings and logical, only numbers (and errors) allowed | |
if (value.TryPickNumber(out var number)) | |
sum += number; | |
else if (value.TryPickError(out var error)) | |
return error; | |
} | |
} | |
} | |
return sum; | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment