Commit 3a382983 authored by Tom Lane's avatar Tom Lane

Allow plperl_sv_to_datum to look through scalar refs.

There seems little reason for the policy of throwing error if we
find a ref to something other than a hash or array.   Recursively
look through the ref, instead.  This makes the behavior in non-transform
cases comparable to what was already instantiated for jsonb_plperl.

Note that because we invoke any available transform function before
considering the ref case, it's up to each transform function whether
it wants to play along with this behavior or do something different.

Because the previous behavior was just to throw a useless error,
this seems unlikely to create any compatibility issues.  Still, given
the lack of field complaints so far, seems best not to back-patch.

Discussion: https://postgr.es/m/28336.1528393969@sss.pgh.pa.us
parent e4300a35
...@@ -763,14 +763,17 @@ $$ LANGUAGE plperl; ...@@ -763,14 +763,17 @@ $$ LANGUAGE plperl;
SELECT text_obj(); SELECT text_obj();
ERROR: cannot convert Perl hash to non-composite type text ERROR: cannot convert Perl hash to non-composite type text
CONTEXT: PL/Perl function "text_obj" CONTEXT: PL/Perl function "text_obj"
----- make sure we can't return a scalar ref -- test looking through a scalar ref
CREATE OR REPLACE FUNCTION text_scalarref() RETURNS text AS $$ CREATE OR REPLACE FUNCTION text_scalarref() RETURNS text AS $$
my $str = 'str'; my $str = 'str';
return \$str; return \$str;
$$ LANGUAGE plperl; $$ LANGUAGE plperl;
SELECT text_scalarref(); SELECT text_scalarref();
ERROR: PL/Perl function must return reference to hash or array text_scalarref
CONTEXT: PL/Perl function "text_scalarref" ----------------
str
(1 row)
-- check safe behavior when a function body is replaced during execution -- check safe behavior when a function body is replaced during execution
CREATE OR REPLACE FUNCTION self_modify(INTEGER) RETURNS INTEGER AS $$ CREATE OR REPLACE FUNCTION self_modify(INTEGER) RETURNS INTEGER AS $$
spi_exec_query('CREATE OR REPLACE FUNCTION self_modify(INTEGER) RETURNS INTEGER AS \'return $_[0] * 3;\' LANGUAGE plperl;'); spi_exec_query('CREATE OR REPLACE FUNCTION self_modify(INTEGER) RETURNS INTEGER AS \'return $_[0] * 3;\' LANGUAGE plperl;');
......
...@@ -1402,11 +1402,13 @@ plperl_sv_to_datum(SV *sv, Oid typid, int32 typmod, ...@@ -1402,11 +1402,13 @@ plperl_sv_to_datum(SV *sv, Oid typid, int32 typmod,
return ret; return ret;
} }
/* Reference, but not reference to hash or array ... */ /*
ereport(ERROR, * If it's a reference to something else, such as a scalar, just
(errcode(ERRCODE_DATATYPE_MISMATCH), * recursively look through the reference.
errmsg("PL/Perl function must return reference to hash or array"))); */
return (Datum) 0; /* shut up compiler */ return plperl_sv_to_datum(SvRV(sv), typid, typmod,
fcinfo, finfo, typioparam,
isnull);
} }
else else
{ {
......
...@@ -504,7 +504,7 @@ $$ LANGUAGE plperl; ...@@ -504,7 +504,7 @@ $$ LANGUAGE plperl;
SELECT text_obj(); SELECT text_obj();
----- make sure we can't return a scalar ref -- test looking through a scalar ref
CREATE OR REPLACE FUNCTION text_scalarref() RETURNS text AS $$ CREATE OR REPLACE FUNCTION text_scalarref() RETURNS text AS $$
my $str = 'str'; my $str = 'str';
return \$str; return \$str;
......
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