On Mon, Jul 22, 2024 at 11:17 AM Nathan Bossart <nathandboss...@gmail.com>
wrote:
> On Fri, Jul 19, 2024 at 07:32:18PM -0400, Joseph Koshakow wrote:
>> On Fri, Jul 19, 2024 at 2:45 PM Nathan Bossart <nathandboss...@gmail.com>
>> wrote:
>>> +            /* dim[i] = 1 + upperIndx[i] - lowerIndx[i]; */
>>> +            if (pg_add_s32_overflow(1, upperIndx[i], &dim[i]))
>>> +                ereport(ERROR,
>>> +                        (errcode(ERRCODE_PROGRAM_LIMIT_EXCEEDED),
>>> +                         errmsg("array upper bound is too large: %d",
>>> +                                upperIndx[i])));
>>> +            if (pg_sub_s32_overflow(dim[i], lowerIndx[i], &dim[i]))
>>> +                ereport(ERROR,
>>> +                        (errcode(ERRCODE_PROGRAM_LIMIT_EXCEEDED),
>>> +                         errmsg("array size exceeds the maximum allowed
>> (%d)",
>>> +                                (int) MaxArraySize)));
>
> Am I understanding correctly that the main
> behavioral difference between these two approaches is that users will see
> different error messages?

Yes, you are understanding correctly. The approach written above will
have the error message "array upper bound is too large", while the
approach attached in patch
v13-0002-Remove-overflow-from-array_set_slice.patch will have the error
message "array lower bound is too large".

Thanks,
Joseph Koshakow

Reply via email to