You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Provide a way to add functions that can be called with NULL arguments.
NULL AND TRUE --> NULL
NULL OR FALSE --> NULL
NULL AND FALSE --> FALSE
NULL OR TRUE --> TRUE
NULL * 2 --> NULL
COS(NULL) --> NULL
SUBSTRING(NULL, 1, 2) --> ?
The problem is that some methods cannot accept null values e.g. Cos(double value) but some can e.g. Substring(string str, int start, int length). I think the best design is to allow the the function to specify whether it wish to handle null values itself or not (the default). If not, the invocation node should not call the function but immediatley return null if any argument is null.
If the function wants to handle null values the QE has to check whether the given parameter allows null values. The only datatypes legal for null values are reference types and sql data types. The compiler should check this and insert COALESCE nodes to handle sql data types.
The InvocationExpression should handle this in GetValue() like this:
Type[]parameterTypes=_function.GetParameterTypes();object[]argumentValues=newobject[_arguments.Length];for(inti=0;i<argumentValues.Length;i++){argumentValues[i]=_arguments[i].GetValue(computer);// IS NULL means: either NULL or implements INullable or is // DBNullValueif(argumentValues[i]isnull){if(_function.HandlesNullValues&¶meterTypes[i].IsReferenceType)parameterTypes[i]=null;elsereturnnull;}}return_function.Invoke(argumentValues);
Needless to say that the value array and the parameter type array should be cached so that not every call results in two array creations.
The text was updated successfully, but these errors were encountered:
Ported from CodePlex
Provide a way to add functions that can be called with NULL arguments.
The problem is that some methods cannot accept null values e.g. Cos(double value) but some can e.g. Substring(string str, int start, int length). I think the best design is to allow the the function to specify whether it wish to handle null values itself or not (the default). If not, the invocation node should not call the function but immediatley return null if any argument is null.
If the function wants to handle null values the QE has to check whether the given parameter allows null values. The only datatypes legal for null values are reference types and sql data types. The compiler should check this and insert COALESCE nodes to handle sql data types.
Example:
MyFunction(a, b, c, d)
should result inThe InvocationExpression should handle this in GetValue() like this:
Needless to say that the value array and the parameter type array should be cached so that not every call results in two array creations.
The text was updated successfully, but these errors were encountered: