Commit 30484507 authored by Tom Lane's avatar Tom Lane

Use array_contains_nulls instead of ARR_HASNULL on user-supplied arrays.

This applies the fix for bug #5784 to remaining places where we wish
to reject nulls in user-supplied arrays.  In all these places, there's
no reason not to allow a null bitmap to be present, so long as none of
the current elements are actually null.

I did not change some other places where we are looking at system catalog
entries or aggregate transition values, as the presence of a null bitmap
in such an array would be suspicious.
parent 361418be
...@@ -187,7 +187,7 @@ cube_a_f8_f8(PG_FUNCTION_ARGS) ...@@ -187,7 +187,7 @@ cube_a_f8_f8(PG_FUNCTION_ARGS)
double *dur, double *dur,
*dll; *dll;
if (ARR_HASNULL(ur) || ARR_HASNULL(ll)) if (array_contains_nulls(ur) || array_contains_nulls(ll))
ereport(ERROR, ereport(ERROR,
(errcode(ERRCODE_ARRAY_ELEMENT_ERROR), (errcode(ERRCODE_ARRAY_ELEMENT_ERROR),
errmsg("cannot work with arrays containing NULLs"))); errmsg("cannot work with arrays containing NULLs")));
...@@ -228,7 +228,7 @@ cube_a_f8(PG_FUNCTION_ARGS) ...@@ -228,7 +228,7 @@ cube_a_f8(PG_FUNCTION_ARGS)
int size; int size;
double *dur; double *dur;
if (ARR_HASNULL(ur)) if (array_contains_nulls(ur))
ereport(ERROR, ereport(ERROR,
(errcode(ERRCODE_ARRAY_ELEMENT_ERROR), (errcode(ERRCODE_ARRAY_ELEMENT_ERROR),
errmsg("cannot work with arrays containing NULLs"))); errmsg("cannot work with arrays containing NULLs")));
...@@ -262,7 +262,7 @@ cube_subset(PG_FUNCTION_ARGS) ...@@ -262,7 +262,7 @@ cube_subset(PG_FUNCTION_ARGS)
i; i;
int *dx; int *dx;
if (ARR_HASNULL(idx)) if (array_contains_nulls(idx))
ereport(ERROR, ereport(ERROR,
(errcode(ERRCODE_ARRAY_ELEMENT_ERROR), (errcode(ERRCODE_ARRAY_ELEMENT_ERROR),
errmsg("cannot work with arrays containing NULLs"))); errmsg("cannot work with arrays containing NULLs")));
......
...@@ -92,7 +92,7 @@ _ltree_compress(PG_FUNCTION_ARGS) ...@@ -92,7 +92,7 @@ _ltree_compress(PG_FUNCTION_ARGS)
ereport(ERROR, ereport(ERROR,
(errcode(ERRCODE_ARRAY_SUBSCRIPT_ERROR), (errcode(ERRCODE_ARRAY_SUBSCRIPT_ERROR),
errmsg("array must be one-dimensional"))); errmsg("array must be one-dimensional")));
if (ARR_HASNULL(val)) if (array_contains_nulls(val))
ereport(ERROR, ereport(ERROR,
(errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED), (errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED),
errmsg("array must not contain nulls"))); errmsg("array must not contain nulls")));
...@@ -538,7 +538,7 @@ _arrq_cons(ltree_gist *key, ArrayType *_query) ...@@ -538,7 +538,7 @@ _arrq_cons(ltree_gist *key, ArrayType *_query)
ereport(ERROR, ereport(ERROR,
(errcode(ERRCODE_ARRAY_SUBSCRIPT_ERROR), (errcode(ERRCODE_ARRAY_SUBSCRIPT_ERROR),
errmsg("array must be one-dimensional"))); errmsg("array must be one-dimensional")));
if (ARR_HASNULL(_query)) if (array_contains_nulls(_query))
ereport(ERROR, ereport(ERROR,
(errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED), (errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED),
errmsg("array must not contain nulls"))); errmsg("array must not contain nulls")));
......
...@@ -52,7 +52,7 @@ array_iterator(ArrayType *la, PGCALL2 callback, void *param, ltree **found) ...@@ -52,7 +52,7 @@ array_iterator(ArrayType *la, PGCALL2 callback, void *param, ltree **found)
ereport(ERROR, ereport(ERROR,
(errcode(ERRCODE_ARRAY_SUBSCRIPT_ERROR), (errcode(ERRCODE_ARRAY_SUBSCRIPT_ERROR),
errmsg("array must be one-dimensional"))); errmsg("array must be one-dimensional")));
if (ARR_HASNULL(la)) if (array_contains_nulls(la))
ereport(ERROR, ereport(ERROR,
(errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED), (errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED),
errmsg("array must not contain nulls"))); errmsg("array must not contain nulls")));
...@@ -152,7 +152,7 @@ _lt_q_regex(PG_FUNCTION_ARGS) ...@@ -152,7 +152,7 @@ _lt_q_regex(PG_FUNCTION_ARGS)
ereport(ERROR, ereport(ERROR,
(errcode(ERRCODE_ARRAY_SUBSCRIPT_ERROR), (errcode(ERRCODE_ARRAY_SUBSCRIPT_ERROR),
errmsg("array must be one-dimensional"))); errmsg("array must be one-dimensional")));
if (ARR_HASNULL(_query)) if (array_contains_nulls(_query))
ereport(ERROR, ereport(ERROR,
(errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED), (errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED),
errmsg("array must not contain nulls"))); errmsg("array must not contain nulls")));
...@@ -310,7 +310,7 @@ _lca(PG_FUNCTION_ARGS) ...@@ -310,7 +310,7 @@ _lca(PG_FUNCTION_ARGS)
ereport(ERROR, ereport(ERROR,
(errcode(ERRCODE_ARRAY_SUBSCRIPT_ERROR), (errcode(ERRCODE_ARRAY_SUBSCRIPT_ERROR),
errmsg("array must be one-dimensional"))); errmsg("array must be one-dimensional")));
if (ARR_HASNULL(la)) if (array_contains_nulls(la))
ereport(ERROR, ereport(ERROR,
(errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED), (errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED),
errmsg("array must not contain nulls"))); errmsg("array must not contain nulls")));
......
...@@ -348,7 +348,7 @@ lt_q_regex(PG_FUNCTION_ARGS) ...@@ -348,7 +348,7 @@ lt_q_regex(PG_FUNCTION_ARGS)
ereport(ERROR, ereport(ERROR,
(errcode(ERRCODE_ARRAY_SUBSCRIPT_ERROR), (errcode(ERRCODE_ARRAY_SUBSCRIPT_ERROR),
errmsg("array must be one-dimensional"))); errmsg("array must be one-dimensional")));
if (ARR_HASNULL(_query)) if (array_contains_nulls(_query))
ereport(ERROR, ereport(ERROR,
(errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED), (errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED),
errmsg("array must not contain nulls"))); errmsg("array must not contain nulls")));
......
...@@ -606,7 +606,7 @@ arrq_cons(ltree_gist *key, ArrayType *_query) ...@@ -606,7 +606,7 @@ arrq_cons(ltree_gist *key, ArrayType *_query)
ereport(ERROR, ereport(ERROR,
(errcode(ERRCODE_ARRAY_SUBSCRIPT_ERROR), (errcode(ERRCODE_ARRAY_SUBSCRIPT_ERROR),
errmsg("array must be one-dimensional"))); errmsg("array must be one-dimensional")));
if (ARR_HASNULL(_query)) if (array_contains_nulls(_query))
ereport(ERROR, ereport(ERROR,
(errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED), (errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED),
errmsg("array must not contain nulls"))); errmsg("array must not contain nulls")));
......
...@@ -4700,7 +4700,7 @@ array_fill_internal(ArrayType *dims, ArrayType *lbs, ...@@ -4700,7 +4700,7 @@ array_fill_internal(ArrayType *dims, ArrayType *lbs,
errmsg("wrong range of array subscripts"), errmsg("wrong range of array subscripts"),
errdetail("Lower bound of dimension array must be one."))); errdetail("Lower bound of dimension array must be one.")));
if (ARR_HASNULL(dims)) if (array_contains_nulls(dims))
ereport(ERROR, ereport(ERROR,
(errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED), (errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED),
errmsg("dimension values cannot be null"))); errmsg("dimension values cannot be null")));
...@@ -4732,7 +4732,7 @@ array_fill_internal(ArrayType *dims, ArrayType *lbs, ...@@ -4732,7 +4732,7 @@ array_fill_internal(ArrayType *dims, ArrayType *lbs,
errmsg("wrong range of array subscripts"), errmsg("wrong range of array subscripts"),
errdetail("Lower bound of dimension array must be one."))); errdetail("Lower bound of dimension array must be one.")));
if (ARR_HASNULL(lbs)) if (array_contains_nulls(lbs))
ereport(ERROR, ereport(ERROR,
(errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED), (errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED),
errmsg("dimension values cannot be null"))); errmsg("dimension values cannot be null")));
......
...@@ -213,7 +213,7 @@ ArrayGetIntegerTypmods(ArrayType *arr, int *n) ...@@ -213,7 +213,7 @@ ArrayGetIntegerTypmods(ArrayType *arr, int *n)
(errcode(ERRCODE_ARRAY_SUBSCRIPT_ERROR), (errcode(ERRCODE_ARRAY_SUBSCRIPT_ERROR),
errmsg("typmod array must be one-dimensional"))); errmsg("typmod array must be one-dimensional")));
if (ARR_HASNULL(arr)) if (array_contains_nulls(arr))
ereport(ERROR, ereport(ERROR,
(errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED), (errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED),
errmsg("typmod array must not contain nulls"))); errmsg("typmod array must not contain nulls")));
......
...@@ -408,7 +408,7 @@ getWeights(ArrayType *win) ...@@ -408,7 +408,7 @@ getWeights(ArrayType *win)
(errcode(ERRCODE_ARRAY_SUBSCRIPT_ERROR), (errcode(ERRCODE_ARRAY_SUBSCRIPT_ERROR),
errmsg("array of weight is too short"))); errmsg("array of weight is too short")));
if (ARR_HASNULL(win)) if (array_contains_nulls(win))
ereport(ERROR, ereport(ERROR,
(errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED), (errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED),
errmsg("array of weight must not contain nulls"))); errmsg("array of weight must not contain nulls")));
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment