Package org.yamcs.studio.data.formula
Class AbstractVNumberArrayVNumberArrayToVNumberArrayFormulaFunction
java.lang.Object
org.yamcs.studio.data.formula.AbstractVNumberArrayVNumberArrayToVNumberArrayFormulaFunction
- All Implemented Interfaces:
FormulaFunction
public abstract class AbstractVNumberArrayVNumberArrayToVNumberArrayFormulaFunction
extends Object
implements FormulaFunction
Abstract class for formula functions that take two
VNumberArray
as arguments and return a
VNumberArray
.
This class takes care of:
- extracting ListNumber value from
VNumberArray
- null handling - returns null if one argument is null
- alarm handling - returns highest alarm
- time handling - returns latest time, or now if no time is available
- display handling - returns display none
-
Constructor Summary
ConstructorDescriptionAbstractVNumberArrayVNumberArrayToVNumberArrayFormulaFunction
(String name, String description, String arg1Name, String arg2Name) Creates a new function. -
Method Summary
Modifier and TypeMethodDescriptionfinal Object
Calculate the result of the function given the arguments.abstract ListNumber
calculate
(ListNumber arg1, ListNumber arg2) Calculates the result based on the two arguments.The ordered list of the argument names.The ordered list of the arguments type.final String
Return the description of the function.final String
getName()
Return the name of the function.final Class<?>
The type of the function result.final boolean
Whether the function takes a variable number of arguments.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface org.yamcs.studio.data.formula.FormulaFunction
highestSeverityOf, latestValidTimeOrNowOf
-
Constructor Details
-
AbstractVNumberArrayVNumberArrayToVNumberArrayFormulaFunction
public AbstractVNumberArrayVNumberArrayToVNumberArrayFormulaFunction(String name, String description, String arg1Name, String arg2Name) Creates a new function.- Parameters:
name
- function name; can't be nulldescription
- function description; can't be nullarg1Name
- first argument name; can't be nullarg2Name
- second argument name; can't be null
-
-
Method Details
-
isVarArgs
public final boolean isVarArgs()Description copied from interface:FormulaFunction
Whether the function takes a variable number of arguments.Variable arguments can only be at the end of the argument list, and have the same type.
- Specified by:
isVarArgs
in interfaceFormulaFunction
- Returns:
- true if the function can accept a variable number of arguments
-
getName
Description copied from interface:FormulaFunction
Return the name of the function.- Specified by:
getName
in interfaceFormulaFunction
- Returns:
- the function name
-
getDescription
Description copied from interface:FormulaFunction
Return the description of the function.- Specified by:
getDescription
in interfaceFormulaFunction
- Returns:
- the function description
-
getArgumentTypes
Description copied from interface:FormulaFunction
The ordered list of the arguments type.- Specified by:
getArgumentTypes
in interfaceFormulaFunction
- Returns:
- the types of the arguments
-
getArgumentNames
Description copied from interface:FormulaFunction
The ordered list of the argument names.- Specified by:
getArgumentNames
in interfaceFormulaFunction
- Returns:
- the names of the names
-
getReturnType
Description copied from interface:FormulaFunction
The type of the function result.- Specified by:
getReturnType
in interfaceFormulaFunction
- Returns:
- the result type
-
calculate
Description copied from interface:FormulaFunction
Calculate the result of the function given the arguments.- Specified by:
calculate
in interfaceFormulaFunction
- Parameters:
args
- the argument list- Returns:
- the result of the function
-
calculate
Calculates the result based on the two arguments. This is the only method one has to implement.- Parameters:
arg1
- the first argument; not nullarg2
- the second argument; not null- Returns:
- the result; not null
-