adaptive-expressions
Version:
Common Expression Language
40 lines (36 loc) • 1.46 kB
text/typescript
/**
* @module adaptive-expressions
*/
/**
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License.
*/
import { EvaluateExpressionDelegate, ExpressionEvaluator } from '../expressionEvaluator';
import { FunctionUtils, VerifyExpression } from '../functionUtils';
import { ReturnType } from '../returnType';
/**
* Numeric operators that can have 2 or more args.
*/
export class MultivariateNumericEvaluator extends ExpressionEvaluator {
/**
* Initializes a new instance of the [MultivariateNumericEvaluator](xref:adaptive-expressions.MultivariateNumericEvaluator) class.
*
* @param type Name of the built-in function.
* @param func The evaluation function, it takes a list of objects and returns a number.
* @param verify Optional. [VerifyExpression](xref:adaptive-expressions.VerifyExpression) function to verify each child's result.
*/
constructor(type: string, func: (args: any[]) => number, verify?: VerifyExpression) {
super(
type,
MultivariateNumericEvaluator.evaluator(func, verify),
ReturnType.Number,
FunctionUtils.validateTwoOrMoreThanTwoNumbers,
);
}
/**
* @private
*/
private static evaluator(func: (args: any[]) => number, verify?: VerifyExpression): EvaluateExpressionDelegate {
return FunctionUtils.applySequence(func, verify || FunctionUtils.verifyNumber);
}
}