ilmari@ilmari.org (Dagfinn Ilmari =?utf-8?Q?Manns=C3=A5ker?=) writes:
> Tom Lane <tgl@sss.pgh.pa.us> writes:
>> I think you'd have to convert to text and back. That's kind of icky,
>> but it beats failing.
> I had a look, and that's what the PL/Python transform does. Attached is
> a patch that does that for PL/Perl too, but only if the value is
> actually > PG_INT64_MAX.
> The secondary output files are for Perls with 32bit IV/UV types, but I
> haven't been able to test them, since Debian's Perl uses 64bit integers
> even on 32bit platforms.
Ugh. I really don't want to maintain a separate expected-file for this,
especially not if it's going to be hard to test. Can we choose another
way of exercising the code path?
Another issue with this code as written is that on 32-bit-UV platforms,
at least some vompilers will give warnings about the constant-false
predicate. Not sure about a good solution for that. Maybe it's a
sufficient reason to invent uint8_numeric so we don't need a range check.
regards, tom lane