HHH-17807 fix NPE in array argument validation

probably only occurs when the argument is a parameter
This commit is contained in:
Gavin King 2024-03-05 17:55:09 +01:00
parent 691a2d8109
commit 5a7661be5c
2 changed files with 23 additions and 14 deletions

View File

@ -50,7 +50,12 @@ public class ArrayArgumentValidator implements ArgumentsValidator {
String functionName, String functionName,
TypeConfiguration typeConfiguration) { TypeConfiguration typeConfiguration) {
final SqmTypedNode<?> arrayArgument = arguments.get( arrayIndex ); final SqmTypedNode<?> arrayArgument = arguments.get( arrayIndex );
final SqmExpressible<?> arrayType = arrayArgument.getExpressible().getSqmType(); final SqmExpressible<?> expressible = arrayArgument.getExpressible();
if ( expressible == null ) {
return null;
}
else {
final SqmExpressible<?> arrayType = expressible.getSqmType();
if ( arrayType == null ) { if ( arrayType == null ) {
return null; return null;
} }
@ -66,6 +71,7 @@ public class ArrayArgumentValidator implements ArgumentsValidator {
} }
return (BasicPluralType<?, ?>) arrayType; return (BasicPluralType<?, ?>) arrayType;
} }
}
protected BasicType<?> getElementType( protected BasicType<?> getElementType(
int arrayIndex, int arrayIndex,

View File

@ -31,10 +31,13 @@ public class ArrayContainsArgumentValidator extends ArrayArgumentValidator {
List<? extends SqmTypedNode<?>> arguments, List<? extends SqmTypedNode<?>> arguments,
String functionName, String functionName,
TypeConfiguration typeConfiguration) { TypeConfiguration typeConfiguration) {
final BasicPluralType<?, ?> haystackType = getPluralType( 0, arguments, functionName, typeConfiguration ); final BasicPluralType<?, ?> haystackType =
getPluralType( 0, arguments, functionName, typeConfiguration );
final SqmExpressible<?> expressible = arguments.get( 1 ).getExpressible(); final SqmExpressible<?> expressible = arguments.get( 1 ).getExpressible();
final SqmExpressible<?> needleType = expressible == null ? null : expressible.getSqmType(); final SqmExpressible<?> needleType = expressible == null ? null : expressible.getSqmType();
if ( needleType != null && !haystackType.equals( needleType ) && !haystackType.getElementType().equals( needleType ) ) { if ( haystackType!= null && needleType != null
&& !haystackType.equals( needleType )
&& !haystackType.getElementType().equals( needleType ) ) {
throw new FunctionArgumentException( throw new FunctionArgumentException(
String.format( String.format(
"Parameter 1 of function '%s()' has type %s, but argument is of type '%s'", "Parameter 1 of function '%s()' has type %s, but argument is of type '%s'",